diff --git a/Images.xcassets/Item List/AddItemIcon.imageset/Contents.json b/Images.xcassets/Item List/AddItemIcon.imageset/Contents.json index ffe65a7ec0..2e2e9b52c0 100644 --- a/Images.xcassets/Item List/AddItemIcon.imageset/Contents.json +++ b/Images.xcassets/Item List/AddItemIcon.imageset/Contents.json @@ -2,17 +2,7 @@ "images" : [ { "idiom" : "universal", - "scale" : "1x" - }, - { - "idiom" : "universal", - "filename" : "ic_addoption@2x.png", - "scale" : "2x" - }, - { - "idiom" : "universal", - "filename" : "ic_addoption@3x.png", - "scale" : "3x" + "filename" : "add.pdf" } ], "info" : { diff --git a/Images.xcassets/Item List/AddItemIcon.imageset/add.pdf b/Images.xcassets/Item List/AddItemIcon.imageset/add.pdf new file mode 100644 index 0000000000..931be96420 Binary files /dev/null and b/Images.xcassets/Item List/AddItemIcon.imageset/add.pdf differ diff --git a/Images.xcassets/Item List/AddItemIcon.imageset/ic_addoption@2x.png b/Images.xcassets/Item List/AddItemIcon.imageset/ic_addoption@2x.png deleted file mode 100644 index 4a17bc48eb..0000000000 Binary files a/Images.xcassets/Item List/AddItemIcon.imageset/ic_addoption@2x.png and /dev/null differ diff --git a/Images.xcassets/Item List/AddItemIcon.imageset/ic_addoption@3x.png b/Images.xcassets/Item List/AddItemIcon.imageset/ic_addoption@3x.png deleted file mode 100644 index 0c2b3becdf..0000000000 Binary files a/Images.xcassets/Item List/AddItemIcon.imageset/ic_addoption@3x.png and /dev/null differ diff --git a/Images.xcassets/Item List/RemoveItemIcon.imageset/Contents.json b/Images.xcassets/Item List/RemoveItemIcon.imageset/Contents.json index 7a4287b94c..8edcfb86ed 100644 --- a/Images.xcassets/Item List/RemoveItemIcon.imageset/Contents.json +++ b/Images.xcassets/Item List/RemoveItemIcon.imageset/Contents.json @@ -2,17 +2,7 @@ "images" : [ { "idiom" : "universal", - "scale" : "1x" - }, - { - "idiom" : "universal", - "filename" : "ic_deleteotion@2x.png", - "scale" : "2x" - }, - { - "idiom" : "universal", - "filename" : "ic_deleteotion@3x.png", - "scale" : "3x" + "filename" : "delete.pdf" } ], "info" : { diff --git a/Images.xcassets/Item List/RemoveItemIcon.imageset/delete.pdf b/Images.xcassets/Item List/RemoveItemIcon.imageset/delete.pdf new file mode 100644 index 0000000000..b73c6ec402 Binary files /dev/null and b/Images.xcassets/Item List/RemoveItemIcon.imageset/delete.pdf differ diff --git a/Images.xcassets/Item List/RemoveItemIcon.imageset/ic_deleteotion@2x.png b/Images.xcassets/Item List/RemoveItemIcon.imageset/ic_deleteotion@2x.png deleted file mode 100644 index a52d7ebf3c..0000000000 Binary files a/Images.xcassets/Item List/RemoveItemIcon.imageset/ic_deleteotion@2x.png and /dev/null differ diff --git a/Images.xcassets/Item List/RemoveItemIcon.imageset/ic_deleteotion@3x.png b/Images.xcassets/Item List/RemoveItemIcon.imageset/ic_deleteotion@3x.png deleted file mode 100644 index a4c5861aae..0000000000 Binary files a/Images.xcassets/Item List/RemoveItemIcon.imageset/ic_deleteotion@3x.png and /dev/null differ diff --git a/TelegramUI.xcodeproj/project.pbxproj b/TelegramUI.xcodeproj/project.pbxproj index 40a0afba25..2f8afb56cf 100644 --- a/TelegramUI.xcodeproj/project.pbxproj +++ b/TelegramUI.xcodeproj/project.pbxproj @@ -72,7 +72,6 @@ 099529B021D2123E00805E13 /* ChatMessageUnsupportedBubbleContentNode.swift in Sources */ = {isa = PBXBuildFile; fileRef = 099529AF21D2123E00805E13 /* ChatMessageUnsupportedBubbleContentNode.swift */; }; 099529B221D24F5800805E13 /* RadialDownloadContentNode.swift in Sources */ = {isa = PBXBuildFile; fileRef = 099529B121D24F5800805E13 /* RadialDownloadContentNode.swift */; }; 099529B421D3E5D800805E13 /* CheckDiskSpace.swift in Sources */ = {isa = PBXBuildFile; fileRef = 099529B321D3E5D800805E13 /* CheckDiskSpace.swift */; }; - 099529F321D8FE8300805E13 /* RadialPlayPauseContentNode.swift in Sources */ = {isa = PBXBuildFile; fileRef = 099529F221D8FE8300805E13 /* RadialPlayPauseContentNode.swift */; }; 099529FA21DD8A3100805E13 /* NavigationBarSearchContentNode.swift in Sources */ = {isa = PBXBuildFile; fileRef = 099529F921DD8A3100805E13 /* NavigationBarSearchContentNode.swift */; }; 09AE3823214C110900850BFD /* LegacySecureIdScanController.swift in Sources */ = {isa = PBXBuildFile; fileRef = 09AE3822214C110800850BFD /* LegacySecureIdScanController.swift */; }; 09B4EE4721A6D33F00847FA6 /* RecentSessionsEmptyStateItem.swift in Sources */ = {isa = PBXBuildFile; fileRef = 09B4EE4621A6D33F00847FA6 /* RecentSessionsEmptyStateItem.swift */; }; @@ -111,6 +110,7 @@ D005808B21CAB8F000CB7CD3 /* VoipDerivedState.swift in Sources */ = {isa = PBXBuildFile; fileRef = D005808A21CAB8F000CB7CD3 /* VoipDerivedState.swift */; }; D00580A021DCF0A200CB7CD3 /* WallpaperListPreviewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = D005809F21DCF0A200CB7CD3 /* WallpaperListPreviewController.swift */; }; D00580A221DCF0B700CB7CD3 /* WallpaperListPreviewControllerNode.swift in Sources */ = {isa = PBXBuildFile; fileRef = D00580A121DCF0B700CB7CD3 /* WallpaperListPreviewControllerNode.swift */; }; + D00580B121E3DEF200CB7CD3 /* MergedItemListItem.swift in Sources */ = {isa = PBXBuildFile; fileRef = D00580B021E3DEF200CB7CD3 /* MergedItemListItem.swift */; }; D0068FA821760FA300D1B315 /* StoreDownloadedMedia.swift in Sources */ = {isa = PBXBuildFile; fileRef = D0068FA721760FA300D1B315 /* StoreDownloadedMedia.swift */; }; D007019C2029E8F2006B9E34 /* LegqacyICloudFileController.swift in Sources */ = {isa = PBXBuildFile; fileRef = D007019B2029E8F2006B9E34 /* LegqacyICloudFileController.swift */; }; D007019E2029EFDD006B9E34 /* ICloudResources.swift in Sources */ = {isa = PBXBuildFile; fileRef = D007019D2029EFDD006B9E34 /* ICloudResources.swift */; }; @@ -1180,7 +1180,6 @@ 099529AF21D2123E00805E13 /* ChatMessageUnsupportedBubbleContentNode.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = ChatMessageUnsupportedBubbleContentNode.swift; sourceTree = ""; }; 099529B121D24F5800805E13 /* RadialDownloadContentNode.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = RadialDownloadContentNode.swift; sourceTree = ""; }; 099529B321D3E5D800805E13 /* CheckDiskSpace.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CheckDiskSpace.swift; sourceTree = ""; }; - 099529F221D8FE8300805E13 /* RadialPlayPauseContentNode.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = RadialPlayPauseContentNode.swift; sourceTree = ""; }; 099529F921DD8A3100805E13 /* NavigationBarSearchContentNode.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = NavigationBarSearchContentNode.swift; sourceTree = ""; }; 09AE3822214C110800850BFD /* LegacySecureIdScanController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = LegacySecureIdScanController.swift; sourceTree = ""; }; 09B4EE4621A6D33F00847FA6 /* RecentSessionsEmptyStateItem.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = RecentSessionsEmptyStateItem.swift; sourceTree = ""; }; @@ -1230,6 +1229,7 @@ D005808A21CAB8F000CB7CD3 /* VoipDerivedState.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = VoipDerivedState.swift; sourceTree = ""; }; D005809F21DCF0A200CB7CD3 /* WallpaperListPreviewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = WallpaperListPreviewController.swift; sourceTree = ""; }; D00580A121DCF0B700CB7CD3 /* WallpaperListPreviewControllerNode.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = WallpaperListPreviewControllerNode.swift; sourceTree = ""; }; + D00580B021E3DEF200CB7CD3 /* MergedItemListItem.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = MergedItemListItem.swift; sourceTree = ""; }; D0068FA721760FA300D1B315 /* StoreDownloadedMedia.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = StoreDownloadedMedia.swift; sourceTree = ""; }; D007019B2029E8F2006B9E34 /* LegqacyICloudFileController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = LegqacyICloudFileController.swift; sourceTree = ""; }; D007019D2029EFDD006B9E34 /* ICloudResources.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = ICloudResources.swift; sourceTree = ""; }; @@ -2549,7 +2549,6 @@ D01776B91F1D704F0044446D /* RadialStatusIconContentNode.swift */, D0380DAA204EA72F000414AB /* RadialStatusSecretTimeoutContentNode.swift */, 099529B121D24F5800805E13 /* RadialDownloadContentNode.swift */, - 099529F221D8FE8300805E13 /* RadialPlayPauseContentNode.swift */, ); name = "Radial Status"; sourceTree = ""; @@ -3921,6 +3920,7 @@ D0E305AE1E5BA8E000D7A3A2 /* ItemListLoadingIndicatorEmptyStateItem.swift */, D09AEFD31E5BAF67005C1A8B /* ItemListTextEmptyStateItem.swift */, D0BFAE5A20AB35D200793CF2 /* IconSwitchNode.swift */, + D00580B021E3DEF200CB7CD3 /* MergedItemListItem.swift */, ); name = Items; sourceTree = ""; @@ -5480,6 +5480,7 @@ 9F06830B21A404C4001D8EDB /* NotificationExcetionSettingsController.swift in Sources */, D0EC6D891EB9F58800EBF1C3 /* ChatSecretAutoremoveTimerActionSheet.swift in Sources */, D05D8B782195E0050064586F /* SetupTwoStepVerificationContentNode.swift in Sources */, + D00580B121E3DEF200CB7CD3 /* MergedItemListItem.swift in Sources */, D0EC6D8A1EB9F58800EBF1C3 /* ChatInfo.swift in Sources */, D0EC6D8B1EB9F58800EBF1C3 /* ChatHistoryNavigationStack.swift in Sources */, D0EC6D8C1EB9F58800EBF1C3 /* NavigateToChatController.swift in Sources */, @@ -5733,7 +5734,6 @@ D0EC6E031EB9F58900EBF1C3 /* GalleryFooterContentNode.swift in Sources */, D0E9BA0A1F0457DD00F079A4 /* BotCheckoutWebInteractionController.swift in Sources */, D0EC6E041EB9F58900EBF1C3 /* SecretMediaPreviewController.swift in Sources */, - 099529F321D8FE8300805E13 /* RadialPlayPauseContentNode.swift in Sources */, D0C26D571FDF2388004ABF18 /* OpenChatMessage.swift in Sources */, D0FA08BE20481EA300DD23FC /* Locale.swift in Sources */, D0E412CE206A707400BEE4A2 /* FormControllerTextItem.swift in Sources */, diff --git a/TelegramUI/BotPaymentSwitchItemNode.swift b/TelegramUI/BotPaymentSwitchItemNode.swift index d24982ae01..2a9975a7c3 100644 --- a/TelegramUI/BotPaymentSwitchItemNode.swift +++ b/TelegramUI/BotPaymentSwitchItemNode.swift @@ -66,6 +66,8 @@ final class BotPaymentSwitchItemNode: BotPaymentItemNode { self.switchNode.frameColor = theme.list.itemSwitchColors.frameColor self.switchNode.contentColor = theme.list.itemSwitchColors.contentColor self.switchNode.handleColor = theme.list.itemSwitchColors.handleColor + self.switchNode.positiveContentColor = theme.list.itemSwitchColors.positiveColor + self.switchNode.negativeContentColor = theme.list.itemSwitchColors.negativeColor } let leftInset: CGFloat = 16.0 diff --git a/TelegramUI/CallRatingController.swift b/TelegramUI/CallRatingController.swift index 06dda015dd..82e3e8384a 100644 --- a/TelegramUI/CallRatingController.swift +++ b/TelegramUI/CallRatingController.swift @@ -336,7 +336,7 @@ private func rateCallAndSendLogs(account: Account, callId: CallId, starsCount: I let id = arc4random64() let name = "\(callId.id)_\(callId.accessHash).log" let path = callLogsPath(account: account) + "/" + name - let file = TelegramMediaFile(fileId: MediaId(namespace: Namespaces.Media.LocalFile, id: id), partialReference: nil, resource: LocalFileReferenceMediaResource(localFilePath: path, randomId: id), previewRepresentations: [], mimeType: "application/text", size: nil, attributes: [.FileName(fileName: name)]) + let file = TelegramMediaFile(fileId: MediaId(namespace: Namespaces.Media.LocalFile, id: id), partialReference: nil, resource: LocalFileReferenceMediaResource(localFilePath: path, randomId: id), previewRepresentations: [], immediateThumbnailData: nil, mimeType: "application/text", size: nil, attributes: [.FileName(fileName: name)]) let message = EnqueueMessage.message(text: "", attributes: [], mediaReference: .standalone(media: file), replyToMessageId: nil, localGroupingKey: nil) return rateSignal diff --git a/TelegramUI/ChannelAdminController.swift b/TelegramUI/ChannelAdminController.swift index c11fdacd0b..0d9031d8af 100644 --- a/TelegramUI/ChannelAdminController.swift +++ b/TelegramUI/ChannelAdminController.swift @@ -677,38 +677,50 @@ public func channelAdminController(account: Account, peerId: PeerId, adminId: Pe updateFlags = defaultFlags } - if let updateFlags = updateFlags, updateFlags != defaultFlags { - let signal = convertGroupToSupergroup(account: account, peerId: peerId) - |> map(Optional.init) - |> `catch` { _ -> Signal in - return .single(nil) - } - |> mapToSignal { upgradedPeerId -> Signal in - guard let upgradedPeerId = upgradedPeerId else { + if let updateFlags = updateFlags { + if initialParticipant?.adminInfo == nil && updateFlags == defaultFlags { + updateState { current in + return current.withUpdatedUpdating(true) + } + updateRightsDisposable.set((addGroupAdmin(account: account, peerId: peerId, adminId: adminId) + |> deliverOnMainQueue).start(completed: { + dismissImpl?() + })) + } else if updateFlags != defaultFlags { + let signal = convertGroupToSupergroup(account: account, peerId: peerId) + |> map(Optional.init) + |> `catch` { _ -> Signal in return .single(nil) } - return account.telegramApplicationContext.peerChannelMemberCategoriesContextsManager.updateMemberAdminRights(account: account, peerId: upgradedPeerId, memberId: adminId, adminRights: TelegramChatAdminRights(flags: updateFlags)) - |> mapToSignal { _ -> Signal in - return .complete() + |> mapToSignal { upgradedPeerId -> Signal in + guard let upgradedPeerId = upgradedPeerId else { + return .single(nil) + } + return account.telegramApplicationContext.peerChannelMemberCategoriesContextsManager.updateMemberAdminRights(account: account, peerId: upgradedPeerId, memberId: adminId, adminRights: TelegramChatAdminRights(flags: updateFlags)) + |> mapToSignal { _ -> Signal in + return .complete() + } + |> then(.single(upgradedPeerId)) } - |> then(.single(upgradedPeerId)) - } - |> deliverOnMainQueue - - updateState { current in - return current.withUpdatedUpdating(true) - } - updateRightsDisposable.set(signal.start(next: { upgradedPeerId in - if let upgradedPeerId = upgradedPeerId { - upgradedToSupergroup(upgradedPeerId, { - dismissImpl?() - }) - } - }, error: { _ in + |> deliverOnMainQueue + updateState { current in - return current.withUpdatedUpdating(false) + return current.withUpdatedUpdating(true) } - })) + updateRightsDisposable.set(signal.start(next: { upgradedPeerId in + if let upgradedPeerId = upgradedPeerId { + upgradedToSupergroup(upgradedPeerId, { + dismissImpl?() + }) + } + }, error: { _ in + updateState { current in + return current.withUpdatedUpdating(false) + } + })) + } else { + dismissImpl?() + } } else { dismissImpl?() } diff --git a/TelegramUI/ChannelAdminsController.swift b/TelegramUI/ChannelAdminsController.swift index dc88298e53..77ee1e687c 100644 --- a/TelegramUI/ChannelAdminsController.swift +++ b/TelegramUI/ChannelAdminsController.swift @@ -490,6 +490,9 @@ public func channelAdminsController(account: Account, peerId: PeerId, loadComple upgradedToSupergroupImpl?(upgradedPeerId, f) } + let peerView = Promise() + peerView.set(account.viewTracker.peerView(peerId)) + let arguments = ChannelAdminsControllerArguments(account: account, openRecentActions: { let _ = (account.postbox.loadedPeerWithId(peerId) |> deliverOnMainQueue).start(next: { peer in @@ -526,21 +529,12 @@ public func channelAdminsController(account: Account, peerId: PeerId, loadComple })) } }, addAdmin: { - updateState { current in - var dismissController: (() -> Void)? - let controller = ChannelMembersSearchController(account: account, peerId: peerId, mode: .promote, filters: [], openPeer: { peer, participant in - if peerId.namespace == Namespaces.Peer.CloudGroup { - let presentationData = account.telegramApplicationContext.currentPresentationData.with { $0 } - let progress = OverlayStatusController(theme: presentationData.theme, strings: presentationData.strings, type: .loading(cancelled: nil)) - presentControllerImpl?(progress, nil) - - addAdminDisposable.set((addGroupAdmin(account: account, peerId: peerId, adminId: peer.id) - |> deliverOnMainQueue).start(completed: { - [weak progress] in - dismissController?() - progress?.dismiss() - })) - } else { + let _ = (peerView.get() + |> take(1) + |> deliverOnMainQueue).start(next: { peerView in + updateState { current in + var dismissController: (() -> Void)? + let controller = ChannelMembersSearchController(account: account, peerId: peerId, mode: .promote, filters: [], openPeer: { peer, participant in dismissController?() let presentationData = account.telegramApplicationContext.currentPresentationData.with { $0 } if peer.id == account.peerId { @@ -551,32 +545,39 @@ public func channelAdminsController(account: Account, peerId: PeerId, loadComple case .creator: return case let .member(_, _, _, banInfo): - if let banInfo = banInfo, banInfo.restrictedBy != account.peerId { - presentControllerImpl?(standardTextAlertController(theme: AlertControllerTheme(presentationTheme: presentationData.theme), title: nil, text: presentationData.strings.Channel_Members_AddAdminErrorBlacklisted, actions: [TextAlertAction(type: .defaultAction, title: presentationData.strings.Common_OK, action: {})]), nil) - return + if let banInfo = banInfo { + var canUnban = false + if banInfo.restrictedBy != account.peerId { + canUnban = true + } + if let channel = peerView.peers[peerId] as? TelegramChannel { + if channel.hasPermission(.banMembers) { + canUnban = true + } + } + if !canUnban { + presentControllerImpl?(standardTextAlertController(theme: AlertControllerTheme(presentationTheme: presentationData.theme), title: nil, text: presentationData.strings.Channel_Members_AddAdminErrorBlacklisted, actions: [TextAlertAction(type: .defaultAction, title: presentationData.strings.Common_OK, action: {})]), nil) + return + } } } } presentControllerImpl?(channelAdminController(account: account, peerId: peerId, adminId: peer.id, initialParticipant: participant?.participant, updated: { _ in }, upgradedToSupergroup: upgradedToSupergroup), ViewControllerPresentationArguments(presentationAnimation: .modalSheet)) + }) + dismissController = { [weak controller] in + controller?.dismiss() } - }) - dismissController = { [weak controller] in - controller?.dismiss() + presentControllerImpl?(controller, ViewControllerPresentationArguments(presentationAnimation: .modalSheet)) + + return current } - presentControllerImpl?(controller, ViewControllerPresentationArguments(presentationAnimation: .modalSheet)) - - return current - } - + }) }, openAdmin: { participant in presentControllerImpl?(channelAdminController(account: account, peerId: peerId, adminId: participant.peerId, initialParticipant: participant, updated: { _ in }, upgradedToSupergroup: upgradedToSupergroup), ViewControllerPresentationArguments(presentationAnimation: .modalSheet)) }) - let peerView = Promise() - peerView.set(account.viewTracker.peerView(peerId)) - let membersAndLoadMoreControl: (Disposable, PeerChannelMemberCategoryControl?) if peerId.namespace == Namespaces.Peer.CloudChannel { var didReportLoadCompleted = false diff --git a/TelegramUI/ChannelBannedMemberController.swift b/TelegramUI/ChannelBannedMemberController.swift index 7ccd38fe29..754d967bb5 100644 --- a/TelegramUI/ChannelBannedMemberController.swift +++ b/TelegramUI/ChannelBannedMemberController.swift @@ -510,7 +510,7 @@ public func channelBannedMemberController(account: Account, peerId: PeerId, memb if state.updating { rightNavigationButton = ItemListNavigationButton(content: .none, style: .activity, enabled: true, action: {}) } else { - rightNavigationButton = ItemListNavigationButton(content: .text(presentationData.strings.Common_Done), style: .bold, enabled: true, action: { + rightNavigationButton = ItemListNavigationButton(content: .text(presentationData.strings.GroupPermission_ApplyAlertAction), style: .bold, enabled: true, action: { let _ = (peerView.get() |> take(1) |> deliverOnMainQueue).start(next: { view in diff --git a/TelegramUI/ChannelInfoController.swift b/TelegramUI/ChannelInfoController.swift index 5a55a65f3e..6b6f0def8c 100644 --- a/TelegramUI/ChannelInfoController.swift +++ b/TelegramUI/ChannelInfoController.swift @@ -301,15 +301,15 @@ private enum ChannelInfoEntry: ItemListNodeEntry { }) case let .admins(theme, text, value): - return ItemListDisclosureItem(theme: theme, icon: PresentationResourcesChat.groupInfoAdminsIcon(theme), title: text, label: value, sectionId: self.section, style: .plain, action: { + return ItemListDisclosureItem(theme: theme, title: text, label: value, sectionId: self.section, style: .plain, action: { arguments.openAdmins() }) case let .members(theme, text, value): - return ItemListDisclosureItem(theme: theme, icon: PresentationResourcesChat.groupInfoMembersIcon(theme), title: text, label: value, sectionId: self.section, style: .plain, action: { + return ItemListDisclosureItem(theme: theme, title: text, label: value, sectionId: self.section, style: .plain, action: { arguments.openMembers() }) case let .banned(theme, text, value): - return ItemListDisclosureItem(theme: theme, icon: PresentationResourcesChat.groupInfoBannedIcon(theme), title: text, label: value, sectionId: self.section, style: .plain, action: { + return ItemListDisclosureItem(theme: theme, title: text, label: value, sectionId: self.section, style: .plain, action: { arguments.openBanned() }) case let .signMessages(theme, text, value): @@ -451,7 +451,7 @@ private func channelInfoEntries(account: Account, presentationData: Presentation } if let cachedChannelData = view.cachedData as? CachedChannelData { - if state.editingState != nil && canEditMembers { + if canEditMembers { if peer.adminRights != nil || peer.flags.contains(.isCreator) { let adminCount = cachedChannelData.participantsSummary.adminCount ?? 0 entries.append(.admins(theme: presentationData.theme, text: presentationData.strings.GroupInfo_Administrators, value: "\(adminCount == 0 ? "" : "\(adminCount)")")) @@ -473,6 +473,8 @@ private func channelInfoEntries(account: Account, presentationData: Presentation } else { notificationsText = presentationData.strings.UserInfo_NotificationsDisabled } + } else if case .default = notificationSettings.messageSound { + notificationsText = presentationData.strings.UserInfo_NotificationsEnabled } else { notificationsText = localizedPeerNotificationSoundString(strings: presentationData.strings, sound: notificationSettings.messageSound, default: globalNotificationSettings.effective.channels.sound) } @@ -794,6 +796,11 @@ public func channelInfoController(account: Account, peerId: PeerId) -> ViewContr } } + var canEditChannel = false + if let peer = view.peers[view.peerId] as? TelegramChannel { + canEditChannel = peer.hasPermission(.changeInfo) + } + var leftNavigationButton: ItemListNavigationButton? var rightNavigationButton: ItemListNavigationButton? if let editingState = state.editingState { @@ -856,7 +863,7 @@ public func channelInfoController(account: Account, peerId: PeerId) -> ViewContr })) }) } - } else { + } else if canEditChannel { rightNavigationButton = ItemListNavigationButton(content: .text(presentationData.strings.Common_Edit), style: .regular, enabled: true, action: { if let channel = peer as? TelegramChannel, case .broadcast = channel.info { var text = "" diff --git a/TelegramUI/ChannelMemberCategoryListContext.swift b/TelegramUI/ChannelMemberCategoryListContext.swift index 2b1aba3508..b78c3cc773 100644 --- a/TelegramUI/ChannelMemberCategoryListContext.swift +++ b/TelegramUI/ChannelMemberCategoryListContext.swift @@ -4,7 +4,7 @@ import Postbox import SwiftSignalKit private let initialBatchSize: Int32 = 64 -private let emptyTimeout: Double = 2.0 * 60.0 +private let defaultEmptyTimeout: Double = 2.0 * 60.0 private let headUpdateTimeout: Double = 30.0 private let requestBatchSize: Int32 = 64 @@ -83,7 +83,7 @@ private final class ChannelMemberSingleCategoryListContext: ChannelMemberCategor var listStateValue: ChannelMemberListState { didSet { self.listStatePromise.set(.single(self.listStateValue)) - if case .admins = self.category, case .ready = self.listStateValue.loadingState { + if case .admins(nil) = self.category, case .ready = self.listStateValue.loadingState { let ids: Set = Set(self.listStateValue.list.map { $0.peer.id }) let previousIds: Set = Set(oldValue.list.map { $0.peer.id }) if ids != previousIds { @@ -288,8 +288,8 @@ private final class ChannelMemberSingleCategoryListContext: ChannelMemberCategor } } switch self.category { - case .admins: - if let updated = updated, let _ = updated.participant.adminInfo { + case let .admins(query): + if let updated = updated, let _ = updated.participant.adminInfo, (query == nil || updated.peer.indexName.matchesByTokens(query!)) { var found = false loop: for i in 0 ..< list.count { if list[i].peer.id == updated.peer.id { @@ -512,14 +512,16 @@ struct PeerChannelMemberCategoryControl { private final class PeerChannelMemberContextWithSubscribers { let context: ChannelMemberCategoryListContext + private let emptyTimeout: Double private let subscribers = Bag<(ChannelMemberListState) -> Void>() private let disposable = MetaDisposable() private let becameEmpty: () -> Void private var emptyTimer: SwiftSignalKit.Timer? - init(context: ChannelMemberCategoryListContext, becameEmpty: @escaping () -> Void) { + init(context: ChannelMemberCategoryListContext, emptyTimeout: Double, becameEmpty: @escaping () -> Void) { self.context = context + self.emptyTimeout = emptyTimeout self.becameEmpty = becameEmpty self.disposable.set((context.listState |> deliverOnMainQueue).start(next: { [weak self] value in @@ -539,7 +541,7 @@ private final class PeerChannelMemberContextWithSubscribers { private func resetAndBeginEmptyTimer() { self.context.reset(false) self.emptyTimer?.invalidate() - let emptyTimer = SwiftSignalKit.Timer(timeout: emptyTimeout, repeat: false, completion: { [weak self] in + let emptyTimer = SwiftSignalKit.Timer(timeout: self.emptyTimeout, repeat: false, completion: { [weak self] in if let strongSelf = self { if strongSelf.subscribers.isEmpty { strongSelf.becameEmpty() @@ -605,6 +607,13 @@ final class PeerChannelMemberCategoriesContext { return (current.subscribe(requestUpdate: requestUpdate, updated: updated), PeerChannelMemberCategoryControl(key: key)) } let context: ChannelMemberCategoryListContext + let emptyTimeout: Double + switch key { + case .admins(nil), .banned(nil), .recentSearch(nil), .restricted(nil), .restrictedAndBanned(nil): + emptyTimeout = defaultEmptyTimeout + default: + emptyTimeout = 0.0 + } switch key { case .recent, .recentSearch, .admins: let mappedCategory: ChannelMemberListCategory @@ -626,7 +635,7 @@ final class PeerChannelMemberCategoriesContext { case let .banned(query): context = ChannelMemberSingleCategoryListContext(postbox: self.postbox, network: self.network, accountPeerId: self.accountPeerId, peerId: self.peerId, category: .banned(query)) } - let contextWithSubscribers = PeerChannelMemberContextWithSubscribers(context: context, becameEmpty: { [weak self] in + let contextWithSubscribers = PeerChannelMemberContextWithSubscribers(context: context, emptyTimeout: emptyTimeout, becameEmpty: { [weak self] in assert(Queue.mainQueue().isCurrent()) if let strongSelf = self { strongSelf.contexts.removeValue(forKey: key) diff --git a/TelegramUI/ChannelMembersController.swift b/TelegramUI/ChannelMembersController.swift index 69bdc99e1a..3076efd1f5 100644 --- a/TelegramUI/ChannelMembersController.swift +++ b/TelegramUI/ChannelMembersController.swift @@ -336,40 +336,40 @@ public func channelMembersController(account: Account, peerId: PeerId) -> ViewCo let disabledIds = members?.compactMap({$0.peer.id}) ?? [] let contactsController = ContactMultiselectionController(account: account, mode: .peerSelection(searchChatList: false), options: [], filters: [.excludeSelf, .disable(disabledIds)]) - let addMembers: ([ContactListPeerId]) -> Signal = { members -> Signal in - let peerIds = members.compactMap { contact -> PeerId? in - switch contact { - case let .peer(peerId): - return peerId - default: - return nil - } - } - return account.telegramApplicationContext.peerChannelMemberCategoriesContextsManager.addMembers(account: account, peerId: peerId, memberIds: peerIds) - } - addMembersDisposable.set((contactsController.result |> deliverOnMainQueue - |> mapToSignal { [weak contactsController] contacts -> Signal in + |> introduceError(AddChannelMemberError.self) + |> mapToSignal { [weak contactsController] contacts -> Signal in contactsController?.displayProgress = true - let signals = contacts.compactMap({ contact -> Signal? in + let signal = account.telegramApplicationContext.peerChannelMemberCategoriesContextsManager.addMembers(account: account, peerId: peerId, memberIds: contacts.compactMap({ contact -> PeerId? in switch contact { case let .peer(contactId): - return account.telegramApplicationContext.peerChannelMemberCategoriesContextsManager.addMember(account: account, peerId: peerId, memberId: contactId) - |> ignoreValues - case .deviceContact: + return contactId + default: return nil } - }) + })) - return combineLatest(signals) + return signal |> ignoreValues |> deliverOnMainQueue |> afterCompleted { contactsController?.dismiss() } - }).start()) + }).start(error: { error in + let presentationData = account.telegramApplicationContext.currentPresentationData.with { $0 } + let text: String + switch error { + case .limitExceeded: + text = presentationData.strings.Channel_ErrorAddTooMuch + case .generic: + text = presentationData.strings.Login_UnknownError + case .restricted: + text = presentationData.strings.Channel_ErrorAddBlocked + } + presentControllerImpl?(standardTextAlertController(theme: AlertControllerTheme(presentationTheme: presentationData.theme), title: nil, text: text, actions: [TextAlertAction(type: .defaultAction, title: presentationData.strings.Common_OK, action: {})]), nil) + })) presentControllerImpl?(contactsController, ViewControllerPresentationArguments(presentationAnimation: .modalSheet)) })) diff --git a/TelegramUI/ChannelMembersSearchContainerNode.swift b/TelegramUI/ChannelMembersSearchContainerNode.swift index de0da68883..5c40857d05 100644 --- a/TelegramUI/ChannelMembersSearchContainerNode.swift +++ b/TelegramUI/ChannelMembersSearchContainerNode.swift @@ -260,6 +260,19 @@ final class ChannelMembersSearchContainerNode: SearchDisplayControllerContentNod } if peerId.namespace == Namespaces.Peer.CloudChannel { + if case .searchAdmins = mode { + return account.telegramApplicationContext.peerChannelMemberCategoriesContextsManager.updateMemberAdminRights(account: account, peerId: peerId, memberId: memberId, adminRights: TelegramChatAdminRights(flags: [])) + |> afterDisposed { + Queue.mainQueue().async { + updateState { state in + var state = state + state.removingParticipantIds.remove(memberId) + return state + } + } + } + } + return account.telegramApplicationContext.peerChannelMemberCategoriesContextsManager.updateMemberBannedRights(account: account, peerId: peerId, memberId: memberId, bannedRights: TelegramChatBannedRights(flags: [.banReadMessages], untilDate: Int32.max)) |> afterDisposed { Queue.mainQueue().async { @@ -272,6 +285,21 @@ final class ChannelMembersSearchContainerNode: SearchDisplayControllerContentNod } } + if case .searchAdmins = mode { + return removeGroupAdmin(account: account, peerId: peerId, adminId: memberId) + |> `catch` { _ -> Signal in + return .complete() + } + |> deliverOnMainQueue + |> afterDisposed { + updateState { state in + var state = state + state.removingParticipantIds.remove(memberId) + return state + } + } + } + return removePeerMember(account: account, peerId: peerId, memberId: memberId) |> deliverOnMainQueue |> afterDisposed { @@ -320,11 +348,10 @@ final class ChannelMembersSearchContainerNode: SearchDisplayControllerContentNod let (disposable, _) = account.telegramApplicationContext.peerChannelMemberCategoriesContextsManager.admins(postbox: account.postbox, network: account.network, accountPeerId: account.peerId, peerId: peerId, searchQuery: query, updated: { state in if case .ready = state.loadingState { subscriber.putNext(state.list) - subscriber.putCompletion() } }) return disposable - } |> runOn(Queue.mainQueue()) + } |> runOn(Queue.mainQueue()) foundMembers = .single([]) case .searchBanned: foundGroupMembers = Signal { subscriber in @@ -473,6 +500,10 @@ final class ChannelMembersSearchContainerNode: SearchDisplayControllerContentNod peerActions.append(ParticipantRevealAction(type: .warning, title: themeAndStrings.1.GroupInfo_ActionRestrict, action: .restrict)) peerActions.append(ParticipantRevealAction(type: .destructive, title: themeAndStrings.1.Common_Delete, action: .remove)) } + } else if case .searchAdmins = mode { + if canRestrict { + peerActions.append(ParticipantRevealAction(type: .destructive, title: themeAndStrings.1.Common_Delete, action: .remove)) + } } switch mode { diff --git a/TelegramUI/ChannelPermissionsController.swift b/TelegramUI/ChannelPermissionsController.swift index 8ab17ac368..53b44450bc 100644 --- a/TelegramUI/ChannelPermissionsController.swift +++ b/TelegramUI/ChannelPermissionsController.swift @@ -14,8 +14,9 @@ private final class ChannelPermissionsControllerArguments { let openPeer: (ChannelParticipant) -> Void let openPeerInfo: (Peer) -> Void let openKicked: () -> Void + let presentRestrictedPublicGroupPermissionsAlert: () -> Void - init(account: Account, updatePermission: @escaping (TelegramChatBannedRightsFlags, Bool) -> Void, setPeerIdWithRevealedOptions: @escaping (PeerId?, PeerId?) -> Void, addPeer: @escaping () -> Void, removePeer: @escaping (PeerId) -> Void, openPeer: @escaping (ChannelParticipant) -> Void, openPeerInfo: @escaping (Peer) -> Void, openKicked: @escaping () -> Void) { + init(account: Account, updatePermission: @escaping (TelegramChatBannedRightsFlags, Bool) -> Void, setPeerIdWithRevealedOptions: @escaping (PeerId?, PeerId?) -> Void, addPeer: @escaping () -> Void, removePeer: @escaping (PeerId) -> Void, openPeer: @escaping (ChannelParticipant) -> Void, openPeerInfo: @escaping (Peer) -> Void, openKicked: @escaping () -> Void, presentRestrictedPublicGroupPermissionsAlert: @escaping () -> Void) { self.account = account self.updatePermission = updatePermission self.addPeer = addPeer @@ -24,6 +25,7 @@ private final class ChannelPermissionsControllerArguments { self.openPeer = openPeer self.openPeerInfo = openPeerInfo self.openKicked = openKicked + self.presentRestrictedPublicGroupPermissionsAlert = presentRestrictedPublicGroupPermissionsAlert } } @@ -40,7 +42,7 @@ private enum ChannelPermissionsEntryStableId: Hashable { private enum ChannelPermissionsEntry: ItemListNodeEntry { case permissionsHeader(PresentationTheme, String) - case permission(PresentationTheme, Int, String, Bool, TelegramChatBannedRightsFlags, Bool) + case permission(PresentationTheme, Int, String, Bool, TelegramChatBannedRightsFlags, Bool?) case kicked(PresentationTheme, String, String) case exceptionsHeader(PresentationTheme, String) case add(PresentationTheme, String) @@ -173,8 +175,12 @@ private enum ChannelPermissionsEntry: ItemListNodeEntry { case let .permissionsHeader(theme, text): return ItemListSectionHeaderItem(theme: theme, text: text, sectionId: self.section) case let .permission(theme, _, title, value, rights, enabled): - return ItemListSwitchItem(theme: theme, title: title, value: value, type: .icon, enabled: enabled, sectionId: self.section, style: .blocks, updated: { value in - arguments.updatePermission(rights, value) + return ItemListSwitchItem(theme: theme, title: title, value: value, type: .icon, enableInteractiveChanges: enabled != nil, enabled: enabled ?? true, sectionId: self.section, style: .blocks, updated: { value in + if let _ = enabled { + arguments.updatePermission(rights, value) + } else { + arguments.presentRestrictedPublicGroupPermissionsAlert() + } }) case let .kicked(theme, text, value): return ItemListDisclosureItem(theme: theme, title: text, label: value, sectionId: self.section, style: .blocks, action: { @@ -341,9 +347,9 @@ private func channelPermissionsControllerEntries(presentationData: PresentationD entries.append(.permissionsHeader(presentationData.theme, presentationData.strings.GroupInfo_Permissions_SectionTitle)) var rightIndex: Int = 0 for rights in allGroupPermissionList { - var enabled = true - if channel.addressName != nil { - enabled = !publicGroupRestrictedPermissions.contains(rights) + var enabled: Bool? = true + if channel.addressName != nil && publicGroupRestrictedPermissions.contains(rights) { + enabled = nil } entries.append(.permission(presentationData.theme, rightIndex, stringForGroupPermission(strings: presentationData.strings, right: rights), !effectiveRightsFlags.contains(rights), rights, enabled)) rightIndex += 1 @@ -358,7 +364,7 @@ private func channelPermissionsControllerEntries(presentationData: PresentationD entries.append(.peerItem(presentationData.theme, presentationData.strings, presentationData.dateTimeFormat, presentationData.nameDisplayOrder, index, participant, ItemListPeerItemEditing(editable: true, editing: false, revealed: participant.peer.id == state.peerIdWithRevealedOptions), state.removingPeerId != participant.peer.id, true, effectiveRightsFlags)) index += 1 } - } else if let group = view.peers[view.peerId] as? TelegramGroup, let cachedData = view.cachedData as? CachedGroupData, let defaultBannedRights = group.defaultBannedRights { + } else if let group = view.peers[view.peerId] as? TelegramGroup, let _ = view.cachedData as? CachedGroupData, let defaultBannedRights = group.defaultBannedRights { let effectiveRightsFlags: TelegramChatBannedRightsFlags if let modifiedRightsFlags = state.modifiedRightsFlags { effectiveRightsFlags = modifiedRightsFlags @@ -436,7 +442,7 @@ public func channelPermissionsController(account: Account, peerId: PeerId, loadC let _ = (peerView.get() |> take(1) |> deliverOnMainQueue).start(next: { view in - if let channel = view.peers[peerId] as? TelegramChannel, let cachedData = view.cachedData as? CachedChannelData { + if let channel = view.peers[peerId] as? TelegramChannel, let _ = view.cachedData as? CachedChannelData { updateState { state in var state = state var effectiveRightsFlags: TelegramChatBannedRightsFlags @@ -466,7 +472,7 @@ public func channelPermissionsController(account: Account, peerId: PeerId, loadC updateDefaultRightsDisposable.set((updateDefaultChannelMemberBannedRights(account: account, peerId: peerId, rights: TelegramChatBannedRights(flags: completeRights(modifiedRightsFlags), untilDate: Int32.max)) |> deliverOnMainQueue).start()) } - } else if let group = view.peers[peerId] as? TelegramGroup, let cachedData = view.cachedData as? CachedGroupData { + } else if let group = view.peers[peerId] as? TelegramGroup, let _ = view.cachedData as? CachedGroupData { updateState { state in var state = state var effectiveRightsFlags: TelegramChatBannedRightsFlags @@ -566,6 +572,9 @@ public func channelPermissionsController(account: Account, peerId: PeerId, loadC } }, openKicked: { pushControllerImpl?(channelBlacklistController(account: account, peerId: peerId)) + }, presentRestrictedPublicGroupPermissionsAlert: { + let presentationData = account.telegramApplicationContext.currentPresentationData.with { $0 } + presentControllerImpl?(standardTextAlertController(theme: AlertControllerTheme(presentationTheme: presentationData.theme), title: nil, text: presentationData.strings.GroupPermission_NotAvailableInPublicGroups, actions: [TextAlertAction(type: .defaultAction, title: presentationData.strings.Common_OK, action: {})]), nil) }) let previousParticipants = Atomic<[RenderedChannelParticipant]?>(value: nil) diff --git a/TelegramUI/ChatContextResultPeekContentNode.swift b/TelegramUI/ChatContextResultPeekContentNode.swift index 1b59cdb7cd..e02d49c0a7 100644 --- a/TelegramUI/ChatContextResultPeekContentNode.swift +++ b/TelegramUI/ChatContextResultPeekContentNode.swift @@ -158,7 +158,7 @@ private final class ChatContextResultPeekNode: ASDisplayNode, PeekControllerCont imageDimensions = content?.dimensions if let content = content, type == "gif", let thumbnailResource = imageResource , let dimensions = content.dimensions { - videoFileReference = .standalone(media: TelegramMediaFile(fileId: MediaId(namespace: Namespaces.Media.LocalFile, id: 0), partialReference: nil, resource: content.resource, previewRepresentations: [TelegramMediaImageRepresentation(dimensions: dimensions, resource: thumbnailResource)], mimeType: "video/mp4", size: nil, attributes: [.Animated, .Video(duration: 0, size: dimensions, flags: [])])) + videoFileReference = .standalone(media: TelegramMediaFile(fileId: MediaId(namespace: Namespaces.Media.LocalFile, id: 0), partialReference: nil, resource: content.resource, previewRepresentations: [TelegramMediaImageRepresentation(dimensions: dimensions, resource: thumbnailResource)], immediateThumbnailData: nil, mimeType: "video/mp4", size: nil, attributes: [.Animated, .Video(duration: 0, size: dimensions, flags: [])])) imageResource = nil } case let .internalReference(_, _, _, title, _, image, file, _): diff --git a/TelegramUI/ChatController.swift b/TelegramUI/ChatController.swift index 9b1bbe7526..a3f11be218 100644 --- a/TelegramUI/ChatController.swift +++ b/TelegramUI/ChatController.swift @@ -207,6 +207,8 @@ public final class ChatController: TelegramController, KeyShortcutResponder, Gal private weak var silentPostTooltipController: TooltipController? private weak var mediaRecordingModeTooltipController: TooltipController? + private weak var mediaRestrictedTooltipController: TooltipController? + private var mediaRestrictedTooltipControllerMode = true private var screenCaptureEventsDisposable: Disposable? private let chatAdditionalDataDisposable = MetaDisposable() @@ -2578,8 +2580,10 @@ public final class ChatController: TelegramController, KeyShortcutResponder, Gal let banDescription: String switch subject { case .stickers: - if personal { - banDescription = strongSelf.presentationInterfaceState.strings.Group_ErrorSendRestrictedStickers + if untilDate != 0 && untilDate != Int32.max { + banDescription = strongSelf.presentationInterfaceState.strings.Conversation_RestrictedStickersTimed(stringForFullDate(timestamp: untilDate, strings: strongSelf.presentationInterfaceState.strings, dateTimeFormat: strongSelf.presentationInterfaceState.dateTimeFormat)).0 + } else if personal { + banDescription = strongSelf.presentationInterfaceState.strings.Conversation_RestrictedStickers } else { banDescription = strongSelf.presentationInterfaceState.strings.Conversation_DefaultRestrictedStickers } @@ -2600,6 +2604,7 @@ public final class ChatController: TelegramController, KeyShortcutResponder, Gal strongSelf.recordingModeFeedback?.error() let rect: CGRect? + let isStickers: Bool = subject == .stickers switch subject { case .stickers: rect = strongSelf.chatDisplayNode.frameForStickersButton() @@ -2607,14 +2612,16 @@ public final class ChatController: TelegramController, KeyShortcutResponder, Gal rect = strongSelf.chatDisplayNode.frameForInputActionButton() } - if let tooltipController = strongSelf.mediaRecordingModeTooltipController { + if let tooltipController = strongSelf.mediaRestrictedTooltipController, strongSelf.mediaRestrictedTooltipControllerMode == isStickers { tooltipController.text = banDescription } else if let rect = rect { + strongSelf.mediaRestrictedTooltipController?.dismiss() let tooltipController = TooltipController(text: banDescription) - strongSelf.mediaRecordingModeTooltipController = tooltipController + strongSelf.mediaRestrictedTooltipController = tooltipController + strongSelf.mediaRestrictedTooltipControllerMode = isStickers tooltipController.dismissed = { [weak tooltipController] in - if let strongSelf = self, let tooltipController = tooltipController, strongSelf.mediaRecordingModeTooltipController === tooltipController { - strongSelf.mediaRecordingModeTooltipController = nil + if let strongSelf = self, let tooltipController = tooltipController, strongSelf.mediaRestrictedTooltipController === tooltipController { + strongSelf.mediaRestrictedTooltipController = nil } } strongSelf.present(tooltipController, in: .window(.root), with: TooltipControllerPresentationArguments(sourceNodeAndRect: { @@ -3739,10 +3746,21 @@ public final class ChatController: TelegramController, KeyShortcutResponder, Gal strongSelf.chatDisplayNode.dismissInput() var bannedSendMedia: (Int32, Bool)? - if let channel = peer as? TelegramChannel, let value = channel.hasBannedPermission(.banSendMedia) { - bannedSendMedia = value - } else if let group = peer as? TelegramGroup, group.hasBannedPermission(.banSendMedia) { - bannedSendMedia = (Int32.max, false) + var canSendPolls = true + if let channel = peer as? TelegramChannel { + if let value = channel.hasBannedPermission(.banSendMedia) { + bannedSendMedia = value + } + if channel.hasBannedPermission(.banSendPolls) != nil { + canSendPolls = false + } + } else if let group = peer as? TelegramGroup { + if group.hasBannedPermission(.banSendMedia) { + bannedSendMedia = (Int32.max, false) + } + if group.hasBannedPermission(.banSendPolls) { + canSendPolls = false + } } if editMediaOptions == nil, let (untilDate, personal) = bannedSendMedia { @@ -3756,17 +3774,23 @@ public final class ChatController: TelegramController, KeyShortcutResponder, Gal } let actionSheet = ActionSheetController(presentationTheme: strongSelf.presentationData.theme) - actionSheet.setItemGroups([ActionSheetItemGroup(items: [ - ActionSheetTextItem(title: banDescription), - ActionSheetButtonItem(title: strongSelf.presentationData.strings.Conversation_Location, color: .accent, action: { [weak actionSheet] in + var items: [ActionSheetItem] = [] + items.append(ActionSheetTextItem(title: banDescription)) + items.append(ActionSheetButtonItem(title: strongSelf.presentationData.strings.Conversation_Location, color: .accent, action: { [weak actionSheet] in + actionSheet?.dismissAnimated() + self?.presentMapPicker(editingMessage: false) + })) + if canSendPolls { + items.append(ActionSheetButtonItem(title: strongSelf.presentationData.strings.AttachmentMenu_Poll, color: .accent, action: { [weak actionSheet] in actionSheet?.dismissAnimated() - self?.presentMapPicker(editingMessage: false) - }), - ActionSheetButtonItem(title: strongSelf.presentationData.strings.Conversation_Contact, color: .accent, action: { [weak actionSheet] in - actionSheet?.dismissAnimated() - self?.presentContactPicker() - }) - ]), ActionSheetItemGroup(items: [ + self?.presentPollCreation() + })) + } + items.append(ActionSheetButtonItem(title: strongSelf.presentationData.strings.Conversation_Contact, color: .accent, action: { [weak actionSheet] in + actionSheet?.dismissAnimated() + self?.presentContactPicker() + })) + actionSheet.setItemGroups([ActionSheetItemGroup(items: items), ActionSheetItemGroup(items: [ ActionSheetButtonItem(title: strongSelf.presentationData.strings.Common_Cancel, color: .accent, action: { [weak actionSheet] in actionSheet?.dismissAnimated() }) @@ -3885,7 +3909,7 @@ public final class ChatController: TelegramController, KeyShortcutResponder, Gal for item in results { if let item = item { let fileId = arc4random64() - let file = TelegramMediaFile(fileId: MediaId(namespace: Namespaces.Media.LocalFile, id: fileId), partialReference: nil, resource: ICloudFileResource(urlData: item.urlData), previewRepresentations: [], mimeType: guessMimeTypeByFileExtension((item.fileName as NSString).pathExtension), size: item.fileSize, attributes: [.FileName(fileName: item.fileName)]) + let file = TelegramMediaFile(fileId: MediaId(namespace: Namespaces.Media.LocalFile, id: fileId), partialReference: nil, resource: ICloudFileResource(urlData: item.urlData), previewRepresentations: [], immediateThumbnailData: nil, mimeType: guessMimeTypeByFileExtension((item.fileName as NSString).pathExtension), size: item.fileSize, attributes: [.FileName(fileName: item.fileName)]) let message: EnqueueMessage = .message(text: "", attributes: [], mediaReference: .standalone(media: file), replyToMessageId: replyMessageId, localGroupingKey: nil) messages.append(message) } @@ -4275,7 +4299,7 @@ public final class ChatController: TelegramController, KeyShortcutResponder, Gal fileAttributes.append(.Sticker(displayText: "", packReference: nil, maskData: nil)) fileAttributes.append(.ImageSize(size: size)) - let media = TelegramMediaFile(fileId: MediaId(namespace: Namespaces.Media.LocalFile, id: arc4random64()), partialReference: nil, resource: resource, previewRepresentations: [], mimeType: "image/webp", size: data.count, attributes: fileAttributes) + let media = TelegramMediaFile(fileId: MediaId(namespace: Namespaces.Media.LocalFile, id: arc4random64()), partialReference: nil, resource: resource, previewRepresentations: [], immediateThumbnailData: nil, mimeType: "image/webp", size: data.count, attributes: fileAttributes) let message = EnqueueMessage.message(text: "", attributes: [], mediaReference: .standalone(media: media), replyToMessageId: nil, localGroupingKey: nil) let replyMessageId = strongSelf.presentationInterfaceState.interfaceState.replyMessageId @@ -4444,7 +4468,7 @@ public final class ChatController: TelegramController, KeyShortcutResponder, Gal } }) - strongSelf.sendMessages([.message(text: "", attributes: [], mediaReference: .standalone(media: TelegramMediaFile(fileId: MediaId(namespace: Namespaces.Media.LocalFile, id: randomId), partialReference: nil, resource: resource, previewRepresentations: [], mimeType: "audio/ogg", size: data.compressedData.count, attributes: [.Audio(isVoice: true, duration: Int(data.duration), title: nil, performer: nil, waveform: waveformBuffer)])), replyToMessageId: strongSelf.presentationInterfaceState.interfaceState.replyMessageId, localGroupingKey: nil)]) + strongSelf.sendMessages([.message(text: "", attributes: [], mediaReference: .standalone(media: TelegramMediaFile(fileId: MediaId(namespace: Namespaces.Media.LocalFile, id: randomId), partialReference: nil, resource: resource, previewRepresentations: [], immediateThumbnailData: nil, mimeType: "audio/ogg", size: data.compressedData.count, attributes: [.Audio(isVoice: true, duration: Int(data.duration), title: nil, performer: nil, waveform: waveformBuffer)])), replyToMessageId: strongSelf.presentationInterfaceState.interfaceState.replyMessageId, localGroupingKey: nil)]) strongSelf.recorderFeedback?.tap() strongSelf.recorderFeedback = nil @@ -4515,7 +4539,7 @@ public final class ChatController: TelegramController, KeyShortcutResponder, Gal } }) - self.sendMessages([.message(text: "", attributes: [], mediaReference: .standalone(media: TelegramMediaFile(fileId: MediaId(namespace: Namespaces.Media.LocalFile, id: arc4random64()), partialReference: nil, resource: recordedMediaPreview.resource, previewRepresentations: [], mimeType: "audio/ogg", size: Int(recordedMediaPreview.fileSize), attributes: [.Audio(isVoice: true, duration: Int(recordedMediaPreview.duration), title: nil, performer: nil, waveform: waveformBuffer)])), replyToMessageId: self.presentationInterfaceState.interfaceState.replyMessageId, localGroupingKey: nil)]) + self.sendMessages([.message(text: "", attributes: [], mediaReference: .standalone(media: TelegramMediaFile(fileId: MediaId(namespace: Namespaces.Media.LocalFile, id: arc4random64()), partialReference: nil, resource: recordedMediaPreview.resource, previewRepresentations: [], immediateThumbnailData: nil, mimeType: "audio/ogg", size: Int(recordedMediaPreview.fileSize), attributes: [.Audio(isVoice: true, duration: Int(recordedMediaPreview.duration), title: nil, performer: nil, waveform: waveformBuffer)])), replyToMessageId: self.presentationInterfaceState.interfaceState.replyMessageId, localGroupingKey: nil)]) } } diff --git a/TelegramUI/ChatControllerBackground.swift b/TelegramUI/ChatControllerBackground.swift index 4b581a9f33..7db5ac5678 100644 --- a/TelegramUI/ChatControllerBackground.swift +++ b/TelegramUI/ChatControllerBackground.swift @@ -40,6 +40,35 @@ func chatControllerBackgroundImage(wallpaper: TelegramWallpaper, postbox: Postbo return backgroundImage } +private func serviceColor(for data: Signal) -> Signal { + return data + |> mapToSignal { data -> Signal in + if data.complete { + let image = UIImage(contentsOfFile: data.path) + let context = DrawingContext(size: CGSize(width: 1.0, height: 1.0), scale: 1.0, clear: false) + context.withFlippedContext({ context in + if let cgImage = image?.cgImage { + context.draw(cgImage, in: CGRect(x: 0.0, y: 0.0, width: 1.0, height: 1.0)) + } + }) + var color = context.colorAt(CGPoint()) + + var hue: CGFloat = 0.0 + var saturation: CGFloat = 0.0 + var brightness: CGFloat = 0.0 + var alpha: CGFloat = 0.0 + if color.getHue(&hue, saturation: &saturation, brightness: &brightness, alpha: &alpha) { + saturation = min(1.0, saturation + 0.05 + 0.1 * (1.0 - saturation)) + brightness = max(0.0, brightness * 0.65) + alpha = 0.4 + color = UIColor(hue: hue, saturation: saturation, brightness: brightness, alpha: alpha) + } + return .single(color) + } + return .complete() + } +} + func chatServiceBackgroundColor(wallpaper: TelegramWallpaper, postbox: Postbox) -> Signal { if wallpaper == serviceBackgroundColorForWallpaper?.0, let color = serviceBackgroundColorForWallpaper?.1 { return .single(color) @@ -51,32 +80,7 @@ func chatServiceBackgroundColor(wallpaper: TelegramWallpaper, postbox: Postbox) if let largest = largestImageRepresentation(representations) { return Signal { subscriber in let fetch = postbox.mediaBox.fetchedResource(largest.resource, parameters: nil).start() - let data = (postbox.mediaBox.resourceData(largest.resource) - |> mapToSignal { data -> Signal in - if data.complete { - let image = UIImage(contentsOfFile: data.path) - let context = DrawingContext(size: CGSize(width: 1.0, height: 1.0), scale: 1.0, clear: false) - context.withFlippedContext({ context in - if let cgImage = image?.cgImage { - context.draw(cgImage, in: CGRect(x: 0.0, y: 0.0, width: 1.0, height: 1.0)) - } - }) - var color = context.colorAt(CGPoint()) - - var hue: CGFloat = 0.0 - var saturation: CGFloat = 0.0 - var brightness: CGFloat = 0.0 - var alpha: CGFloat = 0.0 - if color.getHue(&hue, saturation: &saturation, brightness: &brightness, alpha: &alpha) { - saturation = min(1.0, saturation + 0.05 + 0.1 * (1.0 - saturation)) - brightness = max(0.0, brightness * 0.65) - alpha = 0.4 - color = UIColor(hue: hue, saturation: saturation, brightness: brightness, alpha: alpha) - } - return .single(color) - } - return .complete() - }).start(next: { next in + let data = serviceColor(for: postbox.mediaBox.resourceData(largest.resource)).start(next: { next in subscriber.putNext(next) }, completed: { subscriber.putCompletion() @@ -95,32 +99,7 @@ func chatServiceBackgroundColor(wallpaper: TelegramWallpaper, postbox: Postbox) case let .file(file): return Signal { subscriber in let fetch = postbox.mediaBox.fetchedResource(file.file.resource, parameters: nil).start() - let data = (postbox.mediaBox.resourceData(file.file.resource) - |> mapToSignal { data -> Signal in - if data.complete { - let image = UIImage(contentsOfFile: data.path) - let context = DrawingContext(size: CGSize(width: 1.0, height: 1.0), scale: 1.0, clear: false) - context.withFlippedContext({ context in - if let cgImage = image?.cgImage { - context.draw(cgImage, in: CGRect(x: 0.0, y: 0.0, width: 1.0, height: 1.0)) - } - }) - var color = context.colorAt(CGPoint()) - - var hue: CGFloat = 0.0 - var saturation: CGFloat = 0.0 - var brightness: CGFloat = 0.0 - var alpha: CGFloat = 0.0 - if color.getHue(&hue, saturation: &saturation, brightness: &brightness, alpha: &alpha) { - saturation = min(1.0, saturation + 0.05 + 0.1 * (1.0 - saturation)) - brightness = max(0.0, brightness * 0.65) - alpha = 0.4 - color = UIColor(hue: hue, saturation: saturation, brightness: brightness, alpha: alpha) - } - return .single(color) - } - return .complete() - }).start(next: { next in + let data = serviceColor(for: postbox.mediaBox.resourceData(file.file.resource)).start(next: { next in subscriber.putNext(next) }, completed: { subscriber.putCompletion() @@ -136,3 +115,96 @@ func chatServiceBackgroundColor(wallpaper: TelegramWallpaper, postbox: Postbox) } } } + +func chatBackgroundContrastColor(wallpaper: TelegramWallpaper, postbox: Postbox) -> Signal { + // if wallpaper == serviceBackgroundColorForWallpaper?.0, let color = serviceBackgroundColorForWallpaper?.1 { + // return .single(color) + // } else { + switch wallpaper { + case .builtin: + return .single(UIColor(rgb: 0x888f96)) + case let .color(color): + return .single(contrastingColor(for: UIColor(rgb: UInt32(bitPattern: color)))) + case let .image(representations): + if let largest = largestImageRepresentation(representations) { + return Signal { subscriber in + let fetch = postbox.mediaBox.fetchedResource(largest.resource, parameters: nil).start() + let data = backgroundContrastColor(for: postbox.mediaBox.resourceData(largest.resource)).start(next: { next in + subscriber.putNext(next) + }, completed: { + subscriber.putCompletion() + }) + return ActionDisposable { + fetch.dispose() + data.dispose() + } + } + // |> afterNext { color in + // serviceBackgroundColorForWallpaper = (wallpaper, color) + //} + } else { + return .single(.white) + } + case let .file(file): + return Signal { subscriber in + let fetch = postbox.mediaBox.fetchedResource(file.file.resource, parameters: nil).start() + let data = backgroundContrastColor(for: postbox.mediaBox.resourceData(file.file.resource)).start(next: { next in + subscriber.putNext(next) + }, completed: { + subscriber.putCompletion() + }) + return ActionDisposable { + fetch.dispose() + data.dispose() + } + } + // |> afterNext { color in + // serviceBackgroundColorForWallpaper = (wallpaper, color) + //} + } + // } +} + +private func backgroundContrastColor(for data: Signal) -> Signal { + return data + |> mapToSignal { data -> Signal in + if data.complete { + let image = UIImage(contentsOfFile: data.path) + let context = DrawingContext(size: CGSize(width: 128.0, height: 32.0), scale: 1.0, clear: false) + context.withFlippedContext({ context in + if let image = image, let cgImage = image.cgImage { + let size = image.size.aspectFilled(CGSize(width: 128.0, height: 128.0)) + context.draw(cgImage, in: CGRect(x: floor((128.0 - size.width) / 2.0), y: 0.0, width: size.width, height: size.height)) + } + }) + let finalContext = DrawingContext(size: CGSize(width: 1.0, height: 1.0), scale: 1.0, clear: false) + finalContext.withFlippedContext({ c in + if let cgImage = context.generateImage()?.cgImage { + c.draw(cgImage, in: CGRect(x: 0.0, y: 0.0, width: 1.0, height: 1.0)) + } + }) + let color = finalContext.colorAt(CGPoint()) + return .single(contrastingColor(for: color)) + } + return .complete() + } +} + +private func contrastingColor(for color: UIColor) -> UIColor { + var red: CGFloat = 0.0 + var green: CGFloat = 0.0 + var blue: CGFloat = 0.0 + var luminance: CGFloat = 0.0 + var alpha: CGFloat = 0.0; + + if color.getRed(&red, green: &green, blue: &blue, alpha: &alpha) { + luminance = red * 0.2126 + green * 0.7152 + blue * 0.0722 + } else if color.getWhite(&luminance, alpha: &alpha) { + } + + if luminance > 0.6 { + return .black + } else { + return .white + } +} diff --git a/TelegramUI/ChatHistoryEntriesForView.swift b/TelegramUI/ChatHistoryEntriesForView.swift index d0cf004fed..c29789fe1d 100644 --- a/TelegramUI/ChatHistoryEntriesForView.swift +++ b/TelegramUI/ChatHistoryEntriesForView.swift @@ -17,7 +17,7 @@ func chatHistoryEntriesForView(location: ChatLocation, view: MessageHistoryView, } var groupBucket: [(Message, Bool, ChatHistoryMessageSelection, Bool)] = [] - for entry in view.entries { + loop: for entry in view.entries { switch entry { case let .HoleEntry(hole, _): if !groupBucket.isEmpty { @@ -28,6 +28,19 @@ func chatHistoryEntriesForView(location: ChatLocation, view: MessageHistoryView, entries.append(.HoleEntry(hole, presentationData)) } case let .MessageEntry(message, read, _, monthLocation): + if message.id.peerId.namespace == Namespaces.Peer.CloudChannel { + for media in message.media { + if let action = media as? TelegramMediaAction { + switch action.action { + case .channelMigratedFromGroup, .groupMigratedToChannel: + continue loop + default: + break + } + } + } + } + var isAdmin = false if let author = message.author { isAdmin = adminIds.contains(author.id) @@ -100,7 +113,7 @@ func chatHistoryEntriesForView(location: ChatLocation, view: MessageHistoryView, entries.insert(.ChatInfoEntry(botInfo.description, presentationData), at: 0) } var isEmpty = true - if entries.count <= 2 { + if entries.count <= 3 { loop: for entry in view.entries { switch entry { case let .MessageEntry(entry): @@ -108,7 +121,7 @@ func chatHistoryEntriesForView(location: ChatLocation, view: MessageHistoryView, for media in entry.0.media { if let action = media as? TelegramMediaAction { switch action.action { - case .groupCreated, .photoUpdated: + case .groupCreated, .photoUpdated, .channelMigratedFromGroup, .groupMigratedToChannel: isEmptyMedia = true default: break diff --git a/TelegramUI/ChatHistoryListNode.swift b/TelegramUI/ChatHistoryListNode.swift index a3b415b0da..aadca16f7c 100644 --- a/TelegramUI/ChatHistoryListNode.swift +++ b/TelegramUI/ChatHistoryListNode.swift @@ -121,27 +121,48 @@ struct ChatHistoryListViewTransition { let animateIn: Bool } -private func maxMessageIndexForEntries(_ entries: [ChatHistoryEntry], indexRange: (Int, Int)) -> (incoming: MessageIndex?, overall: MessageIndex?) { +private func maxMessageIndexForEntries(_ view: ChatHistoryView, indexRange: (Int, Int)) -> (incoming: MessageIndex?, overall: MessageIndex?) { + var incoming: MessageIndex? var overall: MessageIndex? - for i in (indexRange.0 ... indexRange.1).reversed() { - if case let .MessageEntry(message, _, _, _, _, _) = entries[i] { - if overall == nil { - overall = MessageIndex(message) + var nextLowestIndex: MessageIndex? + if indexRange.0 >= 0 && indexRange.0 < view.filteredEntries.count { + if indexRange.0 > 0 { + nextLowestIndex = view.filteredEntries[indexRange.0 - 1].index + } + } + var nextHighestIndex: MessageIndex? + if indexRange.1 >= 0 && indexRange.1 < view.filteredEntries.count { + if indexRange.1 < view.filteredEntries.count - 1 { + nextHighestIndex = view.filteredEntries[indexRange.1 + 1].index + } + } + for i in (0 ..< view.originalView.entries.count).reversed() { + let index = view.originalView.entries[i].index + if let nextLowestIndex = nextLowestIndex { + if index <= nextLowestIndex { + continue } - if message.flags.contains(.Incoming) { - return (MessageIndex(message), overall) + } + if let nextHighestIndex = nextHighestIndex { + if index >= nextHighestIndex { + continue } - } else if case let .MessageGroupEntry(_, messages, _) = entries[i] { - let index = MessageIndex(messages[messages.count - 1].0) - if overall == nil { + } + if case let .MessageEntry(messageEntry) = view.originalView.entries[i] { + if overall == nil || overall! < index { overall = index } - if messages[messages.count - 1].0.flags.contains(.Incoming) { - return (index, overall) + if messageEntry.0.flags.contains(.Incoming) { + if incoming == nil || incoming! < index { + incoming = index + } + } + if incoming != nil { + return (incoming, overall) } } } - return (nil, overall) + return (incoming, overall) } private func mappedInsertEntries(account: Account, chatLocation: ChatLocation, associatedData: ChatMessageItemAssociatedData, controllerInteraction: ChatControllerInteraction, mode: ChatHistoryListMode, entries: [ChatHistoryViewTransitionInsertEntry]) -> [ListViewInsertItem] { @@ -654,7 +675,7 @@ public final class ChatHistoryListNode: ListView, ChatHistoryNode { } if readIndexRange.0 <= readIndexRange.1 { - let (maxIncomingIndex, maxOverallIndex) = maxMessageIndexForEntries(historyView.filteredEntries, indexRange: readIndexRange) + let (maxIncomingIndex, maxOverallIndex) = maxMessageIndexForEntries(historyView, indexRange: readIndexRange) if let maxIncomingIndex = maxIncomingIndex { strongSelf.updateMaxVisibleReadIncomingMessageIndex(maxIncomingIndex) @@ -980,7 +1001,7 @@ public final class ChatHistoryListNode: ListView, ChatHistoryNode { visibleFirstIndex += 1 }*/ if visibleFirstIndex <= visible.lastIndex { - let (messageIndex, _) = maxMessageIndexForEntries(transition.historyView.filteredEntries, indexRange: (transition.historyView.filteredEntries.count - 1 - visible.lastIndex, transition.historyView.filteredEntries.count - 1 - visibleFirstIndex)) + let (messageIndex, _) = maxMessageIndexForEntries(transition.historyView, indexRange: (transition.historyView.filteredEntries.count - 1 - visible.lastIndex, transition.historyView.filteredEntries.count - 1 - visibleFirstIndex)) if let messageIndex = messageIndex { strongSelf.updateMaxVisibleReadIncomingMessageIndex(messageIndex) } diff --git a/TelegramUI/ChatInterfaceStateContextMenus.swift b/TelegramUI/ChatInterfaceStateContextMenus.swift index e9aa9e4c8d..279a1f2554 100644 --- a/TelegramUI/ChatInterfaceStateContextMenus.swift +++ b/TelegramUI/ChatInterfaceStateContextMenus.swift @@ -585,12 +585,6 @@ private func canPerformEditingActions(limits: LimitsConfiguration, accountPeerId return true } - if let peer = message.peers[message.id.peerId] as? TelegramChannel { - if peer.hasPermission(.pinMessages) { - return true - } - } - return false } diff --git a/TelegramUI/ChatListController.swift b/TelegramUI/ChatListController.swift index c4e2230333..f9bfbaca9c 100644 --- a/TelegramUI/ChatListController.swift +++ b/TelegramUI/ChatListController.swift @@ -442,10 +442,11 @@ public class ChatListController: TelegramController, KeyShortcutResponder, UIVie self.chatListDisplayNode.requestOpenMessageFromSearch = { [weak self] peer, messageId in if let strongSelf = self { - strongSelf.openMessageFromSearchDisposable.set((storedMessageFromSearchPeer(account: strongSelf.account, peer: peer) |> deliverOnMainQueue).start(completed: { [weak strongSelf] in + strongSelf.openMessageFromSearchDisposable.set((storedMessageFromSearchPeer(account: strongSelf.account, peer: peer) + |> deliverOnMainQueue).start(next: { [weak strongSelf] actualPeerId in if let strongSelf = strongSelf { if let navigationController = strongSelf.navigationController as? NavigationController { - navigateToChatController(navigationController: navigationController, account: strongSelf.account, chatLocation: .peer(messageId.peerId), messageId: messageId, purposefulAction: { + navigateToChatController(navigationController: navigationController, account: strongSelf.account, chatLocation: .peer(actualPeerId), messageId: messageId, purposefulAction: { self?.deactivateSearch(animated: false) }) strongSelf.chatListDisplayNode.chatListNode.clearHighlightAnimated(true) @@ -968,7 +969,7 @@ public class ChatListController: TelegramController, KeyShortcutResponder, UIVie let signal: Signal = strongSelf.account.postbox.transaction { transaction -> Void in for peerId in peerIds { - removePeerChat(transaction: transaction, mediaBox: account.postbox.mediaBox, peerId: peerId, reportChatSpam: false) + removePeerChat(transaction: transaction, mediaBox: account.postbox.mediaBox, peerId: peerId, reportChatSpam: false, deleteGloballyIfPossible: false) } } |> afterDisposed { diff --git a/TelegramUI/ChatListItem.swift b/TelegramUI/ChatListItem.swift index c5e19d1ca1..761fe86321 100644 --- a/TelegramUI/ChatListItem.swift +++ b/TelegramUI/ChatListItem.swift @@ -100,8 +100,10 @@ class ChatListItem: ListViewItem { func selected(listView: ListView) { switch self.content { case let .peer(message, peer, _, _, _, _, _, isAd, _): - if let message = message { - self.interaction.messageSelected(message, isAd) + if let message = message, let peer = peer.peer { + self.interaction.messageSelected(peer, message, isAd) + } else if let peer = peer.peer { + self.interaction.peerSelected(peer) } else if let peer = peer.peers[peer.peerId] { self.interaction.peerSelected(peer) } diff --git a/TelegramUI/ChatListNode.swift b/TelegramUI/ChatListNode.swift index 19a956c98c..55367fc02a 100644 --- a/TelegramUI/ChatListNode.swift +++ b/TelegramUI/ChatListNode.swift @@ -60,7 +60,7 @@ final class ChatListNodeInteraction { let activateSearch: () -> Void let peerSelected: (Peer) -> Void let togglePeerSelected: (PeerId) -> Void - let messageSelected: (Message, Bool) -> Void + let messageSelected: (Peer, Message, Bool) -> Void let groupSelected: (PeerGroupId) -> Void let addContact: (String) -> Void let setPeerIdWithRevealedOptions: (PeerId?, PeerId?) -> Void @@ -72,7 +72,7 @@ final class ChatListNodeInteraction { var highlightedChatLocation: ChatListHighlightedLocation? - init(activateSearch: @escaping () -> Void, peerSelected: @escaping (Peer) -> Void, togglePeerSelected: @escaping (PeerId) -> Void, messageSelected: @escaping (Message, Bool) -> Void, groupSelected: @escaping (PeerGroupId) -> Void, addContact: @escaping (String) -> Void, setPeerIdWithRevealedOptions: @escaping (PeerId?, PeerId?) -> Void, setItemPinned: @escaping (PinnedItemId, Bool) -> Void, setPeerMuted: @escaping (PeerId, Bool) -> Void, deletePeer: @escaping (PeerId) -> Void, updatePeerGrouping: @escaping (PeerId, Bool) -> Void, togglePeerMarkedUnread: @escaping (PeerId, Bool) -> Void) { + init(activateSearch: @escaping () -> Void, peerSelected: @escaping (Peer) -> Void, togglePeerSelected: @escaping (PeerId) -> Void, messageSelected: @escaping (Peer, Message, Bool) -> Void, groupSelected: @escaping (PeerGroupId) -> Void, addContact: @escaping (String) -> Void, setPeerIdWithRevealedOptions: @escaping (PeerId?, PeerId?) -> Void, setItemPinned: @escaping (PinnedItemId, Bool) -> Void, setPeerMuted: @escaping (PeerId, Bool) -> Void, deletePeer: @escaping (PeerId) -> Void, updatePeerGrouping: @escaping (PeerId, Bool) -> Void, togglePeerMarkedUnread: @escaping (PeerId, Bool) -> Void) { self.activateSearch = activateSearch self.peerSelected = peerSelected self.togglePeerSelected = togglePeerSelected @@ -386,9 +386,9 @@ final class ChatListNode: ListView { } return state } - }, messageSelected: { [weak self] message, isAd in + }, messageSelected: { [weak self] peer, message, isAd in if let strongSelf = self, let peerSelected = strongSelf.peerSelected { - peerSelected(message.id.peerId, true, isAd) + peerSelected(peer.id, true, isAd) } }, groupSelected: { [weak self] groupId in if let strongSelf = self, let groupSelected = strongSelf.groupSelected { diff --git a/TelegramUI/ChatListSearchContainerNode.swift b/TelegramUI/ChatListSearchContainerNode.swift index e9af505fc2..ac5a9bb3a2 100644 --- a/TelegramUI/ChatListSearchContainerNode.swift +++ b/TelegramUI/ChatListSearchContainerNode.swift @@ -842,7 +842,7 @@ final class ChatListSearchContainerNode: SearchDisplayControllerContentNode { let _ = addRecentlySearchedPeer(postbox: account.postbox, peerId: peer.id).start() self?.listNode.clearHighlightAnimated(true) }, togglePeerSelected: { _ in - }, messageSelected: { [weak self] message, _ in + }, messageSelected: { [weak self] peer, message, _ in if let peer = message.peers[message.id.peerId] { openMessage(peer, message.id) } diff --git a/TelegramUI/ChatMessageActionItemNode.swift b/TelegramUI/ChatMessageActionItemNode.swift index 4aef798898..eb3e3b1088 100644 --- a/TelegramUI/ChatMessageActionItemNode.swift +++ b/TelegramUI/ChatMessageActionItemNode.swift @@ -232,7 +232,7 @@ private func universalServiceMessageString(theme: ChatPresentationThemeData?, st case .joinedByLink: attributedString = addAttributesToStringWithRanges(strings.Notification_JoinedGroupByLink(authorName), body: bodyAttributes, argumentAttributes: peerMentionsAttributes(primaryTextColor: primaryTextColor, peerIds: [(0, message.author?.id)])) case .channelMigratedFromGroup, .groupMigratedToChannel: - attributedString = NSAttributedString(string: strings.Notification_ChannelMigratedFrom, font: titleFont, textColor: primaryTextColor) + attributedString = NSAttributedString(string: "", font: titleFont, textColor: primaryTextColor) case let .messageAutoremoveTimeoutUpdated(timeout): if timeout > 0 { let timeValue = timeIntervalString(strings: strings, value: timeout) diff --git a/TelegramUI/ChatMessageInteractiveFileNode.swift b/TelegramUI/ChatMessageInteractiveFileNode.swift index 3101722070..e8bf43a6ec 100644 --- a/TelegramUI/ChatMessageInteractiveFileNode.swift +++ b/TelegramUI/ChatMessageInteractiveFileNode.swift @@ -195,10 +195,10 @@ final class ChatMessageInteractiveFileNode: ASDisplayNode { statusUpdated = true } - let hasThumbnail = !file.previewRepresentations.isEmpty && !file.isMusic && !file.isVoice + let hasThumbnail = (!file.previewRepresentations.isEmpty || file.immediateThumbnailData != nil) && !file.isMusic && !file.isVoice if mediaUpdated { - if let _ = largestImageRepresentation(file.previewRepresentations) { + if largestImageRepresentation(file.previewRepresentations) != nil || file.immediateThumbnailData != nil { updateImageSignal = chatMessageImageFile(account: account, fileReference: .message(message: MessageReference(message), media: file), thumbnail: true) } diff --git a/TelegramUI/ChatMessageStickerItemNode.swift b/TelegramUI/ChatMessageStickerItemNode.swift index a1c82b345c..cd56ba8504 100644 --- a/TelegramUI/ChatMessageStickerItemNode.swift +++ b/TelegramUI/ChatMessageStickerItemNode.swift @@ -354,7 +354,7 @@ class ChatMessageStickerItemNode: ChatMessageItemView { } if let shareButtonNode = strongSelf.shareButtonNode { - shareButtonNode.frame = CGRect(origin: CGPoint(x: updatedImageFrame.maxX + 8.0, y: updatedImageFrame.maxY - 30.0), size: CGSize(width: 29.0, height: 29.0)) + shareButtonNode.frame = CGRect(origin: CGPoint(x: updatedImageFrame.maxX + 8.0, y: updatedImageFrame.maxY - 30.0 - 10.0), size: CGSize(width: 29.0, height: 29.0)) } dateAndStatusApply(false) @@ -419,7 +419,7 @@ class ChatMessageStickerItemNode: ChatMessageItemView { } let actionButtonsNode = actionButtonsSizeAndApply.1(animated) let previousFrame = actionButtonsNode.frame - let actionButtonsFrame = CGRect(origin: CGPoint(x: imageFrame.minX, y: imageFrame.maxY), size: actionButtonsSizeAndApply.0) + let actionButtonsFrame = CGRect(origin: CGPoint(x: imageFrame.minX, y: imageFrame.maxY - 10.0), size: actionButtonsSizeAndApply.0) actionButtonsNode.frame = actionButtonsFrame if actionButtonsNode !== strongSelf.actionButtonsNode { strongSelf.actionButtonsNode = actionButtonsNode diff --git a/TelegramUI/ChatRecentActionsControllerNode.swift b/TelegramUI/ChatRecentActionsControllerNode.swift index b287e63977..64751da7fc 100644 --- a/TelegramUI/ChatRecentActionsControllerNode.swift +++ b/TelegramUI/ChatRecentActionsControllerNode.swift @@ -770,6 +770,8 @@ final class ChatRecentActionsControllerNode: ViewControllerTracingNode { }, dismissInput: { self?.view.endEditing(true) }) + case let .wallpaper(slug): + break } } })) diff --git a/TelegramUI/ChatRecentActionsHistoryTransition.swift b/TelegramUI/ChatRecentActionsHistoryTransition.swift index f6414cd6aa..174e9382e9 100644 --- a/TelegramUI/ChatRecentActionsHistoryTransition.swift +++ b/TelegramUI/ChatRecentActionsHistoryTransition.swift @@ -767,8 +767,6 @@ struct ChatRecentActionsEntry: Comparable, Identifiable { var text: String = "" var entities: [MessageTextEntity] = [] - let newFlags = new.flags - var addedRights = new.flags var removedRights: TelegramChatBannedRightsFlags = [] addedRights = addedRights.subtracting(prev.flags) @@ -777,8 +775,6 @@ struct ChatRecentActionsEntry: Comparable, Identifiable { text += self.presentationData.strings.Channel_AdminLog_DefaultRestrictionsUpdated text += "\n" - let prevFlags = prev.flags - let order: [(TelegramChatBannedRightsFlags, String)] = [ (.banReadMessages, self.presentationData.strings.Channel_AdminLog_BanReadMessages), (.banSendMessages, self.presentationData.strings.Channel_AdminLog_BanSendMessages), @@ -786,6 +782,10 @@ struct ChatRecentActionsEntry: Comparable, Identifiable { (.banSendStickers, self.presentationData.strings.Channel_AdminLog_BanSendStickers), (.banSendGifs, self.presentationData.strings.Channel_AdminLog_BanSendGifs), (.banEmbedLinks, self.presentationData.strings.Channel_AdminLog_BanEmbedLinks), + (.banSendPolls, self.presentationData.strings.Channel_AdminLog_SendPolls), + (.banAddMembers, self.presentationData.strings.Channel_AdminLog_AddMembers), + (.banPinMessages, self.presentationData.strings.Channel_AdminLog_PinMessages), + (.banSendPolls, self.presentationData.strings.Channel_AdminLog_SendPolls) ] for (flag, string) in order { diff --git a/TelegramUI/ChatTextInputPanelNode.swift b/TelegramUI/ChatTextInputPanelNode.swift index 4727cf8561..56df3d885e 100644 --- a/TelegramUI/ChatTextInputPanelNode.swift +++ b/TelegramUI/ChatTextInputPanelNode.swift @@ -20,11 +20,17 @@ private let searchLayoutProgressImage = generateImage(CGSize(width: 22.0, height private let accessoryButtonFont = Font.medium(14.0) -private final class AccessoryItemIconButton: HighlightableButton { +private final class AccessoryItemIconButton: HighlightTrackingButton { private let item: ChatTextInputAccessoryItem private var width: CGFloat + private let imageNode: ASImageNode init(item: ChatTextInputAccessoryItem, theme: PresentationTheme, strings: PresentationStrings) { + self.imageNode = ASImageNode() + self.imageNode.isLayerBacked = true + self.imageNode.displaysAsynchronously = false + self.imageNode.displayWithoutProcessing = true + self.item = item let (image, text, alpha, insets) = AccessoryItemIconButton.imageAndInsets(item: item, theme: theme, strings: strings) @@ -33,15 +39,29 @@ private final class AccessoryItemIconButton: HighlightableButton { super.init(frame: CGRect()) + self.addSubnode(self.imageNode) + if let text = text { self.titleLabel?.font = accessoryButtonFont self.setTitleColor(theme.chat.inputPanel.inputControlColor, for: []) self.setTitle(text, for: []) } - self.setImage(image, for: []) + self.imageNode.image = image + self.imageNode.alpha = alpha self.imageEdgeInsets = insets - self.imageView?.alpha = alpha + + self.highligthedChanged = { [weak self] highlighted in + if let strongSelf = self { + if highlighted { + strongSelf.layer.removeAnimation(forKey: "opacity") + strongSelf.alpha = 0.4 + } else { + strongSelf.alpha = 1.0 + strongSelf.layer.animateAlpha(from: 0.4, to: 1.0, duration: 0.2) + } + } + } } func updateThemeAndStrings(theme: PresentationTheme, strings: PresentationStrings) { @@ -57,9 +77,9 @@ private final class AccessoryItemIconButton: HighlightableButton { self.setTitle("", for: []) } - self.setImage(image, for: []) + self.imageNode.image = image self.imageEdgeInsets = insets - self.imageView?.alpha = alpha + self.imageNode.alpha = alpha } required init?(coder aDecoder: NSCoder) { @@ -105,6 +125,12 @@ private final class AccessoryItemIconButton: HighlightableButton { } } + func updateLayout(size: CGSize) { + if let image = self.imageNode.image { + self.imageNode.frame = CGRect(origin: CGPoint(x: floor((size.width - image.size.width) / 2.0), y: floor((size.width - image.size.width) / 2.0) - self.imageEdgeInsets.bottom), size: image.size) + } + } + var buttonWidth: CGFloat { return self.width } @@ -984,6 +1010,7 @@ class ChatTextInputPanelNode: ChatInputPanelNode, ASEditableTextNodeDelegate { var nextButtonTopRight = CGPoint(x: width - rightInset - textFieldInsets.right - accessoryButtonInset, y: panelHeight - textFieldInsets.bottom - minimalInputHeight + audioRecordingItemsVerticalOffset) for (_, button) in self.accessoryItemButtons.reversed() { let buttonSize = CGSize(width: button.buttonWidth, height: minimalInputHeight) + button.updateLayout(size: buttonSize) let buttonFrame = CGRect(origin: CGPoint(x: nextButtonTopRight.x - buttonSize.width, y: nextButtonTopRight.y + floor((minimalInputHeight - buttonSize.height) / 2.0)), size: buttonSize) if button.superview == nil { self.view.addSubview(button) diff --git a/TelegramUI/ContactListNode.swift b/TelegramUI/ContactListNode.swift index 45bc57e4bc..2923998203 100644 --- a/TelegramUI/ContactListNode.swift +++ b/TelegramUI/ContactListNode.swift @@ -629,7 +629,12 @@ private func preparedContactListNodeTransition(account: Account, from fromEntrie } } - return ContactsListNodeTransition(deletions: deletions, insertions: insertions, updates: updates, indexSections: indexSections, firstTime: firstTime, isEmpty: isEmpty, animation: animation) + var scrollToItem: ListViewScrollToItem? + if firstTime && toEntries.count >= 1 { + scrollToItem = ListViewScrollToItem(index: 0, position: .top(-navigationBarSearchContentHeight - 50.0), animated: false, curve: .Default(duration: 0.0), directionHint: .Up) + } + + return ContactsListNodeTransition(deletions: deletions, insertions: insertions, updates: updates, indexSections: indexSections, firstTime: firstTime, isEmpty: isEmpty, scrollToItem: scrollToItem, animation: animation) } private struct ContactsListNodeTransition { @@ -639,6 +644,7 @@ private struct ContactsListNodeTransition { let indexSections: [String] let firstTime: Bool let isEmpty: Bool + let scrollToItem: ListViewScrollToItem? let animation: ContactListAnimation } @@ -727,6 +733,9 @@ final class ContactListNode: ASDisplayNode { self.selectionStatePromise.set(.single(self.selectionStateValue)) } } + var selectionState: ContactListNodeGroupSelectionState? { + return self.selectionStateValue + } private var enableUpdatesValue = false var enableUpdates: Bool { @@ -1271,7 +1280,7 @@ final class ContactListNode: ASDisplayNode { self.indexNode.update(size: CGSize(width: 20.0, height: layout.size.height - insets.top - insets.bottom), color: self.presentationData.theme.list.itemAccentColor, sections: transition.indexSections, transition: .animated(duration: 0.2, curve: .easeInOut)) } - self.listNode.transaction(deleteIndices: transition.deletions, insertIndicesAndItems: transition.insertions, updateIndicesAndItems: transition.updates, options: options, updateOpaqueState: nil, completion: { [weak self] _ in + self.listNode.transaction(deleteIndices: transition.deletions, insertIndicesAndItems: transition.insertions, updateIndicesAndItems: transition.updates, options: options, scrollToItem: transition.scrollToItem, updateOpaqueState: nil, completion: { [weak self] _ in if let strongSelf = self { if !strongSelf.didSetReady { strongSelf.didSetReady = true diff --git a/TelegramUI/ContactMultiselectionController.swift b/TelegramUI/ContactMultiselectionController.swift index 46653766f8..d6bf917117 100644 --- a/TelegramUI/ContactMultiselectionController.swift +++ b/TelegramUI/ContactMultiselectionController.swift @@ -131,11 +131,12 @@ class ContactMultiselectionController: ViewController { switch self.mode { case .groupCreation: let maxCount: Int32 = self.limitsConfiguration?.maxSupergroupMemberCount ?? 5000 - self.titleView.title = CounterContollerTitle(title: self.presentationData.strings.Compose_NewGroupTitle, counter: "0/\(maxCount)") + let count = self.contactsNode.contactListNode.selectionState?.selectedPeerIndices.count ?? 0 + self.titleView.title = CounterContollerTitle(title: self.presentationData.strings.Compose_NewGroupTitle, counter: "\(count)/\(maxCount)") let rightNavigationButton = UIBarButtonItem(title: self.presentationData.strings.Common_Next, style: .done, target: self, action: #selector(self.rightNavigationButtonPressed)) self.rightNavigationButton = rightNavigationButton self.navigationItem.rightBarButtonItem = self.rightNavigationButton - rightNavigationButton.isEnabled = false + rightNavigationButton.isEnabled = count != 0 case .channelCreation: self.titleView.title = CounterContollerTitle(title: self.presentationData.strings.GroupInfo_AddParticipantTitle, counter: "") let rightNavigationButton = UIBarButtonItem(title: self.presentationData.strings.Common_Next, style: .done, target: self, action: #selector(self.rightNavigationButtonPressed)) diff --git a/TelegramUI/ContactsController.swift b/TelegramUI/ContactsController.swift index eb9243713c..ba2166fe9d 100644 --- a/TelegramUI/ContactsController.swift +++ b/TelegramUI/ContactsController.swift @@ -5,6 +5,25 @@ import Postbox import SwiftSignalKit import TelegramCore +private func fixListNodeScrolling(_ listNode: ListView, searchNode: NavigationBarSearchContentNode) -> Bool { + if searchNode.expansionProgress > 0.0 && searchNode.expansionProgress < 1.0 { + let scrollToItem: ListViewScrollToItem + let targetProgress: CGFloat + if searchNode.expansionProgress < 0.6 { + scrollToItem = ListViewScrollToItem(index: 1, position: .top(-navigationBarSearchContentHeight), animated: true, curve: .Default(duration: 0.25), directionHint: .Up) + targetProgress = 0.0 + } else { + scrollToItem = ListViewScrollToItem(index: 1, position: .top(0.0), animated: true, curve: .Default(duration: 0.25), directionHint: .Up) + targetProgress = 1.0 + } + searchNode.updateExpansionProgress(targetProgress, animated: true) + + listNode.transaction(deleteIndices: [], insertIndicesAndItems: [], updateIndicesAndItems: [], options: ListViewDeleteAndInsertOptions(), scrollToItem: scrollToItem, updateSizeAndInsets: nil, stationaryItemRange: nil, updateOpaqueState: nil, completion: { _ in }) + return true + } + return false +} + public class ContactsController: ViewController { private let account: Account @@ -229,7 +248,7 @@ public class ContactsController: ViewController { self.contactsNode.contactListNode.contentScrollingEnded = { [weak self] listView in if let strongSelf = self, let searchContentNode = strongSelf.searchContentNode { - return fixNavigationSearchableListNodeScrolling(listView, searchNode: searchContentNode) + return fixListNodeScrolling(listView, searchNode: searchContentNode) } else { return false } diff --git a/TelegramUI/DebugAccountsController.swift b/TelegramUI/DebugAccountsController.swift index c062ab9028..8f0f8a472a 100644 --- a/TelegramUI/DebugAccountsController.swift +++ b/TelegramUI/DebugAccountsController.swift @@ -105,10 +105,31 @@ public func debugAccountsController(account: Account, accountManager: AccountMan transaction.setCurrentId(id) }).start() }, loginNewAccount: { - let _ = accountManager.transaction({ transaction -> Void in - let id = transaction.createRecord([]) - transaction.setCurrentId(id) - }).start() + let presentationData = account.telegramApplicationContext.currentPresentationData.with { $0 } + let controller = ActionSheetController(presentationTheme: presentationData.theme) + let dismissAction: () -> Void = { [weak controller] in + controller?.dismissAnimated() + } + controller.setItemGroups([ + ActionSheetItemGroup(items: [ + ActionSheetButtonItem(title: "Production", color: .accent, action: { + dismissAction() + let _ = accountManager.transaction({ transaction -> Void in + let id = transaction.createRecord([AccountEnvironmentAttribute(environment: .production)]) + transaction.setCurrentId(id) + }).start() + }), + ActionSheetButtonItem(title: "Test", color: .accent, action: { + dismissAction() + let _ = accountManager.transaction({ transaction -> Void in + let id = transaction.createRecord([AccountEnvironmentAttribute(environment: .test)]) + transaction.setCurrentId(id) + }).start() + }) + ]), + ActionSheetItemGroup(items: [ActionSheetButtonItem(title: presentationData.strings.Common_Cancel, action: { dismissAction() })]) + ]) + presentControllerImpl?(controller, ViewControllerPresentationArguments(presentationAnimation: .modalSheet)) }) let signal = combineLatest((account.applicationContext as! TelegramApplicationContext).presentationData, accountManager.accountRecords()) diff --git a/TelegramUI/DebugController.swift b/TelegramUI/DebugController.swift index a5bc8e8dc4..61f4a69e4e 100644 --- a/TelegramUI/DebugController.swift +++ b/TelegramUI/DebugController.swift @@ -118,7 +118,7 @@ private enum DebugControllerEntry: ItemListNodeEntry { let messages = logs.map { (name, path) -> EnqueueMessage in let id = arc4random64() - let file = TelegramMediaFile(fileId: MediaId(namespace: Namespaces.Media.LocalFile, id: id), partialReference: nil, resource: LocalFileReferenceMediaResource(localFilePath: path, randomId: id), previewRepresentations: [], mimeType: "application/text", size: nil, attributes: [.FileName(fileName: name)]) + let file = TelegramMediaFile(fileId: MediaId(namespace: Namespaces.Media.LocalFile, id: id), partialReference: nil, resource: LocalFileReferenceMediaResource(localFilePath: path, randomId: id), previewRepresentations: [], immediateThumbnailData: nil, mimeType: "application/text", size: nil, attributes: [.FileName(fileName: name)]) return .message(text: "", attributes: [], mediaReference: .standalone(media: file), replyToMessageId: nil, localGroupingKey: nil) } let _ = enqueueMessages(account: arguments.account, peerId: peerId, messages: messages).start() @@ -140,7 +140,7 @@ private enum DebugControllerEntry: ItemListNodeEntry { let messages = updatedLogs.map { (name, path) -> EnqueueMessage in let id = arc4random64() - let file = TelegramMediaFile(fileId: MediaId(namespace: Namespaces.Media.LocalFile, id: id), partialReference: nil, resource: LocalFileReferenceMediaResource(localFilePath: path, randomId: id), previewRepresentations: [], mimeType: "application/text", size: nil, attributes: [.FileName(fileName: name)]) + let file = TelegramMediaFile(fileId: MediaId(namespace: Namespaces.Media.LocalFile, id: id), partialReference: nil, resource: LocalFileReferenceMediaResource(localFilePath: path, randomId: id), previewRepresentations: [], immediateThumbnailData: nil, mimeType: "application/text", size: nil, attributes: [.FileName(fileName: name)]) return .message(text: "", attributes: [], mediaReference: .standalone(media: file), replyToMessageId: nil, localGroupingKey: nil) } let _ = enqueueMessages(account: arguments.account, peerId: peerId, messages: messages).start() diff --git a/TelegramUI/DefaultDarkAccentPresentationTheme.swift b/TelegramUI/DefaultDarkAccentPresentationTheme.swift index b5f4c96852..282ebc067c 100644 --- a/TelegramUI/DefaultDarkAccentPresentationTheme.swift +++ b/TelegramUI/DefaultDarkAccentPresentationTheme.swift @@ -57,7 +57,9 @@ private let rootController = PresentationThemeRootController( private let switchColors = PresentationThemeSwitch( frameColor: UIColor(rgb: 0xDBF5FF, alpha: 0.5), handleColor: UIColor(rgb: 0x121212), - contentColor: accentColor + contentColor: accentColor, + positiveColor: accentColor, + negativeColor: destructiveColor ) private let list = PresentationThemeList( diff --git a/TelegramUI/DefaultDarkPresentationTheme.swift b/TelegramUI/DefaultDarkPresentationTheme.swift index 65d30f6cdd..4a06a0d340 100644 --- a/TelegramUI/DefaultDarkPresentationTheme.swift +++ b/TelegramUI/DefaultDarkPresentationTheme.swift @@ -57,7 +57,9 @@ private let rootController = PresentationThemeRootController( private let switchColors = PresentationThemeSwitch( frameColor: UIColor(rgb: 0x545454), handleColor: UIColor(rgb: 0x121212), - contentColor: UIColor(rgb: 0xb2b2b2) + contentColor: UIColor(rgb: 0xb2b2b2), + positiveColor: UIColor(rgb: 0x000000), + negativeColor: destructiveColor ) private let list = PresentationThemeList( diff --git a/TelegramUI/DefaultPresentationTheme.swift b/TelegramUI/DefaultPresentationTheme.swift index e3e5040831..c9375b9a4b 100644 --- a/TelegramUI/DefaultPresentationTheme.swift +++ b/TelegramUI/DefaultPresentationTheme.swift @@ -57,7 +57,9 @@ private func makeDefaultPresentationTheme(accentColor: UIColor, serviceBackgroun let switchColors = PresentationThemeSwitch( frameColor: UIColor(rgb: 0xe0e0e0), handleColor: UIColor(rgb: 0xffffff), - contentColor: UIColor(rgb: 0x42d451) + contentColor: UIColor(rgb: 0x42d451), + positiveColor: UIColor(rgb: 0x00B12C), + negativeColor: destructiveColor ) let list = PresentationThemeList( diff --git a/TelegramUI/GroupInfoController.swift b/TelegramUI/GroupInfoController.swift index 06adaa6e32..9be05a5a28 100644 --- a/TelegramUI/GroupInfoController.swift +++ b/TelegramUI/GroupInfoController.swift @@ -28,7 +28,6 @@ private final class GroupInfoArguments { let promotePeer: (RenderedChannelParticipant) -> Void let restrictPeer: (RenderedChannelParticipant) -> Void let removePeer: (PeerId) -> Void - let convertToSupergroup: () -> Void let leave: () -> Void let displayUsernameShareMenu: (String) -> Void let displayUsernameContextMenu: (String) -> Void @@ -37,7 +36,7 @@ private final class GroupInfoArguments { let openStickerPackSetup: () -> Void let openGroupTypeSetup: () -> Void - init(account: Account, peerId: PeerId, avatarAndNameInfoContext: ItemListAvatarAndNameInfoItemContext, tapAvatarAction: @escaping () -> Void, changeProfilePhoto: @escaping () -> Void, pushController: @escaping (ViewController) -> Void, presentController: @escaping (ViewController, ViewControllerPresentationArguments) -> Void, changeNotificationMuteSettings: @escaping () -> Void, openPreHistory: @escaping () -> Void, openSharedMedia: @escaping () -> Void, openAdministrators: @escaping () -> Void, openPermissions: @escaping () -> Void, updateEditingName: @escaping (ItemListAvatarAndNameInfoItemName) -> Void, updateEditingDescriptionText: @escaping (String) -> Void, setPeerIdWithRevealedOptions: @escaping (PeerId?, PeerId?) -> Void, addMember: @escaping () -> Void, promotePeer: @escaping (RenderedChannelParticipant) -> Void, restrictPeer: @escaping (RenderedChannelParticipant) -> Void, removePeer: @escaping (PeerId) -> Void, convertToSupergroup: @escaping () -> Void, leave: @escaping () -> Void, displayUsernameShareMenu: @escaping (String) -> Void, displayUsernameContextMenu: @escaping (String) -> Void, displayAboutContextMenu: @escaping (String) -> Void, aboutLinkAction: @escaping (TextLinkItemActionType, TextLinkItem) -> Void, openStickerPackSetup: @escaping () -> Void, openGroupTypeSetup: @escaping () -> Void) { + init(account: Account, peerId: PeerId, avatarAndNameInfoContext: ItemListAvatarAndNameInfoItemContext, tapAvatarAction: @escaping () -> Void, changeProfilePhoto: @escaping () -> Void, pushController: @escaping (ViewController) -> Void, presentController: @escaping (ViewController, ViewControllerPresentationArguments) -> Void, changeNotificationMuteSettings: @escaping () -> Void, openPreHistory: @escaping () -> Void, openSharedMedia: @escaping () -> Void, openAdministrators: @escaping () -> Void, openPermissions: @escaping () -> Void, updateEditingName: @escaping (ItemListAvatarAndNameInfoItemName) -> Void, updateEditingDescriptionText: @escaping (String) -> Void, setPeerIdWithRevealedOptions: @escaping (PeerId?, PeerId?) -> Void, addMember: @escaping () -> Void, promotePeer: @escaping (RenderedChannelParticipant) -> Void, restrictPeer: @escaping (RenderedChannelParticipant) -> Void, removePeer: @escaping (PeerId) -> Void, leave: @escaping () -> Void, displayUsernameShareMenu: @escaping (String) -> Void, displayUsernameContextMenu: @escaping (String) -> Void, displayAboutContextMenu: @escaping (String) -> Void, aboutLinkAction: @escaping (TextLinkItemActionType, TextLinkItem) -> Void, openStickerPackSetup: @escaping () -> Void, openGroupTypeSetup: @escaping () -> Void) { self.account = account self.peerId = peerId self.avatarAndNameInfoContext = avatarAndNameInfoContext @@ -57,7 +56,6 @@ private final class GroupInfoArguments { self.promotePeer = promotePeer self.restrictPeer = restrictPeer self.removePeer = removePeer - self.convertToSupergroup = convertToSupergroup self.leave = leave self.displayUsernameShareMenu = displayUsernameShareMenu self.displayUsernameContextMenu = displayUsernameContextMenu @@ -147,7 +145,6 @@ private enum GroupInfoEntry: ItemListNodeEntry { case permissions(PresentationTheme, String, String) case addMember(PresentationTheme, String, editing: Bool) case member(PresentationTheme, PresentationStrings, PresentationDateTimeFormat, PresentationPersonNameOrder, index: Int, peerId: PeerId, peer: Peer, participant: RenderedChannelParticipant?, presence: PeerPresence?, memberStatus: GroupInfoMemberStatus, editing: ItemListPeerItemEditing, revealActions: [ParticipantRevealAction], enabled: Bool) - case convertToSupergroup(PresentationTheme, String) case leave(PresentationTheme, String) var section: ItemListSectionId { @@ -164,7 +161,7 @@ private enum GroupInfoEntry: ItemListNodeEntry { return GroupInfoSection.memberManagement.rawValue case .addMember, .member: return GroupInfoSection.members.rawValue - case .convertToSupergroup, .leave: + case .leave: return GroupInfoSection.leave.rawValue } } @@ -230,12 +227,6 @@ private enum GroupInfoEntry: ItemListNodeEntry { } else { return false } - case let .convertToSupergroup(lhsTheme, lhsText): - if case let .convertToSupergroup(rhsTheme, rhsText) = rhs, lhsTheme === rhsTheme, lhsText == rhsText { - return true - } else { - return false - } case let .aboutHeader(lhsTheme, lhsText): if case let .aboutHeader(rhsTheme, rhsText) = rhs, lhsTheme === rhsTheme, lhsText == rhsText { return true @@ -407,8 +398,6 @@ private enum GroupInfoEntry: ItemListNodeEntry { return 17 case let .member(_, _, _, _, index, _, _, _, _, _, _, _, _): return 20 + index - case .convertToSupergroup: - return 100000 case .leave: return 100000 + 1 } @@ -516,10 +505,6 @@ private enum GroupInfoEntry: ItemListNodeEntry { }, removePeer: { peerId in arguments.removePeer(peerId) }) - case let .convertToSupergroup(theme, title): - return ItemListActionItem(theme: theme, title: title, kind: .generic, alignment: .center, sectionId: self.section, style: .blocks, action: { - arguments.convertToSupergroup() - }) case let .leave(theme, title): return ItemListActionItem(theme: theme, title: title, kind: .destructive, alignment: .center, sectionId: self.section, style: .blocks, action: { arguments.leave() @@ -698,9 +683,7 @@ private func groupInfoEntries(account: Account, presentationData: PresentationDa var canAddMembers = false var isPublic = false var isCreator = false - var isGroup = false if let group = view.peers[view.peerId] as? TelegramGroup { - isGroup = true if case .creator = group.role { isCreator = true } @@ -713,10 +696,13 @@ private func groupInfoEntries(account: Account, presentationData: PresentationDa case .member: break } - } else if let channel = view.peers[view.peerId] as? TelegramChannel { - if case .group = channel.info { - isGroup = true + if !group.hasBannedPermission(.banChangeInfo) { + canEditGroupInfo = true } + if !group.hasBannedPermission(.banAddMembers) { + canAddMembers = true + } + } else if let channel = view.peers[view.peerId] as? TelegramChannel { highlightAdmins = true isPublic = channel.username != nil isCreator = channel.flags.contains(.isCreator) @@ -745,6 +731,8 @@ private func groupInfoEntries(account: Account, presentationData: PresentationDa } else { notificationsText = presentationData.strings.UserInfo_NotificationsDisabled } + } else if case .default = peerNotificationSettings.messageSound { + notificationsText = presentationData.strings.UserInfo_NotificationsEnabled } else { notificationsText = localizedPeerNotificationSoundString(strings: presentationData.strings, sound: peerNotificationSettings.messageSound, default: globalNotificationSettings.effective.channels.sound) } @@ -1022,35 +1010,40 @@ private func groupInfoEntries(account: Account, presentationData: PresentationDa var canPromote: Bool var canRestrict: Bool - switch participant.participant { - case .creator: - canPromote = false - canRestrict = false - case let .member(_, _, adminRights, bannedRights): - if channel.hasPermission(.addAdmins) { - canPromote = true - } else { + if participant.peer.id == account.peerId { + canPromote = false + canRestrict = false + } else { + switch participant.participant { + case .creator: canPromote = false - } - if channel.hasPermission(.banMembers) { - canRestrict = true - } else { canRestrict = false - } - if canPromote { - if let bannedRights = bannedRights { - if bannedRights.restrictedBy != account.peerId && !channel.flags.contains(.isCreator) { - canPromote = false + case let .member(_, _, adminRights, bannedRights): + if channel.hasPermission(.addAdmins) { + canPromote = true + } else { + canPromote = false + } + if channel.hasPermission(.banMembers) { + canRestrict = true + } else { + canRestrict = false + } + if canPromote { + if let bannedRights = bannedRights { + if bannedRights.restrictedBy != account.peerId && !channel.flags.contains(.isCreator) { + canPromote = false + } } } - } - if canRestrict { - if let adminRights = adminRights { - if adminRights.promotedBy != account.peerId && !channel.flags.contains(.isCreator) { - canRestrict = false + if canRestrict { + if let adminRights = adminRights { + if adminRights.promotedBy != account.peerId && !channel.flags.contains(.isCreator) { + canRestrict = false + } } } - } + } } var peerActions: [ParticipantRevealAction] = [] @@ -1068,14 +1061,21 @@ private func groupInfoEntries(account: Account, presentationData: PresentationDa if let group = view.peers[view.peerId] as? TelegramGroup { if case .Member = group.membership { - if case .creator = group.role, state.editingState != nil { - entries.append(.convertToSupergroup(presentationData.theme, presentationData.strings.GroupInfo_ConvertToSupergroup)) - } entries.append(.leave(presentationData.theme, presentationData.strings.Group_LeaveGroup)) } } else if let channel = view.peers[view.peerId] as? TelegramChannel { - if case .member = channel.participationStatus, let cachedChannelData = view.cachedData as? CachedChannelData, let memberCount = cachedChannelData.participantsSummary.memberCount, memberCount <= 200 { - entries.append(.leave(presentationData.theme, presentationData.strings.Group_LeaveGroup)) + if case .member = channel.participationStatus { + if channel.flags.contains(.isCreator) { + if let cachedChannelData = view.cachedData as? CachedChannelData, let memberCount = cachedChannelData.participantsSummary.memberCount, memberCount <= 200 { + if state.editingState != nil { + entries.append(.leave(presentationData.theme, presentationData.strings.ChannelInfo_DeleteGroup)) + } else { + entries.append(.leave(presentationData.theme, presentationData.strings.Group_LeaveGroup)) + } + } + } else { + entries.append(.leave(presentationData.theme, presentationData.strings.Group_LeaveGroup)) + } } } @@ -1177,6 +1177,9 @@ public func groupInfoController(account: Account, peerId: PeerId) -> ViewControl var upgradedToSupergroupImpl: ((PeerId, @escaping () -> Void) -> Void)? + let peerView = Promise() + peerView.set(account.viewTracker.peerView(peerId)) + let arguments = GroupInfoArguments(account: account, peerId: peerId, avatarAndNameInfoContext: avatarAndNameInfoContext, tapAvatarAction: { let _ = (account.postbox.loadedPeerWithId(peerId) |> take(1) @@ -1427,7 +1430,7 @@ public func groupInfoController(account: Account, peerId: PeerId) -> ViewControl return account.telegramApplicationContext.peerChannelMemberCategoriesContextsManager.addMember(account: account, peerId: peerId, memberId: memberId) } - return account.postbox.peerView(id: memberId) + return peerView.get() |> take(1) |> deliverOnMainQueue |> mapToSignal { view -> Signal in @@ -1645,31 +1648,56 @@ public func groupInfoController(account: Account, peerId: PeerId) -> ViewControl } } removeMemberDisposable.set(signal.start()) - }, convertToSupergroup: { - pushControllerImpl?(convertToSupergroupController(account: account, peerId: peerId)) }, leave: { - let presentationData = account.telegramApplicationContext.currentPresentationData.with { $0 } - let controller = ActionSheetController(presentationTheme: presentationData.theme) - let dismissAction: () -> Void = { [weak controller] in - controller?.dismissAnimated() - } - - var items: [ActionSheetItem] = [] - if peerId.namespace == Namespaces.Peer.CloudGroup { - items.append(ActionSheetTextItem(title: presentationData.strings.GroupInfo_DeleteAndExitConfirmation)) - } - items.append(ActionSheetButtonItem(title: presentationData.strings.Group_LeaveGroup, color: .destructive, action: { - dismissAction() - let _ = (removePeerChat(postbox: account.postbox, peerId: peerId, reportChatSpam: false) - |> deliverOnMainQueue).start(completed: { - popToRootImpl?() - }) - })) - controller.setItemGroups([ - ActionSheetItemGroup(items: items), - ActionSheetItemGroup(items: [ActionSheetButtonItem(title: presentationData.strings.Common_Cancel, action: { dismissAction() })]) - ]) - presentControllerImpl?(controller, ViewControllerPresentationArguments(presentationAnimation: .modalSheet)) + let _ = (peerView.get() + |> take(1) + |> deliverOnMainQueue).start(next: { peerView in + let presentationData = account.telegramApplicationContext.currentPresentationData.with { $0 } + + if let channel = peerView.peers[peerId] as? TelegramChannel, channel.flags.contains(.isCreator), stateValue.with({ $0 }).editingState != nil { + let controller = ActionSheetController(presentationTheme: presentationData.theme) + let dismissAction: () -> Void = { [weak controller] in + controller?.dismissAnimated() + } + + var items: [ActionSheetItem] = [] + items.append(ActionSheetTextItem(title: presentationData.strings.ChannelInfo_DeleteGroupConfirmation)) + items.append(ActionSheetButtonItem(title: presentationData.strings.ChannelInfo_DeleteGroup, color: .destructive, action: { + dismissAction() + let _ = (removePeerChat(postbox: account.postbox, peerId: peerId, reportChatSpam: false, deleteGloballyIfPossible: true) + |> deliverOnMainQueue).start(completed: { + popToRootImpl?() + }) + })) + controller.setItemGroups([ + ActionSheetItemGroup(items: items), + ActionSheetItemGroup(items: [ActionSheetButtonItem(title: presentationData.strings.Common_Cancel, action: { dismissAction() })]) + ]) + presentControllerImpl?(controller, ViewControllerPresentationArguments(presentationAnimation: .modalSheet)) + } else { + let controller = ActionSheetController(presentationTheme: presentationData.theme) + let dismissAction: () -> Void = { [weak controller] in + controller?.dismissAnimated() + } + + var items: [ActionSheetItem] = [] + if peerId.namespace == Namespaces.Peer.CloudGroup { + items.append(ActionSheetTextItem(title: presentationData.strings.GroupInfo_DeleteAndExitConfirmation)) + } + items.append(ActionSheetButtonItem(title: presentationData.strings.Group_LeaveGroup, color: .destructive, action: { + dismissAction() + let _ = (removePeerChat(postbox: account.postbox, peerId: peerId, reportChatSpam: false) + |> deliverOnMainQueue).start(completed: { + popToRootImpl?() + }) + })) + controller.setItemGroups([ + ActionSheetItemGroup(items: items), + ActionSheetItemGroup(items: [ActionSheetButtonItem(title: presentationData.strings.Common_Cancel, action: { dismissAction() })]) + ]) + presentControllerImpl?(controller, ViewControllerPresentationArguments(presentationAnimation: .modalSheet)) + } + }) }, displayUsernameShareMenu: { text in let shareController = ShareController(account: account, subject: .url(text)) presentControllerImpl?(shareController, nil) @@ -1709,7 +1737,7 @@ public func groupInfoController(account: Account, peerId: PeerId) -> ViewControl let previousChannelMembers = Atomic<[PeerId]?>(value: nil) let globalNotificationsKey: PostboxViewKey = .preferences(keys: Set([PreferencesKeys.globalNotifications])) - let signal = combineLatest(queue: .mainQueue(), (account.applicationContext as! TelegramApplicationContext).presentationData, statePromise.get(), account.viewTracker.peerView(peerId), account.postbox.combinedView(keys: [globalNotificationsKey]), channelMembersPromise.get()) + let signal = combineLatest(queue: .mainQueue(), (account.applicationContext as! TelegramApplicationContext).presentationData, statePromise.get(), peerView.get(), account.postbox.combinedView(keys: [globalNotificationsKey]), channelMembersPromise.get()) |> map { presentationData, state, view, combinedView, channelMembers -> (ItemListControllerState, (ItemListNodeState, GroupInfoEntry.ItemGenerationArguments)) in let peer = peerViewMainPeer(view) @@ -1720,7 +1748,24 @@ public func groupInfoController(account: Account, peerId: PeerId) -> ViewControl } } - let rightNavigationButton: ItemListNavigationButton + var canEditGroupInfo = false + if let group = view.peers[view.peerId] as? TelegramGroup { + switch group.role { + case .admin, .creator: + canEditGroupInfo = true + case .member: + break + } + if !group.hasBannedPermission(.banChangeInfo) { + canEditGroupInfo = true + } + } else if let channel = view.peers[view.peerId] as? TelegramChannel { + if channel.hasPermission(.changeInfo) || !(channel.adminRights?.flags ?? []).isEmpty { + canEditGroupInfo = true + } + } + + var rightNavigationButton: ItemListNavigationButton? var secondaryRightNavigationButton: ItemListNavigationButton? if let editingState = state.editingState { var doneEnabled = true @@ -1779,7 +1824,7 @@ public func groupInfoController(account: Account, peerId: PeerId) -> ViewControl })) }) } - } else { + } else if canEditGroupInfo { rightNavigationButton = ItemListNavigationButton(content: .text(presentationData.strings.Common_Edit), style: .regular, enabled: true, action: { if let peer = peer as? TelegramGroup { var text = "" @@ -1806,7 +1851,14 @@ public func groupInfoController(account: Account, peerId: PeerId) -> ViewControl } }) } - + } else { + if peer is TelegramChannel { + rightNavigationButton = ItemListNavigationButton(content: .icon(.search), style: .regular, enabled: true, action: { + updateState { state in + return state.withUpdatedSearchingMembers(true) + } + }) + } } var searchItem: ItemListControllerSearch? diff --git a/TelegramUI/HashtagChatInputContextPanelNode.swift b/TelegramUI/HashtagChatInputContextPanelNode.swift index 1f78216040..c6f08b1457 100644 --- a/TelegramUI/HashtagChatInputContextPanelNode.swift +++ b/TelegramUI/HashtagChatInputContextPanelNode.swift @@ -96,7 +96,7 @@ final class HashtagChatInputContextPanelNode: ChatInputContextPanelNode { entries.append(entry) index += 1 } - prepareTransition(from: self.currentEntries ?? [], to: entries) + self.prepareTransition(from: self.currentEntries ?? [], to: entries) } private func prepareTransition(from: [HashtagChatInputContextPanelEntry]? , to: [HashtagChatInputContextPanelEntry]) { @@ -132,7 +132,7 @@ final class HashtagChatInputContextPanelNode: ChatInputContextPanelNode { } private func enqueueTransition(_ transition: HashtagChatInputContextPanelTransition, firstTime: Bool) { - enqueuedTransitions.append((transition, firstTime)) + self.enqueuedTransitions.append((transition, firstTime)) if self.validLayout != nil { while !self.enqueuedTransitions.isEmpty { @@ -233,7 +233,7 @@ final class HashtagChatInputContextPanelNode: ChatInputContextPanelNode { self.listView.keepBottomItemOverscrollBackground = self.theme.list.plainBackgroundColor let new = self.currentEntries?.map({$0.withUpdatedTheme(interfaceState.theme)}) ?? [] - prepareTransition(from: self.currentEntries, to: new) + self.prepareTransition(from: self.currentEntries, to: new) } } diff --git a/TelegramUI/HashtagSearchController.swift b/TelegramUI/HashtagSearchController.swift index f9bb2c88c4..e2c9507366 100644 --- a/TelegramUI/HashtagSearchController.swift +++ b/TelegramUI/HashtagSearchController.swift @@ -44,15 +44,13 @@ final class HashtagSearchController: TelegramController { let interaction = ChatListNodeInteraction(activateSearch: { }, peerSelected: { peer in }, togglePeerSelected: { _ in - }, messageSelected: { [weak self] message, _ in + }, messageSelected: { [weak self] peer, message, _ in if let strongSelf = self { - if let peer = message.peers[message.id.peerId] { - strongSelf.openMessageFromSearchDisposable.set((storedMessageFromSearchPeer(account: strongSelf.account, peer: peer) |> deliverOnMainQueue).start(completed: { - if let strongSelf = self { - (strongSelf.navigationController as? NavigationController)?.pushViewController(ChatController(account: strongSelf.account, chatLocation: .peer(message.id.peerId), messageId: message.id)) - } - })) - } + strongSelf.openMessageFromSearchDisposable.set((storedMessageFromSearchPeer(account: strongSelf.account, peer: peer) |> deliverOnMainQueue).start(next: { actualPeerId in + if let strongSelf = self { + (strongSelf.navigationController as? NavigationController)?.pushViewController(ChatController(account: strongSelf.account, chatLocation: .peer(actualPeerId), messageId: message.id.peerId == actualPeerId ? message.id : nil)) + } + })) strongSelf.controllerNode.listNode.clearHighlightAnimated(true) } }, groupSelected: { _ in diff --git a/TelegramUI/HorizontalListContextResultsChatInputPanelItem.swift b/TelegramUI/HorizontalListContextResultsChatInputPanelItem.swift index 6de738c72c..b2dbf4669f 100644 --- a/TelegramUI/HorizontalListContextResultsChatInputPanelItem.swift +++ b/TelegramUI/HorizontalListContextResultsChatInputPanelItem.swift @@ -209,7 +209,7 @@ final class HorizontalListContextResultsChatInputPanelItemNode: ListViewItemNode } imageDimensions = content?.dimensions if type == "gif", let thumbnailResource = imageResource, let content = content, let dimensions = content.dimensions { - videoFile = TelegramMediaFile(fileId: MediaId(namespace: Namespaces.Media.LocalFile, id: 0), partialReference: nil, resource: content.resource, previewRepresentations: [TelegramMediaImageRepresentation(dimensions: dimensions, resource: thumbnailResource)], mimeType: "video/mp4", size: nil, attributes: [.Animated, .Video(duration: 0, size: dimensions, flags: [])]) + videoFile = TelegramMediaFile(fileId: MediaId(namespace: Namespaces.Media.LocalFile, id: 0), partialReference: nil, resource: content.resource, previewRepresentations: [TelegramMediaImageRepresentation(dimensions: dimensions, resource: thumbnailResource)], immediateThumbnailData: nil, mimeType: "video/mp4", size: nil, attributes: [.Animated, .Video(duration: 0, size: dimensions, flags: [])]) imageResource = nil } diff --git a/TelegramUI/HorizontalStickersChatContextPanelNode.swift b/TelegramUI/HorizontalStickersChatContextPanelNode.swift index c193678325..8a717f2328 100644 --- a/TelegramUI/HorizontalStickersChatContextPanelNode.swift +++ b/TelegramUI/HorizontalStickersChatContextPanelNode.swift @@ -56,6 +56,7 @@ final class HorizontalStickersChatContextPanelNode: ChatInputContextPanelNode { private var strings: PresentationStrings private let gridNode: GridNode + private let backgroundNode: ASDisplayNode private var validLayout: (CGSize, CGFloat, CGFloat, ChatPresentationInterfaceState)? private var currentEntries: [StickerEntry] = [] @@ -72,6 +73,9 @@ final class HorizontalStickersChatContextPanelNode: ChatInputContextPanelNode { self.gridNode = GridNode() self.gridNode.view.disablesInteractiveTransitionGestureRecognizer = true + self.backgroundNode = ASDisplayNode() + self.backgroundNode.backgroundColor = theme.list.plainBackgroundColor + self.stickersInteraction = HorizontalStickersChatContextPanelInteraction() super.init(account: account, theme: theme, strings: strings) @@ -80,6 +84,7 @@ final class HorizontalStickersChatContextPanelNode: ChatInputContextPanelNode { self.clipsToBounds = true self.addSubnode(self.gridNode) + self.gridNode.addSubnode(self.backgroundNode) } override func didLoad() { @@ -192,7 +197,13 @@ final class HorizontalStickersChatContextPanelNode: ChatInputContextPanelNode { private func dequeueTransitions() { while !self.queuedTransitions.isEmpty { let transition = self.queuedTransitions.removeFirst() - self.gridNode.transaction(GridNodeTransaction(deleteItems: transition.deletions, insertItems: transition.insertions, updateItems: transition.updates, scrollToItem: transition.scrollToItem, updateLayout: nil, itemTransition: .immediate, stationaryItems: transition.stationaryItems, updateFirstIndexInSectionOffset: transition.updateFirstIndexInSectionOffset), completion: { _ in }) + self.gridNode.transaction(GridNodeTransaction(deleteItems: transition.deletions, insertItems: transition.insertions, updateItems: transition.updates, scrollToItem: transition.scrollToItem, updateLayout: nil, itemTransition: .immediate, stationaryItems: transition.stationaryItems, updateFirstIndexInSectionOffset: transition.updateFirstIndexInSectionOffset), completion: { _ in + +// if let topItemOffset = topItemOffset { +// let position = strongSelf.listView.layer.position +// strongSelf.listView.layer.animatePosition(from: CGPoint(x: position.x, y: position.y + (strongSelf.listView.bounds.size.height - topItemOffset)), to: position, duration: 0.3, timingFunction: kCAMediaTimingFunctionSpring) +// } + }) } } @@ -211,32 +222,12 @@ final class HorizontalStickersChatContextPanelNode: ChatInputContextPanelNode { transition.updateFrame(node: self.gridNode, frame: CGRect(x: 0.0, y: 0.0, width: size.width, height: size.height)) - var duration: Double = 0.0 - var curve: UInt = 0 - switch transition { - case .immediate: - break - case let .animated(animationDuration, animationCurve): - duration = animationDuration - switch animationCurve { - case .easeInOut: - break - case .spring: - curve = 7 - } - } - - let listViewCurve: ListViewAnimationCurve - if curve == 7 { - listViewCurve = .Spring(duration: duration) - } else { - listViewCurve = .Default(duration: duration) - } - - //let updateSizeAndInsets = ListViewUpdateSizeAndInsets(size: size, insets: insets, duration: duration, curve: listViewCurve) + let updateSizeAndInsets = GridNodeUpdateLayout(layout: GridNodeLayout(size: size, insets: insets, preloadSize: 100.0, type: .fixed(itemSize: CGSize(width: 66.0, height: 66.0), fillWidth: nil, lineSpacing: 0.0, itemSpacing: nil)), transition: transition) - self.gridNode.transaction(GridNodeTransaction(deleteItems: [], insertItems: [], updateItems: [], scrollToItem: nil, updateLayout: GridNodeUpdateLayout(layout: GridNodeLayout(size: size, insets: insets, preloadSize: 100.0, type: .fixed(itemSize: CGSize(width: 66.0, height: 66.0), fillWidth: nil, lineSpacing: 0.0, itemSpacing: nil)), transition: .immediate), itemTransition: .immediate, stationaryItems: .all, updateFirstIndexInSectionOffset: nil), completion: { _ in }) + self.gridNode.transaction(GridNodeTransaction(deleteItems: [], insertItems: [], updateItems: [], scrollToItem: nil, updateLayout: updateSizeAndInsets, itemTransition: .immediate, stationaryItems: .all, updateFirstIndexInSectionOffset: nil), completion: { _ in }) + self.backgroundNode.frame = CGRect(x: 0.0, y: 0.0, width: size.width, height: 1000.0) + let dequeue = self.validLayout == nil self.validLayout = (size, leftInset, rightInset, interfaceState) @@ -260,7 +251,7 @@ final class HorizontalStickersChatContextPanelNode: ChatInputContextPanelNode { let listViewFrame = self.gridNode.frame return self.gridNode.hitTest(CGPoint(x: point.x - listViewFrame.minX, y: point.y - listViewFrame.minY), with: event) } - + private func updatePreviewingItem(item: StickerPackItem?, animated: Bool) { if self.stickersInteraction.previewedStickerItem != item { self.stickersInteraction.previewedStickerItem = item diff --git a/TelegramUI/IconSwitchNode.swift b/TelegramUI/IconSwitchNode.swift index f37982b6eb..9658550e9b 100644 --- a/TelegramUI/IconSwitchNode.swift +++ b/TelegramUI/IconSwitchNode.swift @@ -38,6 +38,20 @@ class IconSwitchNode: ASDisplayNode { } } } + public var positiveContentColor = UIColor(rgb: 0x00ff00) { + didSet { + if self.isNodeLoaded { + (self.view as! IconSwitchNodeView).setPositiveContentColor(self.positiveContentColor) + } + } + } + public var negativeContentColor = UIColor(rgb: 0xff0000) { + didSet { + if self.isNodeLoaded { + (self.view as! IconSwitchNodeView).setNegativeContentColor(self.negativeContentColor) + } + } + } private var _isOn: Bool = false public var isOn: Bool { @@ -68,6 +82,8 @@ class IconSwitchNode: ASDisplayNode { (self.view as! UISwitch).tintColor = self.frameColor //(self.view as! UISwitch).thumbTintColor = self.handleColor (self.view as! UISwitch).onTintColor = self.contentColor + (self.view as! IconSwitchNodeView).setNegativeContentColor(self.negativeContentColor) + (self.view as! IconSwitchNodeView).setPositiveContentColor(self.positiveContentColor) (self.view as! UISwitch).setOn(self._isOn, animated: false) diff --git a/TelegramUI/ItemListSwitchItem.swift b/TelegramUI/ItemListSwitchItem.swift index 8ff7d9a13c..8ad810cbaf 100644 --- a/TelegramUI/ItemListSwitchItem.swift +++ b/TelegramUI/ItemListSwitchItem.swift @@ -75,10 +75,25 @@ private protocol ItemListSwitchNodeImpl { var frameColor: UIColor { get set } var contentColor: UIColor { get set } var handleColor: UIColor { get set } + var positiveContentColor: UIColor { get set } + var negativeContentColor: UIColor { get set } } extension SwitchNode: ItemListSwitchNodeImpl { - + var positiveContentColor: UIColor { + get { + return .white + } set(value) { + + } + } + var negativeContentColor: UIColor { + get { + return .white + } set(value) { + + } + } } extension IconSwitchNode: ItemListSwitchNodeImpl { @@ -214,6 +229,8 @@ class ItemListSwitchItemNode: ListViewItemNode { strongSelf.switchNode.frameColor = item.theme.list.itemSwitchColors.frameColor strongSelf.switchNode.contentColor = item.theme.list.itemSwitchColors.contentColor strongSelf.switchNode.handleColor = item.theme.list.itemSwitchColors.handleColor + strongSelf.switchNode.positiveContentColor = item.theme.list.itemSwitchColors.positiveColor + strongSelf.switchNode.negativeContentColor = item.theme.list.itemSwitchColors.negativeColor } let _ = titleApply() diff --git a/TelegramUI/LegacyComponentsStickers.swift b/TelegramUI/LegacyComponentsStickers.swift index 07f5f491db..4f360663a3 100644 --- a/TelegramUI/LegacyComponentsStickers.swift +++ b/TelegramUI/LegacyComponentsStickers.swift @@ -21,7 +21,7 @@ func stickerFromLegacyDocument(_ documentAttachment: TGDocumentMediaAttachment) fileReference = data } - return TelegramMediaFile(fileId: MediaId(namespace: Namespaces.Media.CloudFile, id: documentAttachment.documentId), partialReference: nil, resource: CloudDocumentMediaResource(datacenterId: Int(documentAttachment.datacenterId), fileId: documentAttachment.documentId, accessHash: documentAttachment.accessHash, size: Int(documentAttachment.size), fileReference: fileReference, fileName: documentAttachment.fileName()), previewRepresentations: [], mimeType: documentAttachment.mimeType, size: Int(documentAttachment.size), attributes: attributes) + return TelegramMediaFile(fileId: MediaId(namespace: Namespaces.Media.CloudFile, id: documentAttachment.documentId), partialReference: nil, resource: CloudDocumentMediaResource(datacenterId: Int(documentAttachment.datacenterId), fileId: documentAttachment.documentId, accessHash: documentAttachment.accessHash, size: Int(documentAttachment.size), fileReference: fileReference, fileName: documentAttachment.fileName()), previewRepresentations: [], immediateThumbnailData: nil, mimeType: documentAttachment.mimeType, size: Int(documentAttachment.size), attributes: attributes) } } return nil @@ -184,7 +184,7 @@ final class LegacyStickerImageDataSource: TGImageDataSource { attributes.append(.Sticker(displayText: "", packReference: .id(id: stickerPackId, accessHash: stickerPackAccessHash), maskData: nil)) } - return LegacyStickerImageDataTask(account: account, file: TelegramMediaFile(fileId: MediaId(namespace: Namespaces.Media.CloudFile, id: documentId), partialReference: nil, resource: CloudDocumentMediaResource(datacenterId: datacenterId, fileId: documentId, accessHash: accessHash, size: size, fileReference: nil, fileName: fileNameFromFileAttributes(attributes)), previewRepresentations: [], mimeType: "image/webp", size: size, attributes: attributes), small: !highQuality, fitSize: fitSize, completion: { image in + return LegacyStickerImageDataTask(account: account, file: TelegramMediaFile(fileId: MediaId(namespace: Namespaces.Media.CloudFile, id: documentId), partialReference: nil, resource: CloudDocumentMediaResource(datacenterId: datacenterId, fileId: documentId, accessHash: accessHash, size: size, fileReference: nil, fileName: fileNameFromFileAttributes(attributes)), previewRepresentations: [], immediateThumbnailData: nil, mimeType: "image/webp", size: size, attributes: attributes), small: !highQuality, fitSize: fitSize, completion: { image in if let image = image { sharedImageCache.setImage(image, forKey: uri, attributes: nil) completion?(TGDataResource(image: image, decoded: true)) diff --git a/TelegramUI/LegacyInstantVideoController.swift b/TelegramUI/LegacyInstantVideoController.swift index 4d09c834fb..547080c9ae 100644 --- a/TelegramUI/LegacyInstantVideoController.swift +++ b/TelegramUI/LegacyInstantVideoController.swift @@ -158,7 +158,7 @@ func legacyInstantVideoController(theme: PresentationTheme, panelFrame: CGRect, } } - let media = TelegramMediaFile(fileId: MediaId(namespace: Namespaces.Media.LocalFile, id: arc4random64()), partialReference: nil, resource: resource, previewRepresentations: previewRepresentations, mimeType: "video/mp4", size: nil, attributes: [.FileName(fileName: "video.mp4"), .Video(duration: Int(finalDuration), size: finalDimensions, flags: [.instantRoundVideo])]) + let media = TelegramMediaFile(fileId: MediaId(namespace: Namespaces.Media.LocalFile, id: arc4random64()), partialReference: nil, resource: resource, previewRepresentations: previewRepresentations, immediateThumbnailData: nil, mimeType: "video/mp4", size: nil, attributes: [.FileName(fileName: "video.mp4"), .Video(duration: Int(finalDuration), size: finalDimensions, flags: [.instantRoundVideo])]) let attributes: [MessageAttribute] = [] send(.message(text: "", attributes: attributes, mediaReference: .standalone(media: media), replyToMessageId: nil, localGroupingKey: nil)) } diff --git a/TelegramUI/LegacyMediaPickers.swift b/TelegramUI/LegacyMediaPickers.swift index 2565e3a036..6618d50684 100644 --- a/TelegramUI/LegacyMediaPickers.swift +++ b/TelegramUI/LegacyMediaPickers.swift @@ -237,7 +237,7 @@ func legacyEnqueueGifMessage(account: Account, data: Data) -> Signal Signa arc4random_buf(&randomId, 8) let _ = try? heicData.write(to: URL(fileURLWithPath: tempFilePath + ".heic")) let resource = LocalFileReferenceMediaResource(localFilePath: tempFilePath + ".heic", randomId: randomId) - let media = TelegramMediaFile(fileId: MediaId(namespace: Namespaces.Media.LocalFile, id: randomId), partialReference: nil, resource: resource, previewRepresentations: [], mimeType: "image/heic", size: nil, attributes: [.FileName(fileName: "image.heic")]) + let media = TelegramMediaFile(fileId: MediaId(namespace: Namespaces.Media.LocalFile, id: randomId), partialReference: nil, resource: resource, previewRepresentations: [], immediateThumbnailData: nil, mimeType: "image/heic", size: nil, attributes: [.FileName(fileName: "image.heic")]) var attributes: [MessageAttribute] = [] if let timer = item.timer, timer > 0 && timer <= 60 { attributes.append(AutoremoveTimeoutMessageAttribute(timeout: Int32(timer), countdownBeginTime: nil)) @@ -336,13 +336,13 @@ func legacyAssetPickerEnqueueMessages(account: Account, signals: [Any]) -> Signa var randomId: Int64 = 0 arc4random_buf(&randomId, 8) let resource = LocalFileReferenceMediaResource(localFilePath: path, randomId: randomId) - let media = TelegramMediaFile(fileId: MediaId(namespace: Namespaces.Media.LocalFile, id: randomId), partialReference: nil, resource: resource, previewRepresentations: [], mimeType: mimeType, size: nil, attributes: [.FileName(fileName: name)]) + let media = TelegramMediaFile(fileId: MediaId(namespace: Namespaces.Media.LocalFile, id: randomId), partialReference: nil, resource: resource, previewRepresentations: [], immediateThumbnailData: nil, mimeType: mimeType, size: nil, attributes: [.FileName(fileName: name)]) messages.append(.message(text: caption ?? "", attributes: [], mediaReference: .standalone(media: media), replyToMessageId: nil, localGroupingKey: item.groupedId)) case let .asset(asset): var randomId: Int64 = 0 arc4random_buf(&randomId, 8) let resource = PhotoLibraryMediaResource(localIdentifier: asset.localIdentifier, uniqueId: arc4random64()) - let media = TelegramMediaFile(fileId: MediaId(namespace: Namespaces.Media.LocalFile, id: randomId), partialReference: nil, resource: resource, previewRepresentations: [], mimeType: mimeType, size: nil, attributes: [.FileName(fileName: name)]) + let media = TelegramMediaFile(fileId: MediaId(namespace: Namespaces.Media.LocalFile, id: randomId), partialReference: nil, resource: resource, previewRepresentations: [], immediateThumbnailData: nil, mimeType: mimeType, size: nil, attributes: [.FileName(fileName: name)]) messages.append(.message(text: caption ?? "", attributes: [], mediaReference: .standalone(media: media), replyToMessageId: nil, localGroupingKey: item.groupedId)) default: break @@ -424,7 +424,7 @@ func legacyAssetPickerEnqueueMessages(account: Account, signals: [Any]) -> Signa } } - let media = TelegramMediaFile(fileId: MediaId(namespace: Namespaces.Media.LocalFile, id: arc4random64()), partialReference: nil, resource: resource, previewRepresentations: previewRepresentations, mimeType: "video/mp4", size: nil, attributes: fileAttributes) + let media = TelegramMediaFile(fileId: MediaId(namespace: Namespaces.Media.LocalFile, id: arc4random64()), partialReference: nil, resource: resource, previewRepresentations: previewRepresentations, immediateThumbnailData: nil, mimeType: "video/mp4", size: nil, attributes: fileAttributes) var attributes: [MessageAttribute] = [] if let timer = item.timer, timer > 0 && timer <= 60 { attributes.append(AutoremoveTimeoutMessageAttribute(timeout: Int32(timer), countdownBeginTime: nil)) diff --git a/TelegramUI/MergedItemListItem.swift b/TelegramUI/MergedItemListItem.swift new file mode 100644 index 0000000000..9a30829567 --- /dev/null +++ b/TelegramUI/MergedItemListItem.swift @@ -0,0 +1,3 @@ +import Foundation + + diff --git a/TelegramUI/OpenResolvedUrl.swift b/TelegramUI/OpenResolvedUrl.swift index 2c0019899f..2d4757533f 100644 --- a/TelegramUI/OpenResolvedUrl.swift +++ b/TelegramUI/OpenResolvedUrl.swift @@ -193,5 +193,28 @@ func openResolvedUrl(_ resolvedUrl: ResolvedUrl, account: Account, context: Open (navigationController.viewControllers.last as? ViewController)?.present(controller, in: .window(.root), with: ViewControllerPresentationArguments(presentationAnimation: ViewControllerPresentationAnimation.modalSheet)) } } + case let .wallpaper(slug): + let presentationData = account.telegramApplicationContext.currentPresentationData.with { $0 } + let controller = OverlayStatusController(theme: presentationData.theme, strings: presentationData.strings, type: .loading(cancelled: nil)) + present(controller, nil) + let _ = (getWallpaper(account: account, slug: slug) + |> deliverOnMainQueue).start(next: { [weak controller] wallpaper in + controller?.dismiss() + let wallpaperController = WallpaperListPreviewController(account: account, source: .wallpaper(wallpaper)) + present(wallpaperController, ViewControllerPresentationArguments(presentationAnimation: .modalSheet)) + }, error: { [weak controller] error in + controller?.dismiss() + +// let text: String +// switch error { +// case .limitExceeded: +// text = presentationData.strings.Login_CodeFloodError +// case .generic: +// text = presentationData.strings.Login_UnknownError +// } +// let presentationData = account.telegramApplicationContext.currentPresentationData.with { $0 } +// present(standardTextAlertController(theme: AlertControllerTheme(presentationTheme: presentationData.theme), title: nil, text: text, actions: [TextAlertAction(type: .defaultAction, title: presentationData.strings.Common_OK, action: {})]), nil) + }) + dismissInput() } } diff --git a/TelegramUI/OpenUrl.swift b/TelegramUI/OpenUrl.swift index 250ccd0091..c8345911c6 100644 --- a/TelegramUI/OpenUrl.swift +++ b/TelegramUI/OpenUrl.swift @@ -544,6 +544,22 @@ public func openExternalUrl(account: Account, context: OpenURLContext = .generic convertedUrl = "https://t.me/confirmphone?phone=\(phone)&hash=\(hash)" } } + } else if parsedUrl.host == "bg" { + if let components = URLComponents(string: "/?" + query) { + var slug: String? + if let queryItems = components.queryItems { + for queryItem in queryItems { + if let value = queryItem.value { + if queryItem.name == "slug" { + slug = value + } + } + } + } + if let slug = slug { + convertedUrl = "https://t.me/bg/\(slug)" + } + } } if parsedUrl.host == "resolve" { diff --git a/TelegramUI/PhotoResources.swift b/TelegramUI/PhotoResources.swift index 6bdc4754fa..11516c0fe1 100644 --- a/TelegramUI/PhotoResources.swift +++ b/TelegramUI/PhotoResources.swift @@ -130,6 +130,7 @@ private func chatMessageFileDatas(account: Account, fileReference: FileMediaRefe let fullSizeResource = fileReference.media.resource let maybeFullSize = account.postbox.mediaBox.resourceData(fullSizeResource, pathExtension: pathExtension) + let decodedThumbnailData = fileReference.media.immediateThumbnailData.flatMap(decodeTinyThumbnail) let signal = maybeFullSize |> take(1) @@ -138,18 +139,26 @@ private func chatMessageFileDatas(account: Account, fileReference: FileMediaRefe return .single((nil, maybeData.path, true)) } else { let fetchedThumbnail: Signal - if let thumbnailResource = thumbnailResource { + if !fetched, let _ = decodedThumbnailData { + fetchedThumbnail = .single(.local) + } else if let thumbnailResource = thumbnailResource { fetchedThumbnail = fetchedMediaResource(postbox: account.postbox, reference: fileReference.resourceReference(thumbnailResource), statsCategory: statsCategoryForFileWithAttributes(fileReference.media.attributes)) } else { fetchedThumbnail = .complete() } let thumbnail: Signal - if let thumbnailResource = thumbnailResource { + if !fetched, let decodedThumbnailData = decodedThumbnailData { + thumbnail = .single(decodedThumbnailData) + } else if let thumbnailResource = thumbnailResource { thumbnail = Signal { subscriber in let fetchedDisposable = fetchedThumbnail.start() let thumbnailDisposable = account.postbox.mediaBox.resourceData(thumbnailResource, pathExtension: pathExtension).start(next: { next in - subscriber.putNext(next.size == 0 ? nil : try? Data(contentsOf: URL(fileURLWithPath: next.path), options: [])) + if next.size != 0, let data = try? Data(contentsOf: URL(fileURLWithPath: next.path), options: []) { + subscriber.putNext(data) + } else { + subscriber.putNext(nil) + } }, error: subscriber.putError, completed: subscriber.putCompletion) return ActionDisposable { @@ -186,14 +195,21 @@ private let thumbnailGenerationMimeTypes: Set = Set([ private func chatMessageImageFileThumbnailDatas(account: Account, fileReference: FileMediaReference, pathExtension: String? = nil, progressive: Bool = false) -> Signal<(Data?, String?, Bool), NoError> { let thumbnailResource = smallestImageRepresentation(fileReference.media.previewRepresentations)?.resource + let decodedThumbnailData = fileReference.media.immediateThumbnailData.flatMap(decodeTinyThumbnail) if !thumbnailGenerationMimeTypes.contains(fileReference.media.mimeType) { - if let thumbnailResource = thumbnailResource { + if let decodedThumbnailData = decodedThumbnailData { + return .single((decodedThumbnailData, nil, false)) + } else if let thumbnailResource = thumbnailResource { let fetchedThumbnail: Signal = fetchedMediaResource(postbox: account.postbox, reference: fileReference.resourceReference(thumbnailResource)) return Signal { subscriber in let fetchedDisposable = fetchedThumbnail.start() let thumbnailDisposable = account.postbox.mediaBox.resourceData(thumbnailResource, pathExtension: pathExtension).start(next: { next in - subscriber.putNext(((next.size == 0 ? nil : try? Data(contentsOf: URL(fileURLWithPath: next.path), options: [])), nil, false)) + if next.size != 0, let data = try? Data(contentsOf: URL(fileURLWithPath: next.path), options: []) { + subscriber.putNext((data, nil, false)) + } else { + subscriber.putNext((nil, nil, false)) + } }, error: subscriber.putError, completed: subscriber.putCompletion) return ActionDisposable { @@ -218,18 +234,26 @@ private func chatMessageImageFileThumbnailDatas(account: Account, fileReference: return .single((nil, maybeData.path, true)) } else { let fetchedThumbnail: Signal - if let thumbnailResource = thumbnailResource { + if let _ = fileReference.media.immediateThumbnailData { + fetchedThumbnail = .complete() + } else if let thumbnailResource = thumbnailResource { fetchedThumbnail = fetchedMediaResource(postbox: account.postbox, reference: fileReference.resourceReference(thumbnailResource)) } else { fetchedThumbnail = .complete() } let thumbnail: Signal - if let thumbnailResource = thumbnailResource { + if let decodedThumbnailData = decodedThumbnailData { + thumbnail = .single(decodedThumbnailData) + } else if let thumbnailResource = thumbnailResource { thumbnail = Signal { subscriber in let fetchedDisposable = fetchedThumbnail.start() let thumbnailDisposable = account.postbox.mediaBox.resourceData(thumbnailResource, pathExtension: pathExtension).start(next: { next in - subscriber.putNext(next.size == 0 ? nil : try? Data(contentsOf: URL(fileURLWithPath: next.path), options: [])) + if next.size != 0, let data = try? Data(contentsOf: URL(fileURLWithPath: next.path), options: []) { + subscriber.putNext(data) + } else { + subscriber.putNext(nil) + } }, error: subscriber.putError, completed: subscriber.putCompletion) return ActionDisposable { @@ -2172,9 +2196,10 @@ func instantPageImageFile(account: Account, fileReference: FileMediaReference, f } } -private func avatarGalleryPhotoDatas(account: Account, representations: [ImageRepresentationWithReference], autoFetchFullSize: Bool = false) -> Signal<(Data?, Data?, Bool), NoError> { +private func avatarGalleryPhotoDatas(account: Account, fileReference: FileMediaReference? = nil, representations: [ImageRepresentationWithReference], autoFetchFullSize: Bool = false) -> Signal<(Data?, Data?, Bool), NoError> { if let smallestRepresentation = smallestImageRepresentation(representations.map({ $0.representation })), let largestRepresentation = largestImageRepresentation(representations.map({ $0.representation })), let smallestIndex = representations.index(where: { $0.representation == smallestRepresentation }), let largestIndex = representations.index(where: { $0.representation == largestRepresentation }) { let maybeFullSize = account.postbox.mediaBox.resourceData(largestRepresentation.resource) + let decodedThumbnailData = fileReference?.media.immediateThumbnailData.flatMap(decodeTinyThumbnail) let signal = maybeFullSize |> take(1) @@ -2183,18 +2208,29 @@ private func avatarGalleryPhotoDatas(account: Account, representations: [ImageRe let loadedData: Data? = try? Data(contentsOf: URL(fileURLWithPath: maybeData.path), options: []) return .single((nil, loadedData, true)) } else { - let fetchedThumbnail = fetchedMediaResource(postbox: account.postbox, reference: representations[smallestIndex].reference) + let fetchedThumbnail: Signal + if let _ = decodedThumbnailData { + fetchedThumbnail = .complete() + } else { + fetchedThumbnail = fetchedMediaResource(postbox: account.postbox, reference: representations[smallestIndex].reference) + } + let fetchedFullSize = fetchedMediaResource(postbox: account.postbox, reference: representations[largestIndex].reference) - let thumbnail = Signal { subscriber in - let fetchedDisposable = fetchedThumbnail.start() - let thumbnailDisposable = account.postbox.mediaBox.resourceData(smallestRepresentation.resource).start(next: { next in - subscriber.putNext(next.size == 0 ? nil : try? Data(contentsOf: URL(fileURLWithPath: next.path), options: [])) - }, error: subscriber.putError, completed: subscriber.putCompletion) - - return ActionDisposable { - fetchedDisposable.dispose() - thumbnailDisposable.dispose() + let thumbnail: Signal + if let decodedThumbnailData = decodedThumbnailData { + thumbnail = .single(decodedThumbnailData) + } else { + thumbnail = Signal { subscriber in + let fetchedDisposable = fetchedThumbnail.start() + let thumbnailDisposable = account.postbox.mediaBox.resourceData(smallestRepresentation.resource).start(next: { next in + subscriber.putNext(next.size == 0 ? nil : try? Data(contentsOf: URL(fileURLWithPath: next.path), options: [])) + }, error: subscriber.putError, completed: subscriber.putCompletion) + + return ActionDisposable { + fetchedDisposable.dispose() + thumbnailDisposable.dispose() + } } } @@ -2219,7 +2255,6 @@ private func avatarGalleryPhotoDatas(account: Account, representations: [ImageRe } } - return thumbnail |> mapToSignal { thumbnailData in return fullSizeData |> map { (fullSizeData, complete) in return (thumbnailData, fullSizeData, complete) @@ -2234,8 +2269,8 @@ private func avatarGalleryPhotoDatas(account: Account, representations: [ImageRe } } -func chatAvatarGalleryPhoto(account: Account, representations: [ImageRepresentationWithReference], autoFetchFullSize: Bool = false) -> Signal<(TransformImageArguments) -> DrawingContext?, NoError> { - let signal = avatarGalleryPhotoDatas(account: account, representations: representations, autoFetchFullSize: autoFetchFullSize) +func chatAvatarGalleryPhoto(account: Account, fileReference: FileMediaReference? = nil, representations: [ImageRepresentationWithReference], autoFetchFullSize: Bool = false) -> Signal<(TransformImageArguments) -> DrawingContext?, NoError> { + let signal = avatarGalleryPhotoDatas(account: account, fileReference: fileReference, representations: representations, autoFetchFullSize: autoFetchFullSize) return signal |> map { (thumbnailData, fullSizeData, fullSizeComplete) in diff --git a/TelegramUI/PresentationData.swift b/TelegramUI/PresentationData.swift index 968928e0be..319c9ba0cc 100644 --- a/TelegramUI/PresentationData.swift +++ b/TelegramUI/PresentationData.swift @@ -46,6 +46,7 @@ public final class PresentationData: Equatable { public let strings: PresentationStrings public let theme: PresentationTheme public let chatWallpaper: TelegramWallpaper + public let chatWallpaperMode: PresentationWallpaperMode public let volumeControlStatusBarIcons: PresentationVolumeControlStatusBarIcons public let fontSize: PresentationFontSize public let dateTimeFormat: PresentationDateTimeFormat @@ -53,10 +54,11 @@ public final class PresentationData: Equatable { public let nameSortOrder: PresentationPersonNameOrder public let disableAnimations: Bool - public init(strings: PresentationStrings, theme: PresentationTheme, chatWallpaper: TelegramWallpaper, volumeControlStatusBarIcons: PresentationVolumeControlStatusBarIcons, fontSize: PresentationFontSize, dateTimeFormat: PresentationDateTimeFormat, nameDisplayOrder: PresentationPersonNameOrder, nameSortOrder: PresentationPersonNameOrder, disableAnimations: Bool) { + public init(strings: PresentationStrings, theme: PresentationTheme, chatWallpaper: TelegramWallpaper, chatWallpaperMode: PresentationWallpaperMode, volumeControlStatusBarIcons: PresentationVolumeControlStatusBarIcons, fontSize: PresentationFontSize, dateTimeFormat: PresentationDateTimeFormat, nameDisplayOrder: PresentationPersonNameOrder, nameSortOrder: PresentationPersonNameOrder, disableAnimations: Bool) { self.strings = strings self.theme = theme self.chatWallpaper = chatWallpaper + self.chatWallpaperMode = chatWallpaperMode self.volumeControlStatusBarIcons = volumeControlStatusBarIcons self.fontSize = fontSize self.dateTimeFormat = dateTimeFormat @@ -66,7 +68,7 @@ public final class PresentationData: Equatable { } public static func ==(lhs: PresentationData, rhs: PresentationData) -> Bool { - return lhs.strings === rhs.strings && lhs.theme === rhs.theme && lhs.chatWallpaper == rhs.chatWallpaper && lhs.volumeControlStatusBarIcons == rhs.volumeControlStatusBarIcons && lhs.fontSize == rhs.fontSize && lhs.dateTimeFormat == rhs.dateTimeFormat && lhs.disableAnimations == rhs.disableAnimations + return lhs.strings === rhs.strings && lhs.theme === rhs.theme && lhs.chatWallpaper == rhs.chatWallpaper && lhs.chatWallpaperMode == rhs.chatWallpaperMode && lhs.volumeControlStatusBarIcons == rhs.volumeControlStatusBarIcons && lhs.fontSize == rhs.fontSize && lhs.dateTimeFormat == rhs.dateTimeFormat && lhs.disableAnimations == rhs.disableAnimations } } @@ -234,6 +236,7 @@ public func currentPresentationDataAndSettings(postbox: Postbox) -> Signal Signal Signal PresentationData { let nameSortOrder = currentPersonNameSortOrder() let themeSettings = PresentationThemeSettings.defaultSettings - return PresentationData(strings: defaultPresentationStrings, theme: defaultPresentationTheme, chatWallpaper: .builtin, volumeControlStatusBarIcons: volumeControlStatusBarIcons(), fontSize: themeSettings.fontSize, dateTimeFormat: dateTimeFormat, nameDisplayOrder: nameDisplayOrder, nameSortOrder: nameSortOrder, disableAnimations: themeSettings.disableAnimations) + return PresentationData(strings: defaultPresentationStrings, theme: defaultPresentationTheme, chatWallpaper: .builtin, chatWallpaperMode: .still, volumeControlStatusBarIcons: volumeControlStatusBarIcons(), fontSize: themeSettings.fontSize, dateTimeFormat: dateTimeFormat, nameDisplayOrder: nameDisplayOrder, nameSortOrder: nameSortOrder, disableAnimations: themeSettings.disableAnimations) } diff --git a/TelegramUI/PresentationResourceKey.swift b/TelegramUI/PresentationResourceKey.swift index 313f2b9d4f..149cd1edc8 100644 --- a/TelegramUI/PresentationResourceKey.swift +++ b/TelegramUI/PresentationResourceKey.swift @@ -219,7 +219,6 @@ enum PresentationResourceKey: Int32 { case groupInfoAdminsIcon case groupInfoPermissionsIcon case groupInfoMembersIcon - case groupInfoBannedIcon case emptyChatListCheckIcon } diff --git a/TelegramUI/PresentationResourcesChat.swift b/TelegramUI/PresentationResourcesChat.swift index 6ae2162f4d..65ff5725fb 100644 --- a/TelegramUI/PresentationResourcesChat.swift +++ b/TelegramUI/PresentationResourcesChat.swift @@ -953,12 +953,6 @@ struct PresentationResourcesChat { }) } - static func groupInfoBannedIcon(_ theme: PresentationTheme) -> UIImage? { - return theme.image(PresentationResourceKey.groupInfoBannedIcon.rawValue, { _ in - return UIImage(bundleImageName: "Chat/Info/GroupBannedIcon")?.precomposed() - }) - } - static func emptyChatListCheckIcon(_ theme: PresentationTheme) -> UIImage? { return theme.image(PresentationResourceKey.emptyChatListCheckIcon.rawValue, { _ in return generateTintedImage(image: UIImage(bundleImageName: "Chat/Empty Chat/ListCheckIcon"), color: theme.chat.serviceMessage.components.withDefaultWallpaper.primaryText) diff --git a/TelegramUI/PresentationStrings.swift b/TelegramUI/PresentationStrings.swift index 22d25aee90..099b7aad6f 100644 --- a/TelegramUI/PresentationStrings.swift +++ b/TelegramUI/PresentationStrings.swift @@ -1312,2642 +1312,2646 @@ public final class PresentationStrings { public var Channel_Username_Help: String { return self._s[1038]! } public var Camera_Title: String { return self._s[1039]! } public var GroupInfo_SetGroupPhotoDelete: String { return self._s[1041]! } - public var Channel_AdminLog_TitleAllEvents: String { return self._s[1042]! } - public var Contacts_MemberSearchSectionTitleGroup: String { return self._s[1043]! } - public var Conversation_RestrictedStickers: String { return self._s[1044]! } - public var Notifications_ExceptionsResetToDefaults: String { return self._s[1046]! } - public var UserInfo_TelegramCall: String { return self._s[1048]! } - public var TwoStepAuth_SetupResendEmailCode: String { return self._s[1049]! } - public var CreatePoll_OptionsHeader: String { return self._s[1050]! } - public var Privacy_GroupsAndChannels_AlwaysAllow_Title: String { return self._s[1051]! } - public var Passport_Identity_EditPersonalDetails: String { return self._s[1052]! } + public var Channel_AdminLog_SendPolls: String { return self._s[1042]! } + public var Channel_AdminLog_TitleAllEvents: String { return self._s[1043]! } + public var Contacts_MemberSearchSectionTitleGroup: String { return self._s[1044]! } + public var Conversation_RestrictedStickers: String { return self._s[1045]! } + public var Notifications_ExceptionsResetToDefaults: String { return self._s[1047]! } + public var UserInfo_TelegramCall: String { return self._s[1049]! } + public var TwoStepAuth_SetupResendEmailCode: String { return self._s[1050]! } + public var CreatePoll_OptionsHeader: String { return self._s[1051]! } + public var Privacy_GroupsAndChannels_AlwaysAllow_Title: String { return self._s[1052]! } + public var Passport_Identity_EditPersonalDetails: String { return self._s[1053]! } public func Time_PreciseDate_m1(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1053]!, self._r[1053]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1054]!, self._r[1054]!, [_1, _2, _3]) } - public var Settings_SaveEditedPhotos: String { return self._s[1054]! } - public var TwoStepAuth_ConfirmationTitle: String { return self._s[1055]! } - public var Privacy_GroupsAndChannels_NeverAllow_Title: String { return self._s[1056]! } - public var Conversation_MessageDialogRetry: String { return self._s[1057]! } - public var Conversation_DiscardVoiceMessageAction: String { return self._s[1058]! } - public var Group_Setup_TypeHeader: String { return self._s[1059]! } - public var Paint_RecentStickers: String { return self._s[1060]! } - public var PhotoEditor_GrainTool: String { return self._s[1061]! } - public var CheckoutInfo_ShippingInfoState: String { return self._s[1062]! } - public var EmptyGroupInfo_Line4: String { return self._s[1063]! } - public var Watch_AuthRequired: String { return self._s[1066]! } + public var Settings_SaveEditedPhotos: String { return self._s[1055]! } + public var TwoStepAuth_ConfirmationTitle: String { return self._s[1056]! } + public var Privacy_GroupsAndChannels_NeverAllow_Title: String { return self._s[1057]! } + public var Conversation_MessageDialogRetry: String { return self._s[1058]! } + public var Conversation_DiscardVoiceMessageAction: String { return self._s[1059]! } + public var Group_Setup_TypeHeader: String { return self._s[1060]! } + public var Paint_RecentStickers: String { return self._s[1061]! } + public var PhotoEditor_GrainTool: String { return self._s[1062]! } + public var CheckoutInfo_ShippingInfoState: String { return self._s[1063]! } + public var EmptyGroupInfo_Line4: String { return self._s[1064]! } + public var Watch_AuthRequired: String { return self._s[1067]! } public func Passport_Email_UseTelegramEmail(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1068]!, self._r[1068]!, [_0]) + return formatWithArgumentRanges(self._s[1069]!, self._r[1069]!, [_0]) } public func CHANNEL_MESSAGE_PHOTOS(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1069]!, self._r[1069]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1070]!, self._r[1070]!, [_1, _2]) } - public var Conversation_EncryptedDescriptionTitle: String { return self._s[1070]! } - public var ChannelIntro_Text: String { return self._s[1071]! } - public var DialogList_DeleteBotConfirmation: String { return self._s[1072]! } - public var GroupPermission_NoSendMedia: String { return self._s[1073]! } - public var Calls_AddTab: String { return self._s[1074]! } - public var Message_ReplyActionButtonShowReceipt: String { return self._s[1075]! } - public var Channel_AdminLog_EmptyFilterText: String { return self._s[1076]! } - public var Notification_MessageLifetime1d: String { return self._s[1077]! } - public var Notifications_ChannelNotificationsExceptionsHelp: String { return self._s[1078]! } - public var Channel_BanUser_PermissionsHeader: String { return self._s[1079]! } - public var Passport_Identity_GenderFemale: String { return self._s[1080]! } - public var BlockedUsers_BlockTitle: String { return self._s[1081]! } + public var Conversation_EncryptedDescriptionTitle: String { return self._s[1071]! } + public var ChannelIntro_Text: String { return self._s[1072]! } + public var DialogList_DeleteBotConfirmation: String { return self._s[1073]! } + public var GroupPermission_NoSendMedia: String { return self._s[1074]! } + public var Calls_AddTab: String { return self._s[1075]! } + public var Message_ReplyActionButtonShowReceipt: String { return self._s[1076]! } + public var Channel_AdminLog_EmptyFilterText: String { return self._s[1077]! } + public var Notification_MessageLifetime1d: String { return self._s[1078]! } + public var Notifications_ChannelNotificationsExceptionsHelp: String { return self._s[1079]! } + public var Channel_BanUser_PermissionsHeader: String { return self._s[1080]! } + public var Passport_Identity_GenderFemale: String { return self._s[1081]! } + public var BlockedUsers_BlockTitle: String { return self._s[1082]! } public func MESSAGE_AUDIO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1082]!, self._r[1082]!, [_1]) + return formatWithArgumentRanges(self._s[1083]!, self._r[1083]!, [_1]) } - public var Weekday_Yesterday: String { return self._s[1083]! } - public var AutoNightTheme_Scheduled: String { return self._s[1084]! } + public var Weekday_Yesterday: String { return self._s[1084]! } + public var AutoNightTheme_Scheduled: String { return self._s[1085]! } public func Login_PhoneGenericEmailBody(_ _1: String, _ _2: String, _ _3: String, _ _4: String, _ _5: String, _ _6: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1085]!, self._r[1085]!, [_1, _2, _3, _4, _5, _6]) + return formatWithArgumentRanges(self._s[1086]!, self._r[1086]!, [_1, _2, _3, _4, _5, _6]) } - public var PrivacyPolicy_DeclineDeleteNow: String { return self._s[1086]! } - public var CreatePoll_Create: String { return self._s[1087]! } - public var Channel_Members_AddBannedErrorAdmin: String { return self._s[1088]! } + public var PrivacyPolicy_DeclineDeleteNow: String { return self._s[1087]! } + public var CreatePoll_Create: String { return self._s[1088]! } + public var Channel_Members_AddBannedErrorAdmin: String { return self._s[1089]! } public func Notification_CallFormat(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1089]!, self._r[1089]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1090]!, self._r[1090]!, [_1, _2]) } - public var Checkout_ErrorProviderAccountInvalid: String { return self._s[1090]! } - public var Notifications_InAppNotificationsSounds: String { return self._s[1091]! } - public var Preview_OpenInInstagram: String { return self._s[1092]! } - public var Notification_MessageLifetimeRemovedOutgoing: String { return self._s[1093]! } + public var Checkout_ErrorProviderAccountInvalid: String { return self._s[1091]! } + public var Notifications_InAppNotificationsSounds: String { return self._s[1092]! } + public var Preview_OpenInInstagram: String { return self._s[1093]! } + public var Notification_MessageLifetimeRemovedOutgoing: String { return self._s[1094]! } public func CHANNEL_MESSAGE_GIF_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1094]!, self._r[1094]!, [_1]) + return formatWithArgumentRanges(self._s[1095]!, self._r[1095]!, [_1]) } - public var Channel_AdminLog_InfoPanelAlertTitle: String { return self._s[1095]! } + public var Channel_AdminLog_InfoPanelAlertTitle: String { return self._s[1096]! } public func Passport_PrivacyPolicy(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1096]!, self._r[1096]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1097]!, self._r[1097]!, [_1, _2]) } - public var NetworkUsageSettings_TotalSection: String { return self._s[1097]! } + public var NetworkUsageSettings_TotalSection: String { return self._s[1098]! } public func PINNED_PHOTO_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1098]!, self._r[1098]!, [_1]) + return formatWithArgumentRanges(self._s[1099]!, self._r[1099]!, [_1]) } - public var Channel_Setup_TypePrivateHelp: String { return self._s[1099]! } - public var Wallpaper_PhotoLibrary: String { return self._s[1101]! } - public var Privacy_GroupsAndChannels_NeverAllow_Placeholder: String { return self._s[1102]! } + public var Channel_Setup_TypePrivateHelp: String { return self._s[1100]! } + public var Wallpaper_PhotoLibrary: String { return self._s[1102]! } + public var Privacy_GroupsAndChannels_NeverAllow_Placeholder: String { return self._s[1103]! } public func MESSAGE_PHOTO_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1103]!, self._r[1103]!, [_1]) + return formatWithArgumentRanges(self._s[1104]!, self._r[1104]!, [_1]) } - public var FastTwoStepSetup_HintSection: String { return self._s[1104]! } - public var TwoStepAuth_SetupResendEmailCodeAlert: String { return self._s[1105]! } - public var Watch_LastSeen_WithinAMonth: String { return self._s[1106]! } - public var GroupInfo_ActionPromote: String { return self._s[1107]! } - public var PasscodeSettings_SimplePasscode: String { return self._s[1108]! } - public var GroupInfo_Permissions_Title: String { return self._s[1109]! } - public var Permissions_ContactsText_v0: String { return self._s[1110]! } - public var PrivacySettings_DataSettingsHelp: String { return self._s[1113]! } - public var Passport_FieldEmailHelp: String { return self._s[1114]! } - public var Passport_Identity_GenderPlaceholder: String { return self._s[1115]! } - public var Weekday_ShortSaturday: String { return self._s[1116]! } - public var ContactInfo_PhoneLabelMain: String { return self._s[1117]! } - public var Watch_Conversation_UserInfo: String { return self._s[1118]! } - public var CheckoutInfo_ShippingInfoCityPlaceholder: String { return self._s[1119]! } - public var PrivacyLastSeenSettings_Title: String { return self._s[1120]! } - public var Conversation_ShareBotLocationConfirmation: String { return self._s[1121]! } - public var PhotoEditor_VignetteTool: String { return self._s[1122]! } - public var Passport_Address_Street1Placeholder: String { return self._s[1123]! } - public var Passport_Language_et: String { return self._s[1124]! } - public var Passport_Language_bg: String { return self._s[1126]! } - public var Stickers_NoStickersFound: String { return self._s[1128]! } - public var Settings_About: String { return self._s[1130]! } + public var FastTwoStepSetup_HintSection: String { return self._s[1105]! } + public var TwoStepAuth_SetupResendEmailCodeAlert: String { return self._s[1106]! } + public var Watch_LastSeen_WithinAMonth: String { return self._s[1107]! } + public var GroupInfo_ActionPromote: String { return self._s[1108]! } + public var PasscodeSettings_SimplePasscode: String { return self._s[1109]! } + public var GroupInfo_Permissions_Title: String { return self._s[1110]! } + public var Permissions_ContactsText_v0: String { return self._s[1111]! } + public var PrivacySettings_DataSettingsHelp: String { return self._s[1114]! } + public var Passport_FieldEmailHelp: String { return self._s[1115]! } + public var Passport_Identity_GenderPlaceholder: String { return self._s[1116]! } + public var Weekday_ShortSaturday: String { return self._s[1117]! } + public var ContactInfo_PhoneLabelMain: String { return self._s[1118]! } + public var Watch_Conversation_UserInfo: String { return self._s[1119]! } + public var CheckoutInfo_ShippingInfoCityPlaceholder: String { return self._s[1120]! } + public var PrivacyLastSeenSettings_Title: String { return self._s[1121]! } + public var Conversation_ShareBotLocationConfirmation: String { return self._s[1122]! } + public var PhotoEditor_VignetteTool: String { return self._s[1123]! } + public var Passport_Address_Street1Placeholder: String { return self._s[1124]! } + public var Passport_Language_et: String { return self._s[1125]! } + public var Passport_Language_bg: String { return self._s[1127]! } + public var Stickers_NoStickersFound: String { return self._s[1129]! } + public var Settings_About: String { return self._s[1131]! } public func CHAT_MESSAGE_POLL_SEPARATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1131]!, self._r[1131]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1132]!, self._r[1132]!, [_1, _2]) } public func Channel_AdminLog_MessageRestricted(_ _0: String, _ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1132]!, self._r[1132]!, [_0, _1, _2]) + return formatWithArgumentRanges(self._s[1133]!, self._r[1133]!, [_0, _1, _2]) } - public var KeyCommand_NewMessage: String { return self._s[1134]! } - public var Group_ErrorAddBlocked: String { return self._s[1135]! } + public var KeyCommand_NewMessage: String { return self._s[1135]! } + public var Group_ErrorAddBlocked: String { return self._s[1136]! } public func Message_PaymentSent(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1136]!, self._r[1136]!, [_0]) + return formatWithArgumentRanges(self._s[1137]!, self._r[1137]!, [_0]) } - public var Map_LocationTitle: String { return self._s[1137]! } - public var CallSettings_UseLessDataLongDescription: String { return self._s[1138]! } - public var Cache_ClearProgress: String { return self._s[1139]! } + public var Map_LocationTitle: String { return self._s[1138]! } + public var CallSettings_UseLessDataLongDescription: String { return self._s[1139]! } + public var Cache_ClearProgress: String { return self._s[1140]! } public func Channel_Management_ErrorNotMember(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1140]!, self._r[1140]!, [_0]) + return formatWithArgumentRanges(self._s[1141]!, self._r[1141]!, [_0]) } - public var GroupRemoved_AddToGroup: String { return self._s[1141]! } - public var Passport_UpdateRequiredError: String { return self._s[1142]! } - public var Notifications_PermissionsSuppressWarningText: String { return self._s[1144]! } - public var Passport_Identity_MainPageHelp: String { return self._s[1145]! } - public var Conversation_StatusKickedFromGroup: String { return self._s[1146]! } - public var Passport_Language_ka: String { return self._s[1147]! } - public var Call_Decline: String { return self._s[1148]! } - public var SocksProxySetup_ProxyEnabled: String { return self._s[1149]! } + public var GroupRemoved_AddToGroup: String { return self._s[1142]! } + public var Passport_UpdateRequiredError: String { return self._s[1143]! } + public var Notifications_PermissionsSuppressWarningText: String { return self._s[1145]! } + public var Passport_Identity_MainPageHelp: String { return self._s[1146]! } + public var Conversation_StatusKickedFromGroup: String { return self._s[1147]! } + public var Passport_Language_ka: String { return self._s[1148]! } + public var Call_Decline: String { return self._s[1149]! } + public var SocksProxySetup_ProxyEnabled: String { return self._s[1150]! } public func AuthCode_Alert(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1152]!, self._r[1152]!, [_0]) + return formatWithArgumentRanges(self._s[1153]!, self._r[1153]!, [_0]) } public func CHANNEL_MESSAGE_POLL_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1153]!, self._r[1153]!, [_1]) + return formatWithArgumentRanges(self._s[1154]!, self._r[1154]!, [_1]) } public func Channel_AdminLog_MessagePromotedNameUsername(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1154]!, self._r[1154]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1155]!, self._r[1155]!, [_1, _2]) } - public var Passport_Phone_UseTelegramNumberHelp: String { return self._s[1155]! } - public var Passport_DeletePassport: String { return self._s[1157]! } - public var Privacy_Calls_P2PAlways: String { return self._s[1158]! } - public var Month_ShortDecember: String { return self._s[1159]! } - public var Channel_AdminLog_CanEditMessages: String { return self._s[1161]! } + public var Passport_Phone_UseTelegramNumberHelp: String { return self._s[1156]! } + public var Passport_DeletePassport: String { return self._s[1158]! } + public var Privacy_Calls_P2PAlways: String { return self._s[1159]! } + public var Month_ShortDecember: String { return self._s[1160]! } + public var Channel_AdminLog_CanEditMessages: String { return self._s[1162]! } public func Contacts_AccessDeniedHelpLandscape(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1162]!, self._r[1162]!, [_0]) + return formatWithArgumentRanges(self._s[1163]!, self._r[1163]!, [_0]) } - public var Channel_Stickers_Searching: String { return self._s[1163]! } - public var Conversation_EncryptedDescription1: String { return self._s[1164]! } - public var Conversation_EncryptedDescription2: String { return self._s[1165]! } - public var Conversation_EncryptedDescription3: String { return self._s[1166]! } - public var PhotoEditor_SharpenTool: String { return self._s[1167]! } + public var Channel_Stickers_Searching: String { return self._s[1164]! } + public var Conversation_EncryptedDescription1: String { return self._s[1165]! } + public var Conversation_EncryptedDescription2: String { return self._s[1166]! } + public var Conversation_EncryptedDescription3: String { return self._s[1167]! } + public var PhotoEditor_SharpenTool: String { return self._s[1168]! } public func ENCRYPTED_MESSAGE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1168]!, self._r[1168]!, [_1]) + return formatWithArgumentRanges(self._s[1169]!, self._r[1169]!, [_1]) } - public var Conversation_EncryptedDescription4: String { return self._s[1170]! } - public var Channel_Members_AddMembers: String { return self._s[1171]! } - public var Wallpaper_Search: String { return self._s[1172]! } + public var Conversation_EncryptedDescription4: String { return self._s[1171]! } + public var Channel_Members_AddMembers: String { return self._s[1172]! } + public var Wallpaper_Search: String { return self._s[1173]! } public func CHANNEL_MESSAGE_GAME_SEPARATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1173]!, self._r[1173]!, [_1, _2]) - } - public func CHAT_MESSAGE_GEOLIVE_SEPARATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[1174]!, self._r[1174]!, [_1, _2]) } - public var Weekday_Friday: String { return self._s[1175]! } - public var Privacy_ContactsSync: String { return self._s[1176]! } - public var ApplyLanguage_ChangeLanguageAction: String { return self._s[1177]! } + public func CHAT_MESSAGE_GEOLIVE_SEPARATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1175]!, self._r[1175]!, [_1, _2]) + } + public var Weekday_Friday: String { return self._s[1176]! } + public var Privacy_ContactsSync: String { return self._s[1177]! } + public var ApplyLanguage_ChangeLanguageAction: String { return self._s[1178]! } public func Channel_Management_RestrictedBy(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1178]!, self._r[1178]!, [_0]) + return formatWithArgumentRanges(self._s[1179]!, self._r[1179]!, [_0]) } - public var GroupInfo_Permissions_Removed: String { return self._s[1179]! } - public var Passport_Identity_GenderMale: String { return self._s[1180]! } + public var GroupInfo_Permissions_Removed: String { return self._s[1180]! } + public var Passport_Identity_GenderMale: String { return self._s[1181]! } public func Call_StatusBar(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1181]!, self._r[1181]!, [_0]) + return formatWithArgumentRanges(self._s[1182]!, self._r[1182]!, [_0]) } - public var Notifications_PermissionsKeepDisabled: String { return self._s[1182]! } - public var Conversation_JumpToDate: String { return self._s[1183]! } - public var Contacts_GlobalSearch: String { return self._s[1184]! } - public var AutoDownloadSettings_ResetHelp: String { return self._s[1185]! } - public var Profile_MessageLifetime1d: String { return self._s[1186]! } + public var Notifications_PermissionsKeepDisabled: String { return self._s[1183]! } + public var Conversation_JumpToDate: String { return self._s[1184]! } + public var Contacts_GlobalSearch: String { return self._s[1185]! } + public var AutoDownloadSettings_ResetHelp: String { return self._s[1186]! } + public var Profile_MessageLifetime1d: String { return self._s[1187]! } public func MESSAGE_INVOICE(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1187]!, self._r[1187]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1188]!, self._r[1188]!, [_1, _2]) } - public var StickerPack_BuiltinPackName: String { return self._s[1190]! } - public var Passport_InfoTitle: String { return self._s[1192]! } - public var Notifications_PermissionsUnreachableText: String { return self._s[1193]! } + public var StickerPack_BuiltinPackName: String { return self._s[1191]! } + public var Passport_InfoTitle: String { return self._s[1193]! } + public var Notifications_PermissionsUnreachableText: String { return self._s[1194]! } public func NetworkUsageSettings_CellularUsageSince(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1197]!, self._r[1197]!, [_0]) + return formatWithArgumentRanges(self._s[1198]!, self._r[1198]!, [_0]) } - public var Passport_Address_TypePassportRegistrationUploadScan: String { return self._s[1198]! } - public var Profile_BotInfo: String { return self._s[1199]! } - public var Watch_Compose_CreateMessage: String { return self._s[1200]! } - public var Month_ShortNovember: String { return self._s[1201]! } + public var Passport_Address_TypePassportRegistrationUploadScan: String { return self._s[1199]! } + public var Profile_BotInfo: String { return self._s[1200]! } + public var Watch_Compose_CreateMessage: String { return self._s[1201]! } + public var Month_ShortNovember: String { return self._s[1202]! } public func PHONE_CALL_REQUEST(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1202]!, self._r[1202]!, [_1]) - } - public func ENCRYPTION_REQUEST(_ _1: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[1203]!, self._r[1203]!, [_1]) } - public var Wallpaper_SetCustomBackground: String { return self._s[1204]! } - public var Passport_Identity_TranslationsHelp: String { return self._s[1205]! } - public var NotificationsSound_Chime: String { return self._s[1206]! } - public var Passport_Language_ko: String { return self._s[1208]! } - public var InviteText_URL: String { return self._s[1209]! } - public var TextFormat_Monospace: String { return self._s[1210]! } + public func ENCRYPTION_REQUEST(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1204]!, self._r[1204]!, [_1]) + } + public var Wallpaper_SetCustomBackground: String { return self._s[1205]! } + public var Passport_Identity_TranslationsHelp: String { return self._s[1206]! } + public var NotificationsSound_Chime: String { return self._s[1207]! } + public var Passport_Language_ko: String { return self._s[1209]! } + public var InviteText_URL: String { return self._s[1210]! } + public var TextFormat_Monospace: String { return self._s[1211]! } public func Time_PreciseDate_m11(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1211]!, self._r[1211]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1212]!, self._r[1212]!, [_1, _2, _3]) } public func Login_WillSendSms(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1212]!, self._r[1212]!, [_0]) + return formatWithArgumentRanges(self._s[1213]!, self._r[1213]!, [_0]) } public func Watch_Time_ShortWeekdayAt(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1213]!, self._r[1213]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1214]!, self._r[1214]!, [_1, _2]) } - public var Passport_InfoLearnMore: String { return self._s[1215]! } - public var TwoStepAuth_EmailPlaceholder: String { return self._s[1216]! } - public var Passport_Identity_AddIdentityCard: String { return self._s[1217]! } - public var Your_card_has_expired: String { return self._s[1218]! } - public var StickerPacksSettings_StickerPacksSection: String { return self._s[1219]! } - public var GroupInfo_InviteLink_Help: String { return self._s[1220]! } - public var Conversation_Report: String { return self._s[1223]! } - public var Notifications_MessageNotificationsSound: String { return self._s[1224]! } - public var Notification_MessageLifetime1m: String { return self._s[1225]! } - public var Privacy_ContactsTitle: String { return self._s[1226]! } - public var Conversation_ShareMyContactInfo: String { return self._s[1227]! } - public var ChannelMembers_WhoCanAddMembersAdminsHelp: String { return self._s[1228]! } - public var Channel_Members_Title: String { return self._s[1229]! } - public var Map_OpenInWaze: String { return self._s[1230]! } - public var Login_PhoneBannedError: String { return self._s[1231]! } + public var Passport_InfoLearnMore: String { return self._s[1216]! } + public var TwoStepAuth_EmailPlaceholder: String { return self._s[1217]! } + public var Passport_Identity_AddIdentityCard: String { return self._s[1218]! } + public var Your_card_has_expired: String { return self._s[1219]! } + public var StickerPacksSettings_StickerPacksSection: String { return self._s[1220]! } + public var GroupInfo_InviteLink_Help: String { return self._s[1221]! } + public var Conversation_Report: String { return self._s[1224]! } + public var Notifications_MessageNotificationsSound: String { return self._s[1225]! } + public var Notification_MessageLifetime1m: String { return self._s[1226]! } + public var Privacy_ContactsTitle: String { return self._s[1227]! } + public var Conversation_ShareMyContactInfo: String { return self._s[1228]! } + public var ChannelMembers_WhoCanAddMembersAdminsHelp: String { return self._s[1229]! } + public var Channel_Members_Title: String { return self._s[1230]! } + public var Map_OpenInWaze: String { return self._s[1231]! } + public var Login_PhoneBannedError: String { return self._s[1232]! } public func LiveLocationUpdated_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1232]!, self._r[1232]!, [_0]) + return formatWithArgumentRanges(self._s[1233]!, self._r[1233]!, [_0]) } public func MESSAGE_PHOTO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1233]!, self._r[1233]!, [_1]) + return formatWithArgumentRanges(self._s[1234]!, self._r[1234]!, [_1]) } - public var Group_Management_AddModeratorHelp: String { return self._s[1234]! } - public var Common_OK: String { return self._s[1235]! } - public var Passport_Address_TypeBankStatementUploadScan: String { return self._s[1236]! } - public var Cache_Music: String { return self._s[1237]! } + public var Group_Management_AddModeratorHelp: String { return self._s[1235]! } + public var Common_OK: String { return self._s[1236]! } + public var Passport_Address_TypeBankStatementUploadScan: String { return self._s[1237]! } + public var Cache_Music: String { return self._s[1238]! } public func CHAT_TITLE_EDITED_SEPARATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1238]!, self._r[1238]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1239]!, self._r[1239]!, [_1, _2]) } public func PINNED_AUDIO_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1239]!, self._r[1239]!, [_1]) + return formatWithArgumentRanges(self._s[1240]!, self._r[1240]!, [_1]) } - public var PasscodeSettings_UnlockWithTouchId: String { return self._s[1240]! } - public var TwoStepAuth_HintPlaceholder: String { return self._s[1241]! } + public var PasscodeSettings_UnlockWithTouchId: String { return self._s[1241]! } + public var TwoStepAuth_HintPlaceholder: String { return self._s[1242]! } public func Passport_RequestHeader(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1242]!, self._r[1242]!, [_0]) + return formatWithArgumentRanges(self._s[1243]!, self._r[1243]!, [_0]) } - public var Watch_MessageView_ViewOnPhone: String { return self._s[1244]! } - public var Privacy_Calls_CustomShareHelp: String { return self._s[1245]! } - public var BackgroundPreview_SwipeInfo: String { return self._s[1247]! } - public var ChangePhoneNumberNumber_Title: String { return self._s[1248]! } - public var State_ConnectingToProxyInfo: String { return self._s[1249]! } - public var Message_VideoMessage: String { return self._s[1251]! } - public var ChannelInfo_DeleteChannel: String { return self._s[1252]! } + public var Watch_MessageView_ViewOnPhone: String { return self._s[1245]! } + public var Privacy_Calls_CustomShareHelp: String { return self._s[1246]! } + public var BackgroundPreview_SwipeInfo: String { return self._s[1248]! } + public var ChangePhoneNumberNumber_Title: String { return self._s[1249]! } + public var State_ConnectingToProxyInfo: String { return self._s[1250]! } + public var Message_VideoMessage: String { return self._s[1252]! } + public var ChannelInfo_DeleteChannel: String { return self._s[1253]! } public func CHAT_MESSAGE_POLL(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1253]!, self._r[1253]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1254]!, self._r[1254]!, [_1, _2]) } - public var ContactInfo_PhoneLabelOther: String { return self._s[1254]! } - public var Channel_EditAdmin_CannotEdit: String { return self._s[1255]! } - public var Passport_DeleteAddressConfirmation: String { return self._s[1256]! } - public var Activity_RecordingAudio: String { return self._s[1257]! } - public var PasscodeSettings_TryAgainIn1Minute: String { return self._s[1258]! } + public var ContactInfo_PhoneLabelOther: String { return self._s[1255]! } + public var Channel_EditAdmin_CannotEdit: String { return self._s[1256]! } + public var Passport_DeleteAddressConfirmation: String { return self._s[1257]! } + public var Activity_RecordingAudio: String { return self._s[1258]! } + public var PasscodeSettings_TryAgainIn1Minute: String { return self._s[1259]! } public func Notification_ChangedGroupName(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1260]!, self._r[1260]!, [_0, _1]) + return formatWithArgumentRanges(self._s[1261]!, self._r[1261]!, [_0, _1]) } public func EmptyGroupInfo_Line1(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1263]!, self._r[1263]!, [_0]) + return formatWithArgumentRanges(self._s[1264]!, self._r[1264]!, [_0]) } - public var Conversation_ApplyLocalization: String { return self._s[1264]! } - public var UserInfo_AddPhone: String { return self._s[1265]! } - public var Map_ShareLiveLocationHelp: String { return self._s[1266]! } + public var Conversation_ApplyLocalization: String { return self._s[1265]! } + public var UserInfo_AddPhone: String { return self._s[1266]! } + public var Map_ShareLiveLocationHelp: String { return self._s[1267]! } public func Passport_Identity_NativeNameGenericHelp(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1267]!, self._r[1267]!, [_0]) + return formatWithArgumentRanges(self._s[1268]!, self._r[1268]!, [_0]) } - public var Passport_Scans: String { return self._s[1269]! } - public var BlockedUsers_Unblock: String { return self._s[1270]! } - public var Channel_Management_LabelCreator: String { return self._s[1271]! } - public var Passport_Identity_NativeNameGenericTitle: String { return self._s[1272]! } + public var Passport_Scans: String { return self._s[1270]! } + public var BlockedUsers_Unblock: String { return self._s[1271]! } + public var Channel_Management_LabelCreator: String { return self._s[1272]! } + public var Passport_Identity_NativeNameGenericTitle: String { return self._s[1273]! } public func Login_EmailPhoneBody(_ _0: String, _ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1273]!, self._r[1273]!, [_0, _1, _2]) + return formatWithArgumentRanges(self._s[1274]!, self._r[1274]!, [_0, _1, _2]) } - public var Login_PhoneNumberHelp: String { return self._s[1274]! } - public var LastSeen_ALongTimeAgo: String { return self._s[1275]! } - public var Channel_AdminLog_CanPinMessages: String { return self._s[1276]! } - public var ChannelIntro_CreateChannel: String { return self._s[1277]! } - public var Conversation_UnreadMessages: String { return self._s[1278]! } - public var Channel_AdminLog_EmptyText: String { return self._s[1279]! } - public var Notification_GroupActivated: String { return self._s[1280]! } - public var NotificationSettings_ContactJoinedInfo: String { return self._s[1281]! } + public var Login_PhoneNumberHelp: String { return self._s[1275]! } + public var LastSeen_ALongTimeAgo: String { return self._s[1276]! } + public var Channel_AdminLog_CanPinMessages: String { return self._s[1277]! } + public var ChannelIntro_CreateChannel: String { return self._s[1278]! } + public var Conversation_UnreadMessages: String { return self._s[1279]! } + public var Channel_AdminLog_EmptyText: String { return self._s[1280]! } + public var Notification_GroupActivated: String { return self._s[1281]! } + public var NotificationSettings_ContactJoinedInfo: String { return self._s[1282]! } public func Notification_PinnedContactMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1282]!, self._r[1282]!, [_0]) + return formatWithArgumentRanges(self._s[1283]!, self._r[1283]!, [_0]) } public func DownloadingStatus(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1283]!, self._r[1283]!, [_0, _1]) + return formatWithArgumentRanges(self._s[1284]!, self._r[1284]!, [_0, _1]) } - public var GroupInfo_ConvertToSupergroup: String { return self._s[1285]! } + public var GroupInfo_ConvertToSupergroup: String { return self._s[1286]! } public func PrivacyPolicy_AgeVerificationMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1286]!, self._r[1286]!, [_0]) + return formatWithArgumentRanges(self._s[1287]!, self._r[1287]!, [_0]) } - public var Document_TargetConfirmationFormat: String { return self._s[1287]! } + public var Document_TargetConfirmationFormat: String { return self._s[1288]! } public func Call_StatusOngoing(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1288]!, self._r[1288]!, [_0]) + return formatWithArgumentRanges(self._s[1289]!, self._r[1289]!, [_0]) } - public var Contacts_SortByName: String { return self._s[1289]! } + public var Contacts_SortByName: String { return self._s[1290]! } public func CHAT_MESSAGE_INVOICE(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1291]!, self._r[1291]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1292]!, self._r[1292]!, [_1, _2, _3]) } - public var Conversation_ClearSelfHistory: String { return self._s[1292]! } - public var Checkout_NewCard_PostcodePlaceholder: String { return self._s[1293]! } - public var Stickers_SuggestNone: String { return self._s[1294]! } - public var ChatSettings_Cache: String { return self._s[1295]! } - public var Settings_SaveIncomingPhotos: String { return self._s[1296]! } - public var Media_ShareThisPhoto: String { return self._s[1297]! } - public var InfoPlist_NSContactsUsageDescription: String { return self._s[1298]! } - public var Conversation_ContextMenuCopyLink: String { return self._s[1299]! } - public var PrivacyPolicy_AgeVerificationTitle: String { return self._s[1300]! } - public var TwoStepAuth_SetupPasswordEnterPasswordNew: String { return self._s[1301]! } - public var Permissions_CellularDataTitle_v0: String { return self._s[1302]! } - public var Channel_AdminLog_DefaultRestrictionsUpdated: String { return self._s[1303]! } - public var Map_OpenIn: String { return self._s[1304]! } + public var Conversation_ClearSelfHistory: String { return self._s[1293]! } + public var Checkout_NewCard_PostcodePlaceholder: String { return self._s[1294]! } + public var Stickers_SuggestNone: String { return self._s[1295]! } + public var ChatSettings_Cache: String { return self._s[1296]! } + public var Settings_SaveIncomingPhotos: String { return self._s[1297]! } + public var Media_ShareThisPhoto: String { return self._s[1298]! } + public var InfoPlist_NSContactsUsageDescription: String { return self._s[1299]! } + public var Conversation_ContextMenuCopyLink: String { return self._s[1300]! } + public var PrivacyPolicy_AgeVerificationTitle: String { return self._s[1301]! } + public var TwoStepAuth_SetupPasswordEnterPasswordNew: String { return self._s[1302]! } + public var Permissions_CellularDataTitle_v0: String { return self._s[1303]! } + public var Channel_AdminLog_DefaultRestrictionsUpdated: String { return self._s[1304]! } + public var Map_OpenIn: String { return self._s[1305]! } public func ChannelInfo_AddParticipantConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1307]!, self._r[1307]!, [_0]) + return formatWithArgumentRanges(self._s[1308]!, self._r[1308]!, [_0]) } - public var MessagePoll_LabelClosed: String { return self._s[1308]! } - public var Passport_Identity_MiddleNamePlaceholder: String { return self._s[1310]! } - public var UserInfo_FirstNamePlaceholder: String { return self._s[1311]! } - public var PrivacyLastSeenSettings_WhoCanSeeMyTimestamp: String { return self._s[1312]! } - public var Login_SelectCountry_Title: String { return self._s[1313]! } - public var Channel_EditAdmin_PermissionBanUsers: String { return self._s[1314]! } - public var Watch_Suggestion_BRB: String { return self._s[1315]! } - public var Contacts_PermissionsTitle: String { return self._s[1316]! } - public var Passport_Identity_EditIdentityCard: String { return self._s[1317]! } - public var Conversation_RestrictedInline: String { return self._s[1318]! } - public var StickerPack_ViewPack: String { return self._s[1320]! } + public var MessagePoll_LabelClosed: String { return self._s[1309]! } + public var Passport_Identity_MiddleNamePlaceholder: String { return self._s[1311]! } + public var UserInfo_FirstNamePlaceholder: String { return self._s[1312]! } + public var PrivacyLastSeenSettings_WhoCanSeeMyTimestamp: String { return self._s[1313]! } + public var Login_SelectCountry_Title: String { return self._s[1314]! } + public var Channel_EditAdmin_PermissionBanUsers: String { return self._s[1315]! } + public var Channel_AdminLog_ChangeInfo: String { return self._s[1316]! } + public var Watch_Suggestion_BRB: String { return self._s[1317]! } + public var Passport_Identity_EditIdentityCard: String { return self._s[1318]! } + public var Contacts_PermissionsTitle: String { return self._s[1319]! } + public var Conversation_RestrictedInline: String { return self._s[1320]! } + public var StickerPack_ViewPack: String { return self._s[1322]! } public func Update_AppVersion(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1321]!, self._r[1321]!, [_0]) + return formatWithArgumentRanges(self._s[1323]!, self._r[1323]!, [_0]) } - public var Compose_NewChannel: String { return self._s[1323]! } - public var Channel_Info_Stickers: String { return self._s[1327]! } - public var AutoNightTheme_PreferredTheme: String { return self._s[1328]! } - public var PrivacyPolicy_AgeVerificationAgree: String { return self._s[1329]! } - public var Passport_DeletePersonalDetails: String { return self._s[1330]! } - public var Conversation_SearchNoResults: String { return self._s[1332]! } - public var MessagePoll_LabelAnonymous: String { return self._s[1333]! } - public var Channel_Members_AddAdminErrorNotAMember: String { return self._s[1334]! } - public var Login_Code: String { return self._s[1335]! } - public var Watch_Suggestion_WhatsUp: String { return self._s[1336]! } - public var Weekday_ShortThursday: String { return self._s[1337]! } - public var Resolve_ErrorNotFound: String { return self._s[1339]! } - public var LastSeen_Offline: String { return self._s[1340]! } - public var Privacy_Calls_AlwaysAllow_Title: String { return self._s[1341]! } - public var Channel_AdminLog_CanChangeInviteLink: String { return self._s[1342]! } - public var GroupInfo_Title: String { return self._s[1343]! } - public var NotificationsSound_Note: String { return self._s[1344]! } - public var Conversation_EditingMessagePanelTitle: String { return self._s[1345]! } - public var Watch_Message_Poll: String { return self._s[1346]! } - public var Privacy_Calls: String { return self._s[1347]! } + public var Compose_NewChannel: String { return self._s[1325]! } + public var Channel_Info_Stickers: String { return self._s[1329]! } + public var AutoNightTheme_PreferredTheme: String { return self._s[1330]! } + public var PrivacyPolicy_AgeVerificationAgree: String { return self._s[1331]! } + public var Passport_DeletePersonalDetails: String { return self._s[1332]! } + public var Conversation_SearchNoResults: String { return self._s[1334]! } + public var MessagePoll_LabelAnonymous: String { return self._s[1335]! } + public var Channel_Members_AddAdminErrorNotAMember: String { return self._s[1336]! } + public var Login_Code: String { return self._s[1337]! } + public var Watch_Suggestion_WhatsUp: String { return self._s[1338]! } + public var Weekday_ShortThursday: String { return self._s[1339]! } + public var Resolve_ErrorNotFound: String { return self._s[1341]! } + public var LastSeen_Offline: String { return self._s[1342]! } + public var Privacy_Calls_AlwaysAllow_Title: String { return self._s[1343]! } + public var Channel_AdminLog_CanChangeInviteLink: String { return self._s[1344]! } + public var GroupInfo_Title: String { return self._s[1345]! } + public var NotificationsSound_Note: String { return self._s[1346]! } + public var Conversation_EditingMessagePanelTitle: String { return self._s[1347]! } + public var Watch_Message_Poll: String { return self._s[1348]! } + public var Privacy_Calls: String { return self._s[1349]! } public func CHANNEL_MESSAGE_PHOTO_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1348]!, self._r[1348]!, [_1]) + return formatWithArgumentRanges(self._s[1350]!, self._r[1350]!, [_1]) } - public var Month_ShortAugust: String { return self._s[1349]! } - public var TwoStepAuth_SetPasswordHelp: String { return self._s[1350]! } - public var Notifications_Reset: String { return self._s[1351]! } - public var Conversation_Pin: String { return self._s[1352]! } - public var Passport_Language_lv: String { return self._s[1353]! } - public var BlockedUsers_Info: String { return self._s[1354]! } - public var Watch_Conversation_Unblock: String { return self._s[1357]! } + public var Month_ShortAugust: String { return self._s[1351]! } + public var TwoStepAuth_SetPasswordHelp: String { return self._s[1352]! } + public var Notifications_Reset: String { return self._s[1353]! } + public var Conversation_Pin: String { return self._s[1354]! } + public var Passport_Language_lv: String { return self._s[1355]! } + public var BlockedUsers_Info: String { return self._s[1356]! } + public var Watch_Conversation_Unblock: String { return self._s[1359]! } public func Time_MonthOfYear_m9(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1358]!, self._r[1358]!, [_0]) + return formatWithArgumentRanges(self._s[1360]!, self._r[1360]!, [_0]) } - public var CloudStorage_Title: String { return self._s[1359]! } - public var GroupInfo_DeleteAndExitConfirmation: String { return self._s[1360]! } + public var CloudStorage_Title: String { return self._s[1361]! } + public var GroupInfo_DeleteAndExitConfirmation: String { return self._s[1362]! } public func NetworkUsageSettings_WifiUsageSince(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1361]!, self._r[1361]!, [_0]) + return formatWithArgumentRanges(self._s[1363]!, self._r[1363]!, [_0]) } - public var Channel_AdminLogFilter_AdminsTitle: String { return self._s[1362]! } - public var Watch_Suggestion_OnMyWay: String { return self._s[1363]! } - public var TwoStepAuth_RecoveryEmailTitle: String { return self._s[1364]! } + public var Channel_AdminLogFilter_AdminsTitle: String { return self._s[1364]! } + public var Watch_Suggestion_OnMyWay: String { return self._s[1365]! } + public var TwoStepAuth_RecoveryEmailTitle: String { return self._s[1366]! } public func MESSAGE_CONTACT_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1365]!, self._r[1365]!, [_1]) + return formatWithArgumentRanges(self._s[1367]!, self._r[1367]!, [_1]) } - public var Passport_Address_EditBankStatement: String { return self._s[1366]! } - public var ChatSettings_DownloadInBackgroundInfo: String { return self._s[1367]! } - public var ShareMenu_Comment: String { return self._s[1368]! } - public var Permissions_ContactsTitle_v0: String { return self._s[1369]! } - public var Notifications_PermissionsTitle: String { return self._s[1370]! } - public var GroupPermission_NoSendLinks: String { return self._s[1371]! } - public var Settings_Support: String { return self._s[1372]! } - public var Notifications_ChannelNotificationsSound: String { return self._s[1373]! } + public var Passport_Address_EditBankStatement: String { return self._s[1368]! } + public var ChatSettings_DownloadInBackgroundInfo: String { return self._s[1369]! } + public var ShareMenu_Comment: String { return self._s[1370]! } + public var Permissions_ContactsTitle_v0: String { return self._s[1371]! } + public var Notifications_PermissionsTitle: String { return self._s[1372]! } + public var GroupPermission_NoSendLinks: String { return self._s[1373]! } + public var Settings_Support: String { return self._s[1374]! } + public var Notifications_ChannelNotificationsSound: String { return self._s[1375]! } public func CHAT_RETURNED_SEPARATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1374]!, self._r[1374]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1376]!, self._r[1376]!, [_1, _2]) } - public var GroupPermission_ApplyAlertAction: String { return self._s[1375]! } - public var Channel_AdminLog_BanSendGifs: String { return self._s[1376]! } - public var Watch_Stickers_StickerPacks: String { return self._s[1377]! } - public var Common_Select: String { return self._s[1379]! } - public var CheckoutInfo_ErrorEmailInvalid: String { return self._s[1380]! } - public var ChatAdmins_AllMembersAreAdminsOffHelp: String { return self._s[1382]! } - public var PasscodeSettings_AutoLock_IfAwayFor_5hours: String { return self._s[1383]! } - public var Appearance_PreviewReplyAuthor: String { return self._s[1384]! } - public var TwoStepAuth_RecoveryTitle: String { return self._s[1385]! } - public var Widget_AuthRequired: String { return self._s[1386]! } - public var Camera_FlashOn: String { return self._s[1387]! } - public var Channel_Stickers_NotFoundHelp: String { return self._s[1388]! } - public var Watch_Suggestion_OK: String { return self._s[1389]! } + public var GroupPermission_ApplyAlertAction: String { return self._s[1377]! } + public var Channel_AdminLog_BanSendGifs: String { return self._s[1378]! } + public var Watch_Stickers_StickerPacks: String { return self._s[1379]! } + public var Common_Select: String { return self._s[1381]! } + public var CheckoutInfo_ErrorEmailInvalid: String { return self._s[1382]! } + public var ChatAdmins_AllMembersAreAdminsOffHelp: String { return self._s[1384]! } + public var PasscodeSettings_AutoLock_IfAwayFor_5hours: String { return self._s[1385]! } + public var Appearance_PreviewReplyAuthor: String { return self._s[1386]! } + public var TwoStepAuth_RecoveryTitle: String { return self._s[1387]! } + public var Widget_AuthRequired: String { return self._s[1388]! } + public var Camera_FlashOn: String { return self._s[1389]! } + public var Channel_Stickers_NotFoundHelp: String { return self._s[1390]! } + public var Watch_Suggestion_OK: String { return self._s[1391]! } public func Username_LinkHint(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1391]!, self._r[1391]!, [_0]) + return formatWithArgumentRanges(self._s[1393]!, self._r[1393]!, [_0]) } public func Notification_PinnedLiveLocationMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1392]!, self._r[1392]!, [_0]) + return formatWithArgumentRanges(self._s[1394]!, self._r[1394]!, [_0]) } - public var DialogList_AdLabel: String { return self._s[1393]! } - public var WatchRemote_NotificationText: String { return self._s[1394]! } - public var Conversation_ReportSpam: String { return self._s[1395]! } - public var Settings_LogoutConfirmationTitle: String { return self._s[1397]! } - public var PhoneLabel_Title: String { return self._s[1398]! } - public var Passport_Address_EditRentalAgreement: String { return self._s[1399]! } - public var Notifications_ExceptionsTitle: String { return self._s[1400]! } + public var DialogList_AdLabel: String { return self._s[1395]! } + public var WatchRemote_NotificationText: String { return self._s[1396]! } + public var Conversation_ReportSpam: String { return self._s[1397]! } + public var Settings_LogoutConfirmationTitle: String { return self._s[1399]! } + public var PhoneLabel_Title: String { return self._s[1400]! } + public var Passport_Address_EditRentalAgreement: String { return self._s[1401]! } + public var Notifications_ExceptionsTitle: String { return self._s[1402]! } public func CHANNEL_MESSAGE_PHOTO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1401]!, self._r[1401]!, [_1]) + return formatWithArgumentRanges(self._s[1403]!, self._r[1403]!, [_1]) } - public var Notifications_AlertTones: String { return self._s[1402]! } - public var Call_ReportIncludeLogDescription: String { return self._s[1403]! } + public var Notifications_AlertTones: String { return self._s[1404]! } + public var Call_ReportIncludeLogDescription: String { return self._s[1405]! } public func CHAT_ADD_MEMBER(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1404]!, self._r[1404]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1406]!, self._r[1406]!, [_1, _2, _3]) } - public var AutoDownloadSettings_PrivateChats: String { return self._s[1405]! } - public var TwoStepAuth_AddHintTitle: String { return self._s[1407]! } - public var ReportPeer_ReasonOther: String { return self._s[1408]! } - public var KeyCommand_ScrollDown: String { return self._s[1410]! } + public var AutoDownloadSettings_PrivateChats: String { return self._s[1407]! } + public var TwoStepAuth_AddHintTitle: String { return self._s[1409]! } + public var ReportPeer_ReasonOther: String { return self._s[1410]! } + public var KeyCommand_ScrollDown: String { return self._s[1412]! } public func Login_BannedPhoneSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1411]!, self._r[1411]!, [_0]) + return formatWithArgumentRanges(self._s[1413]!, self._r[1413]!, [_0]) } - public var NetworkUsageSettings_MediaVideoDataSection: String { return self._s[1412]! } - public var ChannelInfo_DeleteGroupConfirmation: String { return self._s[1413]! } - public var AuthSessions_LogOut: String { return self._s[1414]! } + public var NetworkUsageSettings_MediaVideoDataSection: String { return self._s[1414]! } + public var ChannelInfo_DeleteGroupConfirmation: String { return self._s[1415]! } + public var AuthSessions_LogOut: String { return self._s[1416]! } public func CHAT_PHOTO_EDITED_SEPARATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1415]!, self._r[1415]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1417]!, self._r[1417]!, [_1, _2]) } - public var Passport_Identity_TypeInternalPassport: String { return self._s[1416]! } - public var ChatSettings_AutoDownloadVoiceMessages: String { return self._s[1417]! } + public var Passport_Identity_TypeInternalPassport: String { return self._s[1418]! } + public var ChatSettings_AutoDownloadVoiceMessages: String { return self._s[1419]! } public func CHAT_MESSAGE_DOC(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1418]!, self._r[1418]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1420]!, self._r[1420]!, [_1, _2]) } - public var Passport_Phone_Title: String { return self._s[1419]! } - public var Settings_PhoneNumber: String { return self._s[1420]! } - public var NotificationsSound_Alert: String { return self._s[1421]! } - public var PhotoEditor_CurvesTool: String { return self._s[1423]! } - public var Checkout_PaymentMethod: String { return self._s[1425]! } - public var Contacts_AccessDeniedError: String { return self._s[1426]! } - public var Camera_PhotoMode: String { return self._s[1429]! } - public var Passport_Address_AddUtilityBill: String { return self._s[1430]! } - public var CallSettings_OnMobile: String { return self._s[1431]! } - public var Tour_Text2: String { return self._s[1432]! } + public var Passport_Phone_Title: String { return self._s[1421]! } + public var Settings_PhoneNumber: String { return self._s[1422]! } + public var NotificationsSound_Alert: String { return self._s[1423]! } + public var PhotoEditor_CurvesTool: String { return self._s[1425]! } + public var Checkout_PaymentMethod: String { return self._s[1427]! } + public var Contacts_AccessDeniedError: String { return self._s[1428]! } + public var Camera_PhotoMode: String { return self._s[1431]! } + public var Passport_Address_AddUtilityBill: String { return self._s[1432]! } + public var CallSettings_OnMobile: String { return self._s[1433]! } + public var Tour_Text2: String { return self._s[1434]! } public func MESSAGE_STICKER_SEPARATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1434]!, self._r[1434]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1436]!, self._r[1436]!, [_1, _2]) } - public var DialogList_EncryptionProcessing: String { return self._s[1435]! } - public var Permissions_Skip: String { return self._s[1436]! } - public var SecretImage_Title: String { return self._s[1437]! } - public var Watch_MessageView_Title: String { return self._s[1438]! } - public var AttachmentMenu_Poll: String { return self._s[1439]! } + public var DialogList_EncryptionProcessing: String { return self._s[1437]! } + public var Permissions_Skip: String { return self._s[1438]! } + public var SecretImage_Title: String { return self._s[1439]! } + public var Watch_MessageView_Title: String { return self._s[1440]! } + public var AttachmentMenu_Poll: String { return self._s[1441]! } public func Notification_GroupInviter(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1440]!, self._r[1440]!, [_0]) + return formatWithArgumentRanges(self._s[1442]!, self._r[1442]!, [_0]) } - public var Notification_CallCanceled: String { return self._s[1441]! } - public var Privacy_PaymentsClear_PaymentInfo: String { return self._s[1442]! } + public var Notification_CallCanceled: String { return self._s[1443]! } + public var Privacy_PaymentsClear_PaymentInfo: String { return self._s[1444]! } public func MESSAGE_SCREENSHOT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1443]!, self._r[1443]!, [_1]) + return formatWithArgumentRanges(self._s[1445]!, self._r[1445]!, [_1]) } public func CHAT_JOINED_SEPARATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1444]!, self._r[1444]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1446]!, self._r[1446]!, [_1, _2]) } - public var Settings_ProxyConnecting: String { return self._s[1445]! } - public var Profile_MessageLifetime5s: String { return self._s[1447]! } - public var Username_InvalidCharacters: String { return self._s[1448]! } - public var AutoDownloadSettings_LimitBySize: String { return self._s[1449]! } + public var Settings_ProxyConnecting: String { return self._s[1447]! } + public var Profile_MessageLifetime5s: String { return self._s[1449]! } + public var Username_InvalidCharacters: String { return self._s[1450]! } + public var AutoDownloadSettings_LimitBySize: String { return self._s[1451]! } public func CHAT_MESSAGE_GAME_SEPARATED(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1450]!, self._r[1450]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1452]!, self._r[1452]!, [_1, _2, _3]) } - public var Notification_CreatedChannel: String { return self._s[1452]! } - public var Passcode_AppLockedAlert: String { return self._s[1454]! } - public var Contacts_TopSection: String { return self._s[1455]! } + public var Notification_CreatedChannel: String { return self._s[1454]! } + public var Passcode_AppLockedAlert: String { return self._s[1456]! } + public var Contacts_TopSection: String { return self._s[1457]! } public func Time_MonthOfYear_m6(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1456]!, self._r[1456]!, [_0]) + return formatWithArgumentRanges(self._s[1458]!, self._r[1458]!, [_0]) } public func CHAT_MESSAGE_DOC_SEPARATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1457]!, self._r[1457]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1459]!, self._r[1459]!, [_1, _2]) } - public var ReportPeer_ReasonSpam: String { return self._s[1458]! } - public var UserInfo_TapToCall: String { return self._s[1459]! } - public var Common_Search: String { return self._s[1461]! } - public var AuthSessions_IncompleteAttemptsInfo: String { return self._s[1462]! } - public var Message_InvoiceLabel: String { return self._s[1463]! } - public var Conversation_InputTextPlaceholder: String { return self._s[1464]! } - public var NetworkUsageSettings_MediaImageDataSection: String { return self._s[1465]! } + public var ReportPeer_ReasonSpam: String { return self._s[1460]! } + public var UserInfo_TapToCall: String { return self._s[1461]! } + public var Common_Search: String { return self._s[1463]! } + public var AuthSessions_IncompleteAttemptsInfo: String { return self._s[1464]! } + public var Message_InvoiceLabel: String { return self._s[1465]! } + public var Conversation_InputTextPlaceholder: String { return self._s[1466]! } + public var NetworkUsageSettings_MediaImageDataSection: String { return self._s[1467]! } public func Passport_Address_UploadOneOfScan(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1466]!, self._r[1466]!, [_0]) + return formatWithArgumentRanges(self._s[1468]!, self._r[1468]!, [_0]) } public func MESSAGE_DOC(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1467]!, self._r[1467]!, [_1]) + return formatWithArgumentRanges(self._s[1469]!, self._r[1469]!, [_1]) } - public var Conversation_Info: String { return self._s[1468]! } - public var Login_InfoDeletePhoto: String { return self._s[1469]! } - public var Passport_Language_vi: String { return self._s[1471]! } - public var Conversation_Search: String { return self._s[1472]! } - public var DialogList_DeleteBotConversationConfirmation: String { return self._s[1473]! } + public var Conversation_Info: String { return self._s[1470]! } + public var Login_InfoDeletePhoto: String { return self._s[1471]! } + public var Passport_Language_vi: String { return self._s[1473]! } + public var Conversation_Search: String { return self._s[1474]! } + public var DialogList_DeleteBotConversationConfirmation: String { return self._s[1475]! } public func MESSAGE_AUDIO_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1474]!, self._r[1474]!, [_1]) + return formatWithArgumentRanges(self._s[1476]!, self._r[1476]!, [_1]) } - public var ReportPeer_ReasonPornography: String { return self._s[1475]! } - public var AutoDownloadSettings_PhotosTitle: String { return self._s[1476]! } + public var ReportPeer_ReasonPornography: String { return self._s[1477]! } + public var AutoDownloadSettings_PhotosTitle: String { return self._s[1478]! } public func CHAT_MESSAGE_PHOTO_SEPARATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1477]!, self._r[1477]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1479]!, self._r[1479]!, [_1, _2]) } - public var Conversation_SendMessageErrorGroupRestricted: String { return self._s[1478]! } - public var Map_LiveLocationGroupDescription: String { return self._s[1479]! } - public var Channel_Setup_TypeHeader: String { return self._s[1480]! } - public var AuthSessions_LoggedIn: String { return self._s[1481]! } - public var Login_SmsRequestState3: String { return self._s[1482]! } - public var Passport_Address_EditUtilityBill: String { return self._s[1483]! } - public var Appearance_ReduceMotionInfo: String { return self._s[1484]! } - public var Channel_Edit_LinkItem: String { return self._s[1485]! } - public var Privacy_Calls_P2PNever: String { return self._s[1486]! } - public var Conversation_AddToReadingList: String { return self._s[1488]! } + public var Conversation_SendMessageErrorGroupRestricted: String { return self._s[1480]! } + public var Map_LiveLocationGroupDescription: String { return self._s[1481]! } + public var Channel_Setup_TypeHeader: String { return self._s[1482]! } + public var AuthSessions_LoggedIn: String { return self._s[1483]! } + public var Login_SmsRequestState3: String { return self._s[1484]! } + public var Passport_Address_EditUtilityBill: String { return self._s[1485]! } + public var Appearance_ReduceMotionInfo: String { return self._s[1486]! } + public var Channel_Edit_LinkItem: String { return self._s[1487]! } + public var Privacy_Calls_P2PNever: String { return self._s[1488]! } + public var Conversation_AddToReadingList: String { return self._s[1490]! } public func MESSAGE_GEO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1489]!, self._r[1489]!, [_1]) + return formatWithArgumentRanges(self._s[1491]!, self._r[1491]!, [_1]) } - public var Message_Animation: String { return self._s[1490]! } - public var Conversation_DefaultRestrictedMedia: String { return self._s[1491]! } - public var Map_Unknown: String { return self._s[1492]! } - public var Call_StatusRequesting: String { return self._s[1493]! } + public var Message_Animation: String { return self._s[1492]! } + public var Conversation_DefaultRestrictedMedia: String { return self._s[1493]! } + public var Map_Unknown: String { return self._s[1494]! } + public var Call_StatusRequesting: String { return self._s[1495]! } public func Passport_FieldOneOf_Or(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1494]!, self._r[1494]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1496]!, self._r[1496]!, [_1, _2]) } - public var Conversation_SecretChatContextBotAlert: String { return self._s[1495]! } - public var SocksProxySetup_ProxyStatusChecking: String { return self._s[1496]! } + public var Conversation_SecretChatContextBotAlert: String { return self._s[1497]! } + public var SocksProxySetup_ProxyStatusChecking: String { return self._s[1498]! } public func MESSAGE_PHOTO_SECRET(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1497]!, self._r[1497]!, [_1]) + return formatWithArgumentRanges(self._s[1499]!, self._r[1499]!, [_1]) } public func Notification_PinnedLocationMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1498]!, self._r[1498]!, [_0]) + return formatWithArgumentRanges(self._s[1500]!, self._r[1500]!, [_0]) } - public var Update_Skip: String { return self._s[1499]! } - public var Group_Username_RemoveExistingUsernamesInfo: String { return self._s[1500]! } - public var Message_PinnedPollMessage: String { return self._s[1501]! } - public var BlockedUsers_Title: String { return self._s[1502]! } - public var Weekday_Monday: String { return self._s[1503]! } - public var Username_CheckingUsername: String { return self._s[1504]! } - public var NotificationsSound_Bell: String { return self._s[1505]! } - public var Conversation_SendMessageErrorFlood: String { return self._s[1506]! } - public var ChannelMembers_ChannelAdminsTitle: String { return self._s[1507]! } - public var ChatSettings_Groups: String { return self._s[1508]! } - public var Your_card_was_declined: String { return self._s[1509]! } - public var TwoStepAuth_EnterPasswordHelp: String { return self._s[1511]! } - public var ChatList_Unmute: String { return self._s[1512]! } + public var Update_Skip: String { return self._s[1501]! } + public var Group_Username_RemoveExistingUsernamesInfo: String { return self._s[1502]! } + public var Message_PinnedPollMessage: String { return self._s[1503]! } + public var BlockedUsers_Title: String { return self._s[1504]! } + public var Weekday_Monday: String { return self._s[1505]! } + public var Username_CheckingUsername: String { return self._s[1506]! } + public var NotificationsSound_Bell: String { return self._s[1507]! } + public var Conversation_SendMessageErrorFlood: String { return self._s[1508]! } + public var ChannelMembers_ChannelAdminsTitle: String { return self._s[1509]! } + public var ChatSettings_Groups: String { return self._s[1510]! } + public var Your_card_was_declined: String { return self._s[1511]! } + public var TwoStepAuth_EnterPasswordHelp: String { return self._s[1513]! } + public var ChatList_Unmute: String { return self._s[1514]! } public func PINNED_GEO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1513]!, self._r[1513]!, [_1]) + return formatWithArgumentRanges(self._s[1515]!, self._r[1515]!, [_1]) } - public var PhotoEditor_CurvesAll: String { return self._s[1514]! } - public var Weekday_ShortTuesday: String { return self._s[1515]! } - public var DialogList_Read: String { return self._s[1516]! } + public var PhotoEditor_CurvesAll: String { return self._s[1516]! } + public var Weekday_ShortTuesday: String { return self._s[1517]! } + public var DialogList_Read: String { return self._s[1518]! } public func PINNED_TEXT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1517]!, self._r[1517]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1519]!, self._r[1519]!, [_1, _2]) } - public var ChannelMembers_WhoCanAddMembers_AllMembers: String { return self._s[1518]! } - public var Passport_Identity_Gender: String { return self._s[1519]! } + public var ChannelMembers_WhoCanAddMembers_AllMembers: String { return self._s[1520]! } + public var Passport_Identity_Gender: String { return self._s[1521]! } public func Target_ShareGameConfirmationPrivate(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1520]!, self._r[1520]!, [_0]) + return formatWithArgumentRanges(self._s[1522]!, self._r[1522]!, [_0]) } - public var Target_SelectGroup: String { return self._s[1521]! } + public var Target_SelectGroup: String { return self._s[1523]! } public func DialogList_EncryptedChatStartedIncoming(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1523]!, self._r[1523]!, [_0]) + return formatWithArgumentRanges(self._s[1525]!, self._r[1525]!, [_0]) } - public var Passport_Language_en: String { return self._s[1524]! } - public var Channel_Username_CreatePublicLinkHelp: String { return self._s[1525]! } - public var Login_CancelPhoneVerificationContinue: String { return self._s[1526]! } + public var Passport_Language_en: String { return self._s[1526]! } + public var Channel_Username_CreatePublicLinkHelp: String { return self._s[1527]! } + public var Login_CancelPhoneVerificationContinue: String { return self._s[1528]! } public func AUTH_REGION(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1527]!, self._r[1527]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1529]!, self._r[1529]!, [_1, _2]) } - public var Checkout_NewCard_PaymentCard: String { return self._s[1529]! } - public var Login_InfoHelp: String { return self._s[1530]! } - public var Contacts_PermissionsSuppressWarningTitle: String { return self._s[1531]! } - public var SocksProxySetup_AddProxy: String { return self._s[1534]! } - public var CreatePoll_Title: String { return self._s[1535]! } - public var PasscodeSettings_SimplePasscodeHelp: String { return self._s[1536]! } - public var UserInfo_GroupsInCommon: String { return self._s[1537]! } - public var Call_AudioRouteHide: String { return self._s[1538]! } - public var ContactInfo_PhoneLabelMobile: String { return self._s[1540]! } - public var TextFormat_Bold: String { return self._s[1541]! } - public var FastTwoStepSetup_EmailSection: String { return self._s[1542]! } - public var Notifications_Title: String { return self._s[1543]! } - public var Group_Username_InvalidTooShort: String { return self._s[1544]! } - public var Channel_ErrorAddTooMuch: String { return self._s[1545]! } + public var Checkout_NewCard_PaymentCard: String { return self._s[1531]! } + public var Login_InfoHelp: String { return self._s[1532]! } + public var Contacts_PermissionsSuppressWarningTitle: String { return self._s[1533]! } + public var SocksProxySetup_AddProxy: String { return self._s[1536]! } + public var CreatePoll_Title: String { return self._s[1537]! } + public var PasscodeSettings_SimplePasscodeHelp: String { return self._s[1538]! } + public var UserInfo_GroupsInCommon: String { return self._s[1539]! } + public var Call_AudioRouteHide: String { return self._s[1540]! } + public var ContactInfo_PhoneLabelMobile: String { return self._s[1542]! } + public var TextFormat_Bold: String { return self._s[1543]! } + public var FastTwoStepSetup_EmailSection: String { return self._s[1544]! } + public var Notifications_Title: String { return self._s[1545]! } + public var Group_Username_InvalidTooShort: String { return self._s[1546]! } + public var Channel_ErrorAddTooMuch: String { return self._s[1547]! } public func DialogList_MultipleTypingSuffix(_ _0: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1546]!, self._r[1546]!, ["\(_0)"]) + return formatWithArgumentRanges(self._s[1548]!, self._r[1548]!, ["\(_0)"]) } - public var Stickers_SuggestAdded: String { return self._s[1548]! } - public var Login_CountryCode: String { return self._s[1549]! } - public var Map_GetDirections: String { return self._s[1550]! } - public var Login_PhoneFloodError: String { return self._s[1551]! } + public var Stickers_SuggestAdded: String { return self._s[1550]! } + public var Login_CountryCode: String { return self._s[1551]! } + public var Map_GetDirections: String { return self._s[1552]! } + public var Login_PhoneFloodError: String { return self._s[1553]! } public func Time_MonthOfYear_m3(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1552]!, self._r[1552]!, [_0]) + return formatWithArgumentRanges(self._s[1554]!, self._r[1554]!, [_0]) } - public var Settings_SetUsername: String { return self._s[1554]! } + public var Settings_SetUsername: String { return self._s[1556]! } public func CHAT_MESSAGE_NOTEXT_SEPARATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1555]!, self._r[1555]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1557]!, self._r[1557]!, [_1, _2]) } - public var Notification_GroupInviterSelf: String { return self._s[1556]! } - public var InstantPage_TapToOpenLink: String { return self._s[1557]! } + public var Notification_GroupInviterSelf: String { return self._s[1558]! } + public var InstantPage_TapToOpenLink: String { return self._s[1559]! } public func Notification_ChannelInviter(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1558]!, self._r[1558]!, [_0]) + return formatWithArgumentRanges(self._s[1560]!, self._r[1560]!, [_0]) } - public var Watch_Suggestion_TalkLater: String { return self._s[1559]! } - public var SecretChat_Title: String { return self._s[1560]! } - public var Group_UpgradeNoticeText1: String { return self._s[1561]! } - public var AuthSessions_Title: String { return self._s[1562]! } - public var PhotoEditor_CropAuto: String { return self._s[1563]! } - public var Channel_About_Title: String { return self._s[1564]! } - public var FastTwoStepSetup_EmailHelp: String { return self._s[1565]! } + public var Watch_Suggestion_TalkLater: String { return self._s[1561]! } + public var SecretChat_Title: String { return self._s[1562]! } + public var Group_UpgradeNoticeText1: String { return self._s[1563]! } + public var AuthSessions_Title: String { return self._s[1564]! } + public var PhotoEditor_CropAuto: String { return self._s[1565]! } + public var Channel_About_Title: String { return self._s[1566]! } + public var FastTwoStepSetup_EmailHelp: String { return self._s[1567]! } public func CHAT_ADD_YOU(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1566]!, self._r[1566]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1568]!, self._r[1568]!, [_1, _2]) } public func Conversation_Bytes(_ _0: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1567]!, self._r[1567]!, ["\(_0)"]) + return formatWithArgumentRanges(self._s[1569]!, self._r[1569]!, ["\(_0)"]) } - public var Conversation_PinMessageAlert_OnlyPin: String { return self._s[1570]! } - public var Group_Setup_HistoryVisibleHelp: String { return self._s[1571]! } + public var Conversation_PinMessageAlert_OnlyPin: String { return self._s[1572]! } + public var Group_Setup_HistoryVisibleHelp: String { return self._s[1573]! } public func SharedMedia_SearchNoResultsDescription(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1573]!, self._r[1573]!, [_0]) + return formatWithArgumentRanges(self._s[1575]!, self._r[1575]!, [_0]) } public func TwoStepAuth_RecoveryEmailUnavailable(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1574]!, self._r[1574]!, [_0]) + return formatWithArgumentRanges(self._s[1576]!, self._r[1576]!, [_0]) } - public var Privacy_PaymentsClearInfoHelp: String { return self._s[1575]! } - public var Presence_online: String { return self._s[1577]! } - public var PasscodeSettings_Title: String { return self._s[1578]! } - public var Passport_Identity_ExpiryDatePlaceholder: String { return self._s[1579]! } - public var Web_OpenExternal: String { return self._s[1580]! } + public var Privacy_PaymentsClearInfoHelp: String { return self._s[1577]! } + public var Presence_online: String { return self._s[1579]! } + public var PasscodeSettings_Title: String { return self._s[1580]! } + public var Passport_Identity_ExpiryDatePlaceholder: String { return self._s[1581]! } + public var Web_OpenExternal: String { return self._s[1582]! } public func AutoNightTheme_AutomaticHelp(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1582]!, self._r[1582]!, [_0]) + return formatWithArgumentRanges(self._s[1584]!, self._r[1584]!, [_0]) } - public var FastTwoStepSetup_PasswordConfirmationPlaceholder: String { return self._s[1583]! } - public var Map_YouAreHere: String { return self._s[1584]! } + public var FastTwoStepSetup_PasswordConfirmationPlaceholder: String { return self._s[1585]! } + public var Map_YouAreHere: String { return self._s[1586]! } public func MESSAGE_GIF(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1585]!, self._r[1585]!, [_1]) + return formatWithArgumentRanges(self._s[1587]!, self._r[1587]!, [_1]) } public func AuthSessions_Message(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1586]!, self._r[1586]!, [_0]) + return formatWithArgumentRanges(self._s[1588]!, self._r[1588]!, [_0]) } - public var PrivacyLastSeenSettings_AlwaysShareWith: String { return self._s[1587]! } - public var Target_InviteToGroupErrorAlreadyInvited: String { return self._s[1588]! } + public var PrivacyLastSeenSettings_AlwaysShareWith: String { return self._s[1589]! } + public var Target_InviteToGroupErrorAlreadyInvited: String { return self._s[1590]! } public func AuthSessions_AppUnofficial(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1589]!, self._r[1589]!, [_0]) + return formatWithArgumentRanges(self._s[1591]!, self._r[1591]!, [_0]) } public func CHANNEL_MESSAGE_GEO_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1590]!, self._r[1590]!, [_1]) + return formatWithArgumentRanges(self._s[1592]!, self._r[1592]!, [_1]) } - public var SocksProxySetup_Username: String { return self._s[1591]! } + public var SocksProxySetup_Username: String { return self._s[1593]! } public func DialogList_LiveLocationSharingTo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1592]!, self._r[1592]!, [_0]) - } - public var Bot_Start: String { return self._s[1593]! } - public func Channel_AdminLog_EmptyFilterQueryText(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[1594]!, self._r[1594]!, [_0]) } + public var Bot_Start: String { return self._s[1595]! } + public func Channel_AdminLog_EmptyFilterQueryText(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1596]!, self._r[1596]!, [_0]) + } public func Channel_AdminLog_MessagePinned(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1595]!, self._r[1595]!, [_0]) + return formatWithArgumentRanges(self._s[1597]!, self._r[1597]!, [_0]) } - public var Contacts_SortByPresence: String { return self._s[1596]! } + public var Contacts_SortByPresence: String { return self._s[1598]! } public func PINNED_GEOLIVE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1598]!, self._r[1598]!, [_1]) + return formatWithArgumentRanges(self._s[1600]!, self._r[1600]!, [_1]) } - public var Conversation_DiscardVoiceMessageTitle: String { return self._s[1599]! } + public var Conversation_DiscardVoiceMessageTitle: String { return self._s[1601]! } public func PrivacySettings_LastSeenContactsMinus(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1600]!, self._r[1600]!, [_0]) + return formatWithArgumentRanges(self._s[1602]!, self._r[1602]!, [_0]) } public func MESSAGE_DOC_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1601]!, self._r[1601]!, [_1]) + return formatWithArgumentRanges(self._s[1603]!, self._r[1603]!, [_1]) } - public var Passport_Email_EnterOtherEmail: String { return self._s[1602]! } - public var Login_InfoAvatarPhoto: String { return self._s[1603]! } - public var Privacy_PaymentsClear_ShippingInfo: String { return self._s[1604]! } - public var Tour_Title4: String { return self._s[1605]! } - public var Passport_Identity_Translation: String { return self._s[1606]! } - public var Login_TermsOfServiceLabel: String { return self._s[1608]! } - public var Passport_Language_it: String { return self._s[1609]! } - public var KeyCommand_JumpToNextUnreadChat: String { return self._s[1610]! } - public var Passport_Identity_SelfieHelp: String { return self._s[1611]! } - public var Conversation_ClearAll: String { return self._s[1613]! } + public var Passport_Email_EnterOtherEmail: String { return self._s[1604]! } + public var Login_InfoAvatarPhoto: String { return self._s[1605]! } + public var Privacy_PaymentsClear_ShippingInfo: String { return self._s[1606]! } + public var Tour_Title4: String { return self._s[1607]! } + public var Passport_Identity_Translation: String { return self._s[1608]! } + public var Login_TermsOfServiceLabel: String { return self._s[1610]! } + public var Passport_Language_it: String { return self._s[1611]! } + public var KeyCommand_JumpToNextUnreadChat: String { return self._s[1612]! } + public var Passport_Identity_SelfieHelp: String { return self._s[1613]! } + public var Conversation_ClearAll: String { return self._s[1615]! } public func MESSAGE_PHOTOS(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1615]!, self._r[1615]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1617]!, self._r[1617]!, [_1, _2]) } - public var TwoStepAuth_FloodError: String { return self._s[1616]! } - public var Paint_Delete: String { return self._s[1617]! } + public var TwoStepAuth_FloodError: String { return self._s[1618]! } + public var Paint_Delete: String { return self._s[1619]! } public func Passport_AcceptHelp(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1618]!, self._r[1618]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1620]!, self._r[1620]!, [_1, _2]) } - public var Message_PinnedAudioMessage: String { return self._s[1619]! } + public var Message_PinnedAudioMessage: String { return self._s[1621]! } public func Watch_Time_ShortTodayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1620]!, self._r[1620]!, [_0]) + return formatWithArgumentRanges(self._s[1622]!, self._r[1622]!, [_0]) } - public var Notification_Mute1hMin: String { return self._s[1621]! } - public var Notifications_GroupNotificationsSound: String { return self._s[1622]! } - public var SocksProxySetup_ShareProxyList: String { return self._s[1623]! } - public var Conversation_MessageEditedLabel: String { return self._s[1624]! } - public var Notification_Exceptions_AlwaysOff: String { return self._s[1625]! } + public var Notification_Mute1hMin: String { return self._s[1623]! } + public var Notifications_GroupNotificationsSound: String { return self._s[1624]! } + public var SocksProxySetup_ShareProxyList: String { return self._s[1625]! } + public var Conversation_MessageEditedLabel: String { return self._s[1626]! } + public var Notification_Exceptions_AlwaysOff: String { return self._s[1627]! } public func Channel_AdminLog_MessageAdmin(_ _0: String, _ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1626]!, self._r[1626]!, [_0, _1, _2]) + return formatWithArgumentRanges(self._s[1628]!, self._r[1628]!, [_0, _1, _2]) } - public var NetworkUsageSettings_ResetStats: String { return self._s[1627]! } - public var AccessDenied_LocationTracking: String { return self._s[1628]! } - public var Month_GenOctober: String { return self._s[1629]! } - public var GroupInfo_InviteLink_RevokeAlert_Revoke: String { return self._s[1630]! } + public var NetworkUsageSettings_ResetStats: String { return self._s[1629]! } + public var AccessDenied_LocationTracking: String { return self._s[1630]! } + public var Month_GenOctober: String { return self._s[1631]! } + public var GroupInfo_InviteLink_RevokeAlert_Revoke: String { return self._s[1632]! } public func CHAT_MESSAGE_INVOICE_SEPARATED(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1631]!, self._r[1631]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1633]!, self._r[1633]!, [_1, _2, _3]) } - public var EnterPasscode_EnterPasscode: String { return self._s[1633]! } - public var MediaPicker_TimerTooltip: String { return self._s[1634]! } - public var SharedMedia_TitleAll: String { return self._s[1635]! } - public var Conversation_RestrictedMedia: String { return self._s[1637]! } - public var AccessDenied_PhotosRestricted: String { return self._s[1638]! } - public var ChangePhoneNumberCode_Called: String { return self._s[1640]! } + public var EnterPasscode_EnterPasscode: String { return self._s[1635]! } + public var MediaPicker_TimerTooltip: String { return self._s[1636]! } + public var SharedMedia_TitleAll: String { return self._s[1637]! } + public var Conversation_RestrictedMedia: String { return self._s[1639]! } + public var AccessDenied_PhotosRestricted: String { return self._s[1640]! } + public var ChangePhoneNumberCode_Called: String { return self._s[1642]! } public func Notification_PinnedDocumentMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1641]!, self._r[1641]!, [_0]) + return formatWithArgumentRanges(self._s[1643]!, self._r[1643]!, [_0]) } - public var Conversation_SavedMessages: String { return self._s[1644]! } - public var Your_cards_expiration_month_is_invalid: String { return self._s[1646]! } - public var FastTwoStepSetup_PasswordPlaceholder: String { return self._s[1647]! } + public var Conversation_SavedMessages: String { return self._s[1646]! } + public var Your_cards_expiration_month_is_invalid: String { return self._s[1648]! } + public var FastTwoStepSetup_PasswordPlaceholder: String { return self._s[1649]! } public func Target_ShareGameConfirmationGroup(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1649]!, self._r[1649]!, [_0]) + return formatWithArgumentRanges(self._s[1651]!, self._r[1651]!, [_0]) } - public var ReportPeer_AlertSuccess: String { return self._s[1650]! } - public var PhotoEditor_CropAspectRatioOriginal: String { return self._s[1651]! } + public var ReportPeer_AlertSuccess: String { return self._s[1652]! } + public var PhotoEditor_CropAspectRatioOriginal: String { return self._s[1653]! } public func MESSAGE_PHOTO_SECRET_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1652]!, self._r[1652]!, [_1]) + return formatWithArgumentRanges(self._s[1654]!, self._r[1654]!, [_1]) } public func InstantPage_RelatedArticleAuthorAndDateTitle(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1653]!, self._r[1653]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1655]!, self._r[1655]!, [_1, _2]) } - public var Checkout_PasswordEntry_Title: String { return self._s[1654]! } - public var PhotoEditor_FadeTool: String { return self._s[1655]! } - public var Privacy_ContactsReset: String { return self._s[1656]! } + public var Checkout_PasswordEntry_Title: String { return self._s[1656]! } + public var PhotoEditor_FadeTool: String { return self._s[1657]! } + public var Privacy_ContactsReset: String { return self._s[1658]! } public func Channel_AdminLog_MessageRestrictedUntil(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1658]!, self._r[1658]!, [_0]) + return formatWithArgumentRanges(self._s[1660]!, self._r[1660]!, [_0]) } - public var Message_PinnedVideoMessage: String { return self._s[1659]! } - public var ChatList_Mute: String { return self._s[1660]! } - public var Permissions_CellularDataText_v0: String { return self._s[1661]! } - public var ShareMenu_SelectChats: String { return self._s[1663]! } - public var MusicPlayer_VoiceNote: String { return self._s[1664]! } - public var Conversation_RestrictedText: String { return self._s[1665]! } - public var TwoStepAuth_DisableSuccess: String { return self._s[1666]! } - public var Cache_Videos: String { return self._s[1667]! } - public var FeatureDisabled_Oops: String { return self._s[1669]! } - public var Passport_Address_PostcodePlaceholder: String { return self._s[1670]! } + public var Message_PinnedVideoMessage: String { return self._s[1661]! } + public var ChatList_Mute: String { return self._s[1662]! } + public var Permissions_CellularDataText_v0: String { return self._s[1663]! } + public var ShareMenu_SelectChats: String { return self._s[1665]! } + public var MusicPlayer_VoiceNote: String { return self._s[1666]! } + public var Conversation_RestrictedText: String { return self._s[1667]! } + public var TwoStepAuth_DisableSuccess: String { return self._s[1668]! } + public var Cache_Videos: String { return self._s[1669]! } + public var FeatureDisabled_Oops: String { return self._s[1671]! } + public var Passport_Address_PostcodePlaceholder: String { return self._s[1672]! } public func CHAT_MESSAGE_VIDEO(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1671]!, self._r[1671]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1673]!, self._r[1673]!, [_1, _2]) } - public var BackgroundPreview_Perspective: String { return self._s[1672]! } - public var Stickers_GroupStickersHelp: String { return self._s[1673]! } - public var GroupPermission_NoSendPolls: String { return self._s[1674]! } - public var Message_VideoExpired: String { return self._s[1676]! } - public var GroupInfo_GroupHistoryVisible: String { return self._s[1677]! } - public var Notifications_Badge: String { return self._s[1678]! } - public var CreatePoll_OptionPlaceholder: String { return self._s[1679]! } - public var Username_InvalidTooShort: String { return self._s[1680]! } - public var EnterPasscode_EnterNewPasscodeChange: String { return self._s[1681]! } + public var BackgroundPreview_Perspective: String { return self._s[1674]! } + public var Stickers_GroupStickersHelp: String { return self._s[1675]! } + public var GroupPermission_NoSendPolls: String { return self._s[1676]! } + public var Message_VideoExpired: String { return self._s[1678]! } + public var GroupInfo_GroupHistoryVisible: String { return self._s[1679]! } + public var Notifications_Badge: String { return self._s[1680]! } + public var CreatePoll_OptionPlaceholder: String { return self._s[1681]! } + public var Username_InvalidTooShort: String { return self._s[1682]! } + public var EnterPasscode_EnterNewPasscodeChange: String { return self._s[1683]! } + public var Channel_AdminLog_PinMessages: String { return self._s[1684]! } public func Notification_MessageLifetimeRemoved(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1682]!, self._r[1682]!, [_1]) + return formatWithArgumentRanges(self._s[1685]!, self._r[1685]!, [_1]) } - public var Permissions_SiriAllowInSettings_v0: String { return self._s[1683]! } - public var Conversation_DefaultRestrictedText: String { return self._s[1684]! } - public var SharedMedia_CategoryDocs: String { return self._s[1687]! } + public var Permissions_SiriAllowInSettings_v0: String { return self._s[1686]! } + public var Conversation_DefaultRestrictedText: String { return self._s[1687]! } + public var SharedMedia_CategoryDocs: String { return self._s[1690]! } public func CHAT_MESSAGE_STICKER_SEPARATED(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1688]!, self._r[1688]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1691]!, self._r[1691]!, [_1, _2, _3]) } public func Notification_MessageLifetimeChangedOutgoing(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1690]!, self._r[1690]!, [_1]) + return formatWithArgumentRanges(self._s[1693]!, self._r[1693]!, [_1]) } - public var CheckoutInfo_ErrorShippingNotAvailable: String { return self._s[1691]! } + public var CheckoutInfo_ErrorShippingNotAvailable: String { return self._s[1694]! } public func Time_MonthOfYear_m12(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1692]!, self._r[1692]!, [_0]) + return formatWithArgumentRanges(self._s[1695]!, self._r[1695]!, [_0]) } - public var ChatSettings_PrivateChats: String { return self._s[1693]! } - public var Channel_UpdatePhotoItem: String { return self._s[1694]! } - public var GroupInfo_LeftStatus: String { return self._s[1695]! } - public var Watch_MessageView_Forward: String { return self._s[1697]! } - public var ReportPeer_ReasonChildAbuse: String { return self._s[1698]! } - public var Cache_ClearEmpty: String { return self._s[1700]! } + public var ChatSettings_PrivateChats: String { return self._s[1696]! } + public var Channel_UpdatePhotoItem: String { return self._s[1697]! } + public var GroupInfo_LeftStatus: String { return self._s[1698]! } + public var Watch_MessageView_Forward: String { return self._s[1700]! } + public var ReportPeer_ReasonChildAbuse: String { return self._s[1701]! } + public var Cache_ClearEmpty: String { return self._s[1703]! } public func MESSAGE_VIDEO_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1701]!, self._r[1701]!, [_1]) + return formatWithArgumentRanges(self._s[1704]!, self._r[1704]!, [_1]) } - public var Localization_LanguageName: String { return self._s[1702]! } - public var WebSearch_GIFs: String { return self._s[1703]! } - public var Notifications_DisplayNamesOnLockScreenInfoWithLink: String { return self._s[1704]! } - public var Username_InvalidStartsWithNumber: String { return self._s[1705]! } - public var Common_Back: String { return self._s[1706]! } - public var Passport_Identity_DateOfBirthPlaceholder: String { return self._s[1707]! } + public var Localization_LanguageName: String { return self._s[1705]! } + public var WebSearch_GIFs: String { return self._s[1706]! } + public var Notifications_DisplayNamesOnLockScreenInfoWithLink: String { return self._s[1707]! } + public var Username_InvalidStartsWithNumber: String { return self._s[1708]! } + public var Common_Back: String { return self._s[1709]! } + public var Passport_Identity_DateOfBirthPlaceholder: String { return self._s[1710]! } public func CHANNEL_MESSAGE_AUDIO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1708]!, self._r[1708]!, [_1]) + return formatWithArgumentRanges(self._s[1711]!, self._r[1711]!, [_1]) } public func CHANNEL_MESSAGE_ROUND(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1709]!, self._r[1709]!, [_1]) + return formatWithArgumentRanges(self._s[1712]!, self._r[1712]!, [_1]) } - public var Passport_Email_Help: String { return self._s[1710]! } - public var Watch_Conversation_Reply: String { return self._s[1711]! } - public var Conversation_EditingMessageMediaChange: String { return self._s[1713]! } - public var Passport_Identity_IssueDatePlaceholder: String { return self._s[1714]! } - public var Channel_BanUser_Unban: String { return self._s[1716]! } - public var Channel_EditAdmin_PermissionPostMessages: String { return self._s[1717]! } - public var Group_Username_CreatePublicLinkHelp: String { return self._s[1718]! } - public var TwoStepAuth_ConfirmEmailCodePlaceholder: String { return self._s[1720]! } - public var Passport_Identity_Name: String { return self._s[1721]! } - public var GroupRemoved_ViewUserInfo: String { return self._s[1722]! } - public var Conversation_BlockUser: String { return self._s[1723]! } - public var Month_GenJanuary: String { return self._s[1724]! } - public var ChatSettings_TextSize: String { return self._s[1725]! } - public var Notification_PassportValuePhone: String { return self._s[1726]! } - public var Passport_Language_ne: String { return self._s[1727]! } - public var Notification_CallBack: String { return self._s[1728]! } - public var TwoStepAuth_EmailHelp: String { return self._s[1729]! } + public var Passport_Email_Help: String { return self._s[1713]! } + public var Watch_Conversation_Reply: String { return self._s[1714]! } + public var Conversation_EditingMessageMediaChange: String { return self._s[1716]! } + public var Passport_Identity_IssueDatePlaceholder: String { return self._s[1717]! } + public var Channel_BanUser_Unban: String { return self._s[1719]! } + public var Channel_EditAdmin_PermissionPostMessages: String { return self._s[1720]! } + public var Group_Username_CreatePublicLinkHelp: String { return self._s[1721]! } + public var TwoStepAuth_ConfirmEmailCodePlaceholder: String { return self._s[1723]! } + public var Passport_Identity_Name: String { return self._s[1724]! } + public var GroupRemoved_ViewUserInfo: String { return self._s[1725]! } + public var Conversation_BlockUser: String { return self._s[1726]! } + public var Month_GenJanuary: String { return self._s[1727]! } + public var ChatSettings_TextSize: String { return self._s[1728]! } + public var Notification_PassportValuePhone: String { return self._s[1729]! } + public var Passport_Language_ne: String { return self._s[1730]! } + public var Notification_CallBack: String { return self._s[1731]! } + public var TwoStepAuth_EmailHelp: String { return self._s[1732]! } public func Time_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1730]!, self._r[1730]!, [_0]) + return formatWithArgumentRanges(self._s[1733]!, self._r[1733]!, [_0]) } - public var Channel_Info_Management: String { return self._s[1731]! } - public var Passport_FieldIdentityUploadHelp: String { return self._s[1732]! } - public var Stickers_FrequentlyUsed: String { return self._s[1733]! } - public var Channel_BanUser_PermissionSendMessages: String { return self._s[1734]! } - public var Passport_Address_OneOfTypeUtilityBill: String { return self._s[1736]! } - public var Passport_Address_EditResidentialAddress: String { return self._s[1737]! } - public var PrivacyPolicy_DeclineTitle: String { return self._s[1738]! } - public var CreatePoll_TextHeader: String { return self._s[1739]! } + public var Channel_Info_Management: String { return self._s[1734]! } + public var Passport_FieldIdentityUploadHelp: String { return self._s[1735]! } + public var Stickers_FrequentlyUsed: String { return self._s[1736]! } + public var Channel_BanUser_PermissionSendMessages: String { return self._s[1737]! } + public var Passport_Address_OneOfTypeUtilityBill: String { return self._s[1739]! } + public var Passport_Address_EditResidentialAddress: String { return self._s[1740]! } + public var PrivacyPolicy_DeclineTitle: String { return self._s[1741]! } + public var CreatePoll_TextHeader: String { return self._s[1742]! } public func Checkout_SavePasswordTimeoutAndTouchId(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1740]!, self._r[1740]!, [_0]) - } - public var PhotoEditor_QualityMedium: String { return self._s[1741]! } - public var InfoPlist_NSMicrophoneUsageDescription: String { return self._s[1742]! } - public func Conversation_RestrictedInlineTimed(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[1743]!, self._r[1743]!, [_0]) } - public var Conversation_StatusKickedFromChannel: String { return self._s[1744]! } - public var CheckoutInfo_ReceiverInfoName: String { return self._s[1745]! } - public var Group_ErrorSendRestrictedStickers: String { return self._s[1746]! } - public var Conversation_LinkDialogOpen: String { return self._s[1748]! } - public var Settings_Username: String { return self._s[1749]! } - public func PINNED_GEOLIVE_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1751]!, self._r[1751]!, [_1]) + public var PhotoEditor_QualityMedium: String { return self._s[1744]! } + public var InfoPlist_NSMicrophoneUsageDescription: String { return self._s[1745]! } + public func Conversation_RestrictedInlineTimed(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1746]!, self._r[1746]!, [_0]) } - public var Wallpaper_Wallpaper: String { return self._s[1752]! } - public func PINNED_GIF(_ _1: String) -> (String, [(Int, NSRange)]) { + public var Conversation_StatusKickedFromChannel: String { return self._s[1747]! } + public var CheckoutInfo_ReceiverInfoName: String { return self._s[1748]! } + public var Group_ErrorSendRestrictedStickers: String { return self._s[1749]! } + public var Conversation_LinkDialogOpen: String { return self._s[1751]! } + public var Settings_Username: String { return self._s[1752]! } + public func PINNED_GEOLIVE_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[1754]!, self._r[1754]!, [_1]) } - public var SocksProxySetup_UseProxy: String { return self._s[1755]! } - public var UserInfo_ShareMyContactInfo: String { return self._s[1756]! } - public var MessageTimer_Forever: String { return self._s[1757]! } - public var Privacy_Calls_WhoCanCallMe: String { return self._s[1758]! } - public var PhotoEditor_DiscardChanges: String { return self._s[1759]! } - public var AuthSessions_TerminateOtherSessionsHelp: String { return self._s[1760]! } - public var Passport_Language_da: String { return self._s[1761]! } - public var SocksProxySetup_PortPlaceholder: String { return self._s[1762]! } - public func SecretGIF_NotViewedYet(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1763]!, self._r[1763]!, [_0]) + public var Wallpaper_Wallpaper: String { return self._s[1755]! } + public func PINNED_GIF(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1757]!, self._r[1757]!, [_1]) } - public var Passport_Address_EditPassportRegistration: String { return self._s[1764]! } - public func Channel_AdminLog_MessageChangedGroupAbout(_ _0: String) -> (String, [(Int, NSRange)]) { + public var SocksProxySetup_UseProxy: String { return self._s[1758]! } + public var UserInfo_ShareMyContactInfo: String { return self._s[1759]! } + public var MessageTimer_Forever: String { return self._s[1760]! } + public var Privacy_Calls_WhoCanCallMe: String { return self._s[1761]! } + public var PhotoEditor_DiscardChanges: String { return self._s[1762]! } + public var AuthSessions_TerminateOtherSessionsHelp: String { return self._s[1763]! } + public var Passport_Language_da: String { return self._s[1764]! } + public var SocksProxySetup_PortPlaceholder: String { return self._s[1765]! } + public func SecretGIF_NotViewedYet(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[1766]!, self._r[1766]!, [_0]) } - public var Passport_Identity_ResidenceCountryPlaceholder: String { return self._s[1768]! } - public var Conversation_SearchByName_Prefix: String { return self._s[1769]! } + public var Passport_Address_EditPassportRegistration: String { return self._s[1767]! } + public func Channel_AdminLog_MessageChangedGroupAbout(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1769]!, self._r[1769]!, [_0]) + } + public var Passport_Identity_ResidenceCountryPlaceholder: String { return self._s[1771]! } + public var Conversation_SearchByName_Prefix: String { return self._s[1772]! } public func PINNED_AUDIO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1770]!, self._r[1770]!, [_1]) + return formatWithArgumentRanges(self._s[1773]!, self._r[1773]!, [_1]) } - public var Conversation_PinnedPoll: String { return self._s[1771]! } - public var Conversation_EmptyGifPanelPlaceholder: String { return self._s[1772]! } - public var Cache_ByPeerHeader: String { return self._s[1773]! } + public var Conversation_PinnedPoll: String { return self._s[1774]! } + public var Conversation_EmptyGifPanelPlaceholder: String { return self._s[1775]! } + public var Cache_ByPeerHeader: String { return self._s[1776]! } public func Conversation_EncryptedPlaceholderTitleIncoming(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1774]!, self._r[1774]!, [_0]) + return formatWithArgumentRanges(self._s[1777]!, self._r[1777]!, [_0]) } - public var ChatSettings_AutoDownloadDocuments: String { return self._s[1775]! } - public var Notification_PinnedMessage: String { return self._s[1778]! } - public var Contacts_SortBy: String { return self._s[1780]! } - public var Call_EncryptionKey_Title: String { return self._s[1782]! } - public var Watch_UserInfo_Service: String { return self._s[1783]! } - public var Conversation_Unpin: String { return self._s[1786]! } - public var CancelResetAccount_Title: String { return self._s[1787]! } - public var Map_LiveLocationFor15Minutes: String { return self._s[1788]! } + public var ChatSettings_AutoDownloadDocuments: String { return self._s[1778]! } + public var Notification_PinnedMessage: String { return self._s[1781]! } + public var Contacts_SortBy: String { return self._s[1783]! } + public var Call_EncryptionKey_Title: String { return self._s[1785]! } + public var Watch_UserInfo_Service: String { return self._s[1786]! } + public var Conversation_Unpin: String { return self._s[1789]! } + public var CancelResetAccount_Title: String { return self._s[1790]! } + public var Map_LiveLocationFor15Minutes: String { return self._s[1791]! } public func Time_PreciseDate_m8(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1790]!, self._r[1790]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1793]!, self._r[1793]!, [_1, _2, _3]) } - public var Group_Members_AddMemberBotErrorNotAllowed: String { return self._s[1791]! } - public var CallSettings_Title: String { return self._s[1792]! } - public var PasscodeSettings_EncryptDataHelp: String { return self._s[1794]! } - public var AutoDownloadSettings_Contacts: String { return self._s[1795]! } - public var Passport_Identity_DocumentDetails: String { return self._s[1796]! } - public var LoginPassword_PasswordHelp: String { return self._s[1797]! } - public var PrivacyLastSeenSettings_CustomShareSettings_Delete: String { return self._s[1798]! } - public var Checkout_TotalPaidAmount: String { return self._s[1799]! } + public var Group_Members_AddMemberBotErrorNotAllowed: String { return self._s[1794]! } + public var CallSettings_Title: String { return self._s[1795]! } + public var PasscodeSettings_EncryptDataHelp: String { return self._s[1797]! } + public var AutoDownloadSettings_Contacts: String { return self._s[1798]! } + public var Passport_Identity_DocumentDetails: String { return self._s[1799]! } + public var LoginPassword_PasswordHelp: String { return self._s[1800]! } + public var PrivacyLastSeenSettings_CustomShareSettings_Delete: String { return self._s[1801]! } + public var Checkout_TotalPaidAmount: String { return self._s[1802]! } public func FileSize_KB(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1800]!, self._r[1800]!, [_0]) + return formatWithArgumentRanges(self._s[1803]!, self._r[1803]!, [_0]) } - public var PasscodeSettings_ChangePasscode: String { return self._s[1801]! } - public var Conversation_SecretLinkPreviewAlert: String { return self._s[1803]! } - public var Privacy_SecretChatsLinkPreviews: String { return self._s[1804]! } - public var Contacts_InviteFriends: String { return self._s[1806]! } - public var Map_ChooseLocationTitle: String { return self._s[1807]! } - public var Conversation_StopPoll: String { return self._s[1809]! } - public var Calls_RatingFeedback: String { return self._s[1810]! } - public var GroupInfo_BroadcastListNamePlaceholder: String { return self._s[1811]! } - public var NotificationsSound_Pulse: String { return self._s[1812]! } - public var Watch_LastSeen_Lately: String { return self._s[1813]! } + public var PasscodeSettings_ChangePasscode: String { return self._s[1804]! } + public var Conversation_SecretLinkPreviewAlert: String { return self._s[1806]! } + public var Privacy_SecretChatsLinkPreviews: String { return self._s[1807]! } + public var Contacts_InviteFriends: String { return self._s[1809]! } + public var Map_ChooseLocationTitle: String { return self._s[1810]! } + public var Conversation_StopPoll: String { return self._s[1812]! } + public var Calls_RatingFeedback: String { return self._s[1813]! } + public var GroupInfo_BroadcastListNamePlaceholder: String { return self._s[1814]! } + public var NotificationsSound_Pulse: String { return self._s[1815]! } + public var Watch_LastSeen_Lately: String { return self._s[1816]! } public func CHAT_MESSAGE_VIDEO_SEPARATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1816]!, self._r[1816]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1819]!, self._r[1819]!, [_1, _2]) } - public var Widget_NoUsers: String { return self._s[1817]! } - public var Conversation_UnvotePoll: String { return self._s[1818]! } - public var NotificationsSound_Circles: String { return self._s[1820]! } - public var PrivacyLastSeenSettings_AlwaysShareWith_Title: String { return self._s[1822]! } + public var Widget_NoUsers: String { return self._s[1820]! } + public var Conversation_UnvotePoll: String { return self._s[1821]! } + public var NotificationsSound_Circles: String { return self._s[1823]! } + public var PrivacyLastSeenSettings_AlwaysShareWith_Title: String { return self._s[1825]! } public func CHANNEL_MESSAGE_GEOLIVE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1823]!, self._r[1823]!, [_1]) + return formatWithArgumentRanges(self._s[1826]!, self._r[1826]!, [_1]) } - public var TwoStepAuth_RecoveryCodeExpired: String { return self._s[1824]! } + public var TwoStepAuth_RecoveryCodeExpired: String { return self._s[1827]! } public func CHAT_MESSAGE_GIF(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1825]!, self._r[1825]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1828]!, self._r[1828]!, [_1, _2]) } - public var Passport_Identity_CountryPlaceholder: String { return self._s[1827]! } - public var Conversation_FileDropbox: String { return self._s[1829]! } - public var Notifications_ExceptionsUnmuted: String { return self._s[1830]! } - public var Tour_Text3: String { return self._s[1832]! } - public var Login_ResetAccountProtected_Title: String { return self._s[1834]! } - public var GroupPermission_NoSendMessages: String { return self._s[1835]! } - public var ChatAdmins_AllMembersAreAdminsOnHelp: String { return self._s[1836]! } + public var Passport_Identity_CountryPlaceholder: String { return self._s[1830]! } + public var Conversation_FileDropbox: String { return self._s[1832]! } + public var Notifications_ExceptionsUnmuted: String { return self._s[1833]! } + public var Tour_Text3: String { return self._s[1835]! } + public var Login_ResetAccountProtected_Title: String { return self._s[1837]! } + public var GroupPermission_NoSendMessages: String { return self._s[1838]! } + public var ChatAdmins_AllMembersAreAdminsOnHelp: String { return self._s[1839]! } public func Conversation_LiveLocationYouAnd(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1838]!, self._r[1838]!, [_0]) + return formatWithArgumentRanges(self._s[1841]!, self._r[1841]!, [_0]) } - public var GroupInfo_AddParticipantTitle: String { return self._s[1839]! } - public var Checkout_ShippingOption_Title: String { return self._s[1840]! } - public var ChatSettings_AutoDownloadTitle: String { return self._s[1841]! } + public var GroupInfo_AddParticipantTitle: String { return self._s[1842]! } + public var Checkout_ShippingOption_Title: String { return self._s[1843]! } + public var ChatSettings_AutoDownloadTitle: String { return self._s[1844]! } public func DialogList_SingleTypingSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1842]!, self._r[1842]!, [_0]) + return formatWithArgumentRanges(self._s[1845]!, self._r[1845]!, [_0]) } public func CHAT_MESSAGE_ROUND(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1843]!, self._r[1843]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1846]!, self._r[1846]!, [_1, _2]) } - public var PrivacyLastSeenSettings_NeverShareWith_Placeholder: String { return self._s[1844]! } - public var Appearance_PreviewIncomingText: String { return self._s[1846]! } - public var ChannelInfo_ConfirmLeave: String { return self._s[1847]! } - public var MediaPicker_MomentsDateRangeSameMonthYearFormat: String { return self._s[1848]! } - public var Passport_Identity_DocumentNumberPlaceholder: String { return self._s[1849]! } - public var Channel_AdminLogFilter_EventsNewMembers: String { return self._s[1850]! } - public var PasscodeSettings_AutoLock_IfAwayFor_5minutes: String { return self._s[1851]! } - public var GroupInfo_SetGroupPhotoStop: String { return self._s[1852]! } - public var Notification_SecretChatScreenshot: String { return self._s[1853]! } - public var Passport_Address_City: String { return self._s[1855]! } - public var InfoPlist_NSPhotoLibraryAddUsageDescription: String { return self._s[1856]! } - public var SocksProxySetup_SecretPlaceholder: String { return self._s[1857]! } - public var AccessDenied_LocationDisabled: String { return self._s[1858]! } - public var SocksProxySetup_HostnamePlaceholder: String { return self._s[1860]! } - public var GroupInfo_Sound: String { return self._s[1861]! } - public var Stickers_RemoveFromFavorites: String { return self._s[1862]! } - public var Contacts_Title: String { return self._s[1863]! } - public var Passport_Language_fr: String { return self._s[1864]! } + public var PrivacyLastSeenSettings_NeverShareWith_Placeholder: String { return self._s[1847]! } + public var Appearance_PreviewIncomingText: String { return self._s[1849]! } + public var ChannelInfo_ConfirmLeave: String { return self._s[1850]! } + public var MediaPicker_MomentsDateRangeSameMonthYearFormat: String { return self._s[1851]! } + public var Passport_Identity_DocumentNumberPlaceholder: String { return self._s[1852]! } + public var Channel_AdminLogFilter_EventsNewMembers: String { return self._s[1853]! } + public var PasscodeSettings_AutoLock_IfAwayFor_5minutes: String { return self._s[1854]! } + public var GroupInfo_SetGroupPhotoStop: String { return self._s[1855]! } + public var Notification_SecretChatScreenshot: String { return self._s[1856]! } + public var Passport_Address_City: String { return self._s[1858]! } + public var InfoPlist_NSPhotoLibraryAddUsageDescription: String { return self._s[1859]! } + public var SocksProxySetup_SecretPlaceholder: String { return self._s[1860]! } + public var AccessDenied_LocationDisabled: String { return self._s[1861]! } + public var SocksProxySetup_HostnamePlaceholder: String { return self._s[1863]! } + public var GroupInfo_Sound: String { return self._s[1864]! } + public var Stickers_RemoveFromFavorites: String { return self._s[1865]! } + public var Contacts_Title: String { return self._s[1866]! } + public var Passport_Language_fr: String { return self._s[1867]! } public func CHAT_TITLE_EDITED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1865]!, self._r[1865]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1868]!, self._r[1868]!, [_1, _2]) } - public var Notifications_ResetAllNotifications: String { return self._s[1866]! } - public var PrivacySettings_SecurityTitle: String { return self._s[1869]! } - public var Checkout_NewCard_Title: String { return self._s[1870]! } - public var Login_HaveNotReceivedCodeInternal: String { return self._s[1871]! } - public var Conversation_ForwardChats: String { return self._s[1872]! } - public var Settings_FAQ: String { return self._s[1875]! } - public var AutoDownloadSettings_DocumentsTitle: String { return self._s[1876]! } - public var Conversation_ContextMenuForward: String { return self._s[1877]! } - public var PrivacyPolicy_Title: String { return self._s[1882]! } - public var Notifications_TextTone: String { return self._s[1883]! } - public var Profile_CreateNewContact: String { return self._s[1884]! } - public var AutoNightTheme_AutomaticSection: String { return self._s[1886]! } - public var Channel_Username_InvalidCharacters: String { return self._s[1888]! } + public var Notifications_ResetAllNotifications: String { return self._s[1869]! } + public var PrivacySettings_SecurityTitle: String { return self._s[1872]! } + public var Checkout_NewCard_Title: String { return self._s[1873]! } + public var Login_HaveNotReceivedCodeInternal: String { return self._s[1874]! } + public var Conversation_ForwardChats: String { return self._s[1875]! } + public var Settings_FAQ: String { return self._s[1878]! } + public var AutoDownloadSettings_DocumentsTitle: String { return self._s[1879]! } + public var Conversation_ContextMenuForward: String { return self._s[1880]! } + public var PrivacyPolicy_Title: String { return self._s[1885]! } + public var Notifications_TextTone: String { return self._s[1886]! } + public var Profile_CreateNewContact: String { return self._s[1887]! } + public var AutoNightTheme_AutomaticSection: String { return self._s[1889]! } + public var Channel_Username_InvalidCharacters: String { return self._s[1891]! } public func Channel_AdminLog_MessageChangedChannelUsername(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1889]!, self._r[1889]!, [_0]) + return formatWithArgumentRanges(self._s[1892]!, self._r[1892]!, [_0]) } - public var PrivacySettings_LastSeenTitle: String { return self._s[1890]! } - public var Channel_AdminLog_CanInviteUsers: String { return self._s[1891]! } - public var Conversation_MessageDeliveryFailed: String { return self._s[1892]! } - public var Watch_ChatList_NoConversationsText: String { return self._s[1893]! } - public var Bot_Unblock: String { return self._s[1894]! } - public var TextFormat_Italic: String { return self._s[1895]! } - public var Settings_About_Help: String { return self._s[1896]! } - public var SearchImages_Title: String { return self._s[1897]! } - public var Weekday_Wednesday: String { return self._s[1898]! } - public var Conversation_ClousStorageInfo_Description1: String { return self._s[1899]! } - public var ExplicitContent_AlertTitle: String { return self._s[1900]! } + public var PrivacySettings_LastSeenTitle: String { return self._s[1893]! } + public var Channel_AdminLog_CanInviteUsers: String { return self._s[1894]! } + public var Conversation_MessageDeliveryFailed: String { return self._s[1895]! } + public var Watch_ChatList_NoConversationsText: String { return self._s[1896]! } + public var Bot_Unblock: String { return self._s[1897]! } + public var TextFormat_Italic: String { return self._s[1898]! } + public var Settings_About_Help: String { return self._s[1899]! } + public var SearchImages_Title: String { return self._s[1900]! } + public var Weekday_Wednesday: String { return self._s[1901]! } + public var Conversation_ClousStorageInfo_Description1: String { return self._s[1902]! } + public var ExplicitContent_AlertTitle: String { return self._s[1903]! } public func Time_PreciseDate_m5(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1901]!, self._r[1901]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1904]!, self._r[1904]!, [_1, _2, _3]) } - public var Weekday_Thursday: String { return self._s[1902]! } - public var Channel_BanUser_PermissionChangeGroupInfo: String { return self._s[1903]! } - public var Channel_Members_AddMembersHelp: String { return self._s[1904]! } + public var Weekday_Thursday: String { return self._s[1905]! } + public var Channel_BanUser_PermissionChangeGroupInfo: String { return self._s[1906]! } + public var Channel_Members_AddMembersHelp: String { return self._s[1907]! } public func Checkout_SavePasswordTimeout(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1905]!, self._r[1905]!, [_0]) + return formatWithArgumentRanges(self._s[1908]!, self._r[1908]!, [_0]) } - public var Passport_RequestedInformation: String { return self._s[1906]! } - public var Login_PhoneAndCountryHelp: String { return self._s[1907]! } + public var Passport_RequestedInformation: String { return self._s[1909]! } + public var Login_PhoneAndCountryHelp: String { return self._s[1910]! } public func CHAT_MESSAGE_AUDIO(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1908]!, self._r[1908]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1911]!, self._r[1911]!, [_1, _2]) } - public var Conversation_EncryptionProcessing: String { return self._s[1909]! } - public var PhotoEditor_EnhanceTool: String { return self._s[1912]! } - public var Notifications_PermissionsSuppressWarningTitle: String { return self._s[1913]! } - public var Channel_Setup_Title: String { return self._s[1914]! } + public var Conversation_EncryptionProcessing: String { return self._s[1912]! } + public var PhotoEditor_EnhanceTool: String { return self._s[1915]! } + public var Notifications_PermissionsSuppressWarningTitle: String { return self._s[1916]! } + public var Channel_Setup_Title: String { return self._s[1917]! } public func PINNED_GIF_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1915]!, self._r[1915]!, [_1]) + return formatWithArgumentRanges(self._s[1918]!, self._r[1918]!, [_1]) } - public var Conversation_SearchPlaceholder: String { return self._s[1916]! } - public var AccessDenied_LocationAlwaysDenied: String { return self._s[1917]! } - public var Checkout_ErrorGeneric: String { return self._s[1918]! } - public var Passport_Language_hu: String { return self._s[1919]! } + public var Conversation_SearchPlaceholder: String { return self._s[1919]! } + public var AccessDenied_LocationAlwaysDenied: String { return self._s[1920]! } + public var Checkout_ErrorGeneric: String { return self._s[1921]! } + public var Passport_Language_hu: String { return self._s[1922]! } public func Passport_Identity_UploadOneOfScan(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1921]!, self._r[1921]!, [_0]) + return formatWithArgumentRanges(self._s[1924]!, self._r[1924]!, [_0]) } - public var Conversation_CloudStorageInfo_Title: String { return self._s[1924]! } - public var PhotoEditor_CropAspectRatioSquare: String { return self._s[1925]! } + public var Conversation_CloudStorageInfo_Title: String { return self._s[1927]! } + public var PhotoEditor_CropAspectRatioSquare: String { return self._s[1928]! } public func Notification_Exceptions_MutedUntil(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1926]!, self._r[1926]!, [_0]) + return formatWithArgumentRanges(self._s[1929]!, self._r[1929]!, [_0]) } - public var Conversation_ClearPrivateHistory: String { return self._s[1927]! } - public var ContactInfo_PhoneLabelHome: String { return self._s[1928]! } - public var PrivacySettings_LastSeenContacts: String { return self._s[1929]! } + public var Conversation_ClearPrivateHistory: String { return self._s[1930]! } + public var ContactInfo_PhoneLabelHome: String { return self._s[1931]! } + public var PrivacySettings_LastSeenContacts: String { return self._s[1932]! } public func ChangePhone_ErrorOccupied(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1930]!, self._r[1930]!, [_0]) + return formatWithArgumentRanges(self._s[1933]!, self._r[1933]!, [_0]) } - public var Passport_Language_cs: String { return self._s[1931]! } - public var Message_PinnedAnimationMessage: String { return self._s[1932]! } - public var Passport_Identity_ReverseSideHelp: String { return self._s[1934]! } - public var Embed_PlayingInPIP: String { return self._s[1936]! } - public var AutoNightTheme_ScheduleSection: String { return self._s[1937]! } + public var Passport_Language_cs: String { return self._s[1934]! } + public var Message_PinnedAnimationMessage: String { return self._s[1935]! } + public var Passport_Identity_ReverseSideHelp: String { return self._s[1937]! } + public var Embed_PlayingInPIP: String { return self._s[1939]! } + public var AutoNightTheme_ScheduleSection: String { return self._s[1940]! } public func Call_EmojiDescription(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1938]!, self._r[1938]!, [_0]) + return formatWithArgumentRanges(self._s[1941]!, self._r[1941]!, [_0]) } - public var MediaPicker_LivePhotoDescription: String { return self._s[1939]! } + public var MediaPicker_LivePhotoDescription: String { return self._s[1942]! } public func Channel_AdminLog_MessageRestrictedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1940]!, self._r[1940]!, [_1]) + return formatWithArgumentRanges(self._s[1943]!, self._r[1943]!, [_1]) } - public var Notification_PaymentSent: String { return self._s[1941]! } - public var PhotoEditor_CurvesGreen: String { return self._s[1942]! } - public var SaveIncomingPhotosSettings_Title: String { return self._s[1943]! } + public var Notification_PaymentSent: String { return self._s[1944]! } + public var PhotoEditor_CurvesGreen: String { return self._s[1945]! } + public var SaveIncomingPhotosSettings_Title: String { return self._s[1946]! } public func ApplyLanguage_UnsufficientDataText(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1944]!, self._r[1944]!, [_1]) + return formatWithArgumentRanges(self._s[1947]!, self._r[1947]!, [_1]) } public func CHAT_MESSAGE_GEOLIVE(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1945]!, self._r[1945]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1948]!, self._r[1948]!, [_1, _2]) } - public var NetworkUsageSettings_CallDataSection: String { return self._s[1946]! } - public var PasscodeSettings_HelpTop: String { return self._s[1947]! } - public var Passport_Address_TypeRentalAgreement: String { return self._s[1949]! } - public var ReportPeer_ReasonOther_Placeholder: String { return self._s[1950]! } - public var CheckoutInfo_ErrorPhoneInvalid: String { return self._s[1951]! } - public var Call_Accept: String { return self._s[1953]! } - public var GroupRemoved_RemoveInfo: String { return self._s[1954]! } - public var Month_GenMarch: String { return self._s[1955]! } - public var PhotoEditor_ShadowsTool: String { return self._s[1956]! } - public var LoginPassword_Title: String { return self._s[1957]! } - public var Watch_Conversation_GroupInfo: String { return self._s[1958]! } - public var CallSettings_Always: String { return self._s[1959]! } - public var TwoStepAuth_SetupHint: String { return self._s[1960]! } - public var ConversationProfile_UsersTooMuchError: String { return self._s[1961]! } + public var NetworkUsageSettings_CallDataSection: String { return self._s[1949]! } + public var PasscodeSettings_HelpTop: String { return self._s[1950]! } + public var Passport_Address_TypeRentalAgreement: String { return self._s[1952]! } + public var ReportPeer_ReasonOther_Placeholder: String { return self._s[1953]! } + public var CheckoutInfo_ErrorPhoneInvalid: String { return self._s[1954]! } + public var Call_Accept: String { return self._s[1956]! } + public var GroupRemoved_RemoveInfo: String { return self._s[1957]! } + public var Month_GenMarch: String { return self._s[1958]! } + public var PhotoEditor_ShadowsTool: String { return self._s[1959]! } + public var LoginPassword_Title: String { return self._s[1960]! } + public var Watch_Conversation_GroupInfo: String { return self._s[1961]! } + public var CallSettings_Always: String { return self._s[1962]! } + public var TwoStepAuth_SetupHint: String { return self._s[1963]! } + public var ConversationProfile_UsersTooMuchError: String { return self._s[1964]! } public func MESSAGE_GEOLIVE_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1962]!, self._r[1962]!, [_1]) + return formatWithArgumentRanges(self._s[1965]!, self._r[1965]!, [_1]) } - public var Login_PhoneTitle: String { return self._s[1963]! } - public var Passport_FieldPhoneHelp: String { return self._s[1964]! } - public var Weekday_ShortSunday: String { return self._s[1965]! } - public var Passport_InfoFAQ_URL: String { return self._s[1966]! } - public var ContactInfo_Job: String { return self._s[1968]! } - public var UserInfo_InviteBotToGroup: String { return self._s[1969]! } - public var TwoStepAuth_PasswordRemovePassportConfirmation: String { return self._s[1970]! } - public var Passport_DeletePersonalDetailsConfirmation: String { return self._s[1972]! } - public var Passport_Identity_AddInternalPassport: String { return self._s[1974]! } - public var MediaPicker_AddCaption: String { return self._s[1975]! } - public var CallSettings_TabIconDescription: String { return self._s[1976]! } - public var Privacy_GroupsAndChannels_AlwaysAllow: String { return self._s[1977]! } - public var Passport_Identity_TypePersonalDetails: String { return self._s[1978]! } - public var DialogList_SearchSectionRecent: String { return self._s[1979]! } - public var PrivacyPolicy_DeclineMessage: String { return self._s[1980]! } - public var LastSeen_WithinAWeek: String { return self._s[1983]! } - public var ChannelMembers_GroupAdminsTitle: String { return self._s[1984]! } - public var Conversation_CloudStorage_ChatStatus: String { return self._s[1986]! } - public var Passport_Address_TypeResidentialAddress: String { return self._s[1987]! } - public var Conversation_StatusLeftGroup: String { return self._s[1988]! } - public var SocksProxySetup_ProxyDetailsTitle: String { return self._s[1989]! } + public var Login_PhoneTitle: String { return self._s[1966]! } + public var Passport_FieldPhoneHelp: String { return self._s[1967]! } + public var Weekday_ShortSunday: String { return self._s[1968]! } + public var Passport_InfoFAQ_URL: String { return self._s[1969]! } + public var ContactInfo_Job: String { return self._s[1971]! } + public var UserInfo_InviteBotToGroup: String { return self._s[1972]! } + public var TwoStepAuth_PasswordRemovePassportConfirmation: String { return self._s[1973]! } + public var Passport_DeletePersonalDetailsConfirmation: String { return self._s[1975]! } + public var Passport_Identity_AddInternalPassport: String { return self._s[1977]! } + public var MediaPicker_AddCaption: String { return self._s[1978]! } + public var CallSettings_TabIconDescription: String { return self._s[1979]! } + public var Privacy_GroupsAndChannels_AlwaysAllow: String { return self._s[1980]! } + public var Passport_Identity_TypePersonalDetails: String { return self._s[1981]! } + public var DialogList_SearchSectionRecent: String { return self._s[1982]! } + public var PrivacyPolicy_DeclineMessage: String { return self._s[1983]! } + public var LastSeen_WithinAWeek: String { return self._s[1986]! } + public var ChannelMembers_GroupAdminsTitle: String { return self._s[1987]! } + public var Conversation_CloudStorage_ChatStatus: String { return self._s[1989]! } + public var Passport_Address_TypeResidentialAddress: String { return self._s[1990]! } + public var Conversation_StatusLeftGroup: String { return self._s[1991]! } + public var SocksProxySetup_ProxyDetailsTitle: String { return self._s[1992]! } public func CHANNEL_MESSAGE_AUDIO_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1991]!, self._r[1991]!, [_1]) + return formatWithArgumentRanges(self._s[1994]!, self._r[1994]!, [_1]) } - public var GroupPermission_AddSuccess: String { return self._s[1992]! } - public var PhotoEditor_BlurToolRadial: String { return self._s[1994]! } - public var Conversation_ContextMenuCopy: String { return self._s[1995]! } - public var AccessDenied_CallMicrophone: String { return self._s[1996]! } + public var GroupPermission_AddSuccess: String { return self._s[1995]! } + public var PhotoEditor_BlurToolRadial: String { return self._s[1997]! } + public var Conversation_ContextMenuCopy: String { return self._s[1998]! } + public var AccessDenied_CallMicrophone: String { return self._s[1999]! } public func Time_PreciseDate_m2(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1997]!, self._r[1997]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2000]!, self._r[2000]!, [_1, _2, _3]) } - public var Login_InvalidFirstNameError: String { return self._s[1998]! } - public var Notifications_Badge_CountUnreadMessages_InfoOn: String { return self._s[1999]! } - public var Checkout_PaymentMethod_New: String { return self._s[2000]! } - public var ShareMenu_CopyShareLinkGame: String { return self._s[2001]! } - public var PhotoEditor_QualityTool: String { return self._s[2002]! } - public var Login_SendCodeViaSms: String { return self._s[2003]! } + public var Login_InvalidFirstNameError: String { return self._s[2001]! } + public var Notifications_Badge_CountUnreadMessages_InfoOn: String { return self._s[2002]! } + public var Checkout_PaymentMethod_New: String { return self._s[2003]! } + public var ShareMenu_CopyShareLinkGame: String { return self._s[2004]! } + public var PhotoEditor_QualityTool: String { return self._s[2005]! } + public var Login_SendCodeViaSms: String { return self._s[2006]! } public func CHAT_MESSAGE_CONTACT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2004]!, self._r[2004]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2007]!, self._r[2007]!, [_1, _2]) } - public var Login_EmailNotConfiguredError: String { return self._s[2005]! } - public var PrivacyPolicy_Accept: String { return self._s[2006]! } - public var Notifications_ExceptionsMessagePlaceholder: String { return self._s[2007]! } - public var InfoPlist_NSLocationAlwaysUsageDescription: String { return self._s[2008]! } - public var AutoNightTheme_Automatic: String { return self._s[2009]! } - public var Channel_Username_InvalidStartsWithNumber: String { return self._s[2010]! } - public var Privacy_ContactsSyncHelp: String { return self._s[2011]! } - public var Cache_Help: String { return self._s[2012]! } - public var Passport_Language_fa: String { return self._s[2013]! } - public var Login_ResetAccountProtected_TimerTitle: String { return self._s[2014]! } - public var PrivacySettings_LastSeen: String { return self._s[2015]! } + public var Login_EmailNotConfiguredError: String { return self._s[2008]! } + public var PrivacyPolicy_Accept: String { return self._s[2009]! } + public var Notifications_ExceptionsMessagePlaceholder: String { return self._s[2010]! } + public var InfoPlist_NSLocationAlwaysUsageDescription: String { return self._s[2011]! } + public var AutoNightTheme_Automatic: String { return self._s[2012]! } + public var Channel_Username_InvalidStartsWithNumber: String { return self._s[2013]! } + public var Privacy_ContactsSyncHelp: String { return self._s[2014]! } + public var Cache_Help: String { return self._s[2015]! } + public var Passport_Language_fa: String { return self._s[2016]! } + public var Login_ResetAccountProtected_TimerTitle: String { return self._s[2017]! } + public var PrivacySettings_LastSeen: String { return self._s[2018]! } public func DialogList_MultipleTyping(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2016]!, self._r[2016]!, [_0, _1]) + return formatWithArgumentRanges(self._s[2019]!, self._r[2019]!, [_0, _1]) } - public var Channel_EditAdmin_PermissionInviteUsers: String { return self._s[2018]! } - public var Preview_SaveGif: String { return self._s[2020]! } - public var Profile_About: String { return self._s[2021]! } - public var Channel_About_Placeholder: String { return self._s[2022]! } - public var Login_InfoTitle: String { return self._s[2023]! } + public var Channel_EditAdmin_PermissionInviteUsers: String { return self._s[2021]! } + public var Preview_SaveGif: String { return self._s[2023]! } + public var Profile_About: String { return self._s[2024]! } + public var Channel_About_Placeholder: String { return self._s[2025]! } + public var Login_InfoTitle: String { return self._s[2026]! } public func TwoStepAuth_SetupPendingEmail(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2024]!, self._r[2024]!, [_0]) + return formatWithArgumentRanges(self._s[2027]!, self._r[2027]!, [_0]) } - public var Watch_Suggestion_CantTalk: String { return self._s[2026]! } - public var ContactInfo_Title: String { return self._s[2027]! } - public var Media_ShareThisVideo: String { return self._s[2028]! } - public var Weekday_ShortFriday: String { return self._s[2029]! } - public var AccessDenied_Contacts: String { return self._s[2030]! } - public var Notification_CallIncomingShort: String { return self._s[2031]! } - public var Group_Setup_TypePublic: String { return self._s[2032]! } - public var Notifications_MessageNotificationsExceptions: String { return self._s[2033]! } - public var Notifications_Badge_IncludeChannels: String { return self._s[2034]! } - public var Notifications_MessageNotificationsPreview: String { return self._s[2037]! } - public var ConversationProfile_ErrorCreatingConversation: String { return self._s[2038]! } - public var Group_ErrorAddTooMuchBots: String { return self._s[2039]! } - public var Privacy_GroupsAndChannels_CustomShareHelp: String { return self._s[2040]! } - public var Permissions_CellularDataAllowInSettings_v0: String { return self._s[2041]! } - public var DialogList_Typing: String { return self._s[2042]! } - public var Checkout_Phone: String { return self._s[2045]! } - public var Login_InfoFirstNamePlaceholder: String { return self._s[2048]! } + public var Watch_Suggestion_CantTalk: String { return self._s[2029]! } + public var ContactInfo_Title: String { return self._s[2030]! } + public var Media_ShareThisVideo: String { return self._s[2031]! } + public var Weekday_ShortFriday: String { return self._s[2032]! } + public var AccessDenied_Contacts: String { return self._s[2033]! } + public var Notification_CallIncomingShort: String { return self._s[2034]! } + public var Group_Setup_TypePublic: String { return self._s[2035]! } + public var Notifications_MessageNotificationsExceptions: String { return self._s[2036]! } + public var Notifications_Badge_IncludeChannels: String { return self._s[2037]! } + public var Notifications_MessageNotificationsPreview: String { return self._s[2040]! } + public var ConversationProfile_ErrorCreatingConversation: String { return self._s[2041]! } + public var Group_ErrorAddTooMuchBots: String { return self._s[2042]! } + public var Privacy_GroupsAndChannels_CustomShareHelp: String { return self._s[2043]! } + public var Permissions_CellularDataAllowInSettings_v0: String { return self._s[2044]! } + public var DialogList_Typing: String { return self._s[2045]! } + public var Checkout_Phone: String { return self._s[2048]! } + public var Login_InfoFirstNamePlaceholder: String { return self._s[2051]! } public func PINNED_POLL(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2049]!, self._r[2049]!, [_1]) + return formatWithArgumentRanges(self._s[2052]!, self._r[2052]!, [_1]) } - public var Privacy_Calls_Integration: String { return self._s[2050]! } - public var Notifications_PermissionsAllow: String { return self._s[2052]! } - public var TwoStepAuth_AddHintDescription: String { return self._s[2055]! } - public var Settings_ChatSettings: String { return self._s[2056]! } + public var Privacy_Calls_Integration: String { return self._s[2053]! } + public var Notifications_PermissionsAllow: String { return self._s[2055]! } + public var TwoStepAuth_AddHintDescription: String { return self._s[2058]! } + public var Settings_ChatSettings: String { return self._s[2059]! } public func Channel_AdminLog_MessageInvitedNameUsername(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2057]!, self._r[2057]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2060]!, self._r[2060]!, [_1, _2]) } - public var GroupRemoved_DeleteUser: String { return self._s[2059]! } + public var GroupRemoved_DeleteUser: String { return self._s[2062]! } public func Channel_AdminLog_PollStopped(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2060]!, self._r[2060]!, [_0]) + return formatWithArgumentRanges(self._s[2063]!, self._r[2063]!, [_0]) } - public var Login_ContinueWithLocalization: String { return self._s[2061]! } - public var Watch_Message_ForwardedFrom: String { return self._s[2062]! } - public var TwoStepAuth_EnterEmailCode: String { return self._s[2064]! } - public var Conversation_Unblock: String { return self._s[2065]! } - public var PrivacySettings_DataSettings: String { return self._s[2066]! } - public var Notifications_InAppNotificationsVibrate: String { return self._s[2067]! } + public var Login_ContinueWithLocalization: String { return self._s[2064]! } + public var Watch_Message_ForwardedFrom: String { return self._s[2065]! } + public var TwoStepAuth_EnterEmailCode: String { return self._s[2067]! } + public var Conversation_Unblock: String { return self._s[2068]! } + public var PrivacySettings_DataSettings: String { return self._s[2069]! } + public var Notifications_InAppNotificationsVibrate: String { return self._s[2070]! } public func Privacy_GroupsAndChannels_InviteToChannelError(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2068]!, self._r[2068]!, [_0, _1]) + return formatWithArgumentRanges(self._s[2071]!, self._r[2071]!, [_0, _1]) } - public var PrivacySettings_Passcode: String { return self._s[2071]! } + public var PrivacySettings_Passcode: String { return self._s[2074]! } public func ENCRYPTION_ACCEPT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2072]!, self._r[2072]!, [_1]) + return formatWithArgumentRanges(self._s[2075]!, self._r[2075]!, [_1]) } - public var Passport_Language_dz: String { return self._s[2073]! } - public var Passport_Language_tk: String { return self._s[2074]! } + public var Passport_Language_dz: String { return self._s[2076]! } + public var Passport_Language_tk: String { return self._s[2077]! } public func Login_EmailCodeSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2075]!, self._r[2075]!, [_0]) + return formatWithArgumentRanges(self._s[2078]!, self._r[2078]!, [_0]) } - public var InfoPlist_NSPhotoLibraryUsageDescription: String { return self._s[2076]! } - public var Conversation_ContextMenuReply: String { return self._s[2077]! } - public var Tour_Title1: String { return self._s[2078]! } + public var InfoPlist_NSPhotoLibraryUsageDescription: String { return self._s[2079]! } + public var Conversation_ContextMenuReply: String { return self._s[2080]! } + public var Tour_Title1: String { return self._s[2081]! } public func MESSAGE_STICKER(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2079]!, self._r[2079]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2082]!, self._r[2082]!, [_1, _2]) } - public var Conversation_ClearGroupHistory: String { return self._s[2081]! } + public var Conversation_ClearGroupHistory: String { return self._s[2084]! } public func Checkout_PasswordEntry_Text(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2082]!, self._r[2082]!, [_0]) + return formatWithArgumentRanges(self._s[2085]!, self._r[2085]!, [_0]) } - public var Call_RateCall: String { return self._s[2083]! } - public var Passport_PasswordCompleteSetup: String { return self._s[2084]! } - public var Conversation_InputTextSilentBroadcastPlaceholder: String { return self._s[2085]! } - public var UserInfo_LastNamePlaceholder: String { return self._s[2087]! } + public var Call_RateCall: String { return self._s[2086]! } + public var Passport_PasswordCompleteSetup: String { return self._s[2087]! } + public var Conversation_InputTextSilentBroadcastPlaceholder: String { return self._s[2088]! } + public var UserInfo_LastNamePlaceholder: String { return self._s[2090]! } public func Login_WillCallYou(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2089]!, self._r[2089]!, [_0]) + return formatWithArgumentRanges(self._s[2092]!, self._r[2092]!, [_0]) } - public var Compose_Create: String { return self._s[2090]! } - public var Contacts_InviteToTelegram: String { return self._s[2091]! } - public var GroupInfo_Notifications: String { return self._s[2092]! } - public var Message_PinnedLiveLocationMessage: String { return self._s[2094]! } - public var Month_GenApril: String { return self._s[2095]! } - public var Appearance_AutoNightTheme: String { return self._s[2096]! } - public var ChatSettings_AutomaticAudioDownload: String { return self._s[2098]! } - public var Login_CodeSentSms: String { return self._s[2100]! } + public var Compose_Create: String { return self._s[2093]! } + public var Contacts_InviteToTelegram: String { return self._s[2094]! } + public var GroupInfo_Notifications: String { return self._s[2095]! } + public var Message_PinnedLiveLocationMessage: String { return self._s[2097]! } + public var Month_GenApril: String { return self._s[2098]! } + public var Appearance_AutoNightTheme: String { return self._s[2099]! } + public var ChatSettings_AutomaticAudioDownload: String { return self._s[2101]! } + public var Login_CodeSentSms: String { return self._s[2103]! } public func UserInfo_UnblockConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2101]!, self._r[2101]!, [_0]) - } - public var EmptyGroupInfo_Line3: String { return self._s[2102]! } - public var Passport_Language_hr: String { return self._s[2103]! } - public func Channel_AdminLog_MessageRestrictedNewSetting(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2104]!, self._r[2104]!, [_0]) } - public var GroupInfo_InviteLink_CopyLink: String { return self._s[2105]! } - public var Conversation_InputTextBroadcastPlaceholder: String { return self._s[2106]! } - public var Privacy_SecretChatsTitle: String { return self._s[2107]! } - public var Notification_SecretChatMessageScreenshotSelf: String { return self._s[2109]! } - public var GroupInfo_AddUserLeftError: String { return self._s[2110]! } + public var EmptyGroupInfo_Line3: String { return self._s[2105]! } + public var Passport_Language_hr: String { return self._s[2106]! } + public func Channel_AdminLog_MessageRestrictedNewSetting(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2107]!, self._r[2107]!, [_0]) + } + public var GroupInfo_InviteLink_CopyLink: String { return self._s[2108]! } + public var Conversation_InputTextBroadcastPlaceholder: String { return self._s[2109]! } + public var Privacy_SecretChatsTitle: String { return self._s[2110]! } + public var Notification_SecretChatMessageScreenshotSelf: String { return self._s[2112]! } + public var GroupInfo_AddUserLeftError: String { return self._s[2113]! } public func CHANNEL_MESSAGE_VIDEO_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2111]!, self._r[2111]!, [_1]) + return formatWithArgumentRanges(self._s[2114]!, self._r[2114]!, [_1]) } - public var Preview_DeleteGif: String { return self._s[2112]! } - public var GroupInfo_Permissions_Exceptions: String { return self._s[2113]! } - public var Group_ErrorNotMutualContact: String { return self._s[2114]! } - public var Notification_MessageLifetime5s: String { return self._s[2115]! } + public var Preview_DeleteGif: String { return self._s[2115]! } + public var GroupInfo_Permissions_Exceptions: String { return self._s[2116]! } + public var Group_ErrorNotMutualContact: String { return self._s[2117]! } + public var Notification_MessageLifetime5s: String { return self._s[2118]! } public func Watch_LastSeen_AtDate(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2116]!, self._r[2116]!, [_0]) + return formatWithArgumentRanges(self._s[2119]!, self._r[2119]!, [_0]) } - public var Passport_Address_AddBankStatement: String { return self._s[2118]! } - public var Notification_CallIncoming: String { return self._s[2119]! } - public var Compose_NewGroupTitle: String { return self._s[2120]! } - public var TwoStepAuth_RecoveryCodeHelp: String { return self._s[2122]! } - public var Passport_Address_Postcode: String { return self._s[2124]! } + public var Passport_Address_AddBankStatement: String { return self._s[2121]! } + public var Notification_CallIncoming: String { return self._s[2122]! } + public var Compose_NewGroupTitle: String { return self._s[2123]! } + public var TwoStepAuth_RecoveryCodeHelp: String { return self._s[2125]! } + public var Passport_Address_Postcode: String { return self._s[2127]! } public func LastSeen_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2125]!, self._r[2125]!, [_0]) - } - public var Checkout_NewCard_SaveInfoHelp: String { return self._s[2126]! } - public var GroupPermission_Duration: String { return self._s[2127]! } - public func Cache_Clear(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2128]!, self._r[2128]!, [_0]) } - public var Bot_GroupStatusDoesNotReadHistory: String { return self._s[2129]! } - public var Username_Placeholder: String { return self._s[2130]! } - public var Passport_FieldAddressUploadHelp: String { return self._s[2131]! } - public var Permissions_NotificationsAllowInSettings_v0: String { return self._s[2132]! } + public var Checkout_NewCard_SaveInfoHelp: String { return self._s[2129]! } + public var GroupPermission_Duration: String { return self._s[2130]! } + public func Cache_Clear(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2131]!, self._r[2131]!, [_0]) + } + public var Bot_GroupStatusDoesNotReadHistory: String { return self._s[2132]! } + public var Username_Placeholder: String { return self._s[2133]! } + public var Passport_FieldAddressUploadHelp: String { return self._s[2134]! } + public var Permissions_NotificationsAllowInSettings_v0: String { return self._s[2135]! } public func CHAT_ADD_MEMBER_SEPARATED(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2133]!, self._r[2133]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2136]!, self._r[2136]!, [_1, _2, _3]) } - public var Passport_PasswordDescription: String { return self._s[2135]! } - public var Channel_MessagePhotoUpdated: String { return self._s[2136]! } - public var MediaPicker_TapToUngroupDescription: String { return self._s[2137]! } - public var AttachmentMenu_PhotoOrVideo: String { return self._s[2138]! } - public var Conversation_ContextMenuMore: String { return self._s[2139]! } - public var Privacy_PaymentsClearInfo: String { return self._s[2140]! } - public var CallSettings_TabIcon: String { return self._s[2141]! } - public var KeyCommand_Find: String { return self._s[2142]! } - public var Message_PinnedGame: String { return self._s[2143]! } - public var Notifications_Badge_CountUnreadMessages_InfoOff: String { return self._s[2144]! } - public var Login_CallRequestState2: String { return self._s[2146]! } - public var CheckoutInfo_ReceiverInfoNamePlaceholder: String { return self._s[2148]! } + public var Passport_PasswordDescription: String { return self._s[2138]! } + public var Channel_MessagePhotoUpdated: String { return self._s[2139]! } + public var MediaPicker_TapToUngroupDescription: String { return self._s[2140]! } + public var AttachmentMenu_PhotoOrVideo: String { return self._s[2141]! } + public var Conversation_ContextMenuMore: String { return self._s[2142]! } + public var Privacy_PaymentsClearInfo: String { return self._s[2143]! } + public var CallSettings_TabIcon: String { return self._s[2144]! } + public var KeyCommand_Find: String { return self._s[2145]! } + public var Message_PinnedGame: String { return self._s[2146]! } + public var Notifications_Badge_CountUnreadMessages_InfoOff: String { return self._s[2147]! } + public var Login_CallRequestState2: String { return self._s[2149]! } + public var CheckoutInfo_ReceiverInfoNamePlaceholder: String { return self._s[2151]! } public func Checkout_PayPrice(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2150]!, self._r[2150]!, [_0]) + return formatWithArgumentRanges(self._s[2153]!, self._r[2153]!, [_0]) } - public var Conversation_InstantPagePreview: String { return self._s[2151]! } + public var Conversation_InstantPagePreview: String { return self._s[2154]! } public func DialogList_SingleUploadingVideoSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2152]!, self._r[2152]!, [_0]) + return formatWithArgumentRanges(self._s[2155]!, self._r[2155]!, [_0]) } - public var SecretTimer_VideoDescription: String { return self._s[2155]! } - public var GroupPermission_NoPinMessages: String { return self._s[2156]! } - public var Passport_Language_es: String { return self._s[2157]! } - public var Permissions_ContactsAllow_v0: String { return self._s[2159]! } - public var Conversation_EditingMessageMediaEditCurrentVideo: String { return self._s[2160]! } - public var WebPreview_GettingLinkInfo: String { return self._s[2161]! } - public var Watch_UserInfo_Unmute: String { return self._s[2162]! } - public var GroupInfo_ChannelListNamePlaceholder: String { return self._s[2163]! } - public var AccessDenied_CameraRestricted: String { return self._s[2165]! } + public var SecretTimer_VideoDescription: String { return self._s[2158]! } + public var GroupPermission_NoPinMessages: String { return self._s[2159]! } + public var Passport_Language_es: String { return self._s[2160]! } + public var Permissions_ContactsAllow_v0: String { return self._s[2162]! } + public var Conversation_EditingMessageMediaEditCurrentVideo: String { return self._s[2163]! } + public var WebPreview_GettingLinkInfo: String { return self._s[2164]! } + public var Watch_UserInfo_Unmute: String { return self._s[2165]! } + public var GroupInfo_ChannelListNamePlaceholder: String { return self._s[2166]! } + public var AccessDenied_CameraRestricted: String { return self._s[2168]! } public func Conversation_Kilobytes(_ _0: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2166]!, self._r[2166]!, ["\(_0)"]) + return formatWithArgumentRanges(self._s[2169]!, self._r[2169]!, ["\(_0)"]) } - public var ChatList_ReadAll: String { return self._s[2168]! } - public var Settings_CopyUsername: String { return self._s[2169]! } - public var Contacts_SearchLabel: String { return self._s[2170]! } + public var ChatList_ReadAll: String { return self._s[2171]! } + public var Settings_CopyUsername: String { return self._s[2172]! } + public var Contacts_SearchLabel: String { return self._s[2173]! } public func MESSAGE_GEOLIVE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2172]!, self._r[2172]!, [_1]) + return formatWithArgumentRanges(self._s[2175]!, self._r[2175]!, [_1]) } - public var Map_OpenInYandexNavigator: String { return self._s[2173]! } - public var PasscodeSettings_EncryptData: String { return self._s[2174]! } - public var Notifications_GroupNotificationsPreview: String { return self._s[2176]! } - public var DialogList_AdNoticeAlert: String { return self._s[2177]! } + public var Map_OpenInYandexNavigator: String { return self._s[2176]! } + public var PasscodeSettings_EncryptData: String { return self._s[2177]! } + public var Notifications_GroupNotificationsPreview: String { return self._s[2179]! } + public var DialogList_AdNoticeAlert: String { return self._s[2180]! } public func CHAT_DELETE_MEMBER(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2179]!, self._r[2179]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2182]!, self._r[2182]!, [_1, _2, _3]) } - public var CheckoutInfo_ShippingInfoAddress1: String { return self._s[2180]! } - public var CheckoutInfo_ShippingInfoAddress2: String { return self._s[2181]! } - public var Localization_LanguageCustom: String { return self._s[2182]! } - public var Passport_Identity_TypeDriversLicenseUploadScan: String { return self._s[2183]! } + public var CheckoutInfo_ShippingInfoAddress1: String { return self._s[2183]! } + public var CheckoutInfo_ShippingInfoAddress2: String { return self._s[2184]! } + public var Localization_LanguageCustom: String { return self._s[2185]! } + public var Passport_Identity_TypeDriversLicenseUploadScan: String { return self._s[2186]! } public func CHAT_CREATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2185]!, self._r[2185]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2188]!, self._r[2188]!, [_1, _2]) } - public var Passport_Address_OneOfTypePassportRegistration: String { return self._s[2187]! } - public var Conversation_InfoGroup: String { return self._s[2188]! } - public var Compose_NewMessage: String { return self._s[2189]! } - public var FastTwoStepSetup_HintPlaceholder: String { return self._s[2191]! } - public var ChatSettings_AutoDownloadVideoMessages: String { return self._s[2192]! } + public var Passport_Address_OneOfTypePassportRegistration: String { return self._s[2190]! } + public var Conversation_InfoGroup: String { return self._s[2191]! } + public var Compose_NewMessage: String { return self._s[2192]! } + public var FastTwoStepSetup_HintPlaceholder: String { return self._s[2194]! } + public var ChatSettings_AutoDownloadVideoMessages: String { return self._s[2195]! } public func Passport_Scans_ScanIndex(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2193]!, self._r[2193]!, [_0]) + return formatWithArgumentRanges(self._s[2196]!, self._r[2196]!, [_0]) } - public var Channel_AdminLog_CanDeleteMessages: String { return self._s[2194]! } - public var Login_CancelSignUpConfirmation: String { return self._s[2195]! } - public var ChangePhoneNumberCode_Help: String { return self._s[2196]! } - public var PrivacySettings_DeleteAccountHelp: String { return self._s[2197]! } - public var Channel_BlackList_Title: String { return self._s[2198]! } - public var UserInfo_PhoneCall: String { return self._s[2199]! } - public var Passport_Address_OneOfTypeBankStatement: String { return self._s[2201]! } - public var State_connecting: String { return self._s[2202]! } + public var Channel_AdminLog_CanDeleteMessages: String { return self._s[2197]! } + public var Login_CancelSignUpConfirmation: String { return self._s[2198]! } + public var ChangePhoneNumberCode_Help: String { return self._s[2199]! } + public var PrivacySettings_DeleteAccountHelp: String { return self._s[2200]! } + public var Channel_BlackList_Title: String { return self._s[2201]! } + public var UserInfo_PhoneCall: String { return self._s[2202]! } + public var Passport_Address_OneOfTypeBankStatement: String { return self._s[2204]! } + public var State_connecting: String { return self._s[2205]! } public func DialogList_SingleRecordingAudioSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2203]!, self._r[2203]!, [_0]) + return formatWithArgumentRanges(self._s[2206]!, self._r[2206]!, [_0]) } - public var Notifications_GroupNotifications: String { return self._s[2204]! } - public var Passport_Identity_EditPassport: String { return self._s[2205]! } - public var EnterPasscode_RepeatNewPasscode: String { return self._s[2207]! } - public var Localization_EnglishLanguageName: String { return self._s[2208]! } - public var Share_AuthDescription: String { return self._s[2209]! } - public var Passport_Identity_Surname: String { return self._s[2210]! } - public var Compose_TokenListPlaceholder: String { return self._s[2211]! } - public var Passport_Identity_OneOfTypePassport: String { return self._s[2212]! } - public var Settings_AboutEmpty: String { return self._s[2213]! } - public var Conversation_Unmute: String { return self._s[2214]! } - public var Login_CodeSentCall: String { return self._s[2217]! } - public var ContactInfo_PhoneLabelHomeFax: String { return self._s[2218]! } - public var ChatSettings_Appearance: String { return self._s[2219]! } - public var Appearance_PickAccentColor: String { return self._s[2220]! } - public var Notification_CallMissed: String { return self._s[2221]! } - public var Channel_AdminLogFilter_EventsInfo: String { return self._s[2222]! } - public var ChatAdmins_AdminLabel: String { return self._s[2224]! } - public var KeyCommand_JumpToNextChat: String { return self._s[2225]! } - public var Conversation_StopPollConfirmationTitle: String { return self._s[2227]! } - public var ChangePhoneNumberCode_CodePlaceholder: String { return self._s[2228]! } - public var Month_GenJune: String { return self._s[2229]! } - public var Watch_Location_Current: String { return self._s[2230]! } - public var Conversation_TitleMute: String { return self._s[2231]! } + public var Notifications_GroupNotifications: String { return self._s[2207]! } + public var Passport_Identity_EditPassport: String { return self._s[2208]! } + public var EnterPasscode_RepeatNewPasscode: String { return self._s[2210]! } + public var Localization_EnglishLanguageName: String { return self._s[2211]! } + public var Share_AuthDescription: String { return self._s[2212]! } + public var Passport_Identity_Surname: String { return self._s[2213]! } + public var Compose_TokenListPlaceholder: String { return self._s[2214]! } + public var Passport_Identity_OneOfTypePassport: String { return self._s[2215]! } + public var Settings_AboutEmpty: String { return self._s[2216]! } + public var Conversation_Unmute: String { return self._s[2217]! } + public var Login_CodeSentCall: String { return self._s[2220]! } + public var ContactInfo_PhoneLabelHomeFax: String { return self._s[2221]! } + public var ChatSettings_Appearance: String { return self._s[2222]! } + public var Appearance_PickAccentColor: String { return self._s[2223]! } + public var Notification_CallMissed: String { return self._s[2224]! } + public var Channel_AdminLogFilter_EventsInfo: String { return self._s[2225]! } + public var ChatAdmins_AdminLabel: String { return self._s[2227]! } + public var KeyCommand_JumpToNextChat: String { return self._s[2228]! } + public var Conversation_StopPollConfirmationTitle: String { return self._s[2230]! } + public var ChangePhoneNumberCode_CodePlaceholder: String { return self._s[2231]! } + public var Month_GenJune: String { return self._s[2232]! } + public var Watch_Location_Current: String { return self._s[2233]! } + public var Conversation_TitleMute: String { return self._s[2234]! } public func PINNED_ROUND(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2232]!, self._r[2232]!, [_1]) + return formatWithArgumentRanges(self._s[2235]!, self._r[2235]!, [_1]) } - public var GroupInfo_DeleteAndExit: String { return self._s[2233]! } + public var GroupInfo_DeleteAndExit: String { return self._s[2236]! } public func Conversation_Moderate_DeleteAllMessages(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2234]!, self._r[2234]!, [_0]) - } - public var Call_ReportPlaceholder: String { return self._s[2235]! } - public var MaskStickerSettings_Info: String { return self._s[2236]! } - public func GroupInfo_AddParticipantConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2237]!, self._r[2237]!, [_0]) } - public var Checkout_NewCard_PostcodeTitle: String { return self._s[2238]! } - public var Passport_Address_RegionPlaceholder: String { return self._s[2240]! } - public var Contacts_ShareTelegram: String { return self._s[2241]! } + public var Call_ReportPlaceholder: String { return self._s[2238]! } + public var MaskStickerSettings_Info: String { return self._s[2239]! } + public func GroupInfo_AddParticipantConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2240]!, self._r[2240]!, [_0]) + } + public var Checkout_NewCard_PostcodeTitle: String { return self._s[2241]! } + public var Passport_Address_RegionPlaceholder: String { return self._s[2243]! } + public var Contacts_ShareTelegram: String { return self._s[2244]! } public func CHAT_MESSAGE_GIF_SEPARATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2242]!, self._r[2242]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2245]!, self._r[2245]!, [_1, _2]) } - public var EnterPasscode_EnterNewPasscodeNew: String { return self._s[2243]! } - public var Channel_ErrorAccessDenied: String { return self._s[2244]! } - public var Stickers_GroupChooseStickerPack: String { return self._s[2246]! } - public var Call_ConnectionErrorTitle: String { return self._s[2247]! } - public var UserInfo_NotificationsEnable: String { return self._s[2248]! } - public var Tour_Text4: String { return self._s[2251]! } + public var EnterPasscode_EnterNewPasscodeNew: String { return self._s[2246]! } + public var Channel_ErrorAccessDenied: String { return self._s[2247]! } + public var Stickers_GroupChooseStickerPack: String { return self._s[2249]! } + public var Call_ConnectionErrorTitle: String { return self._s[2250]! } + public var UserInfo_NotificationsEnable: String { return self._s[2251]! } + public var Tour_Text4: String { return self._s[2254]! } public func CHANNEL_MESSAGE_NOTEXT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2253]!, self._r[2253]!, [_1]) + return formatWithArgumentRanges(self._s[2256]!, self._r[2256]!, [_1]) } - public var Profile_MessageLifetime2s: String { return self._s[2254]! } - public var Notification_MessageLifetime2s: String { return self._s[2255]! } + public var Profile_MessageLifetime2s: String { return self._s[2257]! } + public var Notification_MessageLifetime2s: String { return self._s[2258]! } public func Time_PreciseDate_m10(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2256]!, self._r[2256]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2259]!, self._r[2259]!, [_1, _2, _3]) } - public var Cache_ClearCache: String { return self._s[2257]! } - public var AutoNightTheme_UpdateLocation: String { return self._s[2258]! } - public var Permissions_NotificationsUnreachableText_v0: String { return self._s[2259]! } + public var Cache_ClearCache: String { return self._s[2260]! } + public var AutoNightTheme_UpdateLocation: String { return self._s[2261]! } + public var Permissions_NotificationsUnreachableText_v0: String { return self._s[2262]! } public func Channel_AdminLog_MessageChangedGroupUsername(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2261]!, self._r[2261]!, [_0]) + return formatWithArgumentRanges(self._s[2264]!, self._r[2264]!, [_0]) } - public var Channel_AdminLog_EmptyFilterTitle: String { return self._s[2263]! } - public var SocksProxySetup_TypeSocks: String { return self._s[2264]! } - public var AutoNightTheme_Title: String { return self._s[2265]! } - public var InstantPage_FeedbackButton: String { return self._s[2266]! } - public var Passport_FieldAddress: String { return self._s[2267]! } - public var Month_ShortMarch: String { return self._s[2268]! } - public var SocksProxySetup_UsernamePlaceholder: String { return self._s[2269]! } - public var Conversation_ShareInlineBotLocationConfirmation: String { return self._s[2270]! } - public var Passport_FloodError: String { return self._s[2271]! } - public var SecretGif_Title: String { return self._s[2272]! } - public var Passport_Language_th: String { return self._s[2274]! } - public var Passport_Address_Address: String { return self._s[2275]! } - public var Login_InvalidLastNameError: String { return self._s[2276]! } - public var Notifications_InAppNotificationsPreview: String { return self._s[2277]! } - public var Notifications_PermissionsUnreachableTitle: String { return self._s[2278]! } - public var ShareMenu_Send: String { return self._s[2279]! } - public var Month_GenNovember: String { return self._s[2282]! } - public var Checkout_Email: String { return self._s[2284]! } - public var NotificationsSound_Tritone: String { return self._s[2285]! } - public var StickerPacksSettings_ManagingHelp: String { return self._s[2287]! } - public var ChangePhoneNumberNumber_Help: String { return self._s[2290]! } + public var Channel_AdminLog_EmptyFilterTitle: String { return self._s[2266]! } + public var SocksProxySetup_TypeSocks: String { return self._s[2267]! } + public var AutoNightTheme_Title: String { return self._s[2268]! } + public var InstantPage_FeedbackButton: String { return self._s[2269]! } + public var Passport_FieldAddress: String { return self._s[2270]! } + public var Month_ShortMarch: String { return self._s[2271]! } + public var SocksProxySetup_UsernamePlaceholder: String { return self._s[2272]! } + public var Conversation_ShareInlineBotLocationConfirmation: String { return self._s[2273]! } + public var Passport_FloodError: String { return self._s[2274]! } + public var SecretGif_Title: String { return self._s[2275]! } + public var Passport_Language_th: String { return self._s[2277]! } + public var Passport_Address_Address: String { return self._s[2278]! } + public var Login_InvalidLastNameError: String { return self._s[2279]! } + public var Notifications_InAppNotificationsPreview: String { return self._s[2280]! } + public var Notifications_PermissionsUnreachableTitle: String { return self._s[2281]! } + public var ShareMenu_Send: String { return self._s[2282]! } + public var Month_GenNovember: String { return self._s[2285]! } + public var Checkout_Email: String { return self._s[2287]! } + public var NotificationsSound_Tritone: String { return self._s[2288]! } + public var StickerPacksSettings_ManagingHelp: String { return self._s[2290]! } + public var ChangePhoneNumberNumber_Help: String { return self._s[2293]! } public func Checkout_LiabilityAlert(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2291]!, self._r[2291]!, [_1, _1, _1, _2]) + return formatWithArgumentRanges(self._s[2294]!, self._r[2294]!, [_1, _1, _1, _2]) } - public var DialogList_You: String { return self._s[2292]! } - public var MediaPicker_Send: String { return self._s[2295]! } - public var Call_AudioRouteSpeaker: String { return self._s[2296]! } - public var Watch_UserInfo_Title: String { return self._s[2297]! } - public var Appearance_AccentColor: String { return self._s[2298]! } + public var DialogList_You: String { return self._s[2295]! } + public var MediaPicker_Send: String { return self._s[2298]! } + public var Call_AudioRouteSpeaker: String { return self._s[2299]! } + public var Watch_UserInfo_Title: String { return self._s[2300]! } + public var Appearance_AccentColor: String { return self._s[2301]! } public func PINNED_STICKER_SEPARATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2299]!, self._r[2299]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2302]!, self._r[2302]!, [_1, _2]) } public func Login_EmailPhoneSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2300]!, self._r[2300]!, [_0]) + return formatWithArgumentRanges(self._s[2303]!, self._r[2303]!, [_0]) } - public var Permissions_ContactsAllowInSettings_v0: String { return self._s[2301]! } - public var Conversation_ClousStorageInfo_Description2: String { return self._s[2302]! } - public var WebSearch_RecentClearConfirmation: String { return self._s[2303]! } - public var Notification_CallOutgoing: String { return self._s[2304]! } - public var PrivacySettings_PasscodeAndFaceId: String { return self._s[2305]! } - public var Call_RecordingDisabledMessage: String { return self._s[2306]! } - public var PrivacyLastSeenSettings_CustomHelp: String { return self._s[2307]! } - public var Channel_EditAdmin_PermissionAddAdmins: String { return self._s[2308]! } - public var Date_DialogDateFormat: String { return self._s[2309]! } - public var Notifications_InAppNotifications: String { return self._s[2310]! } + public var Permissions_ContactsAllowInSettings_v0: String { return self._s[2304]! } + public var Conversation_ClousStorageInfo_Description2: String { return self._s[2305]! } + public var WebSearch_RecentClearConfirmation: String { return self._s[2306]! } + public var Notification_CallOutgoing: String { return self._s[2307]! } + public var PrivacySettings_PasscodeAndFaceId: String { return self._s[2308]! } + public var Call_RecordingDisabledMessage: String { return self._s[2309]! } + public var PrivacyLastSeenSettings_CustomHelp: String { return self._s[2310]! } + public var Channel_EditAdmin_PermissionAddAdmins: String { return self._s[2311]! } + public var Date_DialogDateFormat: String { return self._s[2312]! } + public var Notifications_InAppNotifications: String { return self._s[2313]! } public func Channel_Management_RemovedBy(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2311]!, self._r[2311]!, [_0]) + return formatWithArgumentRanges(self._s[2314]!, self._r[2314]!, [_0]) } public func Settings_ApplyProxyAlert(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2312]!, self._r[2312]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2315]!, self._r[2315]!, [_1, _2]) } - public var NewContact_Title: String { return self._s[2313]! } - public var Conversation_ViewContactDetails: String { return self._s[2314]! } - public var Checkout_NewCard_CardholderNameTitle: String { return self._s[2316]! } - public var Passport_Identity_ExpiryDateNone: String { return self._s[2317]! } - public var PrivacySettings_Title: String { return self._s[2318]! } - public var Conversation_SilentBroadcastTooltipOff: String { return self._s[2321]! } + public var NewContact_Title: String { return self._s[2316]! } + public var Conversation_ViewContactDetails: String { return self._s[2317]! } + public var Checkout_NewCard_CardholderNameTitle: String { return self._s[2319]! } + public var Passport_Identity_ExpiryDateNone: String { return self._s[2320]! } + public var PrivacySettings_Title: String { return self._s[2321]! } + public var Conversation_SilentBroadcastTooltipOff: String { return self._s[2324]! } public func CHANNEL_MESSAGE_CONTACT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2322]!, self._r[2322]!, [_1]) + return formatWithArgumentRanges(self._s[2325]!, self._r[2325]!, [_1]) } - public var GroupRemoved_UsersSectionTitle: String { return self._s[2323]! } - public var Contacts_PhoneNumber: String { return self._s[2324]! } + public var GroupRemoved_UsersSectionTitle: String { return self._s[2326]! } + public var Contacts_PhoneNumber: String { return self._s[2327]! } public func CHANNEL_MESSAGE_CONTACT_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2326]!, self._r[2326]!, [_1]) + return formatWithArgumentRanges(self._s[2329]!, self._r[2329]!, [_1]) } - public var Map_ShowPlaces: String { return self._s[2327]! } - public var ChatAdmins_Title: String { return self._s[2328]! } - public var InstantPage_Reference: String { return self._s[2330]! } - public var Camera_FlashOff: String { return self._s[2331]! } - public var Watch_UserInfo_Block: String { return self._s[2332]! } - public var ChatSettings_Stickers: String { return self._s[2333]! } - public var ChatSettings_DownloadInBackground: String { return self._s[2334]! } + public var Map_ShowPlaces: String { return self._s[2330]! } + public var ChatAdmins_Title: String { return self._s[2331]! } + public var InstantPage_Reference: String { return self._s[2333]! } + public var Camera_FlashOff: String { return self._s[2334]! } + public var Watch_UserInfo_Block: String { return self._s[2335]! } + public var ChatSettings_Stickers: String { return self._s[2336]! } + public var ChatSettings_DownloadInBackground: String { return self._s[2337]! } public func UserInfo_BlockConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2335]!, self._r[2335]!, [_0]) + return formatWithArgumentRanges(self._s[2338]!, self._r[2338]!, [_0]) } - public var Settings_ViewPhoto: String { return self._s[2336]! } - public var Login_CheckOtherSessionMessages: String { return self._s[2337]! } - public var AutoDownloadSettings_Cellular: String { return self._s[2338]! } + public var Settings_ViewPhoto: String { return self._s[2339]! } + public var Login_CheckOtherSessionMessages: String { return self._s[2340]! } + public var AutoDownloadSettings_Cellular: String { return self._s[2341]! } public func Target_InviteToGroupConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2340]!, self._r[2340]!, [_0]) - } - public var Privacy_DeleteDrafts: String { return self._s[2341]! } - public var Wallpaper_SetCustomBackgroundInfo: String { return self._s[2342]! } - public func LastSeen_AtDate(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2343]!, self._r[2343]!, [_0]) } - public var DialogList_SavedMessagesHelp: String { return self._s[2344]! } - public var DialogList_SavedMessages: String { return self._s[2345]! } - public var GroupInfo_UpgradeButton: String { return self._s[2346]! } - public func CHAT_MESSAGE_GAME(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2347]!, self._r[2347]!, [_1, _2, _3]) + public var Privacy_DeleteDrafts: String { return self._s[2344]! } + public var Wallpaper_SetCustomBackgroundInfo: String { return self._s[2345]! } + public func LastSeen_AtDate(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2346]!, self._r[2346]!, [_0]) } - public var DialogList_Pin: String { return self._s[2348]! } + public var DialogList_SavedMessagesHelp: String { return self._s[2347]! } + public var DialogList_SavedMessages: String { return self._s[2348]! } + public var GroupInfo_UpgradeButton: String { return self._s[2349]! } + public func CHAT_MESSAGE_GAME(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2350]!, self._r[2350]!, [_1, _2, _3]) + } + public var DialogList_Pin: String { return self._s[2351]! } public func ForwardedAuthors2(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2349]!, self._r[2349]!, [_0, _1]) + return formatWithArgumentRanges(self._s[2352]!, self._r[2352]!, [_0, _1]) } public func Login_PhoneGenericEmailSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2350]!, self._r[2350]!, [_0]) + return formatWithArgumentRanges(self._s[2353]!, self._r[2353]!, [_0]) } - public var Notification_Exceptions_AlwaysOn: String { return self._s[2351]! } - public var UserInfo_NotificationsDisable: String { return self._s[2352]! } - public var Paint_Outlined: String { return self._s[2353]! } - public var Activity_PlayingGame: String { return self._s[2354]! } - public var SearchImages_NoImagesFound: String { return self._s[2355]! } - public var SocksProxySetup_ProxyType: String { return self._s[2356]! } - public var AppleWatch_ReplyPresetsHelp: String { return self._s[2358]! } - public var Settings_AppLanguage: String { return self._s[2359]! } - public var TwoStepAuth_ResetAccountHelp: String { return self._s[2360]! } - public var Common_ChoosePhoto: String { return self._s[2361]! } - public var Privacy_Calls_AlwaysAllow: String { return self._s[2362]! } - public var Activity_UploadingVideo: String { return self._s[2363]! } - public var ChannelInfo_DeleteChannelConfirmation: String { return self._s[2364]! } - public var NetworkUsageSettings_Wifi: String { return self._s[2365]! } - public var Channel_BanUser_PermissionReadMessages: String { return self._s[2366]! } - public var Checkout_PayWithTouchId: String { return self._s[2367]! } - public var Notifications_ExceptionsNone: String { return self._s[2369]! } + public var Notification_Exceptions_AlwaysOn: String { return self._s[2354]! } + public var UserInfo_NotificationsDisable: String { return self._s[2355]! } + public var Paint_Outlined: String { return self._s[2356]! } + public var Activity_PlayingGame: String { return self._s[2357]! } + public var SearchImages_NoImagesFound: String { return self._s[2358]! } + public var SocksProxySetup_ProxyType: String { return self._s[2359]! } + public var AppleWatch_ReplyPresetsHelp: String { return self._s[2361]! } + public var Settings_AppLanguage: String { return self._s[2362]! } + public var TwoStepAuth_ResetAccountHelp: String { return self._s[2363]! } + public var Common_ChoosePhoto: String { return self._s[2364]! } + public var Privacy_Calls_AlwaysAllow: String { return self._s[2365]! } + public var Activity_UploadingVideo: String { return self._s[2366]! } + public var ChannelInfo_DeleteChannelConfirmation: String { return self._s[2367]! } + public var NetworkUsageSettings_Wifi: String { return self._s[2368]! } + public var Channel_BanUser_PermissionReadMessages: String { return self._s[2369]! } + public var Checkout_PayWithTouchId: String { return self._s[2370]! } + public var Notifications_ExceptionsNone: String { return self._s[2372]! } public func Message_ForwardedMessageShort(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2370]!, self._r[2370]!, [_0]) + return formatWithArgumentRanges(self._s[2373]!, self._r[2373]!, [_0]) } - public var AuthSessions_IncompleteAttempts: String { return self._s[2372]! } - public var Passport_Address_Region: String { return self._s[2375]! } - public var PhotoEditor_TiltShift: String { return self._s[2376]! } - public var Settings_FAQ_URL: String { return self._s[2377]! } - public var SharedMedia_TitleLink: String { return self._s[2379]! } - public var Settings_PrivacySettings: String { return self._s[2380]! } - public var Passport_Identity_TypePassportUploadScan: String { return self._s[2381]! } - public var Passport_Language_sl: String { return self._s[2382]! } - public var Settings_SetProfilePhoto: String { return self._s[2383]! } - public var Channel_About_Help: String { return self._s[2384]! } - public var Contacts_PermissionsEnable: String { return self._s[2385]! } - public var AttachmentMenu_SendAsFiles: String { return self._s[2386]! } - public var Passport_Address_AddTemporaryRegistration: String { return self._s[2388]! } - public var PrivacySettings_DeleteAccountTitle: String { return self._s[2389]! } - public var AccessDenied_VideoMessageCamera: String { return self._s[2391]! } - public var Map_OpenInYandexMaps: String { return self._s[2393]! } - public var PhotoEditor_SaturationTool: String { return self._s[2394]! } - public var Notification_Exceptions_NewException_NotificationHeader: String { return self._s[2395]! } - public var Appearance_TextSize: String { return self._s[2397]! } - public var Channel_Username_InvalidTooShort: String { return self._s[2399]! } - public var Passport_PassportInformation: String { return self._s[2402]! } - public var WatchRemote_AlertTitle: String { return self._s[2403]! } - public var Privacy_GroupsAndChannels_NeverAllow: String { return self._s[2404]! } - public var ConvertToSupergroup_HelpText: String { return self._s[2406]! } + public var AuthSessions_IncompleteAttempts: String { return self._s[2375]! } + public var Passport_Address_Region: String { return self._s[2378]! } + public var PhotoEditor_TiltShift: String { return self._s[2379]! } + public var Settings_FAQ_URL: String { return self._s[2380]! } + public var SharedMedia_TitleLink: String { return self._s[2382]! } + public var Settings_PrivacySettings: String { return self._s[2383]! } + public var Passport_Identity_TypePassportUploadScan: String { return self._s[2384]! } + public var Passport_Language_sl: String { return self._s[2385]! } + public var Settings_SetProfilePhoto: String { return self._s[2386]! } + public var Channel_About_Help: String { return self._s[2387]! } + public var Contacts_PermissionsEnable: String { return self._s[2388]! } + public var AttachmentMenu_SendAsFiles: String { return self._s[2389]! } + public var Passport_Address_AddTemporaryRegistration: String { return self._s[2391]! } + public var PrivacySettings_DeleteAccountTitle: String { return self._s[2392]! } + public var AccessDenied_VideoMessageCamera: String { return self._s[2394]! } + public var Map_OpenInYandexMaps: String { return self._s[2396]! } + public var PhotoEditor_SaturationTool: String { return self._s[2397]! } + public var Notification_Exceptions_NewException_NotificationHeader: String { return self._s[2398]! } + public var Appearance_TextSize: String { return self._s[2400]! } + public var Channel_Username_InvalidTooShort: String { return self._s[2402]! } + public var Passport_PassportInformation: String { return self._s[2405]! } + public var WatchRemote_AlertTitle: String { return self._s[2406]! } + public var Privacy_GroupsAndChannels_NeverAllow: String { return self._s[2407]! } + public var ConvertToSupergroup_HelpText: String { return self._s[2409]! } public func Time_MonthOfYear_m7(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2407]!, self._r[2407]!, [_0]) + return formatWithArgumentRanges(self._s[2410]!, self._r[2410]!, [_0]) } - public var Privacy_GroupsAndChannels_CustomHelp: String { return self._s[2408]! } - public var TwoStepAuth_RecoveryCodeInvalid: String { return self._s[2410]! } - public var AccessDenied_CameraDisabled: String { return self._s[2411]! } + public var Privacy_GroupsAndChannels_CustomHelp: String { return self._s[2411]! } + public var TwoStepAuth_RecoveryCodeInvalid: String { return self._s[2413]! } + public var AccessDenied_CameraDisabled: String { return self._s[2414]! } public func Channel_Username_UsernameIsAvailable(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2412]!, self._r[2412]!, [_0]) + return formatWithArgumentRanges(self._s[2415]!, self._r[2415]!, [_0]) } - public var PhotoEditor_ContrastTool: String { return self._s[2415]! } - public var DialogList_Draft: String { return self._s[2416]! } - public var Privacy_TopPeersDelete: String { return self._s[2418]! } - public var LoginPassword_PasswordPlaceholder: String { return self._s[2419]! } - public var Passport_Identity_TypeIdentityCardUploadScan: String { return self._s[2420]! } - public var WebSearch_RecentSectionClear: String { return self._s[2421]! } - public var Watch_ChatList_NoConversationsTitle: String { return self._s[2423]! } - public var Common_Done: String { return self._s[2424]! } - public var AuthSessions_EmptyText: String { return self._s[2425]! } - public var Conversation_ShareBotContactConfirmation: String { return self._s[2426]! } - public var Tour_Title5: String { return self._s[2427]! } + public var PhotoEditor_ContrastTool: String { return self._s[2418]! } + public var DialogList_Draft: String { return self._s[2419]! } + public var Privacy_TopPeersDelete: String { return self._s[2421]! } + public var LoginPassword_PasswordPlaceholder: String { return self._s[2422]! } + public var Passport_Identity_TypeIdentityCardUploadScan: String { return self._s[2423]! } + public var WebSearch_RecentSectionClear: String { return self._s[2424]! } + public var Watch_ChatList_NoConversationsTitle: String { return self._s[2426]! } + public var Common_Done: String { return self._s[2427]! } + public var AuthSessions_EmptyText: String { return self._s[2428]! } + public var Conversation_ShareBotContactConfirmation: String { return self._s[2429]! } + public var Tour_Title5: String { return self._s[2430]! } public func Map_DirectionsDriveEta(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2428]!, self._r[2428]!, [_0]) + return formatWithArgumentRanges(self._s[2431]!, self._r[2431]!, [_0]) } - public var ApplyLanguage_UnsufficientDataTitle: String { return self._s[2429]! } - public var Conversation_LinkDialogSave: String { return self._s[2430]! } - public var GroupInfo_ActionRestrict: String { return self._s[2431]! } - public var Checkout_Title: String { return self._s[2432]! } - public var Channel_AdminLog_CanChangeInfo: String { return self._s[2435]! } - public var Notification_RenamedGroup: String { return self._s[2436]! } - public var Checkout_PayWithFaceId: String { return self._s[2437]! } - public var Channel_BanList_BlockedTitle: String { return self._s[2438]! } + public var ApplyLanguage_UnsufficientDataTitle: String { return self._s[2432]! } + public var Conversation_LinkDialogSave: String { return self._s[2433]! } + public var GroupInfo_ActionRestrict: String { return self._s[2434]! } + public var Checkout_Title: String { return self._s[2435]! } + public var Channel_AdminLog_CanChangeInfo: String { return self._s[2438]! } + public var Notification_RenamedGroup: String { return self._s[2439]! } + public var Checkout_PayWithFaceId: String { return self._s[2440]! } + public var Channel_BanList_BlockedTitle: String { return self._s[2441]! } public func PINNED_TEXT_SEPARATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2440]!, self._r[2440]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2443]!, self._r[2443]!, [_1, _2]) } - public var Checkout_WebConfirmation_Title: String { return self._s[2441]! } - public var Notifications_MessageNotificationsAlert: String { return self._s[2442]! } - public var Profile_AddToExisting: String { return self._s[2444]! } + public var Checkout_WebConfirmation_Title: String { return self._s[2444]! } + public var Notifications_MessageNotificationsAlert: String { return self._s[2445]! } + public var Profile_AddToExisting: String { return self._s[2447]! } public func Profile_CreateEncryptedChatOutdatedError(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2445]!, self._r[2445]!, [_0, _1]) + return formatWithArgumentRanges(self._s[2448]!, self._r[2448]!, [_0, _1]) } - public var Cache_Files: String { return self._s[2448]! } - public var Permissions_PrivacyPolicy: String { return self._s[2449]! } - public var SocksProxySetup_ConnectAndSave: String { return self._s[2450]! } - public var UserInfo_NotificationsDefaultDisabled: String { return self._s[2451]! } + public var Cache_Files: String { return self._s[2451]! } + public var Permissions_PrivacyPolicy: String { return self._s[2452]! } + public var SocksProxySetup_ConnectAndSave: String { return self._s[2453]! } + public var UserInfo_NotificationsDefaultDisabled: String { return self._s[2454]! } public func MESSAGE_POLL(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2453]!, self._r[2453]!, [_1]) + return formatWithArgumentRanges(self._s[2456]!, self._r[2456]!, [_1]) } - public var Calls_NoCallsPlaceholder: String { return self._s[2455]! } - public var Channel_Username_RevokeExistingUsernamesInfo: String { return self._s[2456]! } - public var Notifications_ExceptionsGroupPlaceholder: String { return self._s[2458]! } - public var Passport_FieldAddressHelp: String { return self._s[2459]! } - public var Privacy_GroupsAndChannels_InviteToChannelMultipleError: String { return self._s[2460]! } + public var Calls_NoCallsPlaceholder: String { return self._s[2458]! } + public var Channel_Username_RevokeExistingUsernamesInfo: String { return self._s[2459]! } + public var Notifications_ExceptionsGroupPlaceholder: String { return self._s[2461]! } + public var Passport_FieldAddressHelp: String { return self._s[2462]! } + public var Privacy_GroupsAndChannels_InviteToChannelMultipleError: String { return self._s[2463]! } public func Login_TermsOfService_ProceedBot(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2461]!, self._r[2461]!, [_0]) + return formatWithArgumentRanges(self._s[2464]!, self._r[2464]!, [_0]) } - public var Channel_AdminLog_EmptyTitle: String { return self._s[2462]! } - public var Privacy_Calls_NeverAllow_Title: String { return self._s[2464]! } - public var Login_UnknownError: String { return self._s[2465]! } - public var Group_UpgradeNoticeText2: String { return self._s[2467]! } - public var Watch_Compose_AddContact: String { return self._s[2468]! } - public var Web_Error: String { return self._s[2469]! } - public var Profile_MessageLifetime1h: String { return self._s[2470]! } - public var CheckoutInfo_ReceiverInfoEmailPlaceholder: String { return self._s[2471]! } - public var Channel_Username_CheckingUsername: String { return self._s[2472]! } + public var Channel_AdminLog_EmptyTitle: String { return self._s[2465]! } + public var Privacy_Calls_NeverAllow_Title: String { return self._s[2467]! } + public var Login_UnknownError: String { return self._s[2468]! } + public var Group_UpgradeNoticeText2: String { return self._s[2470]! } + public var Watch_Compose_AddContact: String { return self._s[2471]! } + public var Web_Error: String { return self._s[2472]! } + public var Profile_MessageLifetime1h: String { return self._s[2473]! } + public var CheckoutInfo_ReceiverInfoEmailPlaceholder: String { return self._s[2474]! } + public var Channel_Username_CheckingUsername: String { return self._s[2475]! } public func PINNED_GAME(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2473]!, self._r[2473]!, [_1]) + return formatWithArgumentRanges(self._s[2476]!, self._r[2476]!, [_1]) } - public var Channel_AboutItem: String { return self._s[2474]! } - public var Privacy_GroupsAndChannels_AlwaysAllow_Placeholder: String { return self._s[2476]! } - public var GroupInfo_SharedMedia: String { return self._s[2477]! } + public var Channel_AboutItem: String { return self._s[2477]! } + public var Privacy_GroupsAndChannels_AlwaysAllow_Placeholder: String { return self._s[2479]! } + public var GroupInfo_SharedMedia: String { return self._s[2480]! } public func Channel_AdminLog_MessagePromotedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2478]!, self._r[2478]!, [_1]) + return formatWithArgumentRanges(self._s[2481]!, self._r[2481]!, [_1]) } - public var Call_PhoneCallInProgressMessage: String { return self._s[2479]! } - public var GroupInfo_InviteLink_RevokeAlert_Text: String { return self._s[2480]! } - public var Conversation_SearchByName_Placeholder: String { return self._s[2481]! } - public var CreatePoll_AddOption: String { return self._s[2482]! } - public var GroupInfo_Permissions_SearchPlaceholder: String { return self._s[2483]! } - public var Group_UpgradeNoticeHeader: String { return self._s[2484]! } - public var Channel_Management_AddModerator: String { return self._s[2485]! } - public var StickerPacksSettings_ShowStickersButton: String { return self._s[2486]! } - public var NotificationsSound_Hello: String { return self._s[2487]! } + public var Call_PhoneCallInProgressMessage: String { return self._s[2482]! } + public var GroupInfo_InviteLink_RevokeAlert_Text: String { return self._s[2483]! } + public var Conversation_SearchByName_Placeholder: String { return self._s[2484]! } + public var CreatePoll_AddOption: String { return self._s[2485]! } + public var GroupInfo_Permissions_SearchPlaceholder: String { return self._s[2486]! } + public var Group_UpgradeNoticeHeader: String { return self._s[2487]! } + public var Channel_Management_AddModerator: String { return self._s[2488]! } + public var StickerPacksSettings_ShowStickersButton: String { return self._s[2489]! } + public var NotificationsSound_Hello: String { return self._s[2490]! } public func CHAT_MESSAGE_GEO(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2488]!, self._r[2488]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2491]!, self._r[2491]!, [_1, _2]) } - public var SocksProxySetup_SavedProxies: String { return self._s[2489]! } - public var Channel_Stickers_Placeholder: String { return self._s[2491]! } + public var SocksProxySetup_SavedProxies: String { return self._s[2492]! } + public var Channel_Stickers_Placeholder: String { return self._s[2494]! } public func Login_EmailCodeBody(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2492]!, self._r[2492]!, [_0]) + return formatWithArgumentRanges(self._s[2495]!, self._r[2495]!, [_0]) } - public var PrivacyPolicy_DeclineDeclineAndDelete: String { return self._s[2493]! } - public var Channel_Management_AddModeratorHelp: String { return self._s[2494]! } - public var ContactInfo_BirthdayLabel: String { return self._s[2495]! } - public var ChangePhoneNumberCode_RequestingACall: String { return self._s[2496]! } - public var AutoDownloadSettings_Channels: String { return self._s[2497]! } - public var Passport_Language_mn: String { return self._s[2498]! } - public var Notifications_ResetAllNotificationsHelp: String { return self._s[2501]! } - public var Passport_Language_ja: String { return self._s[2503]! } - public var Settings_About_Title: String { return self._s[2504]! } - public var Settings_NotificationsAndSounds: String { return self._s[2505]! } - public var ChannelInfo_DeleteGroup: String { return self._s[2506]! } - public var Settings_BlockedUsers: String { return self._s[2507]! } + public var PrivacyPolicy_DeclineDeclineAndDelete: String { return self._s[2496]! } + public var Channel_Management_AddModeratorHelp: String { return self._s[2497]! } + public var ContactInfo_BirthdayLabel: String { return self._s[2498]! } + public var ChangePhoneNumberCode_RequestingACall: String { return self._s[2499]! } + public var AutoDownloadSettings_Channels: String { return self._s[2500]! } + public var Passport_Language_mn: String { return self._s[2501]! } + public var Notifications_ResetAllNotificationsHelp: String { return self._s[2504]! } + public var Settings_NotificationsAndSounds: String { return self._s[2506]! } + public var Settings_About_Title: String { return self._s[2507]! } + public var Settings_BlockedUsers: String { return self._s[2508]! } + public var ChannelInfo_DeleteGroup: String { return self._s[2509]! } + public var Passport_Language_ja: String { return self._s[2510]! } public func Time_MonthOfYear_m4(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2508]!, self._r[2508]!, [_0]) - } - public var Passport_Address_AddResidentialAddress: String { return self._s[2509]! } - public var Channel_Username_Title: String { return self._s[2510]! } - public func Notification_RemovedGroupPhoto(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2511]!, self._r[2511]!, [_0]) } - public var AttachmentMenu_File: String { return self._s[2513]! } - public var AppleWatch_Title: String { return self._s[2514]! } - public var Activity_RecordingVideoMessage: String { return self._s[2515]! } - public var Weekday_Saturday: String { return self._s[2516]! } - public var Profile_CreateEncryptedChatError: String { return self._s[2517]! } - public var Common_Next: String { return self._s[2519]! } - public var Channel_Stickers_YourStickers: String { return self._s[2521]! } - public var Call_AudioRouteHeadphones: String { return self._s[2522]! } - public var TwoStepAuth_EnterPasswordForgot: String { return self._s[2524]! } - public var Watch_Contacts_NoResults: String { return self._s[2526]! } - public var PhotoEditor_TintTool: String { return self._s[2528]! } - public var LoginPassword_ResetAccount: String { return self._s[2530]! } - public var Settings_SavedMessages: String { return self._s[2531]! } - public func MESSAGE_GIF_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2532]!, self._r[2532]!, [_1]) + public var Passport_Address_AddResidentialAddress: String { return self._s[2512]! } + public var Channel_Username_Title: String { return self._s[2513]! } + public func Notification_RemovedGroupPhoto(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2514]!, self._r[2514]!, [_0]) } - public var StickerPack_Add: String { return self._s[2533]! } - public var Your_cards_number_is_invalid: String { return self._s[2534]! } - public var Checkout_TotalAmount: String { return self._s[2535]! } + public var AttachmentMenu_File: String { return self._s[2516]! } + public var AppleWatch_Title: String { return self._s[2517]! } + public var Activity_RecordingVideoMessage: String { return self._s[2518]! } + public var Weekday_Saturday: String { return self._s[2519]! } + public var Profile_CreateEncryptedChatError: String { return self._s[2520]! } + public var Common_Next: String { return self._s[2522]! } + public var Channel_Stickers_YourStickers: String { return self._s[2524]! } + public var Call_AudioRouteHeadphones: String { return self._s[2525]! } + public var TwoStepAuth_EnterPasswordForgot: String { return self._s[2527]! } + public var Watch_Contacts_NoResults: String { return self._s[2529]! } + public var PhotoEditor_TintTool: String { return self._s[2531]! } + public var LoginPassword_ResetAccount: String { return self._s[2533]! } + public var Settings_SavedMessages: String { return self._s[2534]! } + public func MESSAGE_GIF_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2535]!, self._r[2535]!, [_1]) + } + public var StickerPack_Add: String { return self._s[2536]! } + public var Your_cards_number_is_invalid: String { return self._s[2537]! } + public var Checkout_TotalAmount: String { return self._s[2538]! } public func ChangePhoneNumberCode_CallTimer(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2536]!, self._r[2536]!, [_0]) + return formatWithArgumentRanges(self._s[2539]!, self._r[2539]!, [_0]) } public func GroupPermission_AddedInfo(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2537]!, self._r[2537]!, [_1, _2]) - } - public var ChatSettings_ConnectionType_UseSocks5: String { return self._s[2538]! } - public func CHANNEL_MESSAGE_STICKER(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2540]!, self._r[2540]!, [_1, _2]) } - public func Conversation_RestrictedTextTimed(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2541]!, self._r[2541]!, [_0]) + public var ChatSettings_ConnectionType_UseSocks5: String { return self._s[2541]! } + public func CHANNEL_MESSAGE_STICKER(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2543]!, self._r[2543]!, [_1, _2]) } - public var GroupInfo_InviteLink_ShareLink: String { return self._s[2542]! } - public var StickerPack_Share: String { return self._s[2543]! } - public var Passport_DeleteAddress: String { return self._s[2544]! } - public var Settings_Passport: String { return self._s[2545]! } - public var SharedMedia_EmptyFilesText: String { return self._s[2546]! } - public var Conversation_DeleteMessagesForMe: String { return self._s[2547]! } - public var PasscodeSettings_AutoLock_IfAwayFor_1hour: String { return self._s[2548]! } - public var Contacts_PermissionsText: String { return self._s[2549]! } - public var Group_Setup_HistoryVisible: String { return self._s[2550]! } - public var Passport_Address_AddRentalAgreement: String { return self._s[2552]! } - public var SocksProxySetup_Title: String { return self._s[2553]! } - public var Notification_Mute1h: String { return self._s[2554]! } + public func Conversation_RestrictedTextTimed(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2544]!, self._r[2544]!, [_0]) + } + public var GroupInfo_InviteLink_ShareLink: String { return self._s[2545]! } + public var StickerPack_Share: String { return self._s[2546]! } + public var Passport_DeleteAddress: String { return self._s[2547]! } + public var Settings_Passport: String { return self._s[2548]! } + public var SharedMedia_EmptyFilesText: String { return self._s[2549]! } + public var Conversation_DeleteMessagesForMe: String { return self._s[2550]! } + public var PasscodeSettings_AutoLock_IfAwayFor_1hour: String { return self._s[2551]! } + public var Contacts_PermissionsText: String { return self._s[2552]! } + public var Group_Setup_HistoryVisible: String { return self._s[2553]! } + public var Passport_Address_AddRentalAgreement: String { return self._s[2555]! } + public var SocksProxySetup_Title: String { return self._s[2556]! } + public var Notification_Mute1h: String { return self._s[2557]! } public func Passport_Email_CodeHelp(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2555]!, self._r[2555]!, [_0]) + return formatWithArgumentRanges(self._s[2558]!, self._r[2558]!, [_0]) } public func PINNED_CONTACT_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2556]!, self._r[2556]!, [_1]) + return formatWithArgumentRanges(self._s[2559]!, self._r[2559]!, [_1]) } - public var FastTwoStepSetup_PasswordSection: String { return self._s[2557]! } - public var NetworkUsageSettings_ResetStatsConfirmation: String { return self._s[2560]! } - public var InfoPlist_NSFaceIDUsageDescription: String { return self._s[2562]! } - public var DialogList_NoMessagesText: String { return self._s[2563]! } - public var Privacy_ContactsResetConfirmation: String { return self._s[2564]! } - public var Privacy_Calls_P2PHelp: String { return self._s[2565]! } - public var Your_cards_expiration_year_is_invalid: String { return self._s[2567]! } - public var Common_TakePhotoOrVideo: String { return self._s[2568]! } - public var Call_StatusBusy: String { return self._s[2569]! } - public var Conversation_PinnedMessage: String { return self._s[2570]! } - public var AutoDownloadSettings_VoiceMessagesTitle: String { return self._s[2571]! } - public var TwoStepAuth_SetupPasswordConfirmFailed: String { return self._s[2572]! } - public var AppleWatch_ReplyPresets: String { return self._s[2573]! } - public var Passport_DiscardMessageDescription: String { return self._s[2575]! } - public var Login_NetworkError: String { return self._s[2576]! } + public var FastTwoStepSetup_PasswordSection: String { return self._s[2560]! } + public var NetworkUsageSettings_ResetStatsConfirmation: String { return self._s[2563]! } + public var InfoPlist_NSFaceIDUsageDescription: String { return self._s[2565]! } + public var DialogList_NoMessagesText: String { return self._s[2566]! } + public var Privacy_ContactsResetConfirmation: String { return self._s[2567]! } + public var Privacy_Calls_P2PHelp: String { return self._s[2568]! } + public var Your_cards_expiration_year_is_invalid: String { return self._s[2570]! } + public var Common_TakePhotoOrVideo: String { return self._s[2571]! } + public var Call_StatusBusy: String { return self._s[2572]! } + public var Conversation_PinnedMessage: String { return self._s[2573]! } + public var AutoDownloadSettings_VoiceMessagesTitle: String { return self._s[2574]! } + public var TwoStepAuth_SetupPasswordConfirmFailed: String { return self._s[2575]! } + public var AppleWatch_ReplyPresets: String { return self._s[2576]! } + public var Passport_DiscardMessageDescription: String { return self._s[2578]! } + public var Login_NetworkError: String { return self._s[2579]! } public func Notification_PinnedRoundMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2577]!, self._r[2577]!, [_0]) + return formatWithArgumentRanges(self._s[2580]!, self._r[2580]!, [_0]) } public func Channel_AdminLog_MessageRemovedChannelUsername(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2578]!, self._r[2578]!, [_0]) + return formatWithArgumentRanges(self._s[2581]!, self._r[2581]!, [_0]) } - public var SocksProxySetup_PasswordPlaceholder: String { return self._s[2579]! } + public var SocksProxySetup_PasswordPlaceholder: String { return self._s[2582]! } public func CONTACT_JOINED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2581]!, self._r[2581]!, [_1]) + return formatWithArgumentRanges(self._s[2584]!, self._r[2584]!, [_1]) } - public var Login_ResetAccountProtected_LimitExceeded: String { return self._s[2582]! } + public var Login_ResetAccountProtected_LimitExceeded: String { return self._s[2585]! } public func Watch_LastSeen_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2584]!, self._r[2584]!, [_0]) + return formatWithArgumentRanges(self._s[2587]!, self._r[2587]!, [_0]) } - public var Call_ConnectionErrorMessage: String { return self._s[2585]! } - public var Compose_GroupTokenListPlaceholder: String { return self._s[2587]! } - public var ConversationMedia_Title: String { return self._s[2588]! } - public var EncryptionKey_Title: String { return self._s[2590]! } - public var TwoStepAuth_EnterPasswordTitle: String { return self._s[2591]! } - public var Notification_Exceptions_AddException: String { return self._s[2592]! } - public var Profile_MessageLifetime1m: String { return self._s[2593]! } + public var Call_ConnectionErrorMessage: String { return self._s[2588]! } + public var Compose_GroupTokenListPlaceholder: String { return self._s[2590]! } + public var ConversationMedia_Title: String { return self._s[2591]! } + public var EncryptionKey_Title: String { return self._s[2593]! } + public var TwoStepAuth_EnterPasswordTitle: String { return self._s[2594]! } + public var Notification_Exceptions_AddException: String { return self._s[2595]! } + public var Profile_MessageLifetime1m: String { return self._s[2596]! } public func Channel_AdminLog_MessageUnkickedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2594]!, self._r[2594]!, [_1]) + return formatWithArgumentRanges(self._s[2597]!, self._r[2597]!, [_1]) } - public var Month_GenMay: String { return self._s[2595]! } + public var Month_GenMay: String { return self._s[2598]! } public func LiveLocationUpdated_TodayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2596]!, self._r[2596]!, [_0]) + return formatWithArgumentRanges(self._s[2599]!, self._r[2599]!, [_0]) } - public var ChannelMembers_WhoCanAddMembersAllHelp: String { return self._s[2597]! } - public var Conversation_EmptyPlaceholder: String { return self._s[2599]! } - public var Passport_Address_AddPassportRegistration: String { return self._s[2600]! } - public var Notifications_ChannelNotificationsAlert: String { return self._s[2601]! } - public var Camera_TapAndHoldForVideo: String { return self._s[2602]! } - public var Channel_JoinChannel: String { return self._s[2604]! } - public var Appearance_Animations: String { return self._s[2607]! } + public var ChannelMembers_WhoCanAddMembersAllHelp: String { return self._s[2600]! } + public var Conversation_EmptyPlaceholder: String { return self._s[2602]! } + public var Passport_Address_AddPassportRegistration: String { return self._s[2603]! } + public var Notifications_ChannelNotificationsAlert: String { return self._s[2604]! } + public var Camera_TapAndHoldForVideo: String { return self._s[2605]! } + public var Channel_JoinChannel: String { return self._s[2607]! } + public var Appearance_Animations: String { return self._s[2610]! } public func Notification_MessageLifetimeChanged(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2608]!, self._r[2608]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2611]!, self._r[2611]!, [_1, _2]) } - public var Stickers_GroupStickers: String { return self._s[2610]! } - public var ConvertToSupergroup_HelpTitle: String { return self._s[2612]! } - public var Passport_Address_Street: String { return self._s[2613]! } - public var Conversation_AddContact: String { return self._s[2614]! } - public var Login_PhonePlaceholder: String { return self._s[2615]! } - public var Channel_Members_InviteLink: String { return self._s[2617]! } - public var Bot_Stop: String { return self._s[2618]! } - public var Notification_PassportValueAddress: String { return self._s[2620]! } - public var Month_ShortJuly: String { return self._s[2621]! } - public var Passport_Address_TypeTemporaryRegistrationUploadScan: String { return self._s[2622]! } - public var Channel_AdminLog_BanSendMedia: String { return self._s[2623]! } - public var Passport_Identity_ReverseSide: String { return self._s[2624]! } - public var Watch_Stickers_Recents: String { return self._s[2627]! } - public var PrivacyLastSeenSettings_EmpryUsersPlaceholder: String { return self._s[2629]! } - public var Map_SendThisLocation: String { return self._s[2630]! } + public var Stickers_GroupStickers: String { return self._s[2613]! } + public var ConvertToSupergroup_HelpTitle: String { return self._s[2615]! } + public var Passport_Address_Street: String { return self._s[2616]! } + public var Conversation_AddContact: String { return self._s[2617]! } + public var Login_PhonePlaceholder: String { return self._s[2618]! } + public var Channel_Members_InviteLink: String { return self._s[2620]! } + public var Bot_Stop: String { return self._s[2621]! } + public var Notification_PassportValueAddress: String { return self._s[2623]! } + public var Month_ShortJuly: String { return self._s[2624]! } + public var Passport_Address_TypeTemporaryRegistrationUploadScan: String { return self._s[2625]! } + public var Channel_AdminLog_BanSendMedia: String { return self._s[2626]! } + public var Passport_Identity_ReverseSide: String { return self._s[2627]! } + public var Watch_Stickers_Recents: String { return self._s[2630]! } + public var PrivacyLastSeenSettings_EmpryUsersPlaceholder: String { return self._s[2632]! } + public var Map_SendThisLocation: String { return self._s[2633]! } public func Time_MonthOfYear_m1(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2631]!, self._r[2631]!, [_0]) + return formatWithArgumentRanges(self._s[2634]!, self._r[2634]!, [_0]) } public func CHANNEL_MESSAGE_STICKER_SEPARATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2632]!, self._r[2632]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2635]!, self._r[2635]!, [_1, _2]) } public func InviteText_SingleContact(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2633]!, self._r[2633]!, [_0]) + return formatWithArgumentRanges(self._s[2636]!, self._r[2636]!, [_0]) } - public var ConvertToSupergroup_Note: String { return self._s[2634]! } + public var ConvertToSupergroup_Note: String { return self._s[2637]! } public func FileSize_MB(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2635]!, self._r[2635]!, [_0]) + return formatWithArgumentRanges(self._s[2638]!, self._r[2638]!, [_0]) } - public var NetworkUsageSettings_GeneralDataSection: String { return self._s[2636]! } + public var NetworkUsageSettings_GeneralDataSection: String { return self._s[2639]! } public func PINNED_POLL_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2637]!, self._r[2637]!, [_1]) + return formatWithArgumentRanges(self._s[2640]!, self._r[2640]!, [_1]) } public func Compatibility_SecretMediaVersionTooLow(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2638]!, self._r[2638]!, [_0, _1]) + return formatWithArgumentRanges(self._s[2641]!, self._r[2641]!, [_0, _1]) } - public var Login_CallRequestState3: String { return self._s[2639]! } + public var Login_CallRequestState3: String { return self._s[2642]! } public func CHANNEL_MESSAGE_GEO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2642]!, self._r[2642]!, [_1]) + return formatWithArgumentRanges(self._s[2645]!, self._r[2645]!, [_1]) } - public var PasscodeSettings_UnlockWithFaceId: String { return self._s[2643]! } - public var Channel_AdminLogFilter_Title: String { return self._s[2644]! } - public var Notifications_GroupNotificationsExceptions: String { return self._s[2648]! } + public var PasscodeSettings_UnlockWithFaceId: String { return self._s[2646]! } + public var Channel_AdminLogFilter_Title: String { return self._s[2647]! } + public var Notifications_GroupNotificationsExceptions: String { return self._s[2651]! } public func FileSize_B(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2649]!, self._r[2649]!, [_0]) + return formatWithArgumentRanges(self._s[2652]!, self._r[2652]!, [_0]) } - public var Passport_CorrectErrors: String { return self._s[2650]! } + public var Passport_CorrectErrors: String { return self._s[2653]! } public func Channel_MessageTitleUpdated(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2651]!, self._r[2651]!, [_0]) + return formatWithArgumentRanges(self._s[2654]!, self._r[2654]!, [_0]) } - public var Map_SendMyCurrentLocation: String { return self._s[2652]! } - public var SharedMedia_SearchNoResults: String { return self._s[2653]! } - public var Permissions_NotificationsText_v0: String { return self._s[2654]! } - public var LoginPassword_FloodError: String { return self._s[2655]! } - public var Group_Setup_HistoryHiddenHelp: String { return self._s[2657]! } + public var Map_SendMyCurrentLocation: String { return self._s[2655]! } + public var SharedMedia_SearchNoResults: String { return self._s[2656]! } + public var Permissions_NotificationsText_v0: String { return self._s[2657]! } + public var LoginPassword_FloodError: String { return self._s[2658]! } + public var Group_Setup_HistoryHiddenHelp: String { return self._s[2660]! } public func TwoStepAuth_PendingEmailHelp(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2658]!, self._r[2658]!, [_0]) - } - public var Passport_Language_bn: String { return self._s[2659]! } - public func DialogList_SingleUploadingPhotoSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2660]!, self._r[2660]!, [_0]) - } - public func Notification_PinnedAudioMessage(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2661]!, self._r[2661]!, [_0]) } + public var Passport_Language_bn: String { return self._s[2662]! } + public func DialogList_SingleUploadingPhotoSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2663]!, self._r[2663]!, [_0]) + } + public func Notification_PinnedAudioMessage(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2664]!, self._r[2664]!, [_0]) + } public func Channel_AdminLog_MessageChangedGroupStickerPack(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2662]!, self._r[2662]!, [_0]) + return formatWithArgumentRanges(self._s[2665]!, self._r[2665]!, [_0]) } - public var GroupInfo_InvitationLinkGroupFull: String { return self._s[2665]! } - public var Group_EditAdmin_PermissionChangeInfo: String { return self._s[2667]! } - public var Contacts_PermissionsAllow: String { return self._s[2668]! } - public var ReportPeer_ReasonCopyright: String { return self._s[2669]! } - public var Channel_EditAdmin_PermissinAddAdminOn: String { return self._s[2670]! } - public var Paint_Duplicate: String { return self._s[2671]! } - public var Notification_ChannelMigratedFrom: String { return self._s[2672]! } - public var Passport_Address_Country: String { return self._s[2673]! } - public var Notification_RenamedChannel: String { return self._s[2675]! } - public var CheckoutInfo_ErrorPostcodeInvalid: String { return self._s[2676]! } - public var Group_MessagePhotoUpdated: String { return self._s[2677]! } - public var Channel_BanUser_PermissionSendMedia: String { return self._s[2678]! } - public var Conversation_ContextMenuBan: String { return self._s[2679]! } - public var TwoStepAuth_EmailSent: String { return self._s[2680]! } - public var MessagePoll_NoVotes: String { return self._s[2681]! } - public var Passport_Language_is: String { return self._s[2682]! } - public var Tour_Text5: String { return self._s[2684]! } + public var GroupInfo_InvitationLinkGroupFull: String { return self._s[2668]! } + public var Group_EditAdmin_PermissionChangeInfo: String { return self._s[2670]! } + public var Contacts_PermissionsAllow: String { return self._s[2671]! } + public var ReportPeer_ReasonCopyright: String { return self._s[2672]! } + public var Channel_EditAdmin_PermissinAddAdminOn: String { return self._s[2673]! } + public var Paint_Duplicate: String { return self._s[2674]! } + public var Passport_Address_Country: String { return self._s[2675]! } + public var Notification_RenamedChannel: String { return self._s[2677]! } + public var CheckoutInfo_ErrorPostcodeInvalid: String { return self._s[2678]! } + public var Group_MessagePhotoUpdated: String { return self._s[2679]! } + public var Channel_BanUser_PermissionSendMedia: String { return self._s[2680]! } + public var Conversation_ContextMenuBan: String { return self._s[2681]! } + public var TwoStepAuth_EmailSent: String { return self._s[2682]! } + public var MessagePoll_NoVotes: String { return self._s[2683]! } + public var Passport_Language_is: String { return self._s[2684]! } + public var Tour_Text5: String { return self._s[2686]! } public func Call_GroupFormat(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2686]!, self._r[2686]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2688]!, self._r[2688]!, [_1, _2]) } - public var Paint_Edit: String { return self._s[2688]! } - public var LoginPassword_ForgotPassword: String { return self._s[2691]! } - public var GroupInfo_GroupNamePlaceholder: String { return self._s[2692]! } + public var Paint_Edit: String { return self._s[2690]! } + public var LoginPassword_ForgotPassword: String { return self._s[2693]! } + public var GroupInfo_GroupNamePlaceholder: String { return self._s[2694]! } public func Notification_Kicked(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2693]!, self._r[2693]!, [_0, _1]) + return formatWithArgumentRanges(self._s[2695]!, self._r[2695]!, [_0, _1]) } - public var Conversation_InputTextCaptionPlaceholder: String { return self._s[2694]! } - public var AutoDownloadSettings_VideoMessagesTitle: String { return self._s[2695]! } - public var Conversation_PinMessageAlertGroup: String { return self._s[2696]! } - public var Passport_Language_uz: String { return self._s[2697]! } - public var Map_StopLiveLocation: String { return self._s[2699]! } - public var PasscodeSettings_Help: String { return self._s[2701]! } - public var NotificationsSound_Input: String { return self._s[2702]! } - public var Share_Title: String { return self._s[2704]! } - public var Login_TermsOfServiceAgree: String { return self._s[2705]! } - public var Compose_NewEncryptedChatTitle: String { return self._s[2706]! } - public var Channel_AdminLog_TitleSelectedEvents: String { return self._s[2707]! } - public var Channel_EditAdmin_PermissionEditMessages: String { return self._s[2708]! } - public var EnterPasscode_EnterTitle: String { return self._s[2709]! } + public var Conversation_InputTextCaptionPlaceholder: String { return self._s[2696]! } + public var AutoDownloadSettings_VideoMessagesTitle: String { return self._s[2697]! } + public var Conversation_PinMessageAlertGroup: String { return self._s[2698]! } + public var Passport_Language_uz: String { return self._s[2699]! } + public var Map_StopLiveLocation: String { return self._s[2701]! } + public var PasscodeSettings_Help: String { return self._s[2703]! } + public var NotificationsSound_Input: String { return self._s[2704]! } + public var Share_Title: String { return self._s[2706]! } + public var Login_TermsOfServiceAgree: String { return self._s[2707]! } + public var Compose_NewEncryptedChatTitle: String { return self._s[2708]! } + public var Channel_AdminLog_TitleSelectedEvents: String { return self._s[2709]! } + public var Channel_EditAdmin_PermissionEditMessages: String { return self._s[2710]! } + public var EnterPasscode_EnterTitle: String { return self._s[2711]! } public func Call_PrivacyErrorMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2710]!, self._r[2710]!, [_0]) + return formatWithArgumentRanges(self._s[2712]!, self._r[2712]!, [_0]) } - public var Settings_CopyPhoneNumber: String { return self._s[2711]! } - public var NotificationsSound_Keys: String { return self._s[2712]! } + public var Settings_CopyPhoneNumber: String { return self._s[2713]! } + public var NotificationsSound_Keys: String { return self._s[2714]! } public func Call_ParticipantVersionOutdatedError(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2713]!, self._r[2713]!, [_0]) + return formatWithArgumentRanges(self._s[2715]!, self._r[2715]!, [_0]) } - public var Notification_MessageLifetime1w: String { return self._s[2714]! } - public var Message_Video: String { return self._s[2715]! } + public var Notification_MessageLifetime1w: String { return self._s[2716]! } + public var Message_Video: String { return self._s[2717]! } public func MESSAGE_GEO_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2718]!, self._r[2718]!, [_1]) + return formatWithArgumentRanges(self._s[2720]!, self._r[2720]!, [_1]) } public func Notification_JoinedChat(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2719]!, self._r[2719]!, [_0]) + return formatWithArgumentRanges(self._s[2721]!, self._r[2721]!, [_0]) } public func PrivacySettings_LastSeenContactsPlus(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2720]!, self._r[2720]!, [_0]) + return formatWithArgumentRanges(self._s[2722]!, self._r[2722]!, [_0]) } - public var Passport_Language_mk: String { return self._s[2721]! } - public var CreatePoll_CancelConfirmation: String { return self._s[2722]! } - public var Conversation_SilentBroadcastTooltipOn: String { return self._s[2724]! } - public var PrivacyPolicy_Decline: String { return self._s[2725]! } - public var Passport_Identity_DoesNotExpire: String { return self._s[2726]! } - public var Channel_AdminLogFilter_EventsRestrictions: String { return self._s[2727]! } - public var Permissions_SiriAllow_v0: String { return self._s[2728]! } + public var Passport_Language_mk: String { return self._s[2723]! } + public var CreatePoll_CancelConfirmation: String { return self._s[2724]! } + public var Conversation_SilentBroadcastTooltipOn: String { return self._s[2726]! } + public var PrivacyPolicy_Decline: String { return self._s[2727]! } + public var Passport_Identity_DoesNotExpire: String { return self._s[2728]! } + public var Channel_AdminLogFilter_EventsRestrictions: String { return self._s[2729]! } + public var Permissions_SiriAllow_v0: String { return self._s[2730]! } public func CHAT_MESSAGE_STICKER(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2729]!, self._r[2729]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2731]!, self._r[2731]!, [_1, _2, _3]) } public func CHANNEL_MESSAGES(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2730]!, self._r[2730]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2732]!, self._r[2732]!, [_1, _2]) } public func Notification_RenamedChat(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2731]!, self._r[2731]!, [_0]) + return formatWithArgumentRanges(self._s[2733]!, self._r[2733]!, [_0]) } - public var Paint_Regular: String { return self._s[2732]! } - public var ChatSettings_AutoDownloadReset: String { return self._s[2733]! } - public var BlockedUsers_SelectUserTitle: String { return self._s[2734]! } - public var GroupInfo_InviteByLink: String { return self._s[2736]! } - public var MessageTimer_Custom: String { return self._s[2737]! } - public var UserInfo_NotificationsDefaultEnabled: String { return self._s[2738]! } - public var Passport_Address_TypeTemporaryRegistration: String { return self._s[2740]! } - public var Channel_Username_InvalidTaken: String { return self._s[2741]! } - public var Conversation_ClousStorageInfo_Description3: String { return self._s[2742]! } + public var Paint_Regular: String { return self._s[2734]! } + public var ChatSettings_AutoDownloadReset: String { return self._s[2735]! } + public var BlockedUsers_SelectUserTitle: String { return self._s[2736]! } + public var GroupInfo_InviteByLink: String { return self._s[2738]! } + public var MessageTimer_Custom: String { return self._s[2739]! } + public var UserInfo_NotificationsDefaultEnabled: String { return self._s[2740]! } + public var Passport_Address_TypeTemporaryRegistration: String { return self._s[2742]! } + public var Channel_Username_InvalidTaken: String { return self._s[2743]! } + public var Conversation_ClousStorageInfo_Description3: String { return self._s[2744]! } public func CHANNEL_MESSAGE_VIDEO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2743]!, self._r[2743]!, [_1]) + return formatWithArgumentRanges(self._s[2745]!, self._r[2745]!, [_1]) } - public var Settings_ChatBackground: String { return self._s[2744]! } - public var Channel_Subscribers_Title: String { return self._s[2745]! } - public var ApplyLanguage_ChangeLanguageTitle: String { return self._s[2746]! } - public var Watch_ConnectionDescription: String { return self._s[2747]! } + public var Settings_ChatBackground: String { return self._s[2746]! } + public var Channel_Subscribers_Title: String { return self._s[2747]! } + public var ApplyLanguage_ChangeLanguageTitle: String { return self._s[2748]! } + public var Watch_ConnectionDescription: String { return self._s[2749]! } public func PINNED_VIDEO_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2751]!, self._r[2751]!, [_1]) + return formatWithArgumentRanges(self._s[2753]!, self._r[2753]!, [_1]) } - public var EditProfile_Title: String { return self._s[2752]! } - public var NotificationsSound_Bamboo: String { return self._s[2754]! } - public var Channel_AdminLog_MessagePreviousMessage: String { return self._s[2756]! } - public var Login_SmsRequestState2: String { return self._s[2757]! } - public var Passport_Language_ar: String { return self._s[2758]! } - public var Conversation_MessageDialogEdit: String { return self._s[2759]! } - public var Common_Close: String { return self._s[2760]! } + public var EditProfile_Title: String { return self._s[2754]! } + public var NotificationsSound_Bamboo: String { return self._s[2756]! } + public var Channel_AdminLog_MessagePreviousMessage: String { return self._s[2758]! } + public var Login_SmsRequestState2: String { return self._s[2759]! } + public var Passport_Language_ar: String { return self._s[2760]! } + public var Conversation_MessageDialogEdit: String { return self._s[2761]! } + public var Common_Close: String { return self._s[2762]! } public func CHAT_MESSAGE_TEXT_SEPARATED(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2764]!, self._r[2764]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2766]!, self._r[2766]!, [_1, _2, _3]) } public func Channel_AdminLog_MessageToggleInvitesOff(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2765]!, self._r[2765]!, [_0]) - } - public var UserInfo_About_Placeholder: String { return self._s[2766]! } - public func Conversation_FileHowToText(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2767]!, self._r[2767]!, [_0]) } - public var GroupInfo_Permissions_SectionTitle: String { return self._s[2768]! } - public var Channel_Info_Banned: String { return self._s[2770]! } - public func Time_MonthOfYear_m11(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2771]!, self._r[2771]!, [_0]) + public var UserInfo_About_Placeholder: String { return self._s[2768]! } + public func Conversation_FileHowToText(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2769]!, self._r[2769]!, [_0]) } - public var Passport_Language_my: String { return self._s[2772]! } + public var GroupInfo_Permissions_SectionTitle: String { return self._s[2770]! } + public var Channel_Info_Banned: String { return self._s[2772]! } + public func Time_MonthOfYear_m11(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2773]!, self._r[2773]!, [_0]) + } + public var Passport_Language_my: String { return self._s[2774]! } public func CHAT_MESSAGE_GEO_SEPARATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2773]!, self._r[2773]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2775]!, self._r[2775]!, [_1, _2]) } public func Time_PreciseDate_m9(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2774]!, self._r[2774]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2776]!, self._r[2776]!, [_1, _2, _3]) } - public var Preview_CopyAddress: String { return self._s[2775]! } + public var Preview_CopyAddress: String { return self._s[2777]! } public func DialogList_SinglePlayingGameSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2776]!, self._r[2776]!, [_0]) + return formatWithArgumentRanges(self._s[2778]!, self._r[2778]!, [_0]) } - public var KeyCommand_JumpToPreviousChat: String { return self._s[2777]! } - public var UserInfo_BotSettings: String { return self._s[2778]! } - public var LiveLocation_MenuStopAll: String { return self._s[2780]! } - public var Passport_PasswordCreate: String { return self._s[2781]! } - public var StickerSettings_MaskContextInfo: String { return self._s[2782]! } - public var Message_PinnedLocationMessage: String { return self._s[2783]! } - public var Map_Satellite: String { return self._s[2784]! } - public var Watch_Message_Unsupported: String { return self._s[2785]! } - public var Username_TooManyPublicUsernamesError: String { return self._s[2786]! } - public var TwoStepAuth_EnterPasswordInvalid: String { return self._s[2787]! } + public var KeyCommand_JumpToPreviousChat: String { return self._s[2779]! } + public var UserInfo_BotSettings: String { return self._s[2780]! } + public var LiveLocation_MenuStopAll: String { return self._s[2782]! } + public var Passport_PasswordCreate: String { return self._s[2783]! } + public var StickerSettings_MaskContextInfo: String { return self._s[2784]! } + public var Message_PinnedLocationMessage: String { return self._s[2785]! } + public var Map_Satellite: String { return self._s[2786]! } + public var Watch_Message_Unsupported: String { return self._s[2787]! } + public var Username_TooManyPublicUsernamesError: String { return self._s[2788]! } + public var TwoStepAuth_EnterPasswordInvalid: String { return self._s[2789]! } public func Notification_PinnedTextMessage(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2788]!, self._r[2788]!, [_0, _1]) + return formatWithArgumentRanges(self._s[2790]!, self._r[2790]!, [_0, _1]) } - public var Notifications_ChannelNotificationsHelp: String { return self._s[2789]! } - public var Privacy_Calls_P2PContacts: String { return self._s[2790]! } - public var NotificationsSound_None: String { return self._s[2791]! } - public var AccessDenied_VoiceMicrophone: String { return self._s[2793]! } + public var Notifications_ChannelNotificationsHelp: String { return self._s[2791]! } + public var Privacy_Calls_P2PContacts: String { return self._s[2792]! } + public var NotificationsSound_None: String { return self._s[2793]! } + public var AccessDenied_VoiceMicrophone: String { return self._s[2795]! } public func ApplyLanguage_ChangeLanguageAlreadyActive(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2794]!, self._r[2794]!, [_1]) + return formatWithArgumentRanges(self._s[2796]!, self._r[2796]!, [_1]) } - public var Cache_Indexing: String { return self._s[2795]! } - public var DialogList_RecentTitlePeople: String { return self._s[2797]! } - public var DialogList_EncryptionRejected: String { return self._s[2798]! } - public var GroupInfo_Administrators: String { return self._s[2799]! } - public var Passport_ScanPassportHelp: String { return self._s[2800]! } - public var Application_Name: String { return self._s[2801]! } - public var Channel_AdminLogFilter_ChannelEventsInfo: String { return self._s[2802]! } - public var Passport_Identity_TranslationHelp: String { return self._s[2804]! } + public var Cache_Indexing: String { return self._s[2797]! } + public var DialogList_RecentTitlePeople: String { return self._s[2799]! } + public var DialogList_EncryptionRejected: String { return self._s[2800]! } + public var GroupInfo_Administrators: String { return self._s[2801]! } + public var Passport_ScanPassportHelp: String { return self._s[2802]! } + public var Application_Name: String { return self._s[2803]! } + public var Channel_AdminLogFilter_ChannelEventsInfo: String { return self._s[2804]! } + public var Passport_Identity_TranslationHelp: String { return self._s[2806]! } public func Notification_JoinedGroupByLink(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2805]!, self._r[2805]!, [_0]) + return formatWithArgumentRanges(self._s[2807]!, self._r[2807]!, [_0]) } public func DialogList_EncryptedChatStartedOutgoing(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2806]!, self._r[2806]!, [_0]) + return formatWithArgumentRanges(self._s[2808]!, self._r[2808]!, [_0]) } - public var Channel_EditAdmin_PermissionDeleteMessages: String { return self._s[2807]! } - public var Privacy_ChatsTitle: String { return self._s[2808]! } - public var DialogList_ClearHistoryConfirmation: String { return self._s[2809]! } - public var Watch_Suggestion_HoldOn: String { return self._s[2810]! } - public var SocksProxySetup_RequiredCredentials: String { return self._s[2811]! } - public var Passport_Address_TypeRentalAgreementUploadScan: String { return self._s[2812]! } - public var TwoStepAuth_EmailSkipAlert: String { return self._s[2813]! } - public var Channel_Setup_TypePublic: String { return self._s[2816]! } + public var Channel_EditAdmin_PermissionDeleteMessages: String { return self._s[2809]! } + public var Privacy_ChatsTitle: String { return self._s[2810]! } + public var DialogList_ClearHistoryConfirmation: String { return self._s[2811]! } + public var Watch_Suggestion_HoldOn: String { return self._s[2812]! } + public var SocksProxySetup_RequiredCredentials: String { return self._s[2813]! } + public var Passport_Address_TypeRentalAgreementUploadScan: String { return self._s[2814]! } + public var TwoStepAuth_EmailSkipAlert: String { return self._s[2815]! } + public var Channel_Setup_TypePublic: String { return self._s[2818]! } public func Channel_AdminLog_MessageToggleInvitesOn(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2817]!, self._r[2817]!, [_0]) + return formatWithArgumentRanges(self._s[2819]!, self._r[2819]!, [_0]) } - public var Channel_TypeSetup_Title: String { return self._s[2819]! } - public var Map_OpenInMaps: String { return self._s[2821]! } - public var NotificationsSound_Tremolo: String { return self._s[2823]! } + public var Channel_TypeSetup_Title: String { return self._s[2821]! } + public var Map_OpenInMaps: String { return self._s[2823]! } + public var NotificationsSound_Tremolo: String { return self._s[2825]! } public func Date_ChatDateHeaderYear(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2825]!, self._r[2825]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2827]!, self._r[2827]!, [_1, _2, _3]) } - public var ConversationProfile_UnknownAddMemberError: String { return self._s[2826]! } - public var Passport_PasswordHelp: String { return self._s[2827]! } - public var Login_CodeExpiredError: String { return self._s[2828]! } - public var Channel_EditAdmin_PermissionChangeInfo: String { return self._s[2829]! } - public var Conversation_TitleUnmute: String { return self._s[2830]! } - public var Passport_Identity_ScansHelp: String { return self._s[2831]! } - public var Passport_Language_lo: String { return self._s[2832]! } - public var Camera_FlashAuto: String { return self._s[2833]! } - public var Common_Cancel: String { return self._s[2834]! } - public var DialogList_SavedMessagesTooltip: String { return self._s[2835]! } - public var TwoStepAuth_SetupPasswordTitle: String { return self._s[2836]! } - public var Conversation_ReportSpamConfirmation: String { return self._s[2837]! } - public var ChatSettings_Title: String { return self._s[2839]! } - public var Passport_PasswordReset: String { return self._s[2840]! } - public var SocksProxySetup_TypeNone: String { return self._s[2841]! } - public var PhoneNumberHelp_Help: String { return self._s[2843]! } - public var Checkout_EnterPassword: String { return self._s[2844]! } - public var Activity_UploadingDocument: String { return self._s[2846]! } - public var Share_AuthTitle: String { return self._s[2847]! } - public var State_Connecting: String { return self._s[2848]! } - public var Profile_MessageLifetime1w: String { return self._s[2849]! } - public var Conversation_ContextMenuReport: String { return self._s[2850]! } - public var CheckoutInfo_ReceiverInfoPhone: String { return self._s[2851]! } - public var AutoNightTheme_ScheduledTo: String { return self._s[2852]! } + public var ConversationProfile_UnknownAddMemberError: String { return self._s[2828]! } + public var Passport_PasswordHelp: String { return self._s[2829]! } + public var Login_CodeExpiredError: String { return self._s[2830]! } + public var Channel_EditAdmin_PermissionChangeInfo: String { return self._s[2831]! } + public var Conversation_TitleUnmute: String { return self._s[2832]! } + public var Passport_Identity_ScansHelp: String { return self._s[2833]! } + public var Passport_Language_lo: String { return self._s[2834]! } + public var Camera_FlashAuto: String { return self._s[2835]! } + public var Common_Cancel: String { return self._s[2836]! } + public var DialogList_SavedMessagesTooltip: String { return self._s[2837]! } + public var TwoStepAuth_SetupPasswordTitle: String { return self._s[2838]! } + public var Conversation_ReportSpamConfirmation: String { return self._s[2839]! } + public var ChatSettings_Title: String { return self._s[2841]! } + public var Passport_PasswordReset: String { return self._s[2842]! } + public var SocksProxySetup_TypeNone: String { return self._s[2843]! } + public var PhoneNumberHelp_Help: String { return self._s[2845]! } + public var Checkout_EnterPassword: String { return self._s[2846]! } + public var Activity_UploadingDocument: String { return self._s[2848]! } + public var Share_AuthTitle: String { return self._s[2849]! } + public var State_Connecting: String { return self._s[2850]! } + public var Profile_MessageLifetime1w: String { return self._s[2851]! } + public var Conversation_ContextMenuReport: String { return self._s[2852]! } + public var CheckoutInfo_ReceiverInfoPhone: String { return self._s[2853]! } + public var AutoNightTheme_ScheduledTo: String { return self._s[2854]! } public func CHAT_DELETE_MEMBER_SEPARATED(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2853]!, self._r[2853]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2855]!, self._r[2855]!, [_1, _2, _3]) } - public var AuthSessions_Terminate: String { return self._s[2854]! } + public var AuthSessions_Terminate: String { return self._s[2856]! } public func MESSAGE_TEXT_SEPARATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2855]!, self._r[2855]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2857]!, self._r[2857]!, [_1, _2]) } - public var Checkout_NewCard_CardholderNamePlaceholder: String { return self._s[2856]! } - public var KeyCommand_JumpToPreviousUnreadChat: String { return self._s[2857]! } - public var PhotoEditor_Set: String { return self._s[2858]! } - public var EmptyGroupInfo_Title: String { return self._s[2859]! } - public var Login_PadPhoneHelp: String { return self._s[2860]! } - public var PrivacyPolicy_DeclineLastWarning: String { return self._s[2863]! } - public var NotificationsSound_Complete: String { return self._s[2864]! } + public var Checkout_NewCard_CardholderNamePlaceholder: String { return self._s[2858]! } + public var KeyCommand_JumpToPreviousUnreadChat: String { return self._s[2859]! } + public var PhotoEditor_Set: String { return self._s[2860]! } + public var EmptyGroupInfo_Title: String { return self._s[2861]! } + public var Login_PadPhoneHelp: String { return self._s[2862]! } + public var PrivacyPolicy_DeclineLastWarning: String { return self._s[2865]! } + public var NotificationsSound_Complete: String { return self._s[2866]! } public func CHAT_MESSAGE_CONTACT_SEPARATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2865]!, self._r[2865]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2867]!, self._r[2867]!, [_1, _2]) } - public var Group_Info_AdminLog: String { return self._s[2866]! } - public var Channel_AdminLog_InfoPanelAlertText: String { return self._s[2867]! } - public var Conversation_Admin: String { return self._s[2869]! } - public var Conversation_GifTooltip: String { return self._s[2870]! } - public var Passport_NotLoggedInMessage: String { return self._s[2871]! } - public var Profile_MessageLifetimeForever: String { return self._s[2872]! } + public var Group_Info_AdminLog: String { return self._s[2868]! } + public var GroupPermission_NotAvailableInPublicGroups: String { return self._s[2869]! } + public var Channel_AdminLog_InfoPanelAlertText: String { return self._s[2870]! } + public var Conversation_Admin: String { return self._s[2872]! } + public var Conversation_GifTooltip: String { return self._s[2873]! } + public var Passport_NotLoggedInMessage: String { return self._s[2874]! } + public var Profile_MessageLifetimeForever: String { return self._s[2875]! } public func MESSAGE_POLL_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2874]!, self._r[2874]!, [_1]) + return formatWithArgumentRanges(self._s[2877]!, self._r[2877]!, [_1]) } - public var SharedMedia_EmptyTitle: String { return self._s[2875]! } - public var Channel_Edit_PrivatePublicLinkAlert: String { return self._s[2876]! } - public var Username_Help: String { return self._s[2877]! } - public var DialogList_LanguageTooltip: String { return self._s[2879]! } - public var Map_LoadError: String { return self._s[2880]! } - public var Notification_Exceptions_NewException: String { return self._s[2881]! } - public var TwoStepAuth_EmailTitle: String { return self._s[2882]! } - public var WatchRemote_AlertText: String { return self._s[2883]! } - public var ChatSettings_ConnectionType_Title: String { return self._s[2885]! } + public var SharedMedia_EmptyTitle: String { return self._s[2878]! } + public var Channel_Edit_PrivatePublicLinkAlert: String { return self._s[2879]! } + public var Username_Help: String { return self._s[2880]! } + public var DialogList_LanguageTooltip: String { return self._s[2882]! } + public var Map_LoadError: String { return self._s[2883]! } + public var Channel_AdminLog_AddMembers: String { return self._s[2884]! } + public var Notification_Exceptions_NewException: String { return self._s[2885]! } + public var TwoStepAuth_EmailTitle: String { return self._s[2886]! } + public var WatchRemote_AlertText: String { return self._s[2887]! } + public var ChatSettings_ConnectionType_Title: String { return self._s[2889]! } public func CHANNEL_MESSAGE_GEOLIVE_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2886]!, self._r[2886]!, [_1]) + return formatWithArgumentRanges(self._s[2890]!, self._r[2890]!, [_1]) } public func LOCKED_MESSAGE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2887]!, self._r[2887]!, [_1]) + return formatWithArgumentRanges(self._s[2891]!, self._r[2891]!, [_1]) } - public var Passport_Address_CountryPlaceholder: String { return self._s[2888]! } + public var Passport_Address_CountryPlaceholder: String { return self._s[2892]! } public func DialogList_AwaitingEncryption(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2889]!, self._r[2889]!, [_0]) + return formatWithArgumentRanges(self._s[2893]!, self._r[2893]!, [_0]) } public func Time_PreciseDate_m6(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2890]!, self._r[2890]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2894]!, self._r[2894]!, [_1, _2, _3]) } - public var Group_AdminLog_EmptyText: String { return self._s[2891]! } - public var AccessDenied_VideoMicrophone: String { return self._s[2893]! } - public var Conversation_ContextMenuStickerPackAdd: String { return self._s[2894]! } - public var Cache_ClearNone: String { return self._s[2895]! } - public var SocksProxySetup_FailedToConnect: String { return self._s[2896]! } - public var Permissions_NotificationsTitle_v0: String { return self._s[2897]! } + public var Group_AdminLog_EmptyText: String { return self._s[2895]! } + public var AccessDenied_VideoMicrophone: String { return self._s[2897]! } + public var Conversation_ContextMenuStickerPackAdd: String { return self._s[2898]! } + public var Cache_ClearNone: String { return self._s[2899]! } + public var SocksProxySetup_FailedToConnect: String { return self._s[2900]! } + public var Permissions_NotificationsTitle_v0: String { return self._s[2901]! } public func Channel_AdminLog_MessageEdited(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2898]!, self._r[2898]!, [_0]) + return formatWithArgumentRanges(self._s[2902]!, self._r[2902]!, [_0]) } - public var Passport_Identity_Country: String { return self._s[2899]! } + public var Passport_Identity_Country: String { return self._s[2903]! } public func Notification_CreatedChat(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2900]!, self._r[2900]!, [_0]) + return formatWithArgumentRanges(self._s[2904]!, self._r[2904]!, [_0]) } - public var AccessDenied_Settings: String { return self._s[2901]! } - public var Passport_Address_TypeUtilityBillUploadScan: String { return self._s[2902]! } - public var Month_ShortMay: String { return self._s[2903]! } - public var Compose_NewGroup: String { return self._s[2904]! } - public var Group_Setup_TypePrivate: String { return self._s[2906]! } - public var Login_PadPhoneHelpTitle: String { return self._s[2907]! } - public var Appearance_ThemeDayClassic: String { return self._s[2908]! } - public var Channel_AdminLog_MessagePreviousCaption: String { return self._s[2909]! } - public var Privacy_GroupsAndChannels_WhoCanAddMe: String { return self._s[2910]! } - public var Conversation_typing: String { return self._s[2912]! } - public var Paint_Masks: String { return self._s[2913]! } + public var AccessDenied_Settings: String { return self._s[2905]! } + public var Passport_Address_TypeUtilityBillUploadScan: String { return self._s[2906]! } + public var Month_ShortMay: String { return self._s[2907]! } + public var Compose_NewGroup: String { return self._s[2908]! } + public var Group_Setup_TypePrivate: String { return self._s[2910]! } + public var Login_PadPhoneHelpTitle: String { return self._s[2911]! } + public var Appearance_ThemeDayClassic: String { return self._s[2912]! } + public var Channel_AdminLog_MessagePreviousCaption: String { return self._s[2913]! } + public var Privacy_GroupsAndChannels_WhoCanAddMe: String { return self._s[2914]! } + public var Conversation_typing: String { return self._s[2916]! } + public var Paint_Masks: String { return self._s[2917]! } public func PINNED_DOC_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2914]!, self._r[2914]!, [_1]) + return formatWithArgumentRanges(self._s[2918]!, self._r[2918]!, [_1]) } - public var Username_InvalidTaken: String { return self._s[2915]! } + public var Username_InvalidTaken: String { return self._s[2919]! } public func CHAT_PHOTO_EDITED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2916]!, self._r[2916]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2920]!, self._r[2920]!, [_1, _2]) } - public var Call_StatusNoAnswer: String { return self._s[2917]! } - public var TwoStepAuth_EmailAddSuccess: String { return self._s[2918]! } - public var Passport_Identity_Selfie: String { return self._s[2919]! } - public var Login_InfoLastNamePlaceholder: String { return self._s[2920]! } - public var Privacy_SecretChatsLinkPreviewsHelp: String { return self._s[2921]! } - public var Conversation_ClearSecretHistory: String { return self._s[2922]! } - public var NetworkUsageSettings_Title: String { return self._s[2924]! } - public var Your_cards_security_code_is_invalid: String { return self._s[2926]! } + public var Call_StatusNoAnswer: String { return self._s[2921]! } + public var TwoStepAuth_EmailAddSuccess: String { return self._s[2922]! } + public var Passport_Identity_Selfie: String { return self._s[2923]! } + public var Login_InfoLastNamePlaceholder: String { return self._s[2924]! } + public var Privacy_SecretChatsLinkPreviewsHelp: String { return self._s[2925]! } + public var Conversation_ClearSecretHistory: String { return self._s[2926]! } + public var NetworkUsageSettings_Title: String { return self._s[2928]! } + public var Your_cards_security_code_is_invalid: String { return self._s[2930]! } public func Notification_LeftChannel(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2928]!, self._r[2928]!, [_0]) + return formatWithArgumentRanges(self._s[2932]!, self._r[2932]!, [_0]) } public func Call_CallInProgressMessage(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2929]!, self._r[2929]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2933]!, self._r[2933]!, [_1, _2]) } - public var SaveIncomingPhotosSettings_From: String { return self._s[2931]! } - public var Map_LiveLocationTitle: String { return self._s[2932]! } - public var Login_InfoAvatarAdd: String { return self._s[2933]! } - public var Passport_Identity_FilesView: String { return self._s[2934]! } - public var UserInfo_GenericPhoneLabel: String { return self._s[2935]! } - public var Privacy_Calls_NeverAllow: String { return self._s[2936]! } + public var SaveIncomingPhotosSettings_From: String { return self._s[2935]! } + public var Map_LiveLocationTitle: String { return self._s[2936]! } + public var Login_InfoAvatarAdd: String { return self._s[2937]! } + public var Passport_Identity_FilesView: String { return self._s[2938]! } + public var UserInfo_GenericPhoneLabel: String { return self._s[2939]! } + public var Privacy_Calls_NeverAllow: String { return self._s[2940]! } public func Contacts_AddPhoneNumber(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2937]!, self._r[2937]!, [_0]) + return formatWithArgumentRanges(self._s[2941]!, self._r[2941]!, [_0]) } - public var TwoStepAuth_ConfirmationText: String { return self._s[2938]! } - public var ChatSettings_AutomaticVideoMessageDownload: String { return self._s[2939]! } - public var Channel_AdminLogFilter_AdminsAll: String { return self._s[2940]! } - public var Tour_Title2: String { return self._s[2941]! } - public var Conversation_FileOpenIn: String { return self._s[2942]! } - public var Checkout_ErrorPrecheckoutFailed: String { return self._s[2943]! } - public var Wallpaper_Set: String { return self._s[2944]! } - public var Passport_Identity_Translations: String { return self._s[2946]! } + public var TwoStepAuth_ConfirmationText: String { return self._s[2942]! } + public var ChatSettings_AutomaticVideoMessageDownload: String { return self._s[2943]! } + public var Channel_AdminLogFilter_AdminsAll: String { return self._s[2944]! } + public var Tour_Title2: String { return self._s[2945]! } + public var Conversation_FileOpenIn: String { return self._s[2946]! } + public var Checkout_ErrorPrecheckoutFailed: String { return self._s[2947]! } + public var Wallpaper_Set: String { return self._s[2948]! } + public var Passport_Identity_Translations: String { return self._s[2950]! } public func Channel_AdminLog_MessageChangedChannelAbout(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2947]!, self._r[2947]!, [_0]) + return formatWithArgumentRanges(self._s[2951]!, self._r[2951]!, [_0]) } - public var Channel_LeaveChannel: String { return self._s[2948]! } + public var Channel_LeaveChannel: String { return self._s[2952]! } public func MESSAGE_NOTEXT_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2949]!, self._r[2949]!, [_1]) + return formatWithArgumentRanges(self._s[2953]!, self._r[2953]!, [_1]) } public func PINNED_INVOICE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2950]!, self._r[2950]!, [_1]) + return formatWithArgumentRanges(self._s[2954]!, self._r[2954]!, [_1]) } - public var PhotoEditor_HighlightsTint: String { return self._s[2951]! } - public var Passport_Email_Delete: String { return self._s[2952]! } - public var Conversation_Mute: String { return self._s[2954]! } - public var Channel_AdminLog_CanSendMessages: String { return self._s[2956]! } + public var PhotoEditor_HighlightsTint: String { return self._s[2955]! } + public var Passport_Email_Delete: String { return self._s[2956]! } + public var Conversation_Mute: String { return self._s[2958]! } + public var Channel_AdminLog_CanSendMessages: String { return self._s[2960]! } public func Notification_PassportValuesSentMessage(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2957]!, self._r[2957]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2961]!, self._r[2961]!, [_1, _2]) } - public var Calls_CallTabDescription: String { return self._s[2958]! } - public var Passport_Identity_NativeNameHelp: String { return self._s[2959]! } - public var Common_No: String { return self._s[2960]! } - public var Weekday_Sunday: String { return self._s[2961]! } - public var Notification_Reply: String { return self._s[2962]! } - public var Conversation_ViewMessage: String { return self._s[2963]! } + public var Calls_CallTabDescription: String { return self._s[2962]! } + public var Passport_Identity_NativeNameHelp: String { return self._s[2963]! } + public var Common_No: String { return self._s[2964]! } + public var Weekday_Sunday: String { return self._s[2965]! } + public var Notification_Reply: String { return self._s[2966]! } + public var Conversation_ViewMessage: String { return self._s[2967]! } public func Checkout_SavePasswordTimeoutAndFaceId(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2964]!, self._r[2964]!, [_0]) + return formatWithArgumentRanges(self._s[2968]!, self._r[2968]!, [_0]) } public func Map_LiveLocationPrivateDescription(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2965]!, self._r[2965]!, [_0]) + return formatWithArgumentRanges(self._s[2969]!, self._r[2969]!, [_0]) } - public var Message_PinnedDocumentMessage: String { return self._s[2966]! } - public var DialogList_TabTitle: String { return self._s[2968]! } - public var Passport_FieldEmail: String { return self._s[2969]! } - public var Conversation_UnpinMessageAlert: String { return self._s[2970]! } - public var Passport_Address_TypeBankStatement: String { return self._s[2971]! } - public var Passport_Identity_ExpiryDate: String { return self._s[2972]! } - public var Privacy_Calls_P2P: String { return self._s[2973]! } + public var Message_PinnedDocumentMessage: String { return self._s[2970]! } + public var DialogList_TabTitle: String { return self._s[2972]! } + public var Passport_FieldEmail: String { return self._s[2973]! } + public var Conversation_UnpinMessageAlert: String { return self._s[2974]! } + public var Passport_Address_TypeBankStatement: String { return self._s[2975]! } + public var Passport_Identity_ExpiryDate: String { return self._s[2976]! } + public var Privacy_Calls_P2P: String { return self._s[2977]! } public func CancelResetAccount_Success(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2975]!, self._r[2975]!, [_0]) + return formatWithArgumentRanges(self._s[2979]!, self._r[2979]!, [_0]) } - public var SocksProxySetup_UseForCallsHelp: String { return self._s[2976]! } - public var EnterPasscode_ChangeTitle: String { return self._s[2977]! } - public var Passport_InfoText: String { return self._s[2978]! } - public var Checkout_NewCard_SaveInfoEnableHelp: String { return self._s[2979]! } + public var SocksProxySetup_UseForCallsHelp: String { return self._s[2980]! } + public var EnterPasscode_ChangeTitle: String { return self._s[2981]! } + public var Passport_InfoText: String { return self._s[2982]! } + public var Checkout_NewCard_SaveInfoEnableHelp: String { return self._s[2983]! } public func Login_InvalidPhoneEmailSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2980]!, self._r[2980]!, [_0]) + return formatWithArgumentRanges(self._s[2984]!, self._r[2984]!, [_0]) } public func Time_PreciseDate_m3(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2981]!, self._r[2981]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2985]!, self._r[2985]!, [_1, _2, _3]) } - public var Passport_Identity_EditDriversLicense: String { return self._s[2982]! } - public var Conversation_TapAndHoldToRecord: String { return self._s[2984]! } + public var Passport_Identity_EditDriversLicense: String { return self._s[2986]! } + public var Conversation_TapAndHoldToRecord: String { return self._s[2988]! } public func Notification_CallTimeFormat(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2985]!, self._r[2985]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2989]!, self._r[2989]!, [_1, _2]) } public func MESSAGE_ROUND_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2986]!, self._r[2986]!, [_1]) + return formatWithArgumentRanges(self._s[2990]!, self._r[2990]!, [_1]) } public func PHONE_CALL_MISSED_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2988]!, self._r[2988]!, [_1]) + return formatWithArgumentRanges(self._s[2992]!, self._r[2992]!, [_1]) } public func Generic_OpenHiddenLinkAlert(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2990]!, self._r[2990]!, [_0]) + return formatWithArgumentRanges(self._s[2994]!, self._r[2994]!, [_0]) } - public var DialogList_Unread: String { return self._s[2991]! } - public var User_DeletedAccount: String { return self._s[2992]! } + public var DialogList_Unread: String { return self._s[2995]! } + public var User_DeletedAccount: String { return self._s[2996]! } public func Watch_Time_ShortYesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2993]!, self._r[2993]!, [_0]) + return formatWithArgumentRanges(self._s[2997]!, self._r[2997]!, [_0]) } - public var UserInfo_NotificationsDefault: String { return self._s[2994]! } - public var SharedMedia_CategoryMedia: String { return self._s[2995]! } - public var SocksProxySetup_ProxyStatusUnavailable: String { return self._s[2996]! } - public var Channel_AdminLog_MessageRestrictedForever: String { return self._s[2997]! } - public var Watch_ChatList_Compose: String { return self._s[2998]! } - public var Notifications_MessageNotificationsExceptionsHelp: String { return self._s[2999]! } - public var Watch_Microphone_Access: String { return self._s[3000]! } - public var Group_Setup_HistoryHeader: String { return self._s[3001]! } - public var Activity_UploadingPhoto: String { return self._s[3002]! } + public var UserInfo_NotificationsDefault: String { return self._s[2998]! } + public var SharedMedia_CategoryMedia: String { return self._s[2999]! } + public var SocksProxySetup_ProxyStatusUnavailable: String { return self._s[3000]! } + public var Channel_AdminLog_MessageRestrictedForever: String { return self._s[3001]! } + public var Watch_ChatList_Compose: String { return self._s[3002]! } + public var Notifications_MessageNotificationsExceptionsHelp: String { return self._s[3003]! } + public var Watch_Microphone_Access: String { return self._s[3004]! } + public var Group_Setup_HistoryHeader: String { return self._s[3005]! } + public var Activity_UploadingPhoto: String { return self._s[3006]! } public func MESSAGE_VIDEO_SECRET_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3004]!, self._r[3004]!, [_1]) + return formatWithArgumentRanges(self._s[3008]!, self._r[3008]!, [_1]) } - public var Conversation_Edit: String { return self._s[3005]! } - public var Group_ErrorSendRestrictedMedia: String { return self._s[3006]! } - public var Login_TermsOfServiceDecline: String { return self._s[3007]! } - public var Message_PinnedContactMessage: String { return self._s[3008]! } + public var Conversation_Edit: String { return self._s[3009]! } + public var Group_ErrorSendRestrictedMedia: String { return self._s[3010]! } + public var Login_TermsOfServiceDecline: String { return self._s[3011]! } + public var Message_PinnedContactMessage: String { return self._s[3012]! } public func Channel_AdminLog_MessageRestrictedNameUsername(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3009]!, self._r[3009]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3013]!, self._r[3013]!, [_1, _2]) } public func Login_PhoneBannedEmailBody(_ _1: String, _ _2: String, _ _3: String, _ _4: String, _ _5: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3010]!, self._r[3010]!, [_1, _2, _3, _4, _5]) + return formatWithArgumentRanges(self._s[3014]!, self._r[3014]!, [_1, _2, _3, _4, _5]) } - public var TwoStepAuth_AdditionalPassword: String { return self._s[3012]! } - public var Passport_Phone_EnterOtherNumber: String { return self._s[3013]! } - public var Message_PinnedPhotoMessage: String { return self._s[3014]! } - public var Passport_FieldPhone: String { return self._s[3015]! } - public var TwoStepAuth_RecoveryEmailAddDescription: String { return self._s[3016]! } - public var InfoPlist_NSCameraUsageDescription: String { return self._s[3018]! } - public var Conversation_Call: String { return self._s[3019]! } - public var Common_TakePhoto: String { return self._s[3021]! } - public var Channel_NotificationLoading: String { return self._s[3022]! } + public var TwoStepAuth_AdditionalPassword: String { return self._s[3016]! } + public var Passport_Phone_EnterOtherNumber: String { return self._s[3017]! } + public var Message_PinnedPhotoMessage: String { return self._s[3018]! } + public var Passport_FieldPhone: String { return self._s[3019]! } + public var TwoStepAuth_RecoveryEmailAddDescription: String { return self._s[3020]! } + public var InfoPlist_NSCameraUsageDescription: String { return self._s[3022]! } + public var Conversation_Call: String { return self._s[3023]! } + public var Common_TakePhoto: String { return self._s[3025]! } + public var Channel_NotificationLoading: String { return self._s[3026]! } public func Notification_Exceptions_Sound(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3023]!, self._r[3023]!, [_0]) + return formatWithArgumentRanges(self._s[3027]!, self._r[3027]!, [_0]) } - public var Permissions_SiriTitle_v0: String { return self._s[3024]! } + public var Permissions_SiriTitle_v0: String { return self._s[3028]! } public func Login_ResetAccountProtected_Text(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3025]!, self._r[3025]!, [_0]) + return formatWithArgumentRanges(self._s[3029]!, self._r[3029]!, [_0]) } - public var Channel_MessagePhotoRemoved: String { return self._s[3026]! } - public var Common_edit: String { return self._s[3027]! } - public var PrivacySettings_AuthSessions: String { return self._s[3028]! } - public var Month_ShortJune: String { return self._s[3029]! } - public var PrivacyLastSeenSettings_AlwaysShareWith_Placeholder: String { return self._s[3030]! } - public var Call_ReportSend: String { return self._s[3031]! } - public var Watch_LastSeen_JustNow: String { return self._s[3032]! } - public var Notifications_MessageNotifications: String { return self._s[3033]! } - public var BroadcastListInfo_AddRecipient: String { return self._s[3035]! } - public var Group_Status: String { return self._s[3036]! } + public var Channel_MessagePhotoRemoved: String { return self._s[3030]! } + public var Common_edit: String { return self._s[3031]! } + public var PrivacySettings_AuthSessions: String { return self._s[3032]! } + public var Month_ShortJune: String { return self._s[3033]! } + public var PrivacyLastSeenSettings_AlwaysShareWith_Placeholder: String { return self._s[3034]! } + public var Call_ReportSend: String { return self._s[3035]! } + public var Watch_LastSeen_JustNow: String { return self._s[3036]! } + public var Notifications_MessageNotifications: String { return self._s[3037]! } + public var BroadcastListInfo_AddRecipient: String { return self._s[3039]! } + public var Group_Status: String { return self._s[3040]! } public func AutoNightTheme_LocationHelp(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3037]!, self._r[3037]!, [_0, _1]) + return formatWithArgumentRanges(self._s[3041]!, self._r[3041]!, [_0, _1]) } - public var ShareMenu_ShareTo: String { return self._s[3038]! } - public var Conversation_Moderate_Ban: String { return self._s[3039]! } + public var ShareMenu_ShareTo: String { return self._s[3042]! } + public var Conversation_Moderate_Ban: String { return self._s[3043]! } public func Conversation_DeleteMessagesFor(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3040]!, self._r[3040]!, [_0]) - } - public var SharedMedia_ViewInChat: String { return self._s[3041]! } - public var Map_LiveLocationFor8Hours: String { return self._s[3042]! } - public func Map_AccurateTo(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[3044]!, self._r[3044]!, [_0]) } - public var Appearance_ReduceMotion: String { return self._s[3045]! } - public var Map_OpenInHereMaps: String { return self._s[3046]! } - public var Channel_Setup_TypePublicHelp: String { return self._s[3047]! } - public var Passport_Identity_EditInternalPassport: String { return self._s[3048]! } - public var PhotoEditor_Skip: String { return self._s[3049]! } - public func ForwardedPolls(_ value: Int32) -> String { + public var SharedMedia_ViewInChat: String { return self._s[3045]! } + public var Map_LiveLocationFor8Hours: String { return self._s[3046]! } + public func Map_AccurateTo(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3048]!, self._r[3048]!, [_0]) + } + public var Appearance_ReduceMotion: String { return self._s[3049]! } + public var Map_OpenInHereMaps: String { return self._s[3050]! } + public var Channel_Setup_TypePublicHelp: String { return self._s[3051]! } + public var Passport_Identity_EditInternalPassport: String { return self._s[3052]! } + public var PhotoEditor_Skip: String { return self._s[3053]! } + public func MuteFor_Days(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[0 * 6 + Int(form.rawValue)]!, "\(value)") } - public func MessageTimer_Months(_ value: Int32) -> String { + public func MessageTimer_Hours(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[1 * 6 + Int(form.rawValue)]!, "\(value)") } - public func ServiceMessage_GameScoreSelfSimple(_ value: Int32) -> String { + public func Watch_LastSeen_MinutesAgo(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[2 * 6 + Int(form.rawValue)]!, "\(value)") } - public func UserCount(_ value: Int32) -> String { + public func Call_Minutes(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[3 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Watch_UserInfo_Mute(_ value: Int32) -> String { + public func Invitation_Members(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[4 * 6 + Int(form.rawValue)]!, "\(value)") } - public func SharedMedia_Generic(_ value: Int32) -> String { + public func CHAT_MESSAGE_PHOTOS_SEPARATED(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[5 * 6 + Int(form.rawValue)]!, "\(value)") } - public func QuickSend_Photos(_ value: Int32) -> String { + public func MuteExpires_Days(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[6 * 6 + Int(form.rawValue)]!, "\(value)") } - public func MessageTimer_Minutes(_ value: Int32) -> String { + public func Watch_LastSeen_HoursAgo(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[7 * 6 + Int(form.rawValue)]!, "\(value)") } - public func StickerPack_AddMaskCount(_ value: Int32) -> String { + public func Notification_GameScoreSelfSimple(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[8 * 6 + Int(form.rawValue)]!, "\(value)") } - public func CHAT_MESSAGE_PHOTOS_SEPARATED(_ value: Int32) -> String { + public func ForwardedAuthorsOthers(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[9 * 6 + Int(form.rawValue)]!, "\(value)") } - public func MessagePoll_VotedCount(_ value: Int32) -> String { + public func ForwardedStickers(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[10 * 6 + Int(form.rawValue)]!, "\(value)") } - public func ServiceMessage_GameScoreExtended(_ value: Int32) -> String { + public func AttachmentMenu_SendGif(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[11 * 6 + Int(form.rawValue)]!, "\(value)") } - public func MessageTimer_ShortHours(_ value: Int32) -> String { + public func MessageTimer_ShortWeeks(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[12 * 6 + Int(form.rawValue)]!, "\(value)") } - public func MESSAGE_PHOTOS_SEPARATED(_ value: Int32) -> String { + public func Notification_GameScoreExtended(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[13 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Notification_GameScoreSelfSimple(_ value: Int32) -> String { + public func AttachmentMenu_SendItem(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[14 * 6 + Int(form.rawValue)]!, "\(value)") } - public func ForwardedVideos(_ value: Int32) -> String { + public func StickerPack_AddStickerCount(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[15 * 6 + Int(form.rawValue)]!, "\(value)") } - public func ForwardedStickers(_ value: Int32) -> String { + public func Notifications_ExceptionMuteExpires_Days(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[16 * 6 + Int(form.rawValue)]!, "\(value)") } - public func MessageTimer_Hours(_ value: Int32) -> String { + public func LiveLocationUpdated_MinutesAgo(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[17 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Call_ShortSeconds(_ value: Int32) -> String { + public func MessageTimer_Seconds(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[18 * 6 + Int(form.rawValue)]!, "\(value)") } - public func MuteFor_Days(_ value: Int32) -> String { + public func Media_SharePhoto(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[19 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Notification_GameScoreExtended(_ value: Int32) -> String { + public func SharedMedia_Generic(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[20 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Notification_GameScoreSimple(_ value: Int32) -> String { + public func MessageTimer_ShortSeconds(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[21 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Notifications_Exceptions(_ value: Int32) -> String { + public func Conversation_LiveLocationMembersCount(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[22 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Notification_GameScoreSelfExtended(_ value: Int32) -> String { + public func SharedMedia_File(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[23 * 6 + Int(form.rawValue)]!, "\(value)") } - public func PasscodeSettings_FailedAttempts(_ value: Int32) -> String { + public func MessageTimer_Weeks(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[24 * 6 + Int(form.rawValue)]!, "\(value)") } - public func LiveLocationUpdated_MinutesAgo(_ value: Int32) -> String { + public func MESSAGES_SEPARATED(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[25 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Forward_ConfirmMultipleFiles(_ value: Int32) -> String { + public func Call_Seconds(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[26 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Media_SharePhoto(_ value: Int32) -> String { + public func MessageTimer_Days(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[27 * 6 + Int(form.rawValue)]!, "\(value)") } - public func SharedMedia_File(_ value: Int32) -> String { + public func UserCount(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[28 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Notifications_ExceptionMuteExpires_Hours(_ value: Int32) -> String { + public func MESSAGE_FWDS_SEPARATED(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[29 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Contacts_ImportersCount(_ value: Int32) -> String { + public func Notification_GameScoreSimple(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[30 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Map_ETAMinutes(_ value: Int32) -> String { + public func LiveLocation_MenuChatsCount(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[31 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Invitation_Members(_ value: Int32) -> String { + public func SharedMedia_Photo(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[32 * 6 + Int(form.rawValue)]!, "\(value)") } - public func DialogList_LiveLocationChatsCount(_ value: Int32) -> String { + public func Map_ETAHours(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[33 * 6 + Int(form.rawValue)]!, "\(value)") } - public func ForwardedFiles(_ value: Int32) -> String { + public func Media_ShareVideo(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[34 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Map_ETAHours(_ value: Int32) -> String { + public func SharedMedia_DeleteItemsConfirmation(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[35 * 6 + Int(form.rawValue)]!, "\(value)") } - public func ForwardedContacts(_ value: Int32) -> String { + public func MessageTimer_ShortHours(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[36 * 6 + Int(form.rawValue)]!, "\(value)") } - public func CHANNEL_MESSAGE_PHOTOS_SEPARATED(_ value: Int32) -> String { + public func ForwardedGifs(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[37 * 6 + Int(form.rawValue)]!, "\(value)") } - public func MessageTimer_Seconds(_ value: Int32) -> String { + public func SharedMedia_Link(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[38 * 6 + Int(form.rawValue)]!, "\(value)") } - public func PrivacyLastSeenSettings_AddUsers(_ value: Int32) -> String { + public func PasscodeSettings_FailedAttempts(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[39 * 6 + Int(form.rawValue)]!, "\(value)") } - public func AttachmentMenu_SendVideo(_ value: Int32) -> String { + public func ServiceMessage_GameScoreSelfExtended(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[40 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Call_ShortMinutes(_ value: Int32) -> String { + public func ServiceMessage_GameScoreSelfSimple(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[41 * 6 + Int(form.rawValue)]!, "\(value)") } - public func MessageTimer_ShortSeconds(_ value: Int32) -> String { + public func MessageTimer_ShortDays(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[42 * 6 + Int(form.rawValue)]!, "\(value)") } - public func ForwardedLocations(_ value: Int32) -> String { + public func ServiceMessage_GameScoreExtended(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[43 * 6 + Int(form.rawValue)]!, "\(value)") } - public func CHANNEL_MESSAGES_SEPARATED(_ value: Int32) -> String { + public func Map_ETAMinutes(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[44 * 6 + Int(form.rawValue)]!, "\(value)") } - public func SharedMedia_Video(_ value: Int32) -> String { + public func CHANNEL_MESSAGES_SEPARATED(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[45 * 6 + Int(form.rawValue)]!, "\(value)") } - public func MessageTimer_ShortDays(_ value: Int32) -> String { + public func Conversation_StatusSubscribers(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[46 * 6 + Int(form.rawValue)]!, "\(value)") } - public func ServiceMessage_GameScoreSelfExtended(_ value: Int32) -> String { + public func ForwardedPhotos(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[47 * 6 + Int(form.rawValue)]!, "\(value)") } - public func MESSAGE_FWDS_SEPARATED(_ value: Int32) -> String { + public func StickerPack_AddMaskCount(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[48 * 6 + Int(form.rawValue)]!, "\(value)") } - public func AttachmentMenu_SendGif(_ value: Int32) -> String { + public func MuteExpires_Hours(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[49 * 6 + Int(form.rawValue)]!, "\(value)") } - public func AttachmentMenu_SendPhoto(_ value: Int32) -> String { + public func CHAT_MESSAGE_FWDS_SEPARATED(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[50 * 6 + Int(form.rawValue)]!, "\(value)") } - public func MessageTimer_ShortMinutes(_ value: Int32) -> String { + public func ForwardedFiles(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[51 * 6 + Int(form.rawValue)]!, "\(value)") } - public func MuteExpires_Days(_ value: Int32) -> String { + public func MessageTimer_Years(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[52 * 6 + Int(form.rawValue)]!, "\(value)") } - public func AttachmentMenu_SendItem(_ value: Int32) -> String { + public func MessageTimer_Months(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[53 * 6 + Int(form.rawValue)]!, "\(value)") } - public func ForwardedGifs(_ value: Int32) -> String { + public func Passport_Scans(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[54 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Media_ShareItem(_ value: Int32) -> String { + public func Forward_ConfirmMultipleFiles(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[55 * 6 + Int(form.rawValue)]!, "\(value)") } - public func ForwardedPhotos(_ value: Int32) -> String { + public func StickerPack_RemoveMaskCount(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[56 * 6 + Int(form.rawValue)]!, "\(value)") } - public func CHAT_MESSAGE_FWDS_SEPARATED(_ value: Int32) -> String { + public func PrivacyLastSeenSettings_AddUsers(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[57 * 6 + Int(form.rawValue)]!, "\(value)") } - public func MessageTimer_Days(_ value: Int32) -> String { + public func AttachmentMenu_SendPhoto(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[58 * 6 + Int(form.rawValue)]!, "\(value)") } - public func ForwardedVideoMessages(_ value: Int32) -> String { + public func ServiceMessage_GameScoreSimple(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[59 * 6 + Int(form.rawValue)]!, "\(value)") } - public func MuteExpires_Hours(_ value: Int32) -> String { + public func StickerPack_StickerCount(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[60 * 6 + Int(form.rawValue)]!, "\(value)") } - public func MuteFor_Hours(_ value: Int32) -> String { + public func CHAT_MESSAGES_SEPARATED(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[61 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Call_Seconds(_ value: Int32) -> String { + public func ChatList_DeleteConfirmation(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[62 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Conversation_StatusMembers(_ value: Int32) -> String { + public func MessagePoll_VotedCount(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[63 * 6 + Int(form.rawValue)]!, "\(value)") } - public func LastSeen_MinutesAgo(_ value: Int32) -> String { + public func InviteText_ContactsCountText(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[64 * 6 + Int(form.rawValue)]!, "\(value)") } - public func ForwardedAuthorsOthers(_ value: Int32) -> String { + public func MuteExpires_Minutes(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[65 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Conversation_StatusSubscribers(_ value: Int32) -> String { + public func Contacts_ImportersCount(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[66 * 6 + Int(form.rawValue)]!, "\(value)") } - public func MuteExpires_Minutes(_ value: Int32) -> String { + public func Call_ShortMinutes(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[67 * 6 + Int(form.rawValue)]!, "\(value)") } - public func LastSeen_HoursAgo(_ value: Int32) -> String { + public func MuteFor_Hours(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[68 * 6 + Int(form.rawValue)]!, "\(value)") } - public func CHAT_MESSAGES_SEPARATED(_ value: Int32) -> String { + public func DialogList_LiveLocationChatsCount(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[69 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Call_Minutes(_ value: Int32) -> String { + public func ForwardedContacts(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[70 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Watch_LastSeen_MinutesAgo(_ value: Int32) -> String { + public func CHANNEL_MESSAGE_FWDS_SEPARATED(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[71 * 6 + Int(form.rawValue)]!, "\(value)") } - public func ChatList_DeleteConfirmation(_ value: Int32) -> String { + public func GroupInfo_ParticipantCount(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[72 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Conversation_StatusOnline(_ value: Int32) -> String { + public func CreatePoll_AddMoreOptions(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[73 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Conversation_LiveLocationMembersCount(_ value: Int32) -> String { + public func StickerPack_RemoveStickerCount(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[74 * 6 + Int(form.rawValue)]!, "\(value)") } - public func MessageTimer_ShortWeeks(_ value: Int32) -> String { + public func MessageTimer_ShortMinutes(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[75 * 6 + Int(form.rawValue)]!, "\(value)") } - public func GroupInfo_ParticipantCount(_ value: Int32) -> String { + public func ForwardedAudios(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[76 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Media_ShareVideo(_ value: Int32) -> String { + public func MESSAGE_PHOTOS_SEPARATED(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[77 * 6 + Int(form.rawValue)]!, "\(value)") } - public func CHANNEL_MESSAGE_FWDS_SEPARATED(_ value: Int32) -> String { + public func ForwardedLocations(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[78 * 6 + Int(form.rawValue)]!, "\(value)") } - public func MessageTimer_Weeks(_ value: Int32) -> String { + public func Media_ShareItem(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[79 * 6 + Int(form.rawValue)]!, "\(value)") } - public func StickerPack_StickerCount(_ value: Int32) -> String { + public func Watch_UserInfo_Mute(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[80 * 6 + Int(form.rawValue)]!, "\(value)") } - public func LiveLocation_MenuChatsCount(_ value: Int32) -> String { + public func Notifications_ExceptionMuteExpires_Hours(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[81 * 6 + Int(form.rawValue)]!, "\(value)") } - public func InviteText_ContactsCountText(_ value: Int32) -> String { + public func ForwardedVideos(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[82 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Passport_Scans(_ value: Int32) -> String { + public func ForwardedMessages(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[83 * 6 + Int(form.rawValue)]!, "\(value)") } - public func ForwardedMessages(_ value: Int32) -> String { + public func Conversation_StatusOnline(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[84 * 6 + Int(form.rawValue)]!, "\(value)") } - public func SharedMedia_Link(_ value: Int32) -> String { + public func QuickSend_Photos(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[85 * 6 + Int(form.rawValue)]!, "\(value)") } - public func StickerPack_AddStickerCount(_ value: Int32) -> String { + public func LastSeen_MinutesAgo(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[86 * 6 + Int(form.rawValue)]!, "\(value)") } - public func ServiceMessage_GameScoreSimple(_ value: Int32) -> String { + public func LastSeen_HoursAgo(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[87 * 6 + Int(form.rawValue)]!, "\(value)") } - public func StickerPack_RemoveStickerCount(_ value: Int32) -> String { + public func CHANNEL_MESSAGE_PHOTOS_SEPARATED(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[88 * 6 + Int(form.rawValue)]!, "\(value)") } - public func SharedMedia_Photo(_ value: Int32) -> String { + public func Conversation_StatusMembers(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[89 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Watch_LastSeen_HoursAgo(_ value: Int32) -> String { + public func SharedMedia_Video(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[90 * 6 + Int(form.rawValue)]!, "\(value)") } - public func StickerPack_RemoveMaskCount(_ value: Int32) -> String { + public func AttachmentMenu_SendVideo(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[91 * 6 + Int(form.rawValue)]!, "\(value)") } - public func MESSAGES_SEPARATED(_ value: Int32) -> String { + public func Notifications_ExceptionMuteExpires_Minutes(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[92 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Notifications_ExceptionMuteExpires_Days(_ value: Int32) -> String { + public func Call_ShortSeconds(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[93 * 6 + Int(form.rawValue)]!, "\(value)") } - public func SharedMedia_DeleteItemsConfirmation(_ value: Int32) -> String { + public func Notifications_Exceptions(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[94 * 6 + Int(form.rawValue)]!, "\(value)") } - public func CreatePoll_AddMoreOptions(_ value: Int32) -> String { + public func ForwardedPolls(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[95 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Notifications_ExceptionMuteExpires_Minutes(_ value: Int32) -> String { + public func Notification_GameScoreSelfExtended(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[96 * 6 + Int(form.rawValue)]!, "\(value)") } - public func ForwardedAudios(_ value: Int32) -> String { + public func MessageTimer_Minutes(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[97 * 6 + Int(form.rawValue)]!, "\(value)") } - public func MessageTimer_Years(_ value: Int32) -> String { + public func ForwardedVideoMessages(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[98 * 6 + Int(form.rawValue)]!, "\(value)") } diff --git a/TelegramUI/PresentationTheme.swift b/TelegramUI/PresentationTheme.swift index 2bbe699a22..1c3644c64f 100644 --- a/TelegramUI/PresentationTheme.swift +++ b/TelegramUI/PresentationTheme.swift @@ -210,11 +210,15 @@ public final class PresentationThemeSwitch { public let frameColor: UIColor public let handleColor: UIColor public let contentColor: UIColor + public let positiveColor: UIColor + public let negativeColor: UIColor - public init(frameColor: UIColor, handleColor: UIColor, contentColor: UIColor) { + public init(frameColor: UIColor, handleColor: UIColor, contentColor: UIColor, positiveColor: UIColor, negativeColor: UIColor) { self.frameColor = frameColor self.handleColor = handleColor self.contentColor = contentColor + self.positiveColor = positiveColor + self.negativeColor = negativeColor } } diff --git a/TelegramUI/PresentationThemeSettings.swift b/TelegramUI/PresentationThemeSettings.swift index ded94666cd..dd1791e8ef 100644 --- a/TelegramUI/PresentationThemeSettings.swift +++ b/TelegramUI/PresentationThemeSettings.swift @@ -10,6 +10,12 @@ public enum PresentationBuiltinThemeReference: Int32 { case nightAccent = 3 } +public enum PresentationWallpaperMode: Int32 { + case still + case perspective + case blurred +} + public enum PresentationThemeReference: PostboxCoding, Equatable { case builtin(PresentationBuiltinThemeReference) @@ -141,6 +147,7 @@ public struct AutomaticThemeSwitchSetting: PostboxCoding, Equatable { public struct PresentationThemeSettings: PreferencesEntry { public var chatWallpaper: TelegramWallpaper + public var chatWallpaperMode: PresentationWallpaperMode public var theme: PresentationThemeReference public var themeAccentColor: Int32? public var fontSize: PresentationFontSize @@ -157,11 +164,12 @@ public struct PresentationThemeSettings: PreferencesEntry { } public static var defaultSettings: PresentationThemeSettings { - return PresentationThemeSettings(chatWallpaper: .builtin, theme: .builtin(.dayClassic), themeAccentColor: nil, fontSize: .regular, automaticThemeSwitchSetting: AutomaticThemeSwitchSetting(trigger: .none, theme: .nightAccent), disableAnimations: true) + return PresentationThemeSettings(chatWallpaper: .builtin, chatWallpaperMode: .still, theme: .builtin(.dayClassic), themeAccentColor: nil, fontSize: .regular, automaticThemeSwitchSetting: AutomaticThemeSwitchSetting(trigger: .none, theme: .nightAccent), disableAnimations: true) } - public init(chatWallpaper: TelegramWallpaper, theme: PresentationThemeReference, themeAccentColor: Int32?, fontSize: PresentationFontSize, automaticThemeSwitchSetting: AutomaticThemeSwitchSetting, disableAnimations: Bool) { + public init(chatWallpaper: TelegramWallpaper, chatWallpaperMode: PresentationWallpaperMode, theme: PresentationThemeReference, themeAccentColor: Int32?, fontSize: PresentationFontSize, automaticThemeSwitchSetting: AutomaticThemeSwitchSetting, disableAnimations: Bool) { self.chatWallpaper = chatWallpaper + self.chatWallpaperMode = chatWallpaperMode self.theme = theme self.themeAccentColor = themeAccentColor self.fontSize = fontSize @@ -171,6 +179,7 @@ public struct PresentationThemeSettings: PreferencesEntry { public init(decoder: PostboxDecoder) { self.chatWallpaper = (decoder.decodeObjectForKey("w", decoder: { TelegramWallpaper(decoder: $0) }) as? TelegramWallpaper) ?? .builtin + self.chatWallpaperMode = PresentationWallpaperMode(rawValue: decoder.decodeInt32ForKey("m", orElse: 0)) ?? .still self.theme = decoder.decodeObjectForKey("t", decoder: { PresentationThemeReference(decoder: $0) }) as! PresentationThemeReference self.themeAccentColor = decoder.decodeOptionalInt32ForKey("themeAccentColor") self.fontSize = PresentationFontSize(rawValue: decoder.decodeInt32ForKey("f", orElse: PresentationFontSize.regular.rawValue)) ?? .regular @@ -180,6 +189,7 @@ public struct PresentationThemeSettings: PreferencesEntry { public func encode(_ encoder: PostboxEncoder) { encoder.encodeObject(self.chatWallpaper, forKey: "w") + encoder.encodeInt32(self.chatWallpaperMode.rawValue, forKey: "m") encoder.encodeObject(self.theme, forKey: "t") if let themeAccentColor = self.themeAccentColor { encoder.encodeInt32(themeAccentColor, forKey: "themeAccentColor") @@ -200,7 +210,7 @@ public struct PresentationThemeSettings: PreferencesEntry { } public static func ==(lhs: PresentationThemeSettings, rhs: PresentationThemeSettings) -> Bool { - return lhs.chatWallpaper == rhs.chatWallpaper && lhs.theme == rhs.theme && lhs.themeAccentColor == rhs.themeAccentColor && lhs.fontSize == rhs.fontSize && lhs.automaticThemeSwitchSetting == rhs.automaticThemeSwitchSetting && lhs.disableAnimations == rhs.disableAnimations + return lhs.chatWallpaper == rhs.chatWallpaper && lhs.chatWallpaperMode == rhs.chatWallpaperMode && lhs.theme == rhs.theme && lhs.themeAccentColor == rhs.themeAccentColor && lhs.fontSize == rhs.fontSize && lhs.automaticThemeSwitchSetting == rhs.automaticThemeSwitchSetting && lhs.disableAnimations == rhs.disableAnimations } } diff --git a/TelegramUI/RadialPlayPauseContentNode.swift b/TelegramUI/RadialPlayPauseContentNode.swift deleted file mode 100644 index 65fe53d3e8..0000000000 --- a/TelegramUI/RadialPlayPauseContentNode.swift +++ /dev/null @@ -1,60 +0,0 @@ -import Foundation -import Display -import AsyncDisplayKit -import LegacyComponents -import SwiftSignalKit - -enum RadialPlayPauseMode { - case play - case pause -} - -class RadialPlayPauseContentNode: RadialStatusContentNode { - var color: UIColor { - didSet { - self.leftShape.fillColor = self.color.cgColor - self.rightShape.fillColor = self.color.cgColor - self.setNeedsDisplay() - } - } - - private var effectiveProgress: CGFloat = 1.0 { - didSet { - self.setNeedsDisplay() - } - } - - private var animationCompletionTimer: SwiftSignalKit.Timer? - - private var isAnimatingProgress: Bool { - return self.pop_animation(forKey: "progress") != nil || self.animationCompletionTimer != nil - } - - private var enqueuedReadyForTransition: (() -> Void)? - - private let leftShape = CAShapeLayer() - private let rightShape = CAShapeLayer() - - init(color: UIColor, mode: RadialPlayPauseMode) { - self.color = color - - super.init() - - self.leftShape.fillColor = self.color.cgColor - self.rightShape.fillColor = self.color.cgColor - - self.isLayerBacked = true - self.isOpaque = false - - self.layer.addSublayer(self.leftShape) - self.layer.addSublayer(self.rightShape) - } - - override func enqueueReadyForTransition(_ f: @escaping () -> Void) { - if self.isAnimatingProgress { - self.enqueuedReadyForTransition = f - } else { - f() - } - } -} diff --git a/TelegramUI/RadialStatusNode.swift b/TelegramUI/RadialStatusNode.swift index 27c8a963d4..1c91cdc4e1 100644 --- a/TelegramUI/RadialStatusNode.swift +++ b/TelegramUI/RadialStatusNode.swift @@ -183,8 +183,13 @@ public final class RadialStatusNode: ASControlNode { contentNode.animateIn(from: fromState) } } - strongSelf.transitionToBackgroundColor(backgroundColor, previousContentNode: previousContentNode, animated: animated, completion: completion) + if backgroundColor != nil { + strongSelf.transitionToBackgroundColor(backgroundColor, previousContentNode: previousContentNode, animated: animated, completion: completion) + } }) + if backgroundColor == nil { + strongSelf.transitionToBackgroundColor(backgroundColor, previousContentNode: previousContentNode, animated: animated, completion: completion) + } } else { previousContentNode.removeFromSupernode() strongSelf.contentNode = strongSelf.nextContentNode diff --git a/TelegramUI/Resources/PresentationStrings.mapping b/TelegramUI/Resources/PresentationStrings.mapping index bd4dd9cbfc..0a7e961806 100644 Binary files a/TelegramUI/Resources/PresentationStrings.mapping and b/TelegramUI/Resources/PresentationStrings.mapping differ diff --git a/TelegramUI/SearchBarPlaceholderNode.swift b/TelegramUI/SearchBarPlaceholderNode.swift index b5a68243fc..6266537aa4 100644 --- a/TelegramUI/SearchBarPlaceholderNode.swift +++ b/TelegramUI/SearchBarPlaceholderNode.swift @@ -65,9 +65,9 @@ class SearchBarPlaceholderNode: ASDisplayNode { self.iconNode.displayWithoutProcessing = true self.labelNode = TextNode() - self.labelNode.isOpaque = true + self.labelNode.isOpaque = false self.labelNode.isLayerBacked = true - self.labelNode.backgroundColor = self.foregroundColor + //self.labelNode.backgroundColor = self.foregroundColor super.init() @@ -90,7 +90,7 @@ class SearchBarPlaceholderNode: ASDisplayNode { let currentIconColor = self.iconColor return { placeholderString, constrainedSize, expansionProgress, iconColor, foregroundColor, backgroundColor, transition in - let (labelLayoutResult, labelApply) = labelLayout(TextNodeLayoutArguments(attributedString: placeholderString, backgroundColor: foregroundColor, maximumNumberOfLines: 1, truncationType: .end, constrainedSize: constrainedSize, alignment: .natural, cutout: nil, insets: UIEdgeInsets())) + let (labelLayoutResult, labelApply) = labelLayout(TextNodeLayoutArguments(attributedString: placeholderString, backgroundColor: .clear, maximumNumberOfLines: 1, truncationType: .end, constrainedSize: constrainedSize, alignment: .natural, cutout: nil, insets: UIEdgeInsets())) var updatedColor: UIColor? var updatedIconImage: UIImage? @@ -111,7 +111,7 @@ class SearchBarPlaceholderNode: ASDisplayNode { strongSelf.backgroundNode.isUserInteractionEnabled = expansionProgress > 1.0 - CGFloat.ulpOfOne if let updatedColor = updatedColor { - strongSelf.labelNode.backgroundColor = updatedColor + //strongSelf.labelNode.backgroundColor = updatedColor strongSelf.backgroundNode.backgroundColor = updatedColor } if let updatedIconImage = updatedIconImage { diff --git a/TelegramUI/StoredMessageFromSearchPeer.swift b/TelegramUI/StoredMessageFromSearchPeer.swift index f66049a2f2..a243458229 100644 --- a/TelegramUI/StoredMessageFromSearchPeer.swift +++ b/TelegramUI/StoredMessageFromSearchPeer.swift @@ -3,13 +3,17 @@ import Postbox import TelegramCore import SwiftSignalKit -func storedMessageFromSearchPeer(account: Account, peer: Peer) -> Signal { - return account.postbox.transaction { transaction -> Void in +func storedMessageFromSearchPeer(account: Account, peer: Peer) -> Signal { + return account.postbox.transaction { transaction -> PeerId in if transaction.getPeer(peer.id) == nil { updatePeers(transaction: transaction, peers: [peer], update: { previousPeer, updatedPeer in return updatedPeer }) } + if let group = transaction.getPeer(peer.id) as? TelegramGroup, let migrationReference = group.migrationReference { + return migrationReference.peerId + } + return peer.id } } diff --git a/TelegramUI/TelegramRootController.swift b/TelegramUI/TelegramRootController.swift index 4e670d436e..bf7b30bc44 100644 --- a/TelegramUI/TelegramRootController.swift +++ b/TelegramUI/TelegramRootController.swift @@ -83,7 +83,7 @@ public final class TelegramRootController: NavigationController { } DispatchQueue.main.asyncAfter(deadline: DispatchTime.now() + 0.3) { - (controller.navigationController as? NavigationController)?.pushViewController(ThemeGridController(account: self.account, mode: .wallpapers)) + //(controller.navigationController as? NavigationController)?.pushViewController(ThemeGridController(account: self.account, mode: .wallpapers)) // let wrapperNode = ASDisplayNode() // let bounds = controller.displayNode.bounds diff --git a/TelegramUI/ThemeGalleryController.swift b/TelegramUI/ThemeGalleryController.swift index 3a87609683..5d6b6cc2d3 100644 --- a/TelegramUI/ThemeGalleryController.swift +++ b/TelegramUI/ThemeGalleryController.swift @@ -220,7 +220,7 @@ class ThemeGalleryController: ViewController { wallpaper = value } let _ = (updatePresentationThemeSettingsInteractively(postbox: strongSelf.account.postbox, { current in - return PresentationThemeSettings(chatWallpaper: wallpaper, theme: current.theme, themeAccentColor: current.themeAccentColor, fontSize: current.fontSize, automaticThemeSwitchSetting: current.automaticThemeSwitchSetting, disableAnimations: current.disableAnimations) + return PresentationThemeSettings(chatWallpaper: wallpaper, chatWallpaperMode: .still, theme: current.theme, themeAccentColor: current.themeAccentColor, fontSize: current.fontSize, automaticThemeSwitchSetting: current.automaticThemeSwitchSetting, disableAnimations: current.disableAnimations) }) |> deliverOnMainQueue).start(completed: { self?.dismiss(forceAway: true) }) diff --git a/TelegramUI/ThemeGridController.swift b/TelegramUI/ThemeGridController.swift index bfbfd69a79..e190f16dba 100644 --- a/TelegramUI/ThemeGridController.swift +++ b/TelegramUI/ThemeGridController.swift @@ -58,7 +58,7 @@ final class ThemeGridController: ViewController { }) self.searchContentNode = NavigationBarSearchContentNode(theme: self.presentationData.theme, placeholder: self.presentationData.strings.Wallpaper_Search, activate: { [weak self] in - self?.activateSearch() + //self?.activateSearch() }) self.navigationBar?.setContentNode(self.searchContentNode, animated: false) } @@ -147,12 +147,17 @@ final class ThemeGridController: ViewController { let wallpaper: TelegramWallpaper = .image([TelegramMediaImageRepresentation(dimensions: image.size, resource: resource)]) let _ = (updatePresentationThemeSettingsInteractively(postbox: self.account.postbox, { current in - return PresentationThemeSettings(chatWallpaper: wallpaper, theme: current.theme, themeAccentColor: current.themeAccentColor, fontSize: current.fontSize, automaticThemeSwitchSetting: current.automaticThemeSwitchSetting, disableAnimations: current.disableAnimations) - }) |> deliverOnMainQueue).start(completed: { [weak self] in - let _ = (self?.navigationController as? NavigationController)?.popViewController(animated: true) - }) + return PresentationThemeSettings(chatWallpaper: wallpaper, chatWallpaperMode: .still, theme: current.theme, themeAccentColor: current.themeAccentColor, fontSize: current.fontSize, automaticThemeSwitchSetting: current.automaticThemeSwitchSetting, disableAnimations: current.disableAnimations) + }) |> deliverOnMainQueue).start() - let _ = uploadWallpaper(account: self.account, resource: resource) + let account = self.account + let _ = uploadWallpaper(account: account, resource: resource).start(next: { status in + if case let .complete(wallpaper) = status { + let _ = (updatePresentationThemeSettingsInteractively(postbox: account.postbox, { current in + return PresentationThemeSettings(chatWallpaper: wallpaper, chatWallpaperMode: .still, theme: current.theme, themeAccentColor: current.themeAccentColor, fontSize: current.fontSize, automaticThemeSwitchSetting: current.automaticThemeSwitchSetting, disableAnimations: current.disableAnimations) + })).start() + } + }) } override func containerLayoutUpdated(_ layout: ContainerViewLayout, transition: ContainedViewLayoutTransition) { diff --git a/TelegramUI/ThemeGridControllerNode.swift b/TelegramUI/ThemeGridControllerNode.swift index 5db5fa8169..50a01ecba0 100644 --- a/TelegramUI/ThemeGridControllerNode.swift +++ b/TelegramUI/ThemeGridControllerNode.swift @@ -168,8 +168,9 @@ final class ThemeGridControllerNode: ASDisplayNode { let transition = combineLatest(telegramWallpapers(postbox: account.postbox, network: account.network), account.telegramApplicationContext.presentationData) |> map { wallpapers, presentationData -> (ThemeGridEntryTransition, Bool) in var entries: [ThemeGridControllerEntry] = [] - var index = 0 + var index = 1 + var hasCurrent = false switch presentationData.theme.name { case let .builtin(name): switch name { @@ -177,15 +178,21 @@ final class ThemeGridControllerNode: ASDisplayNode { break case .day: let wallpaper = TelegramWallpaper.color(0xffffff) - entries.append(ThemeGridControllerEntry(index: index, wallpaper: wallpaper, selected: presentationData.chatWallpaper == wallpaper)) + let selected = presentationData.chatWallpaper == wallpaper + entries.append(ThemeGridControllerEntry(index: index, wallpaper: wallpaper, selected: selected)) + hasCurrent = hasCurrent || selected index += 1 case .nightGrayscale: let wallpaper = TelegramWallpaper.color(0xffffff) - entries.append(ThemeGridControllerEntry(index: index, wallpaper: wallpaper, selected: presentationData.chatWallpaper == wallpaper)) + let selected = presentationData.chatWallpaper == wallpaper + entries.append(ThemeGridControllerEntry(index: index, wallpaper: wallpaper, selected: selected)) + hasCurrent = hasCurrent || selected index += 1 case .nightAccent: let wallpaper = TelegramWallpaper.color(0xffffff) - entries.append(ThemeGridControllerEntry(index: index, wallpaper: wallpaper, selected: presentationData.chatWallpaper == wallpaper)) + let selected = presentationData.chatWallpaper == wallpaper + entries.append(ThemeGridControllerEntry(index: index, wallpaper: wallpaper, selected: selected)) + hasCurrent = hasCurrent || selected index += 1 } default: @@ -193,9 +200,16 @@ final class ThemeGridControllerNode: ASDisplayNode { } for wallpaper in wallpapers { - entries.append(ThemeGridControllerEntry(index: index, wallpaper: wallpaper, selected: presentationData.chatWallpaper == wallpaper)) + let selected = presentationData.chatWallpaper == wallpaper + entries.append(ThemeGridControllerEntry(index: index, wallpaper: wallpaper, selected: selected)) + hasCurrent = hasCurrent || selected index += 1 } + + if !hasCurrent { + entries.insert(ThemeGridControllerEntry(index: 0, wallpaper: presentationData.chatWallpaper, selected: true), at: 0) + } + let previous = previousEntries.swap(entries) return (preparedThemeGridEntryTransition(account: account, from: previous ?? [], to: entries, interaction: interaction), previous == nil) } diff --git a/TelegramUI/ThemeSettingsController.swift b/TelegramUI/ThemeSettingsController.swift index 61c51bb0f8..b4e67ac21c 100644 --- a/TelegramUI/ThemeSettingsController.swift +++ b/TelegramUI/ThemeSettingsController.swift @@ -268,26 +268,25 @@ public func themeSettingsController(account: Account) -> ViewController { wallpaper = .color(0x18222D) theme = .builtin(.nightAccent) } - return PresentationThemeSettings(chatWallpaper: wallpaper, theme: theme, themeAccentColor: current.themeAccentColor, fontSize: current.fontSize, automaticThemeSwitchSetting: current.automaticThemeSwitchSetting, disableAnimations: current.disableAnimations) + return PresentationThemeSettings(chatWallpaper: wallpaper, chatWallpaperMode: .still, theme: theme, themeAccentColor: current.themeAccentColor, fontSize: current.fontSize, automaticThemeSwitchSetting: current.automaticThemeSwitchSetting, disableAnimations: current.disableAnimations) }).start() }, selectFontSize: { size in let _ = updatePresentationThemeSettingsInteractively(postbox: account.postbox, { current in - return PresentationThemeSettings(chatWallpaper: current.chatWallpaper, theme: current.theme, themeAccentColor: current.themeAccentColor, fontSize: size, automaticThemeSwitchSetting: current.automaticThemeSwitchSetting, disableAnimations: current.disableAnimations) + return PresentationThemeSettings(chatWallpaper: current.chatWallpaper, chatWallpaperMode: current.chatWallpaperMode, theme: current.theme, themeAccentColor: current.themeAccentColor, fontSize: size, automaticThemeSwitchSetting: current.automaticThemeSwitchSetting, disableAnimations: current.disableAnimations) }).start() }, openWallpaperSettings: { pushControllerImpl?(ThemeGridController(account: account, mode: .wallpapers)) }, openAccentColor: { color in - let presentationData = account.telegramApplicationContext.currentPresentationData.with { $0 } presentControllerImpl?(ThemeAccentColorActionSheet(account: account, currentValue: color, applyValue: { color in let _ = updatePresentationThemeSettingsInteractively(postbox: account.postbox, { current in - return PresentationThemeSettings(chatWallpaper: current.chatWallpaper, theme: current.theme, themeAccentColor: color, fontSize: current.fontSize, automaticThemeSwitchSetting: current.automaticThemeSwitchSetting, disableAnimations: current.disableAnimations) + return PresentationThemeSettings(chatWallpaper: current.chatWallpaper, chatWallpaperMode: current.chatWallpaperMode, theme: current.theme, themeAccentColor: color, fontSize: current.fontSize, automaticThemeSwitchSetting: current.automaticThemeSwitchSetting, disableAnimations: current.disableAnimations) }).start() })) }, openAutoNightTheme: { pushControllerImpl?(themeAutoNightSettingsController(account: account)) }, disableAnimations: { disabled in let _ = updatePresentationThemeSettingsInteractively(postbox: account.postbox, { current in - return PresentationThemeSettings(chatWallpaper: current.chatWallpaper, theme: current.theme, themeAccentColor: current.themeAccentColor, fontSize: current.fontSize, automaticThemeSwitchSetting: current.automaticThemeSwitchSetting, disableAnimations: disabled) + return PresentationThemeSettings(chatWallpaper: current.chatWallpaper, chatWallpaperMode: current.chatWallpaperMode, theme: current.theme, themeAccentColor: current.themeAccentColor, fontSize: current.fontSize, automaticThemeSwitchSetting: current.automaticThemeSwitchSetting, disableAnimations: disabled) }).start() }) diff --git a/TelegramUI/UrlHandling.swift b/TelegramUI/UrlHandling.swift index 1da3b13e1a..b8fd9d90b4 100644 --- a/TelegramUI/UrlHandling.swift +++ b/TelegramUI/UrlHandling.swift @@ -20,6 +20,7 @@ enum ParsedInternalUrl { case confirmationCode(Int) case cancelAccountReset(phone: String, hash: String) case share(url: String?, text: String?, to: String?) + case wallpaper(String) } private enum ParsedUrl { @@ -41,6 +42,7 @@ enum ResolvedUrl { case confirmationCode(Int) case cancelAccountReset(phone: String, hash: String) case share(url: String?, text: String?, to: String?) + case wallpaper(String) } func parseInternalUrl(query: String) -> ParsedInternalUrl? { @@ -167,6 +169,8 @@ func parseInternalUrl(query: String) -> ParsedInternalUrl? { } } return nil + } else if pathComponents[0] == "bg" { + return .wallpaper(pathComponents[1]) } else if let value = Int(pathComponents[1]) { return .peerName(peerName, .channelMessage(Int32(value))) } else { @@ -233,6 +237,8 @@ private func resolveInternalUrl(account: Account, url: ParsedInternalUrl) -> Sig return .single(.cancelAccountReset(phone: phone, hash: hash)) case let .share(url, text, to): return .single(.share(url: url, text: text, to: to)) + case let .wallpaper(slug): + return .single(.wallpaper(slug)) } } diff --git a/TelegramUI/UserInfoController.swift b/TelegramUI/UserInfoController.swift index 066050d259..8e7ecd2861 100644 --- a/TelegramUI/UserInfoController.swift +++ b/TelegramUI/UserInfoController.swift @@ -665,6 +665,8 @@ private func userInfoEntries(account: Account, presentationData: PresentationDat } else { notificationsLabel = presentationData.strings.UserInfo_NotificationsDisabled } + } else if case .default = notificationSettings.messageSound { + notificationsLabel = presentationData.strings.UserInfo_NotificationsEnabled } else { notificationsLabel = localizedPeerNotificationSoundString(strings: presentationData.strings, sound: notificationSettings.messageSound, default: globalNotificationSettings.effective.channels.sound) } diff --git a/TelegramUI/WallpaperListPreviewController.swift b/TelegramUI/WallpaperListPreviewController.swift index 4354733094..bebc946617 100644 --- a/TelegramUI/WallpaperListPreviewController.swift +++ b/TelegramUI/WallpaperListPreviewController.swift @@ -26,6 +26,9 @@ final class WallpaperListPreviewController: ViewController { private var presentationData: PresentationData private var presentationDataDisposable: Disposable? + private var wallpaper: TelegramWallpaper? + private var wallpaperDisposable: Disposable? + private var didPlayPresentationAnimation = false init(account: Account, source: WallpaperListPreviewSource) { @@ -62,12 +65,12 @@ final class WallpaperListPreviewController: ViewController { deinit { self.presentationDataDisposable?.dispose() + self.wallpaperDisposable?.dispose() } private func updateThemeAndStrings() { self.title = self.presentationData.strings.BackgroundPreview_Title self.navigationItem.backBarButtonItem = UIBarButtonItem(title: self.presentationData.strings.Common_Back, style: .plain, target: nil, action: nil) - self.navigationItem.rightBarButtonItem = UIBarButtonItem(image: generateTintedImage(image: UIImage(bundleImageName: "Chat/Input/Accessory Panels/MessageSelectionAction"), color: self.presentationData.theme.rootController.navigationBar.accentTextColor), style: .plain, target: self, action: #selector(self.sharePressed)) self.statusBar.statusBarStyle = self.presentationData.theme.rootController.statusBar.style.style self.navigationBar?.updatePresentationData(NavigationBarPresentationData(presentationData: self.presentationData)) @@ -96,13 +99,13 @@ final class WallpaperListPreviewController: ViewController { override public func loadDisplayNode() { self.displayNode = WallpaperListPreviewControllerNode(account: self.account, presentationData: self.presentationData, source: self.source, dismiss: { [weak self] in self?.dismiss() - }, apply: { [weak self] wallpaper in + }, apply: { [weak self] wallpaper, mode in guard let strongSelf = self else { return } let _ = (updatePresentationThemeSettingsInteractively(postbox: strongSelf.account.postbox, { current in - return PresentationThemeSettings(chatWallpaper: wallpaper, theme: current.theme, themeAccentColor: current.themeAccentColor, fontSize: current.fontSize, automaticThemeSwitchSetting: current.automaticThemeSwitchSetting, disableAnimations: current.disableAnimations) + return PresentationThemeSettings(chatWallpaper: wallpaper, chatWallpaperMode: mode, theme: current.theme, themeAccentColor: current.themeAccentColor, fontSize: current.fontSize, automaticThemeSwitchSetting: current.automaticThemeSwitchSetting, disableAnimations: current.disableAnimations) }) |> deliverOnMainQueue).start(completed: { self?.dismiss() @@ -110,6 +113,20 @@ final class WallpaperListPreviewController: ViewController { }) self._ready.set(self.controllerNode.ready.get()) self.displayNodeDidLoad() + + self.wallpaperDisposable = (self.controllerNode.currentWallpaper + |> deliverOnMainQueue).start(next: { [weak self] wallpaper in + guard let strongSelf = self else { + return + } + + if case let .file(_, _, _, _, slug, _, _) = wallpaper, let wallpaperSlug = slug, !wallpaperSlug.isEmpty { + strongSelf.wallpaper = wallpaper + strongSelf.navigationItem.rightBarButtonItem = UIBarButtonItem(image: generateTintedImage(image: UIImage(bundleImageName: "Chat/Input/Accessory Panels/MessageSelectionAction"), color: strongSelf.presentationData.theme.rootController.navigationBar.accentTextColor), style: .plain, target: self, action: #selector(strongSelf.sharePressed)) + } else { + strongSelf.navigationItem.rightBarButtonItem = nil + } + }) } override func containerLayoutUpdated(_ layout: ContainerViewLayout, transition: ContainedViewLayoutTransition) { @@ -119,7 +136,9 @@ final class WallpaperListPreviewController: ViewController { } @objc func sharePressed() { - let shareController = ShareController(account: account, subject: .url("link")) - self.present(shareController, in: .window(.root), blockInteraction: true) + if let wallpaper = self.wallpaper, case let .file(_, _, _, _, slug, _, _) = wallpaper, let wallpaperSlug = slug, !wallpaperSlug.isEmpty { + let shareController = ShareController(account: account, subject: .url("https://t.me/bg/\(wallpaperSlug)")) + self.present(shareController, in: .window(.root), blockInteraction: true) + } } } diff --git a/TelegramUI/WallpaperListPreviewControllerNode.swift b/TelegramUI/WallpaperListPreviewControllerNode.swift index b0f66eca61..e5b9cf4c7a 100644 --- a/TelegramUI/WallpaperListPreviewControllerNode.swift +++ b/TelegramUI/WallpaperListPreviewControllerNode.swift @@ -5,13 +5,29 @@ import SwiftSignalKit import Postbox import TelegramCore +private enum WallpaperSegmentedControlStyle { + case dark + case light + + var color: UIColor { + switch self { + case .dark: + return UIColor(rgb: 0x484848) + case .light: + return .white + } + } +} + private final class WallpaperBackgroundNode: ASDisplayNode { let wallpaper: TelegramWallpaper private var fetchDisposable: Disposable? private var statusDisposable: Disposable? - private let imageNode: TransformImageNode + let imageNode: TransformImageNode private let statusNode: RadialStatusNode + let segmentedControlColor = Promise(.white) + init(account: Account, wallpaper: TelegramWallpaper) { self.wallpaper = wallpaper self.imageNode = TransformImageNode() @@ -55,7 +71,7 @@ private final class WallpaperBackgroundNode: ASDisplayNode { convertedRepresentations.append(ImageRepresentationWithReference(representation: representation, reference: .standalone(resource: representation.resource))) } convertedRepresentations.append(ImageRepresentationWithReference(representation: .init(dimensions: dimensions, resource: file.file.resource), reference: .standalone(resource: file.file.resource))) - signal = chatAvatarGalleryPhoto(account: account, representations: convertedRepresentations) + signal = chatMessageImageFile(account: account, fileReference: .standalone(media: file.file), thumbnail: false) fetchSignal = fetchedMediaResource(postbox: account.postbox, reference: convertedRepresentations[convertedRepresentations.count - 1].reference) statusSignal = account.postbox.mediaBox.resourceStatus(file.file.resource) case let .image(representations): @@ -101,6 +117,8 @@ private final class WallpaperBackgroundNode: ASDisplayNode { } }) self.imageNode.contentMode = .scaleAspectFill + + self.segmentedControlColor.set(.single(.white) |> then(chatBackgroundContrastColor(wallpaper: wallpaper, postbox: account.postbox))) } deinit { @@ -120,7 +138,7 @@ final class WallpaperListPreviewControllerNode: ViewControllerTracingNode { private let account: Account private var presentationData: PresentationData private let dismiss: () -> Void - private let apply: (TelegramWallpaper) -> Void + private let apply: (TelegramWallpaper, PresentationWallpaperMode) -> Void private var validLayout: (ContainerViewLayout, CGFloat)? @@ -133,6 +151,8 @@ final class WallpaperListPreviewControllerNode: ViewControllerTracingNode { private let toolbarButtonApplyBackground: ASDisplayNode private let segmentedControl: UISegmentedControl + private var segmentedControlColor = Promise(.white) + private var segmentedControlColorDisposable: Disposable? private var wallpapersDisposable: Disposable? private var wallpapers: [TelegramWallpaper]? @@ -142,9 +162,14 @@ final class WallpaperListPreviewControllerNode: ViewControllerTracingNode { private var visibleBackgroundNodes: [WallpaperBackgroundNode] = [] private var centralWallpaper: TelegramWallpaper? + + private let currentWallpaperPromise = Promise() + var currentWallpaper: Signal { + return self.currentWallpaperPromise.get() + } private var visibleBackgroundNodesOffset: CGFloat = 0.0 - init(account: Account, presentationData: PresentationData, source: WallpaperListPreviewSource, dismiss: @escaping () -> Void, apply: @escaping (TelegramWallpaper) -> Void) { + init(account: Account, presentationData: PresentationData, source: WallpaperListPreviewSource, dismiss: @escaping () -> Void, apply: @escaping (TelegramWallpaper, PresentationWallpaperMode) -> Void) { self.account = account self.presentationData = presentationData self.dismiss = dismiss @@ -223,6 +248,14 @@ final class WallpaperListPreviewControllerNode: ViewControllerTracingNode { } } + self.segmentedControl.addTarget(self, action: #selector(self.indexChanged), for: .valueChanged) + self.segmentedControlColorDisposable = (self.segmentedControlColor.get() + |> deliverOnMainQueue).start(next: { [weak self] color in + if let strongSelf = self { + strongSelf.segmentedControl.tintColor = color + } + }) + switch source { case let .list(wallpapers, central): self.wallpapers = wallpapers @@ -239,6 +272,9 @@ final class WallpaperListPreviewControllerNode: ViewControllerTracingNode { } self.ready.set(true) } + if let wallpaper = self.centralWallpaper { + self.currentWallpaperPromise.set(.single(wallpaper)) + } } deinit { @@ -405,6 +441,11 @@ final class WallpaperListPreviewControllerNode: ViewControllerTracingNode { } else { itemNodeTransition = transition } + + if j == i { + self.segmentedControlColor.set(itemNode.segmentedControlColor.get()) + } + itemNodeTransition.updateFrame(node: itemNode, frame: itemFrame) itemNode.updateLayout(layout, navigationHeight: navigationBarHeight, transition: itemNodeTransition) visibleBackgroundNodes.append(itemNode) @@ -451,13 +492,64 @@ final class WallpaperListPreviewControllerNode: ViewControllerTracingNode { return super.hitTest(point, with: event) } + private func addParallaxToView(_ view: UIView) { + let amount = 16.0 + + let horizontal = UIInterpolatingMotionEffect(keyPath: "center.x", type: .tiltAlongHorizontalAxis) + horizontal.minimumRelativeValue = -amount + horizontal.maximumRelativeValue = amount + + let vertical = UIInterpolatingMotionEffect(keyPath: "center.y", type: .tiltAlongVerticalAxis) + vertical.minimumRelativeValue = -amount + vertical.maximumRelativeValue = amount + + let group = UIMotionEffectGroup() + group.motionEffects = [horizontal, vertical] + view.addMotionEffect(group) + } + + private func removeParallaxFromView(_ view: UIView) { + for effect in view.motionEffects { + view.removeMotionEffect(effect) + } + } + + @objc private func indexChanged() { + guard let mode = PresentationWallpaperMode(rawValue: Int32(self.segmentedControl.selectedSegmentIndex)) else { + return + } + + if mode == .perspective { + for node in self.visibleBackgroundNodes { + if node.wallpaper == self.centralWallpaper { + self.addParallaxToView(node.imageNode.view) + } + } + } else { + for node in self.visibleBackgroundNodes { + if node.wallpaper == self.centralWallpaper { + self.removeParallaxFromView(node.imageNode.view) + } + } + } + } + @objc private func cancelPressed() { self.dismiss() } @objc private func applyPressed() { if let wallpaper = self.centralWallpaper { - self.apply(wallpaper) + let mode: PresentationWallpaperMode + switch self.segmentedControl.selectedSegmentIndex { + case 1: + mode = .perspective + case 2: + mode = .blurred + default: + mode = .still + } + self.apply(wallpaper, mode) } } } diff --git a/TelegramUI/WebSearchGalleryController.swift b/TelegramUI/WebSearchGalleryController.swift index 5e6a399cae..1097beb3ae 100644 --- a/TelegramUI/WebSearchGalleryController.swift +++ b/TelegramUI/WebSearchGalleryController.swift @@ -32,7 +32,7 @@ struct WebSearchGalleryEntry: Equatable { switch self.result { case let .externalReference(_, _, type, _, _, _, content, thumbnail, _): if let content = content, type == "gif", let thumbnailResource = thumbnail?.resource, let dimensions = content.dimensions { - let fileReference = FileMediaReference.standalone(media: TelegramMediaFile(fileId: MediaId(namespace: Namespaces.Media.LocalFile, id: 0), partialReference: nil, resource: content.resource, previewRepresentations: [TelegramMediaImageRepresentation(dimensions: dimensions, resource: thumbnailResource)], mimeType: "video/mp4", size: nil, attributes: [.Animated, .Video(duration: 0, size: dimensions, flags: [])])) + let fileReference = FileMediaReference.standalone(media: TelegramMediaFile(fileId: MediaId(namespace: Namespaces.Media.LocalFile, id: 0), partialReference: nil, resource: content.resource, previewRepresentations: [TelegramMediaImageRepresentation(dimensions: dimensions, resource: thumbnailResource)], immediateThumbnailData: nil, mimeType: "video/mp4", size: nil, attributes: [.Animated, .Video(duration: 0, size: dimensions, flags: [])])) return WebSearchVideoGalleryItem(account: account, presentationData: presentationData, result: self.result, content: NativeVideoContent(id: .contextResult(self.result.queryId, self.result.id), fileReference: fileReference, streamVideo: false, loopVideo: true, enableSound: false, fetchAutomatically: true), controllerInteraction: controllerInteraction) } case let .internalReference(_, _, _, _, _, _, file, _):