diff --git a/Images.xcassets/Chat/Info/GroupAdminsIcon.imageset/Admin.pdf b/Images.xcassets/Chat/Info/GroupAdminsIcon.imageset/Admin.pdf new file mode 100644 index 0000000000..0642012e7a Binary files /dev/null and b/Images.xcassets/Chat/Info/GroupAdminsIcon.imageset/Admin.pdf differ diff --git a/Images.xcassets/Chat/Info/GroupAdminsIcon.imageset/Contents.json b/Images.xcassets/Chat/Info/GroupAdminsIcon.imageset/Contents.json new file mode 100644 index 0000000000..eb45dbaa86 --- /dev/null +++ b/Images.xcassets/Chat/Info/GroupAdminsIcon.imageset/Contents.json @@ -0,0 +1,12 @@ +{ + "images" : [ + { + "idiom" : "universal", + "filename" : "Admin.pdf" + } + ], + "info" : { + "version" : 1, + "author" : "xcode" + } +} \ No newline at end of file diff --git a/Images.xcassets/Chat/Info/GroupMembersIcon.imageset/Contents.json b/Images.xcassets/Chat/Info/GroupMembersIcon.imageset/Contents.json new file mode 100644 index 0000000000..a18f26cad9 --- /dev/null +++ b/Images.xcassets/Chat/Info/GroupMembersIcon.imageset/Contents.json @@ -0,0 +1,12 @@ +{ + "images" : [ + { + "idiom" : "universal", + "filename" : "Members.pdf" + } + ], + "info" : { + "version" : 1, + "author" : "xcode" + } +} \ No newline at end of file diff --git a/Images.xcassets/Chat/Info/GroupMembersIcon.imageset/Members.pdf b/Images.xcassets/Chat/Info/GroupMembersIcon.imageset/Members.pdf new file mode 100644 index 0000000000..9acdeec97f Binary files /dev/null and b/Images.xcassets/Chat/Info/GroupMembersIcon.imageset/Members.pdf differ diff --git a/Images.xcassets/Chat/Info/GroupPermissionsIcon.imageset/Contents.json b/Images.xcassets/Chat/Info/GroupPermissionsIcon.imageset/Contents.json new file mode 100644 index 0000000000..b2010c6dd0 --- /dev/null +++ b/Images.xcassets/Chat/Info/GroupPermissionsIcon.imageset/Contents.json @@ -0,0 +1,12 @@ +{ + "images" : [ + { + "idiom" : "universal", + "filename" : "Permissions.pdf" + } + ], + "info" : { + "version" : 1, + "author" : "xcode" + } +} \ No newline at end of file diff --git a/Images.xcassets/Chat/Info/GroupPermissionsIcon.imageset/Permissions.pdf b/Images.xcassets/Chat/Info/GroupPermissionsIcon.imageset/Permissions.pdf new file mode 100644 index 0000000000..ef2a10c8a6 Binary files /dev/null and b/Images.xcassets/Chat/Info/GroupPermissionsIcon.imageset/Permissions.pdf differ diff --git a/TelegramUI.xcodeproj/project.pbxproj b/TelegramUI.xcodeproj/project.pbxproj index 233b545e57..29fb4c2915 100644 --- a/TelegramUI.xcodeproj/project.pbxproj +++ b/TelegramUI.xcodeproj/project.pbxproj @@ -385,6 +385,7 @@ D0AB262F21C3D3DE008F6685 /* CreatePollController.swift in Sources */ = {isa = PBXBuildFile; fileRef = D0AB262E21C3D3DE008F6685 /* CreatePollController.swift */; }; D0AB263121C3DB21008F6685 /* CreatePollOptionItem.swift in Sources */ = {isa = PBXBuildFile; fileRef = D0AB263021C3DB21008F6685 /* CreatePollOptionItem.swift */; }; D0AB263321C3DFEA008F6685 /* CreatePollOptionActionItem.swift in Sources */ = {isa = PBXBuildFile; fileRef = D0AB263221C3DFEA008F6685 /* CreatePollOptionActionItem.swift */; }; + D0AB269E21D56A12008F6685 /* ChannelPermissionsController.swift in Sources */ = {isa = PBXBuildFile; fileRef = D0AB269D21D56A12008F6685 /* ChannelPermissionsController.swift */; }; D0ACCB1A1EC5E0C20079D8BF /* CallControllerKeyPreviewNode.swift in Sources */ = {isa = PBXBuildFile; fileRef = D0ACCB191EC5E0C20079D8BF /* CallControllerKeyPreviewNode.swift */; }; D0ACCB1C1EC5FF4B0079D8BF /* ChatMessageCallBubbleContentNode.swift in Sources */ = {isa = PBXBuildFile; fileRef = D0ACCB1B1EC5FF4B0079D8BF /* ChatMessageCallBubbleContentNode.swift */; }; D0AD02E81FFFDE5F00C1DCFF /* ChatMessageLiveLocationTimerNode.swift in Sources */ = {isa = PBXBuildFile; fileRef = D0AD02E71FFFDE5F00C1DCFF /* ChatMessageLiveLocationTimerNode.swift */; }; @@ -1793,6 +1794,7 @@ D0AB262E21C3D3DE008F6685 /* CreatePollController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CreatePollController.swift; sourceTree = ""; }; D0AB263021C3DB21008F6685 /* CreatePollOptionItem.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CreatePollOptionItem.swift; sourceTree = ""; }; D0AB263221C3DFEA008F6685 /* CreatePollOptionActionItem.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CreatePollOptionActionItem.swift; sourceTree = ""; }; + D0AB269D21D56A12008F6685 /* ChannelPermissionsController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = ChannelPermissionsController.swift; sourceTree = ""; }; D0ACCB191EC5E0C20079D8BF /* CallControllerKeyPreviewNode.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = CallControllerKeyPreviewNode.swift; sourceTree = ""; }; D0ACCB1B1EC5FF4B0079D8BF /* ChatMessageCallBubbleContentNode.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = ChatMessageCallBubbleContentNode.swift; sourceTree = ""; }; D0AD02E71FFFDE5F00C1DCFF /* ChatMessageLiveLocationTimerNode.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = ChatMessageLiveLocationTimerNode.swift; sourceTree = ""; }; @@ -4089,6 +4091,7 @@ D00BDA1E1EE5B69200C64C5E /* ChannelAdminController.swift */, D0F680091EE750EE000E5906 /* ChannelBannedMemberController.swift */, D0B98E7E1E575D2C008084B1 /* ChannelBlacklistController.swift */, + D0AB269D21D56A12008F6685 /* ChannelPermissionsController.swift */, D0613FC71E5F8AB100202CDB /* ChannelInfoController.swift */, D0613FCC1E60482300202CDB /* ChannelMembersController.swift */, D0613FD41E6064D200202CDB /* ConvertToSupergroupController.swift */, @@ -5226,6 +5229,7 @@ D0EC6D0C1EB9F58800EBF1C3 /* stream.c in Sources */, D0EC6D0D1EB9F58800EBF1C3 /* MediaFrameSource.swift in Sources */, D0EC6D0E1EB9F58800EBF1C3 /* MediaPlaybackData.swift in Sources */, + D0AB269E21D56A12008F6685 /* ChannelPermissionsController.swift in Sources */, D0EC6D0F1EB9F58800EBF1C3 /* MediaPlayer.swift in Sources */, D0EC6D101EB9F58800EBF1C3 /* MediaPlayerAudioRenderer.swift in Sources */, D0EC6D111EB9F58800EBF1C3 /* MediaPlayerNode.swift in Sources */, diff --git a/TelegramUI/ChannelAdminController.swift b/TelegramUI/ChannelAdminController.swift index 3c106981a4..a915ee2aa7 100644 --- a/TelegramUI/ChannelAdminController.swift +++ b/TelegramUI/ChannelAdminController.swift @@ -6,10 +6,10 @@ import TelegramCore private final class ChannelAdminControllerArguments { let account: Account - let toggleRight: (TelegramChannelAdminRightsFlags, TelegramChannelAdminRightsFlags) -> Void + let toggleRight: (TelegramChatAdminRightsFlags, TelegramChatAdminRightsFlags) -> Void let dismissAdmin: () -> Void - init(account: Account, toggleRight: @escaping (TelegramChannelAdminRightsFlags, TelegramChannelAdminRightsFlags) -> Void, dismissAdmin: @escaping () -> Void) { + init(account: Account, toggleRight: @escaping (TelegramChatAdminRightsFlags, TelegramChatAdminRightsFlags) -> Void, dismissAdmin: @escaping () -> Void) { self.account = account self.toggleRight = toggleRight self.dismissAdmin = dismissAdmin @@ -25,7 +25,7 @@ private enum ChannelAdminSection: Int32 { private enum ChannelAdminEntryStableId: Hashable { case info case rightsTitle - case right(TelegramChannelAdminRightsFlags) + case right(TelegramChatAdminRightsFlags) case addAdminsInfo case dismiss @@ -83,7 +83,7 @@ private enum ChannelAdminEntryStableId: Hashable { private enum ChannelAdminEntry: ItemListNodeEntry { case info(PresentationTheme, PresentationStrings, PresentationDateTimeFormat, Peer, TelegramUserPresence?) case rightsTitle(PresentationTheme, String) - case rightItem(PresentationTheme, Int, String, TelegramChannelAdminRightsFlags, TelegramChannelAdminRightsFlags, Bool, Bool) + case rightItem(PresentationTheme, Int, String, TelegramChatAdminRightsFlags, TelegramChatAdminRightsFlags, Bool, Bool) case addAdminsInfo(PresentationTheme, String) case dismiss(PresentationTheme, String) @@ -245,10 +245,10 @@ private enum ChannelAdminEntry: ItemListNodeEntry { } private struct ChannelAdminControllerState: Equatable { - let updatedFlags: TelegramChannelAdminRightsFlags? + let updatedFlags: TelegramChatAdminRightsFlags? let updating: Bool - init(updatedFlags: TelegramChannelAdminRightsFlags? = nil, updating: Bool = false) { + init(updatedFlags: TelegramChatAdminRightsFlags? = nil, updating: Bool = false) { self.updatedFlags = updatedFlags self.updating = updating } @@ -263,7 +263,7 @@ private struct ChannelAdminControllerState: Equatable { return true } - func withUpdatedUpdatedFlags(_ updatedFlags: TelegramChannelAdminRightsFlags?) -> ChannelAdminControllerState { + func withUpdatedUpdatedFlags(_ updatedFlags: TelegramChatAdminRightsFlags?) -> ChannelAdminControllerState { return ChannelAdminControllerState(updatedFlags: updatedFlags, updating: self.updating) } @@ -272,7 +272,7 @@ private struct ChannelAdminControllerState: Equatable { } } -private func stringForRight(strings: PresentationStrings, right: TelegramChannelAdminRightsFlags, isGroup: Bool) -> String { +private func stringForRight(strings: PresentationStrings, right: TelegramChatAdminRightsFlags, isGroup: Bool) -> String { if right.contains(.canChangeInfo) { return isGroup ? strings.Group_EditAdmin_PermissionChangeInfo : strings.Channel_EditAdmin_PermissionChangeInfo } else if right.contains(.canPostMessages) { @@ -296,7 +296,7 @@ private func stringForRight(strings: PresentationStrings, right: TelegramChannel } } -private func rightDependencies(_ right: TelegramChannelAdminRightsFlags) -> [TelegramChannelAdminRightsFlags] { +private func rightDependencies(_ right: TelegramChatAdminRightsFlags) -> [TelegramChatAdminRightsFlags] { if right.contains(.canChangeInfo) { return [] } else if right.contains(.canPostMessages) { @@ -332,11 +332,11 @@ private func canEditAdminRights(accountPeerId: PeerId, channelView: PeerView, in if let adminInfo = adminInfo { return adminInfo.canBeEditedByAccountPeer || adminInfo.promotedBy == accountPeerId } else { - return channel.hasAdminRights(.canAddAdmins) + return channel.hasPermission(.addAdmins) } } } else { - return channel.hasAdminRights(.canAddAdmins) + return channel.hasPermission(.addAdmins) } } else { return false @@ -352,8 +352,8 @@ private func channelAdminControllerEntries(presentationData: PresentationData, s entries.append(.rightsTitle(presentationData.theme, presentationData.strings.Channel_EditAdmin_PermissionsHeader)) let isGroup: Bool - let maskRightsFlags: TelegramChannelAdminRightsFlags - let rightsOrder: [TelegramChannelAdminRightsFlags] + let maskRightsFlags: TelegramChatAdminRightsFlags + let rightsOrder: [TelegramChatAdminRightsFlags] switch channel.info { case .broadcast: @@ -381,7 +381,7 @@ private func channelAdminControllerEntries(presentationData: PresentationData, s } if canEditAdminRights(accountPeerId: accountPeerId, channelView: channelView, initialParticipant: initialParticipant) { - let accountUserRightsFlags: TelegramChannelAdminRightsFlags + let accountUserRightsFlags: TelegramChatAdminRightsFlags if channel.flags.contains(.isCreator) { accountUserRightsFlags = maskRightsFlags } else if let adminRights = channel.adminRights { @@ -390,7 +390,7 @@ private func channelAdminControllerEntries(presentationData: PresentationData, s accountUserRightsFlags = [] } - let currentRightsFlags: TelegramChannelAdminRightsFlags + let currentRightsFlags: TelegramChatAdminRightsFlags if let updatedFlags = state.updatedFlags { currentRightsFlags = updatedFlags } else if let initialParticipant = initialParticipant, case let .member(_, _, maybeAdminRights, _) = initialParticipant, let adminRights = maybeAdminRights { @@ -443,7 +443,7 @@ private func channelAdminControllerEntries(presentationData: PresentationData, s return entries } -public func channelAdminController(account: Account, peerId: PeerId, adminId: PeerId, initialParticipant: ChannelParticipant?, updated: @escaping (TelegramChannelAdminRights) -> Void) -> ViewController { +public func channelAdminController(account: Account, peerId: PeerId, adminId: PeerId, initialParticipant: ChannelParticipant?, updated: @escaping (TelegramChatAdminRights) -> Void) -> ViewController { let statePromise = ValuePromise(ChannelAdminControllerState(), ignoreRepeated: true) let stateValue = Atomic(value: ChannelAdminControllerState()) let updateState: ((ChannelAdminControllerState) -> ChannelAdminControllerState) -> Void = { f in @@ -471,10 +471,10 @@ public func channelAdminController(account: Account, peerId: PeerId, adminId: Pe updateState { current in return current.withUpdatedUpdating(true) } - updateRightsDisposable.set((account.telegramApplicationContext.peerChannelMemberCategoriesContextsManager.updateMemberAdminRights(account: account, peerId: peerId, memberId: adminId, adminRights: TelegramChannelAdminRights(flags: [])) |> deliverOnMainQueue).start(error: { _ in + updateRightsDisposable.set((account.telegramApplicationContext.peerChannelMemberCategoriesContextsManager.updateMemberAdminRights(account: account, peerId: peerId, memberId: adminId, adminRights: TelegramChatAdminRights(flags: [])) |> deliverOnMainQueue).start(error: { _ in }, completed: { - updated(TelegramChannelAdminRights(flags: [])) + updated(TelegramChatAdminRights(flags: [])) dismissImpl?() })) }) @@ -505,7 +505,7 @@ public func channelAdminController(account: Account, peerId: PeerId, adminId: Pe } else if canEdit { rightNavigationButton = ItemListNavigationButton(content: .text(presentationData.strings.Common_Done), style: .bold, enabled: true, action: { if let initialParticipant = initialParticipant, let channel = channelView.peers[channelView.peerId] as? TelegramChannel { - var updateFlags: TelegramChannelAdminRightsFlags? + var updateFlags: TelegramChatAdminRightsFlags? updateState { current in updateFlags = current.updatedFlags if let _ = updateFlags { @@ -521,7 +521,7 @@ public func channelAdminController(account: Account, peerId: PeerId, adminId: Pe break case let .member(member): if member.adminInfo?.rights == nil { - let maskRightsFlags: TelegramChannelAdminRightsFlags + let maskRightsFlags: TelegramChatAdminRightsFlags switch channel.info { case .broadcast: maskRightsFlags = .broadcastSpecific @@ -544,24 +544,24 @@ public func channelAdminController(account: Account, peerId: PeerId, adminId: Pe updateState { current in return current.withUpdatedUpdating(true) } - updateRightsDisposable.set((account.telegramApplicationContext.peerChannelMemberCategoriesContextsManager.updateMemberAdminRights(account: account, peerId: peerId, memberId: adminId, adminRights: TelegramChannelAdminRights(flags: updateFlags)) |> deliverOnMainQueue).start(error: { _ in + updateRightsDisposable.set((account.telegramApplicationContext.peerChannelMemberCategoriesContextsManager.updateMemberAdminRights(account: account, peerId: peerId, memberId: adminId, adminRights: TelegramChatAdminRights(flags: updateFlags)) |> deliverOnMainQueue).start(error: { _ in }, completed: { - updated(TelegramChannelAdminRights(flags: updateFlags)) + updated(TelegramChatAdminRights(flags: updateFlags)) dismissImpl?() })) } else { dismissImpl?() } } else if canEdit, let channel = channelView.peers[channelView.peerId] as? TelegramChannel { - var updateFlags: TelegramChannelAdminRightsFlags? + var updateFlags: TelegramChatAdminRightsFlags? updateState { current in updateFlags = current.updatedFlags return current.withUpdatedUpdating(true) } if updateFlags == nil { - let maskRightsFlags: TelegramChannelAdminRightsFlags + let maskRightsFlags: TelegramChatAdminRightsFlags switch channel.info { case .broadcast: maskRightsFlags = .broadcastSpecific @@ -582,10 +582,10 @@ public func channelAdminController(account: Account, peerId: PeerId, adminId: Pe updateState { current in return current.withUpdatedUpdating(true) } - updateRightsDisposable.set((account.telegramApplicationContext.peerChannelMemberCategoriesContextsManager.updateMemberAdminRights(account: account, peerId: peerId, memberId: adminId, adminRights: TelegramChannelAdminRights(flags: updateFlags)) |> deliverOnMainQueue).start(error: { _ in + updateRightsDisposable.set((account.telegramApplicationContext.peerChannelMemberCategoriesContextsManager.updateMemberAdminRights(account: account, peerId: peerId, memberId: adminId, adminRights: TelegramChatAdminRights(flags: updateFlags)) |> deliverOnMainQueue).start(error: { _ in }, completed: { - updated(TelegramChannelAdminRights(flags: updateFlags)) + updated(TelegramChatAdminRights(flags: updateFlags)) dismissImpl?() })) } diff --git a/TelegramUI/ChannelAdminsController.swift b/TelegramUI/ChannelAdminsController.swift index 1caa2bc5ad..627caa44e7 100644 --- a/TelegramUI/ChannelAdminsController.swift +++ b/TelegramUI/ChannelAdminsController.swift @@ -8,16 +8,14 @@ private final class ChannelAdminsControllerArguments { let account: Account let openRecentActions: () -> Void - let updateCurrentAdministrationType: () -> Void let setPeerIdWithRevealedOptions: (PeerId?, PeerId?) -> Void let removeAdmin: (PeerId) -> Void let addAdmin: () -> Void let openAdmin: (ChannelParticipant) -> Void - init(account: Account, openRecentActions: @escaping () -> Void, updateCurrentAdministrationType: @escaping () -> Void, setPeerIdWithRevealedOptions: @escaping (PeerId?, PeerId?) -> Void, removeAdmin: @escaping (PeerId) -> Void, addAdmin: @escaping () -> Void, openAdmin: @escaping (ChannelParticipant) -> Void) { + init(account: Account, openRecentActions: @escaping () -> Void, setPeerIdWithRevealedOptions: @escaping (PeerId?, PeerId?) -> Void, removeAdmin: @escaping (PeerId) -> Void, addAdmin: @escaping () -> Void, openAdmin: @escaping (ChannelParticipant) -> Void) { self.account = account self.openRecentActions = openRecentActions - self.updateCurrentAdministrationType = updateCurrentAdministrationType self.setPeerIdWithRevealedOptions = setPeerIdWithRevealedOptions self.removeAdmin = removeAdmin self.addAdmin = addAdmin @@ -63,8 +61,6 @@ private enum ChannelAdminsEntryStableId: Hashable { private enum ChannelAdminsEntry: ItemListNodeEntry { case recentActions(PresentationTheme, String) - case administrationType(PresentationTheme, String, String) - case administrationInfo(PresentationTheme, String) case adminsHeader(PresentationTheme, String) case adminPeerItem(PresentationTheme, PresentationStrings, PresentationDateTimeFormat, PresentationPersonNameOrder, Bool, Int32, RenderedChannelParticipant, ItemListPeerItemEditing, Bool) @@ -73,7 +69,7 @@ private enum ChannelAdminsEntry: ItemListNodeEntry { var section: ItemListSectionId { switch self { - case .recentActions, .administrationType, .administrationInfo: + case .recentActions: return ChannelAdminsSection.administration.rawValue case .adminsHeader, .adminPeerItem, .addAdmin, .adminsInfo: return ChannelAdminsSection.admins.rawValue @@ -84,10 +80,6 @@ private enum ChannelAdminsEntry: ItemListNodeEntry { switch self { case .recentActions: return .index(0) - case .administrationType: - return .index(1) - case .administrationInfo: - return .index(2) case .adminsHeader: return .index(3) case .addAdmin: @@ -107,18 +99,6 @@ private enum ChannelAdminsEntry: ItemListNodeEntry { } else { return false } - case let .administrationType(lhsTheme, lhsText, lhsValue): - if case let .administrationType(rhsTheme, rhsText, rhsValue) = rhs, lhsTheme === rhsTheme, lhsText == rhsText, lhsValue == rhsValue { - return true - } else { - return false - } - case let .administrationInfo(lhsTheme, lhsText): - if case let .administrationInfo(rhsTheme, rhsText) = rhs, lhsTheme === rhsTheme, lhsText == rhsText { - return true - } else { - return false - } case let .adminsHeader(lhsTheme, lhsText): if case let .adminsHeader(rhsTheme, rhsText) = rhs, lhsTheme === rhsTheme, lhsText == rhsText { return true @@ -177,30 +157,16 @@ private enum ChannelAdminsEntry: ItemListNodeEntry { switch lhs { case .recentActions: return true - case .administrationType: + case .adminsHeader: switch rhs { case .recentActions: return false default: return true } - case .administrationInfo: - switch rhs { - case .recentActions, .administrationType: - return false - default: - return true - } - case .adminsHeader: - switch rhs { - case .recentActions, .administrationType, .administrationInfo: - return false - default: - return true - } case let .adminPeerItem(_, _, _, _, _, index, _, _, _): switch rhs { - case .recentActions, .administrationType, .administrationInfo, .adminsHeader, .addAdmin: + case .recentActions, .adminsHeader, .addAdmin: return false case let .adminPeerItem(_, _, _, _, _, rhsIndex, _, _, _): return index < rhsIndex @@ -209,7 +175,7 @@ private enum ChannelAdminsEntry: ItemListNodeEntry { } case .addAdmin: switch rhs { - case .recentActions, .administrationType, .administrationInfo, .adminsHeader, .addAdmin: + case .recentActions, .adminsHeader, .addAdmin: return false default: return true @@ -225,12 +191,6 @@ private enum ChannelAdminsEntry: ItemListNodeEntry { return ItemListDisclosureItem(theme: theme, title: text, label: "", sectionId: self.section, style: .blocks, action: { arguments.openRecentActions() }) - case let .administrationType(theme, text, value): - return ItemListDisclosureItem(theme: theme, title: text, label: value, sectionId: self.section, style: .blocks, action: { - arguments.updateCurrentAdministrationType() - }) - case let .administrationInfo(theme, text): - return ItemListTextItem(theme: theme, text: .plain(text), sectionId: self.section) case let .adminsHeader(theme, title): return ItemListSectionHeaderItem(theme: theme, text: title, sectionId: self.section) case let .adminPeerItem(theme, strings, dateTimeFormat, nameDisplayOrder, _, _, participant, editing, enabled): @@ -269,13 +229,7 @@ private enum ChannelAdminsEntry: ItemListNodeEntry { } } -private enum CurrentAdministrationType { - case everyoneCanAddMembers - case adminsCanAddMembers -} - private struct ChannelAdminsControllerState: Equatable { - let selectedType: CurrentAdministrationType? let editing: Bool let peerIdWithRevealedOptions: PeerId? let removingPeerId: PeerId? @@ -284,7 +238,6 @@ private struct ChannelAdminsControllerState: Equatable { let searchingMembers: Bool init() { - self.selectedType = nil self.editing = false self.peerIdWithRevealedOptions = nil self.removingPeerId = nil @@ -293,8 +246,7 @@ private struct ChannelAdminsControllerState: Equatable { self.searchingMembers = false } - init(selectedType: CurrentAdministrationType?, editing: Bool, peerIdWithRevealedOptions: PeerId?, removingPeerId: PeerId?, removedPeerIds: Set, temporaryAdmins: [RenderedChannelParticipant], searchingMembers: Bool) { - self.selectedType = selectedType + init(editing: Bool, peerIdWithRevealedOptions: PeerId?, removingPeerId: PeerId?, removedPeerIds: Set, temporaryAdmins: [RenderedChannelParticipant], searchingMembers: Bool) { self.editing = editing self.peerIdWithRevealedOptions = peerIdWithRevealedOptions self.removingPeerId = removingPeerId @@ -304,9 +256,6 @@ private struct ChannelAdminsControllerState: Equatable { } static func ==(lhs: ChannelAdminsControllerState, rhs: ChannelAdminsControllerState) -> Bool { - if lhs.selectedType != rhs.selectedType { - return false - } if lhs.editing != rhs.editing { return false } @@ -330,31 +279,27 @@ private struct ChannelAdminsControllerState: Equatable { } func withUpdatedSearchingMembers(_ searchingMembers: Bool) -> ChannelAdminsControllerState { - return ChannelAdminsControllerState(selectedType: self.selectedType, editing: self.editing, peerIdWithRevealedOptions: self.peerIdWithRevealedOptions, removingPeerId: self.removingPeerId, removedPeerIds: self.removedPeerIds, temporaryAdmins: self.temporaryAdmins, searchingMembers: searchingMembers) - } - - func withUpdatedSelectedType(_ selectedType: CurrentAdministrationType?) -> ChannelAdminsControllerState { - return ChannelAdminsControllerState(selectedType: selectedType, editing: self.editing, peerIdWithRevealedOptions: self.peerIdWithRevealedOptions, removingPeerId: self.removingPeerId, removedPeerIds: self.removedPeerIds, temporaryAdmins: self.temporaryAdmins, searchingMembers: self.searchingMembers) + return ChannelAdminsControllerState(editing: self.editing, peerIdWithRevealedOptions: self.peerIdWithRevealedOptions, removingPeerId: self.removingPeerId, removedPeerIds: self.removedPeerIds, temporaryAdmins: self.temporaryAdmins, searchingMembers: searchingMembers) } func withUpdatedEditing(_ editing: Bool) -> ChannelAdminsControllerState { - return ChannelAdminsControllerState(selectedType: self.selectedType, editing: editing, peerIdWithRevealedOptions: self.peerIdWithRevealedOptions, removingPeerId: self.removingPeerId, removedPeerIds: self.removedPeerIds, temporaryAdmins: self.temporaryAdmins, searchingMembers: self.searchingMembers) + return ChannelAdminsControllerState(editing: editing, peerIdWithRevealedOptions: self.peerIdWithRevealedOptions, removingPeerId: self.removingPeerId, removedPeerIds: self.removedPeerIds, temporaryAdmins: self.temporaryAdmins, searchingMembers: self.searchingMembers) } func withUpdatedPeerIdWithRevealedOptions(_ peerIdWithRevealedOptions: PeerId?) -> ChannelAdminsControllerState { - return ChannelAdminsControllerState(selectedType: self.selectedType, editing: self.editing, peerIdWithRevealedOptions: peerIdWithRevealedOptions, removingPeerId: self.removingPeerId, removedPeerIds: self.removedPeerIds, temporaryAdmins: self.temporaryAdmins, searchingMembers: self.searchingMembers) + return ChannelAdminsControllerState(editing: self.editing, peerIdWithRevealedOptions: peerIdWithRevealedOptions, removingPeerId: self.removingPeerId, removedPeerIds: self.removedPeerIds, temporaryAdmins: self.temporaryAdmins, searchingMembers: self.searchingMembers) } func withUpdatedRemovingPeerId(_ removingPeerId: PeerId?) -> ChannelAdminsControllerState { - return ChannelAdminsControllerState(selectedType: self.selectedType, editing: self.editing, peerIdWithRevealedOptions: self.peerIdWithRevealedOptions, removingPeerId: removingPeerId, removedPeerIds: self.removedPeerIds, temporaryAdmins: self.temporaryAdmins, searchingMembers: self.searchingMembers) + return ChannelAdminsControllerState(editing: self.editing, peerIdWithRevealedOptions: self.peerIdWithRevealedOptions, removingPeerId: removingPeerId, removedPeerIds: self.removedPeerIds, temporaryAdmins: self.temporaryAdmins, searchingMembers: self.searchingMembers) } func withUpdatedRemovedPeerIds(_ removedPeerIds: Set) -> ChannelAdminsControllerState { - return ChannelAdminsControllerState(selectedType: self.selectedType, editing: self.editing, peerIdWithRevealedOptions: self.peerIdWithRevealedOptions, removingPeerId: self.removingPeerId, removedPeerIds: removedPeerIds, temporaryAdmins: self.temporaryAdmins, searchingMembers: self.searchingMembers) + return ChannelAdminsControllerState(editing: self.editing, peerIdWithRevealedOptions: self.peerIdWithRevealedOptions, removingPeerId: self.removingPeerId, removedPeerIds: removedPeerIds, temporaryAdmins: self.temporaryAdmins, searchingMembers: self.searchingMembers) } func withUpdatedTemporaryAdmins(_ temporaryAdmins: [RenderedChannelParticipant]) -> ChannelAdminsControllerState { - return ChannelAdminsControllerState(selectedType: self.selectedType, editing: self.editing, peerIdWithRevealedOptions: self.peerIdWithRevealedOptions, removingPeerId: self.removingPeerId, removedPeerIds: self.removedPeerIds, temporaryAdmins: temporaryAdmins, searchingMembers: self.searchingMembers) + return ChannelAdminsControllerState(editing: self.editing, peerIdWithRevealedOptions: self.peerIdWithRevealedOptions, removingPeerId: self.removingPeerId, removedPeerIds: self.removedPeerIds, temporaryAdmins: temporaryAdmins, searchingMembers: self.searchingMembers) } } @@ -371,33 +316,6 @@ private func channelAdminsControllerEntries(presentationData: PresentationData, isGroup = true entries.append(.recentActions(presentationData.theme, presentationData.strings.Group_Info_AdminLog)) - - if peer.flags.contains(.isCreator) { - let selectedType: CurrentAdministrationType - if let current = state.selectedType { - selectedType = current - } else { - if info.flags.contains(.everyMemberCanInviteMembers) { - selectedType = .everyoneCanAddMembers - } else { - selectedType = .adminsCanAddMembers - } - } - let selectedTypeValue: String - let infoText: String - switch selectedType { - case .everyoneCanAddMembers: - selectedTypeValue = presentationData.strings.ChannelMembers_WhoCanAddMembers_AllMembers - infoText = presentationData.strings.ChannelMembers_WhoCanAddMembersAllHelp - case .adminsCanAddMembers: - selectedTypeValue = presentationData.strings.ChannelMembers_WhoCanAddMembers_Admins - infoText = presentationData.strings.ChannelMembers_WhoCanAddMembersAdminsHelp - } - - entries.append(.administrationType(presentationData.theme, presentationData.strings.ChannelMembers_WhoCanAddMembers, selectedTypeValue)) - - entries.append(.administrationInfo(presentationData.theme, infoText)) - } } else { entries.append(.recentActions(presentationData.theme, presentationData.strings.Group_Info_AdminLog)) } @@ -405,7 +323,7 @@ private func channelAdminsControllerEntries(presentationData: PresentationData, if let participants = participants { entries.append(.adminsHeader(presentationData.theme, isGroup ? presentationData.strings.ChannelMembers_GroupAdminsTitle : presentationData.strings.ChannelMembers_ChannelAdminsTitle)) - if peer.hasAdminRights(.canAddAdmins) { + if peer.hasPermission(.addAdmins) { entries.append(.addAdmin(presentationData.theme, presentationData.strings.Channel_Management_AddModerator, state.editing)) } @@ -462,7 +380,7 @@ private func channelAdminsControllerEntries(presentationData: PresentationData, } } - if peer.hasAdminRights(.canAddAdmins) { + if peer.hasPermission(.addAdmins) { let info = isGroup ? presentationData.strings.Group_Management_AddModeratorHelp : presentationData.strings.Channel_Management_AddModeratorHelp entries.append(.adminsInfo(presentationData.theme, info)) } @@ -483,9 +401,6 @@ public func channelAdminsController(account: Account, peerId: PeerId) -> ViewCon var presentControllerImpl: ((ViewController, Any?) -> Void)? let actionsDisposable = DisposableSet() - - let updateAdministrationDisposable = MetaDisposable() - actionsDisposable.add(updateAdministrationDisposable) let removeAdminDisposable = MetaDisposable() actionsDisposable.add(removeAdminDisposable) @@ -502,56 +417,6 @@ public func channelAdminsController(account: Account, peerId: PeerId) -> ViewCon |> deliverOnMainQueue).start(next: { peer in pushControllerImpl?(ChatRecentActionsController(account: account, peer: peer)) }) - }, updateCurrentAdministrationType: { - let _ = (presentationDataSignal |> take(1) |> deliverOnMainQueue).start(next: { presentationData in - let actionSheet = ActionSheetController(presentationTheme: presentationData.theme) - let result = ValuePromise() - actionSheet.setItemGroups([ActionSheetItemGroup(items: [ - ActionSheetButtonItem(title: presentationData.strings.ChannelMembers_WhoCanAddMembers_AllMembers, color: .accent, action: { [weak actionSheet] in - actionSheet?.dismissAnimated() - result.set(true) - }), - ActionSheetButtonItem(title: presentationData.strings.ChannelMembers_WhoCanAddMembers_Admins, color: .accent, action: { [weak actionSheet] in - actionSheet?.dismissAnimated() - result.set(false) - }) - ]), ActionSheetItemGroup(items: [ - ActionSheetButtonItem(title: presentationData.strings.Common_Cancel, color: .accent, action: { [weak actionSheet] in - actionSheet?.dismissAnimated() - }) - ])]) - let updateSignal = result.get() - |> take(1) - |> mapToSignal { value -> Signal in - updateState { state in - return state.withUpdatedSelectedType(value ? .everyoneCanAddMembers : .adminsCanAddMembers) - } - - return account.postbox.loadedPeerWithId(peerId) - |> mapToSignal { peer -> Signal in - if let peer = peer as? TelegramChannel, case let .group(info) = peer.info { - var updatedValue: Bool? - if value && !info.flags.contains(.everyMemberCanInviteMembers) { - updatedValue = true - } else if !value && info.flags.contains(.everyMemberCanInviteMembers) { - updatedValue = false - } - if let updatedValue = updatedValue { - return updateGroupManagementType(account: account, peerId: peerId, type: updatedValue ? .unrestricted : .restrictedToAdmins) - |> `catch` { _ -> Signal in - return .complete() - } - } else { - return .complete() - } - } else { - return .complete() - } - } - } - updateAdministrationDisposable.set(updateSignal.start()) - presentControllerImpl?(actionSheet, nil) - }) }, setPeerIdWithRevealedOptions: { peerId, fromPeerId in updateState { state in if (peerId == nil && fromPeerId == state.peerIdWithRevealedOptions) || (peerId != nil && fromPeerId == nil) { @@ -564,7 +429,7 @@ public func channelAdminsController(account: Account, peerId: PeerId) -> ViewCon updateState { return $0.withUpdatedRemovingPeerId(adminId) } - removeAdminDisposable.set((account.telegramApplicationContext.peerChannelMemberCategoriesContextsManager.updateMemberAdminRights(account: account, peerId: peerId, memberId: adminId, adminRights: TelegramChannelAdminRights(flags: [])) + removeAdminDisposable.set((account.telegramApplicationContext.peerChannelMemberCategoriesContextsManager.updateMemberAdminRights(account: account, peerId: peerId, memberId: adminId, adminRights: TelegramChatAdminRights(flags: [])) |> deliverOnMainQueue).start(completed: { updateState { return $0.withUpdatedRemovingPeerId(nil) @@ -572,8 +437,9 @@ public func channelAdminsController(account: Account, peerId: PeerId) -> ViewCon })) }, addAdmin: { updateState { current in - - presentControllerImpl?(ChannelMembersSearchController(account: account, peerId: peerId, mode: .promote, filters: [], openPeer: { peer, participant 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 { return @@ -591,7 +457,11 @@ public func channelAdminsController(account: Account, peerId: PeerId) -> ViewCon } presentControllerImpl?(channelAdminController(account: account, peerId: peerId, adminId: peer.id, initialParticipant: participant?.participant, updated: { _ in }), ViewControllerPresentationArguments(presentationAnimation: .modalSheet)) - }), ViewControllerPresentationArguments(presentationAnimation: .modalSheet)) + }) + dismissController = { [weak controller] in + controller?.dismiss() + } + presentControllerImpl?(controller, ViewControllerPresentationArguments(presentationAnimation: .modalSheet)) return current } diff --git a/TelegramUI/ChannelBannedMemberController.swift b/TelegramUI/ChannelBannedMemberController.swift index 8c3d0baf02..ecc024bfbd 100644 --- a/TelegramUI/ChannelBannedMemberController.swift +++ b/TelegramUI/ChannelBannedMemberController.swift @@ -6,13 +6,15 @@ import TelegramCore private final class ChannelBannedMemberControllerArguments { let account: Account - let toggleRight: (TelegramChannelBannedRightsFlags, TelegramChannelBannedRightsFlags) -> Void + let toggleRight: (TelegramChatBannedRightsFlags, Bool) -> Void let openTimeout: () -> Void + let delete: () -> Void - init(account: Account, toggleRight: @escaping (TelegramChannelBannedRightsFlags, TelegramChannelBannedRightsFlags) -> Void, openTimeout: @escaping () -> Void) { + init(account: Account, toggleRight: @escaping (TelegramChatBannedRightsFlags, Bool) -> Void, openTimeout: @escaping () -> Void, delete: @escaping () -> Void) { self.account = account self.toggleRight = toggleRight self.openTimeout = openTimeout + self.delete = delete } } @@ -20,61 +22,53 @@ private enum ChannelBannedMemberSection: Int32 { case info case rights case timeout + case delete } private enum ChannelBannedMemberEntryStableId: Hashable { case info - case right(TelegramChannelBannedRightsFlags) + case rightsHeader + case right(TelegramChatBannedRightsFlags) case timeout + case exceptionInfo + case delete var hashValue: Int { switch self { case .info: return 0 - case .timeout: + case .rightsHeader: return 1 + case .timeout: + return 2 + case .exceptionInfo: + return 3 + case .delete: + return 4 case let .right(flags): return flags.rawValue.hashValue } } - - static func ==(lhs: ChannelBannedMemberEntryStableId, rhs: ChannelBannedMemberEntryStableId) -> Bool { - switch lhs { - case .info: - if case .info = rhs { - return true - } else { - return false - } - case let right(flags): - if case .right(flags) = rhs { - return true - } else { - return false - } - case .timeout: - if case .timeout = rhs { - return true - } else { - return false - } - } - } } private enum ChannelBannedMemberEntry: ItemListNodeEntry { case info(PresentationTheme, PresentationStrings, PresentationDateTimeFormat, Peer, TelegramUserPresence?) - case rightItem(PresentationTheme, Int, String, TelegramChannelBannedRightsFlags, TelegramChannelBannedRightsFlags, Bool, Bool) + case rightsHeader(PresentationTheme, String) + case rightItem(PresentationTheme, Int, String, TelegramChatBannedRightsFlags, Bool, Bool) case timeout(PresentationTheme, String, String) + case exceptionInfo(PresentationTheme, String) + case delete(PresentationTheme, String) var section: ItemListSectionId { switch self { case .info: return ChannelBannedMemberSection.info.rawValue - case .rightItem: + case .rightsHeader, .rightItem: return ChannelBannedMemberSection.rights.rawValue - case .timeout: + case .timeout, .exceptionInfo: return ChannelBannedMemberSection.timeout.rawValue + case .delete: + return ChannelBannedMemberSection.delete.rawValue } } @@ -82,70 +76,91 @@ private enum ChannelBannedMemberEntry: ItemListNodeEntry { switch self { case .info: return .info - case let .rightItem(_, _, _, right, _, _, _): + case .rightsHeader: + return .rightsHeader + case let .rightItem(_, _, _, right, _, _): return .right(right) case .timeout: return .timeout + case .exceptionInfo: + return .exceptionInfo + case .delete: + return .delete } } static func ==(lhs: ChannelBannedMemberEntry, rhs: ChannelBannedMemberEntry) -> Bool { switch lhs { - case let .info(lhsTheme, lhsStrings, lhsDateTimeFormat, lhsPeer, lhsPresence): - if case let .info(rhsTheme, rhsStrings, rhsDateTimeFormat, rhsPeer, rhsPresence) = rhs { - if lhsTheme !== rhsTheme { + case let .info(lhsTheme, lhsStrings, lhsDateTimeFormat, lhsPeer, lhsPresence): + if case let .info(rhsTheme, rhsStrings, rhsDateTimeFormat, rhsPeer, rhsPresence) = rhs { + if lhsTheme !== rhsTheme { + return false + } + if lhsStrings !== rhsStrings { + return false + } + if lhsDateTimeFormat != rhsDateTimeFormat { + return false + } + if !arePeersEqual(lhsPeer, rhsPeer) { + return false + } + if lhsPresence != rhsPresence { + return false + } + + return true + } else { return false } - if lhsStrings !== rhsStrings { + case let .rightsHeader(theme, title): + if case .rightsHeader(theme, title) = rhs { + return true + } else { return false } - if lhsDateTimeFormat != rhsDateTimeFormat { + case let .rightItem(lhsTheme, lhsIndex, lhsText, lhsRight, lhsValue, lhsEnabled): + if case let .rightItem(rhsTheme, rhsIndex, rhsText, rhsRight, rhsValue, rhsEnabled) = rhs { + if lhsTheme !== rhsTheme { + return false + } + if lhsIndex != rhsIndex { + return false + } + if lhsText != rhsText { + return false + } + if lhsRight != rhsRight { + return false + } + if lhsValue != rhsValue { + return false + } + if lhsEnabled != rhsEnabled { + return false + } + return true + } else { return false } - if !arePeersEqual(lhsPeer, rhsPeer) { + case let .timeout(lhsTheme, lhsText, lhsValue): + if case let .timeout(rhsTheme, rhsText, rhsValue) = rhs, lhsTheme === rhsTheme, lhsText == rhsText, lhsValue == rhsValue { + return true + } else { return false } - if lhsPresence != rhsPresence { + case let .exceptionInfo(theme, title): + if case .exceptionInfo(theme, title) = rhs { + return true + } else { return false } - - return true - } else { - return false - } - case let .rightItem(lhsTheme, lhsIndex, lhsText, lhsRight, lhsFlags, lhsValue, lhsEnabled): - if case let .rightItem(rhsTheme, rhsIndex, rhsText, rhsRight, rhsFlags, rhsValue, rhsEnabled) = rhs { - if lhsTheme !== rhsTheme { + case let .delete(theme, title): + if case .delete(theme, title) = rhs { + return true + } else { return false } - if lhsIndex != rhsIndex { - return false - } - if lhsText != rhsText { - return false - } - if lhsRight != rhsRight { - return false - } - if lhsFlags != rhsFlags { - return false - } - if lhsValue != rhsValue { - return false - } - if lhsEnabled != rhsEnabled { - return false - } - return true - } else { - return false - } - case let .timeout(lhsTheme, lhsText, lhsValue): - if case let .timeout(rhsTheme, rhsText, rhsValue) = rhs, lhsTheme === rhsTheme, lhsText == rhsText, lhsValue == rhsValue { - return true - } else { - return false - } } } @@ -158,16 +173,37 @@ private enum ChannelBannedMemberEntry: ItemListNodeEntry { default: return true } - case let .rightItem(_, lhsIndex, _, _, _, _, _): + case .rightsHeader: switch rhs { - case .info: + case .info, .rightsHeader: return false - case let .rightItem(_, rhsIndex, _, _, _, _, _): + default: + return true + } + case let .rightItem(_, lhsIndex, _, _, _, _): + switch rhs { + case .info, .rightsHeader: + return false + case let .rightItem(_, rhsIndex, _, _, _, _): return lhsIndex < rhsIndex default: return true } case .timeout: + switch rhs { + case .delete, .exceptionInfo: + return true + default: + return false + } + case .exceptionInfo: + switch rhs { + case .delete: + return true + default: + return false + } + case .delete: return false } } @@ -178,143 +214,66 @@ private enum ChannelBannedMemberEntry: ItemListNodeEntry { return ItemListAvatarAndNameInfoItem(account: arguments.account, theme: theme, strings: strings, dateTimeFormat: dateTimeFormat, mode: .generic, peer: peer, presence: presence, cachedData: nil, state: ItemListAvatarAndNameInfoItemState(), sectionId: self.section, style: .blocks(withTopInset: true), editingNameUpdated: { _ in }, avatarTapped: { }) - case let .rightItem(theme, _, text, right, flags, value, enabled): - return ItemListSwitchItem(theme: theme, title: text, value: value, type: .icon, enabled: enabled, sectionId: self.section, style: .blocks, updated: { _ in - arguments.toggleRight(right, flags) + case let .rightsHeader(theme, text): + return ItemListSectionHeaderItem(theme: theme, text: text, sectionId: self.section) + case let .rightItem(theme, _, text, right, value, enabled): + return ItemListSwitchItem(theme: theme, title: text, value: value, type: .icon, enabled: enabled, sectionId: self.section, style: .blocks, updated: { value in + arguments.toggleRight(right, value) }) case let .timeout(theme, text, value): return ItemListDisclosureItem(theme: theme, title: text, label: value, sectionId: self.section, style: .blocks, action: { arguments.openTimeout() }) + case let .exceptionInfo(theme, text): + return ItemListTextItem(theme: theme, text: .plain(text), sectionId: self.section) + case let .delete(theme, text): + return ItemListActionItem(theme: theme, title: text, kind: .destructive, alignment: .center, sectionId: self.section, style: .blocks, action: { + arguments.delete() + }) } } } private struct ChannelBannedMemberControllerState: Equatable { - let referenceTimestamp: Int32 - let updatedFlags: TelegramChannelBannedRightsFlags? - let updatedTimeout: Int32? - let updating: Bool - - init(referenceTimestamp: Int32, updatedFlags: TelegramChannelBannedRightsFlags? = nil, updatedTimeout: Int32? = nil, updating: Bool = false) { - self.referenceTimestamp = referenceTimestamp - self.updatedFlags = updatedFlags - self.updatedTimeout = updatedTimeout - self.updating = updating - } - - static func ==(lhs: ChannelBannedMemberControllerState, rhs: ChannelBannedMemberControllerState) -> Bool { - if lhs.referenceTimestamp != rhs.referenceTimestamp { - return false - } - if lhs.updatedFlags != rhs.updatedFlags { - return false - } - if lhs.updatedTimeout != rhs.updatedTimeout { - return false - } - if lhs.updating != rhs.updating { - return false - } - return true - } - - func withUpdatedUpdatedFlags(_ updatedFlags: TelegramChannelBannedRightsFlags?) -> ChannelBannedMemberControllerState { - return ChannelBannedMemberControllerState(referenceTimestamp: self.referenceTimestamp, updatedFlags: updatedFlags, updatedTimeout: self.updatedTimeout, updating: self.updating) - } - - func withUpdatedUpdatedTimeout(_ updatedTimeout: Int32?) -> ChannelBannedMemberControllerState { - return ChannelBannedMemberControllerState(referenceTimestamp: self.referenceTimestamp, updatedFlags: self.updatedFlags, updatedTimeout: updatedTimeout, updating: self.updating) - } - - func withUpdatedUpdating(_ updating: Bool) -> ChannelBannedMemberControllerState { - return ChannelBannedMemberControllerState(referenceTimestamp: self.referenceTimestamp, updatedFlags: self.updatedFlags, updatedTimeout: self.updatedTimeout, updating: updating) - } + var referenceTimestamp: Int32 + var updatedFlags: TelegramChatBannedRightsFlags? + var updatedTimeout: Int32? + var updating: Bool = false } -private func stringForRight(strings: PresentationStrings, right: TelegramChannelBannedRightsFlags) -> String { - if right.contains(.banReadMessages) { - return strings.Channel_BanUser_PermissionReadMessages - } else if right.contains(.banSendMessages) { - return strings.Channel_BanUser_PermissionSendMessages - } else if right.contains(.banSendMedia) { - return strings.Channel_BanUser_PermissionSendMedia - } else if right.contains(.banSendGifs) { - return strings.Channel_BanUser_PermissionSendStickersAndGifs - } else if right.contains(.banEmbedLinks) { - return strings.Channel_BanUser_PermissionEmbedLinks +private func completeRights(_ flags: TelegramChatBannedRightsFlags) -> TelegramChatBannedRightsFlags { + var result = flags + result.remove(.banReadMessages) + if result.contains(.banSendGifs) { + result.insert(.banSendStickers) + result.insert(.banSendGifs) + result.insert(.banSendGames) } else { - return "" + result.remove(.banSendStickers) + result.remove(.banSendGifs) + result.remove(.banSendGames) } -} - -private func rightDependencies(_ right: TelegramChannelBannedRightsFlags) -> TelegramChannelBannedRightsFlags { - if right.contains(.banReadMessages) { - return [] - } else if right.contains(.banSendMessages) { - return [.banReadMessages] - } else if right.contains(.banSendMedia) { - return [.banReadMessages, .banSendMessages] - } else if right.contains(.banSendGifs) { - return [.banReadMessages, .banSendMessages, .banSendGifs, .banSendGames, .banSendInline] - } else if right.contains(.banEmbedLinks) { - return [.banReadMessages, .banSendMessages] + if result.contains(.banEmbedLinks) { + result.insert(.banSendInline) } else { - return [] + result.remove(.banSendInline) } + return result } -/* - TelegramChannelBannedRightsFlags = [ - .banReadMessages, - .banSendMessages, - .banSendMedia, - .banSendStickers, .banSendGifs, .banSendGames, .banSendInline, - .banEmbedLinks - ] - */ - -private func rightReverseDependencies(_ right: TelegramChannelBannedRightsFlags) -> TelegramChannelBannedRightsFlags { - if right.contains(.banReadMessages) { - return [.banSendMessages, .banSendMedia, .banSendStickers, .banSendGifs, .banSendGames, .banSendInline, .banEmbedLinks] - } else if right.contains(.banSendMessages) { - return [.banSendMedia, .banSendStickers, .banSendGifs, .banSendGames, .banSendInline, .banEmbedLinks] - } else if right.contains(.banSendMedia) { - return [] - } else if right.contains(.banSendGifs) { - return [.banSendStickers, .banSendGames, .banSendInline] - } else if right.contains(.banEmbedLinks) { - return [] - } else { - return [] - } -} - -private let initialRightFlags: TelegramChannelBannedRightsFlags = [.banReadMessages, .banSendMessages, .banSendGifs, .banSendGames, .banSendInline, .banSendStickers, .banSendMedia, .banEmbedLinks] - -func maskedFlags(_ flags: TelegramChannelBannedRightsFlags) -> TelegramChannelBannedRightsFlags { - return flags.intersection([ - .banReadMessages, - .banSendMessages, - .banSendMedia, - .banSendStickers, .banSendGifs, .banSendGames, .banSendInline, - .banEmbedLinks - ]) -} - -private func channelBannedMemberControllerEntries(presentationData: PresentationData, state: ChannelBannedMemberControllerState, accountPeerId: PeerId, channelView: PeerView, memberView: PeerView, initialParticipant: ChannelParticipant?) -> [ChannelBannedMemberEntry] { +private func channelBannedMemberControllerEntries(presentationData: PresentationData, state: ChannelBannedMemberControllerState, accountPeerId: PeerId, channelView: PeerView, memberView: PeerView, initialParticipant: ChannelParticipant?, initialBannedBy: Peer?) -> [ChannelBannedMemberEntry] { var entries: [ChannelBannedMemberEntry] = [] - if let _ = channelView.peers[channelView.peerId] as? TelegramChannel, let member = memberView.peers[memberView.peerId] { + if let _ = channelView.peers[channelView.peerId] as? TelegramChannel, let cachedData = channelView.cachedData as? CachedChannelData, let defaultBannedRights = cachedData.defaultBannedRights, let member = memberView.peers[memberView.peerId] { entries.append(.info(presentationData.theme, presentationData.strings, presentationData.dateTimeFormat, member, memberView.peerPresences[member.id] as? TelegramUserPresence)) - let currentRightsFlags: TelegramChannelBannedRightsFlags + let currentRightsFlags: TelegramChatBannedRightsFlags if let updatedFlags = state.updatedFlags { currentRightsFlags = updatedFlags } else if let initialParticipant = initialParticipant, case let .member(_, _, _, maybeBanInfo) = initialParticipant, let banInfo = maybeBanInfo { currentRightsFlags = banInfo.rights.flags } else { - currentRightsFlags = initialRightFlags + currentRightsFlags = defaultBannedRights.flags } let currentTimeout: Int32 @@ -334,28 +293,28 @@ private func channelBannedMemberControllerEntries(presentationData: Presentation currentTimeoutString = timeIntervalString(strings: presentationData.strings, value: remainingTimeout) } - let rightsOrder: [TelegramChannelBannedRightsFlags] = [ - .banReadMessages, - .banSendMessages, - .banSendMedia, - .banSendGifs, - .banEmbedLinks - ] + entries.append(.rightsHeader(presentationData.theme, presentationData.strings.GroupPermission_SectionTitle)) var index = 0 - for right in rightsOrder { - entries.append(.rightItem(presentationData.theme, index, stringForRight(strings: presentationData.strings, right: right), right, currentRightsFlags, !currentRightsFlags.contains(right), !state.updating)) + for right in allGroupPermissionList { + let defaultEnabled = !defaultBannedRights.flags.contains(right) + entries.append(.rightItem(presentationData.theme, index, stringForGroupPermission(strings: presentationData.strings, right: right), right, defaultEnabled && !currentRightsFlags.contains(right), defaultEnabled && !state.updating)) index += 1 } - entries.append(.timeout(presentationData.theme, presentationData.strings.Channel_BanUser_BlockFor, currentTimeoutString)) + entries.append(.timeout(presentationData.theme, presentationData.strings.GroupPermission_Duration, currentTimeoutString)) + + if let initialParticipant = initialParticipant, case let .member(member) = initialParticipant, let banInfo = member.banInfo, let initialBannedBy = initialBannedBy { + entries.append(.exceptionInfo(presentationData.theme, presentationData.strings.GroupPermission_AddedInfo(initialBannedBy.displayTitle, stringForRelativeSymbolicTimestamp(strings: presentationData.strings, relativeTimestamp: banInfo.timestamp, relativeTo: state.referenceTimestamp, dateTimeFormat: presentationData.dateTimeFormat)).0)) + entries.append(.delete(presentationData.theme, presentationData.strings.GroupPermission_Delete)) + } } return entries } -public func channelBannedMemberController(account: Account, peerId: PeerId, memberId: PeerId, initialParticipant: ChannelParticipant?, updated: @escaping (TelegramChannelBannedRights) -> Void) -> ViewController { - let initialState = ChannelBannedMemberControllerState(referenceTimestamp: Int32(Date().timeIntervalSince1970)) +public func channelBannedMemberController(account: Account, peerId: PeerId, memberId: PeerId, initialParticipant: ChannelParticipant?, updated: @escaping (TelegramChatBannedRights?) -> Void) -> ViewController { + let initialState = ChannelBannedMemberControllerState(referenceTimestamp: Int32(Date().timeIntervalSince1970), updatedFlags: nil, updatedTimeout: nil, updating: false) let statePromise = ValuePromise(initialState, ignoreRepeated: true) let stateValue = Atomic(value: initialState) let updateState: ((ChannelBannedMemberControllerState) -> ChannelBannedMemberControllerState) -> Void = { f in @@ -370,36 +329,54 @@ public func channelBannedMemberController(account: Account, peerId: PeerId, memb var dismissImpl: (() -> Void)? var presentControllerImpl: ((ViewController, Any?) -> Void)? - let arguments = ChannelBannedMemberControllerArguments(account: account, toggleRight: { right, flags in - updateState { current in - var updated = flags - let compositeFlags: TelegramChannelBannedRightsFlags - switch right { - case .banSendStickers, .banSendGifs, .banSendGames, .banSendInline: - compositeFlags = [.banSendStickers, .banSendGifs, .banSendGames, .banSendInline] - default: - compositeFlags = right - + let peerView = Promise() + peerView.set(account.viewTracker.peerView(peerId)) + + let arguments = ChannelBannedMemberControllerArguments(account: account, toggleRight: { rights, value in + let _ = (peerView.get() + |> take(1) + |> deliverOnMainQueue).start(next: { view in + if let cachedData = view.cachedData as? CachedChannelData { + updateState { state in + var state = state + var effectiveRightsFlags: TelegramChatBannedRightsFlags + if let updatedFlags = state.updatedFlags { + effectiveRightsFlags = updatedFlags + } else if let initialParticipant = initialParticipant, case let .member(member) = initialParticipant, let banInfo = member.banInfo { + effectiveRightsFlags = banInfo.rights.flags + } else if let defaultBannedRightsFlags = cachedData.defaultBannedRights?.flags { + effectiveRightsFlags = defaultBannedRightsFlags + } else { + effectiveRightsFlags = TelegramChatBannedRightsFlags() + } + if value { + effectiveRightsFlags.remove(rights) + effectiveRightsFlags = effectiveRightsFlags.subtracting(groupPermissionDependencies(rights)) + } else { + effectiveRightsFlags.insert(rights) + for right in allGroupPermissionList { + if groupPermissionDependencies(right).contains(rights) { + effectiveRightsFlags.insert(right) + } + } + } + state.updatedFlags = effectiveRightsFlags + return state + } } - if !flags.intersection(compositeFlags).isEmpty { - updated = updated.subtracting(compositeFlags) - updated = updated.subtracting(rightDependencies(right)) - } else { - updated = updated.union(compositeFlags) - updated = updated.union(rightReverseDependencies(right)) - } - return current.withUpdatedUpdatedFlags(updated) - } + }) }, openTimeout: { let presentationData = account.telegramApplicationContext.currentPresentationData.with { $0 } let actionSheet = ActionSheetController(presentationTheme: presentationData.theme) let intervals: [Int32] = [ 1 * 60 * 60 * 24, - 7 * 60 * 60 * 24 + 7 * 60 * 60 * 24, + 30 * 60 * 60 * 24 ] let applyValue: (Int32?) -> Void = { value in updateState { state in - let state = state.withUpdatedUpdatedTimeout(value) + var state = state + state.updatedTimeout = value return state } } @@ -410,6 +387,10 @@ public func channelBannedMemberController(account: Account, peerId: PeerId, memb applyValue(initialState.referenceTimestamp + interval) })) } + items.append(ActionSheetButtonItem(title: presentationData.strings.MessageTimer_Forever, color: .accent, action: { [weak actionSheet] in + actionSheet?.dismissAnimated() + applyValue(Int32.max) + })) items.append(ActionSheetButtonItem(title: presentationData.strings.MessageTimer_Custom, color: .accent, action: { [weak actionSheet] in actionSheet?.dismissAnimated() presentControllerImpl?(PeerBanTimeoutController(account: account, currentValue: Int32(Date().timeIntervalSince1970), applyValue: { value in @@ -422,30 +403,70 @@ public func channelBannedMemberController(account: Account, peerId: PeerId, memb }) ])]) presentControllerImpl?(actionSheet, nil) + }, delete: { + let presentationData = account.telegramApplicationContext.currentPresentationData.with { $0 } + let actionSheet = ActionSheetController(presentationTheme: presentationData.theme) + var items: [ActionSheetItem] = [] + items.append(ActionSheetButtonItem(title: presentationData.strings.GroupPermission_Delete, color: .destructive, font: .default, enabled: true, action: { [weak actionSheet] in + actionSheet?.dismissAnimated() + updateState { state in + var state = state + state.updating = true + return state + } + updateRightsDisposable.set((account.telegramApplicationContext.peerChannelMemberCategoriesContextsManager.updateMemberBannedRights(account: account, peerId: peerId, memberId: memberId, bannedRights: nil) + |> deliverOnMainQueue).start(error: { _ in + + }, completed: { + updated(nil) + dismissImpl?() + })) + })) + actionSheet.setItemGroups([ActionSheetItemGroup(items: items), ActionSheetItemGroup(items: [ + ActionSheetButtonItem(title: presentationData.strings.Common_Cancel, color: .accent, action: { [weak actionSheet] in + actionSheet?.dismissAnimated() + }) + ])]) + presentControllerImpl?(actionSheet, nil) }) - let combinedView = account.postbox.combinedView(keys: [.peer(peerId: peerId, components: .all), .peer(peerId: memberId, components: .all)]) + var keys: [PostboxViewKey] = [.peer(peerId: peerId, components: .all), .peer(peerId: memberId, components: .all)] + if let banInfo = initialParticipant?.banInfo { + keys.append(.peer(peerId: banInfo.restrictedBy, components: [])) + } + let combinedView = account.postbox.combinedView(keys: keys) let canEdit = true let signal = combineLatest((account.applicationContext as! TelegramApplicationContext).presentationData, statePromise.get(), combinedView) - |> deliverOnMainQueue - |> map { presentationData, state, combinedView -> (ItemListControllerState, (ItemListNodeState, ChannelBannedMemberEntry.ItemGenerationArguments)) in - let channelView = combinedView.views[.peer(peerId: peerId, components: .all)] as! PeerView - let memberView = combinedView.views[.peer(peerId: memberId, components: .all)] as! PeerView - - let leftNavigationButton: ItemListNavigationButton - leftNavigationButton = ItemListNavigationButton(content: .text(presentationData.strings.Common_Cancel), style: .regular, enabled: true, action: { - dismissImpl?() - }) - - var rightNavigationButton: ItemListNavigationButton? - 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: { + |> deliverOnMainQueue + |> map { presentationData, state, combinedView -> (ItemListControllerState, (ItemListNodeState, ChannelBannedMemberEntry.ItemGenerationArguments)) in + let channelView = combinedView.views[.peer(peerId: peerId, components: .all)] as! PeerView + let memberView = combinedView.views[.peer(peerId: memberId, components: .all)] as! PeerView + var initialBannedByPeer: Peer? + if let banInfo = initialParticipant?.banInfo { + initialBannedByPeer = (combinedView.views[.peer(peerId: banInfo.restrictedBy, components: [])] as? PeerView)?.peers[banInfo.restrictedBy] + } + + let leftNavigationButton: ItemListNavigationButton + leftNavigationButton = ItemListNavigationButton(content: .text(presentationData.strings.Common_Cancel), style: .regular, enabled: true, action: { + dismissImpl?() + }) + + var rightNavigationButton: ItemListNavigationButton? + 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: { + let _ = (peerView.get() + |> take(1) + |> deliverOnMainQueue).start(next: { view in + guard let channel = view.peers[peerId] as? TelegramChannel, let cachedData = view.cachedData as? CachedChannelData, let initialRightFlags = cachedData.defaultBannedRights?.flags else { + return + } + var resolvedRights: TelegramChatBannedRights? if let initialParticipant = initialParticipant { - var updateFlags: TelegramChannelBannedRightsFlags? + var updateFlags: TelegramChatBannedRightsFlags? var updateTimeout: Int32? updateState { current in updateFlags = current.updatedFlags @@ -454,7 +475,7 @@ public func channelBannedMemberController(account: Account, peerId: PeerId, memb } if updateFlags == nil && updateTimeout == nil { - if case let .member(_, _, _, maybeBanInfo) = initialParticipant { + if case let .member(_, _, _, maybeBanInfo) = initialParticipant { if maybeBanInfo == nil { updateFlags = initialRightFlags updateTimeout = Int32.max @@ -463,11 +484,7 @@ public func channelBannedMemberController(account: Account, peerId: PeerId, memb } if updateFlags != nil || updateTimeout != nil { - updateState { current in - return current.withUpdatedUpdating(true) - } - - let currentRightsFlags: TelegramChannelBannedRightsFlags + let currentRightsFlags: TelegramChatBannedRightsFlags if let updatedFlags = updateFlags { currentRightsFlags = updatedFlags } else if case let .member(_, _, _, maybeBanInfo) = initialParticipant, let banInfo = maybeBanInfo { @@ -485,25 +502,17 @@ public func channelBannedMemberController(account: Account, peerId: PeerId, memb currentTimeout = Int32.max } - let rights = TelegramChannelBannedRights(flags: maskedFlags(currentRightsFlags), untilDate: currentTimeout) - - updateRightsDisposable.set((account.telegramApplicationContext.peerChannelMemberCategoriesContextsManager.updateMemberBannedRights(account: account, peerId: peerId, memberId: memberId, bannedRights: rights) - |> deliverOnMainQueue).start(error: { _ in - - }, completed: { - updated(rights) - dismissImpl?() - })) - } else { - dismissImpl?() + resolvedRights = TelegramChatBannedRights(flags: completeRights(currentRightsFlags), untilDate: currentTimeout) } } else if canEdit, let _ = channelView.peers[channelView.peerId] as? TelegramChannel { - var updateFlags: TelegramChannelBannedRightsFlags? + var updateFlags: TelegramChatBannedRightsFlags? var updateTimeout: Int32? - updateState { current in - updateFlags = current.updatedFlags - updateTimeout = current.updatedTimeout - return current.withUpdatedUpdating(true) + updateState { state in + var state = state + updateFlags = state.updatedFlags + updateTimeout = state.updatedTimeout + state.updating = false + return state } if updateFlags == nil { @@ -514,28 +523,81 @@ public func channelBannedMemberController(account: Account, peerId: PeerId, memb } if let updateFlags = updateFlags, let updateTimeout = updateTimeout { - let rights = TelegramChannelBannedRights(flags: maskedFlags(updateFlags), untilDate: updateTimeout) - updateRightsDisposable.set((account.telegramApplicationContext.peerChannelMemberCategoriesContextsManager.updateMemberBannedRights(account: account, peerId: peerId, memberId: memberId, bannedRights: rights) - |> deliverOnMainQueue).start(error: { _ in - - }, completed: { - updated(rights) - dismissImpl?() + resolvedRights = TelegramChatBannedRights(flags: completeRights(updateFlags), untilDate: updateTimeout) + } + } + + var previousRights: TelegramChatBannedRights? + if let initialParticipant = initialParticipant, case let .member(member) = initialParticipant, member.banInfo != nil { + previousRights = member.banInfo?.rights + } + + if let resolvedRights = resolvedRights, previousRights != resolvedRights { + let cleanResolvedRightsFlags = resolvedRights.flags.intersection(initialRightFlags) + let cleanResolvedRights = TelegramChatBannedRights(flags: cleanResolvedRightsFlags, untilDate: resolvedRights.untilDate) + + if cleanResolvedRights.flags.isEmpty && previousRights == nil { + dismissImpl?() + } else { + let applyRights: () -> Void = { + updateState { state in + var state = state + state.updating = true + return state + } + updateRightsDisposable.set((account.telegramApplicationContext.peerChannelMemberCategoriesContextsManager.updateMemberBannedRights(account: account, peerId: peerId, memberId: memberId, bannedRights: cleanResolvedRights) + |> deliverOnMainQueue).start(error: { _ in + + }, completed: { + if previousRights == nil { + let presentationData = account.telegramApplicationContext.currentPresentationData.with { $0 } + presentControllerImpl?(OverlayStatusController(theme: presentationData.theme, strings: presentationData.strings, type: .genericSuccess(presentationData.strings.GroupPermission_AddSuccess)), nil) + } + updated(cleanResolvedRights.flags.isEmpty ? nil : cleanResolvedRights) + dismissImpl?() + })) + } + if previousRights == nil { + applyRights() + } else { + let presentationData = account.telegramApplicationContext.currentPresentationData.with { $0 } + let actionSheet = ActionSheetController(presentationTheme: presentationData.theme) + var items: [ActionSheetItem] = [] + items.append(ActionSheetTextItem(title: presentationData.strings.GroupPermission_ApplyAlertText(channel.displayTitle).0)) + items.append(ActionSheetButtonItem(title: presentationData.strings.GroupPermission_ApplyAlertAction, color: .accent, font: .default, enabled: true, action: { [weak actionSheet] in + actionSheet?.dismissAnimated() + applyRights() })) + actionSheet.setItemGroups([ActionSheetItemGroup(items: items), ActionSheetItemGroup(items: [ + ActionSheetButtonItem(title: presentationData.strings.Common_Cancel, color: .accent, action: { [weak actionSheet] in + actionSheet?.dismissAnimated() + }) + ])]) + presentControllerImpl?(actionSheet, nil) + } } } else { dismissImpl?() } }) - } - - let controllerState = ItemListControllerState(theme: presentationData.theme, title: .text(presentationData.strings.Channel_BanUser_Title), leftNavigationButton: leftNavigationButton, rightNavigationButton: rightNavigationButton, backNavigationButton: ItemListBackButton(title: presentationData.strings.Common_Back), animateChanges: false) - - let listState = ItemListNodeState(entries: channelBannedMemberControllerEntries(presentationData: presentationData, state: state, accountPeerId: account.peerId, channelView: channelView, memberView: memberView, initialParticipant: initialParticipant), style: .blocks, emptyStateItem: nil, animateChanges: true) - - return (controllerState, (listState, arguments)) - } |> afterDisposed { - actionsDisposable.dispose() + }) + } + + let title: String + if let initialParticipant = initialParticipant, case let .member(member) = initialParticipant, member.banInfo != nil { + title = presentationData.strings.GroupPermission_Title + } else { + title = presentationData.strings.GroupPermission_NewTitle + } + + let controllerState = ItemListControllerState(theme: presentationData.theme, title: .text(title), leftNavigationButton: leftNavigationButton, rightNavigationButton: rightNavigationButton, backNavigationButton: ItemListBackButton(title: presentationData.strings.Common_Back), animateChanges: false) + + let listState = ItemListNodeState(entries: channelBannedMemberControllerEntries(presentationData: presentationData, state: state, accountPeerId: account.peerId, channelView: channelView, memberView: memberView, initialParticipant: initialParticipant, initialBannedBy: initialBannedByPeer), style: .blocks, emptyStateItem: nil, animateChanges: true) + + return (controllerState, (listState, arguments)) + } + |> afterDisposed { + actionsDisposable.dispose() } let controller = ItemListController(account: account, state: signal) diff --git a/TelegramUI/ChannelBlacklistController.swift b/TelegramUI/ChannelBlacklistController.swift index 0024ca3765..bd787d25c6 100644 --- a/TelegramUI/ChannelBlacklistController.swift +++ b/TelegramUI/ChannelBlacklistController.swift @@ -10,21 +10,19 @@ private final class ChannelBlacklistControllerArguments { let setPeerIdWithRevealedOptions: (PeerId?, PeerId?) -> Void let addPeer: () -> Void let removePeer: (PeerId) -> Void - let openPeer: (ChannelParticipant) -> Void - let openPeerInfo:(Peer) -> Void - init(account: Account, setPeerIdWithRevealedOptions: @escaping (PeerId?, PeerId?) -> Void, addPeer: @escaping () -> Void, removePeer: @escaping (PeerId) -> Void, openPeer: @escaping (ChannelParticipant) -> Void, openPeerInfo: @escaping(Peer)->Void) { + let openPeer: (RenderedChannelParticipant) -> Void + + init(account: Account, setPeerIdWithRevealedOptions: @escaping (PeerId?, PeerId?) -> Void, addPeer: @escaping () -> Void, removePeer: @escaping (PeerId) -> Void, openPeer: @escaping (RenderedChannelParticipant) -> Void) { self.account = account self.addPeer = addPeer self.setPeerIdWithRevealedOptions = setPeerIdWithRevealedOptions self.removePeer = removePeer self.openPeer = openPeer - self.openPeerInfo = openPeerInfo } } private enum ChannelBlacklistSection: Int32 { case add - case restricted case banned } @@ -33,32 +31,20 @@ private enum ChannelBlacklistEntryStableId: Hashable { case peer(PeerId) } -private enum ChannelBlacklistPeerCategory { - case restricted - case banned -} - private enum ChannelBlacklistEntry: ItemListNodeEntry { case add(PresentationTheme, String) - case restrictedHeader(PresentationTheme, String) + case addInfo(PresentationTheme, String) case bannedHeader(PresentationTheme, String) - case peerItem(PresentationTheme, PresentationStrings, PresentationDateTimeFormat, PresentationPersonNameOrder, Int32, ChannelBlacklistPeerCategory, RenderedChannelParticipant, ItemListPeerItemEditing, Bool, Bool) + case peerItem(PresentationTheme, PresentationStrings, PresentationDateTimeFormat, PresentationPersonNameOrder, Int32, RenderedChannelParticipant, ItemListPeerItemEditing, Bool) var section: ItemListSectionId { switch self { - case .add: + case .add, .addInfo: return ChannelBlacklistSection.add.rawValue - case .restrictedHeader: - return ChannelBlacklistSection.restricted.rawValue case .bannedHeader: return ChannelBlacklistSection.banned.rawValue - case let .peerItem(_, _, _, _, _, category, _, _, _, _): - switch category { - case .restricted: - return ChannelBlacklistSection.restricted.rawValue - case .banned: - return ChannelBlacklistSection.banned.rawValue - } + case .peerItem: + return ChannelBlacklistSection.banned.rawValue } } @@ -66,11 +52,11 @@ private enum ChannelBlacklistEntry: ItemListNodeEntry { switch self { case .add: return .index(0) - case .restrictedHeader: + case .addInfo: return .index(1) case .bannedHeader: return .index(2) - case let .peerItem(_, _, _, _, _, _, participant, _, _, _): + case let .peerItem(_, _, _, _, _, participant, _, _): return .peer(participant.peer.id) } } @@ -83,8 +69,8 @@ private enum ChannelBlacklistEntry: ItemListNodeEntry { } else { return false } - case let .restrictedHeader(lhsTheme, lhsText): - if case let .restrictedHeader(rhsTheme, rhsText) = rhs, lhsTheme === rhsTheme, lhsText == rhsText { + case let .addInfo(lhsTheme, lhsText): + if case let .addInfo(rhsTheme, rhsText) = rhs, lhsTheme === rhsTheme, lhsText == rhsText { return true } else { return false @@ -95,8 +81,8 @@ private enum ChannelBlacklistEntry: ItemListNodeEntry { } else { return false } - case let .peerItem(lhsTheme, lhsStrings, lhsDateTimeFormat, lhsNameOrder, lhsIndex, lhsCategory, lhsParticipant, lhsEditing, lhsEnabled, lhsCanOpen): - if case let .peerItem(rhsTheme, rhsStrings, rhsDateTimeFormat, rhsNameOrder, rhsIndex, rhsCategory, rhsParticipant, rhsEditing, rhsEnabled, rhsCanOpen) = rhs { + case let .peerItem(lhsTheme, lhsStrings, lhsDateTimeFormat, lhsNameOrder, lhsIndex, lhsParticipant, lhsEditing, lhsEnabled): + if case let .peerItem(rhsTheme, rhsStrings, rhsDateTimeFormat, rhsNameOrder, rhsIndex, rhsParticipant, rhsEditing, rhsEnabled) = rhs { if lhsTheme !== rhsTheme { return false } @@ -112,9 +98,6 @@ private enum ChannelBlacklistEntry: ItemListNodeEntry { if lhsIndex != rhsIndex { return false } - if lhsCategory != rhsCategory { - return false - } if lhsParticipant != rhsParticipant { return false } @@ -124,9 +107,6 @@ private enum ChannelBlacklistEntry: ItemListNodeEntry { if lhsEnabled != rhsEnabled { return false } - if lhsCanOpen != rhsCanOpen { - return false - } return true } else { return false @@ -136,45 +116,23 @@ private enum ChannelBlacklistEntry: ItemListNodeEntry { static func <(lhs: ChannelBlacklistEntry, rhs: ChannelBlacklistEntry) -> Bool { switch lhs { - case .add: + case let .peerItem(_, _, _, _, index, _, _, _): switch rhs { - case .add: - return false - default: - return true - } - case .restrictedHeader: - switch rhs { - case .add, .restrictedHeader: - return false - default: - return true - } - case .bannedHeader: - switch rhs { - case .add, .restrictedHeader, .bannedHeader: - return false - case let .peerItem(_, _, _, _, _, category, _, _, _, _): - switch category { - case .restricted: - return false - case .banned: - return true - } - } - case let .peerItem(_, _, _, _, index, category, _, _, _, _): - switch rhs { - case .add, .restrictedHeader: - return false - case .bannedHeader: - switch category { - case .restricted: - return true - case .banned: - return false - } - case let .peerItem(_, _, _, _, rhsIndex, _, _, _, _, _): + case let .peerItem(_, _, _, _, rhsIndex, _, _, _): return index < rhsIndex + default: + return false + } + default: + if case let .index(lhsIndex) = lhs.stableId { + if case let .index(rhsIndex) = rhs.stableId { + return lhsIndex < rhsIndex + } else { + return true + } + } else { + assertionFailure() + return false } } } @@ -182,28 +140,26 @@ private enum ChannelBlacklistEntry: ItemListNodeEntry { func item(_ arguments: ChannelBlacklistControllerArguments) -> ListViewItem { switch self { case let .add(theme, text): - return ItemListPeerActionItem(theme: theme, icon: PresentationResourcesItemList.addPersonIcon(theme), title: text, sectionId: self.section, editing: false, action: { + return ItemListActionItem(theme: theme, title: text, kind: .generic, alignment: .natural, sectionId: self.section, style: .blocks, action: { arguments.addPeer() }) - case let .restrictedHeader(theme, text): - return ItemListSectionHeaderItem(theme: theme, text: text, sectionId: self.section) + case let .addInfo(theme, text): + return ItemListTextItem(theme: theme, text: .plain(text), sectionId: self.section) case let .bannedHeader(theme, text): return ItemListSectionHeaderItem(theme: theme, text: text, sectionId: self.section) - case let .peerItem(theme, strings, dateTimeFormat, nameDisplayOrder, _, _, participant, editing, enabled, canOpen): + case let .peerItem(theme, strings, dateTimeFormat, nameDisplayOrder, _, participant, editing, enabled): var text: ItemListPeerItemText = .none switch participant.participant { case let .member(_, _, _, banInfo): if let banInfo = banInfo, let peer = participant.peers[banInfo.restrictedBy] { - text = .text(strings.Channel_Management_RestrictedBy(peer.displayTitle).0) + text = .text(strings.Channel_Management_RemovedBy(peer.displayTitle).0) } default: break } - return ItemListPeerItem(theme: theme, strings: strings, dateTimeFormat: dateTimeFormat, nameDisplayOrder: nameDisplayOrder, account: arguments.account, peer: participant.peer, presence: nil, text: text, label: .none, editing: editing, switchValue: nil, enabled: enabled, sectionId: self.section, action: canOpen ? { - arguments.openPeer(participant.participant) - } : { - arguments.openPeerInfo(participant.peer) - }, setPeerIdWithRevealedOptions: { previousId, id in + return ItemListPeerItem(theme: theme, strings: strings, dateTimeFormat: dateTimeFormat, nameDisplayOrder: nameDisplayOrder, account: arguments.account, peer: participant.peer, presence: nil, text: text, label: .none, editing: editing, switchValue: nil, enabled: enabled, sectionId: self.section, action: { + arguments.openPeer(participant) + }, setPeerIdWithRevealedOptions: { previousId, id in arguments.setPeerIdWithRevealedOptions(previousId, id) }, removePeer: { peerId in arguments.removePeer(peerId) @@ -213,19 +169,22 @@ private enum ChannelBlacklistEntry: ItemListNodeEntry { } private struct ChannelBlacklistControllerState: Equatable { + let referenceTimestamp: Int32 let editing: Bool let peerIdWithRevealedOptions: PeerId? let removingPeerId: PeerId? let searchingMembers: Bool - init() { + init(referenceTimestamp: Int32) { + self.referenceTimestamp = referenceTimestamp self.editing = false self.peerIdWithRevealedOptions = nil self.removingPeerId = nil self.searchingMembers = false } - init(editing: Bool, peerIdWithRevealedOptions: PeerId?, removingPeerId: PeerId?, searchingMembers: Bool) { + init(referenceTimestamp: Int32, editing: Bool, peerIdWithRevealedOptions: PeerId?, removingPeerId: PeerId?, searchingMembers: Bool) { + self.referenceTimestamp = referenceTimestamp self.editing = editing self.peerIdWithRevealedOptions = peerIdWithRevealedOptions self.removingPeerId = removingPeerId @@ -233,6 +192,9 @@ private struct ChannelBlacklistControllerState: Equatable { } static func ==(lhs: ChannelBlacklistControllerState, rhs: ChannelBlacklistControllerState) -> Bool { + if lhs.referenceTimestamp != rhs.referenceTimestamp { + return false + } if lhs.editing != rhs.editing { return false } @@ -250,56 +212,43 @@ private struct ChannelBlacklistControllerState: Equatable { } func withUpdatedSearchingMembers(_ searchingMembers: Bool) -> ChannelBlacklistControllerState { - return ChannelBlacklistControllerState(editing: self.editing, peerIdWithRevealedOptions: self.peerIdWithRevealedOptions, removingPeerId: self.removingPeerId, searchingMembers: searchingMembers) + return ChannelBlacklistControllerState(referenceTimestamp: self.referenceTimestamp, editing: self.editing, peerIdWithRevealedOptions: self.peerIdWithRevealedOptions, removingPeerId: self.removingPeerId, searchingMembers: searchingMembers) } func withUpdatedEditing(_ editing: Bool) -> ChannelBlacklistControllerState { - return ChannelBlacklistControllerState(editing: editing, peerIdWithRevealedOptions: self.peerIdWithRevealedOptions, removingPeerId: self.removingPeerId, searchingMembers: self.searchingMembers) + return ChannelBlacklistControllerState(referenceTimestamp: self.referenceTimestamp, editing: editing, peerIdWithRevealedOptions: self.peerIdWithRevealedOptions, removingPeerId: self.removingPeerId, searchingMembers: self.searchingMembers) } func withUpdatedPeerIdWithRevealedOptions(_ peerIdWithRevealedOptions: PeerId?) -> ChannelBlacklistControllerState { - return ChannelBlacklistControllerState(editing: self.editing, peerIdWithRevealedOptions: peerIdWithRevealedOptions, removingPeerId: self.removingPeerId, searchingMembers: self.searchingMembers) + return ChannelBlacklistControllerState(referenceTimestamp: self.referenceTimestamp, editing: self.editing, peerIdWithRevealedOptions: peerIdWithRevealedOptions, removingPeerId: self.removingPeerId, searchingMembers: self.searchingMembers) } func withUpdatedRemovingPeerId(_ removingPeerId: PeerId?) -> ChannelBlacklistControllerState { - return ChannelBlacklistControllerState(editing: self.editing, peerIdWithRevealedOptions: self.peerIdWithRevealedOptions, removingPeerId: removingPeerId, searchingMembers: self.searchingMembers) + return ChannelBlacklistControllerState(referenceTimestamp: self.referenceTimestamp, editing: self.editing, peerIdWithRevealedOptions: self.peerIdWithRevealedOptions, removingPeerId: removingPeerId, searchingMembers: self.searchingMembers) } } -private func channelBlacklistControllerEntries(presentationData: PresentationData, view: PeerView, state: ChannelBlacklistControllerState, blacklist: ChannelBlacklist?) -> [ChannelBlacklistEntry] { +private func channelBlacklistControllerEntries(presentationData: PresentationData, view: PeerView, state: ChannelBlacklistControllerState, participants: [RenderedChannelParticipant]?) -> [ChannelBlacklistEntry] { var entries: [ChannelBlacklistEntry] = [] - if let channel = view.peers[view.peerId] as? TelegramChannel, let blacklist = blacklist { - entries.append(.add(presentationData.theme, presentationData.strings.Channel_Members_AddMembers)) + if let channel = view.peers[view.peerId] as? TelegramChannel, let participants = participants { + entries.append(.add(presentationData.theme, presentationData.strings.GroupRemoved_Remove)) + + let isGroup: Bool + if case .group = channel.info { + isGroup = true + } else { + isGroup = false + } + entries.append(.addInfo(presentationData.theme, isGroup ? presentationData.strings.GroupRemoved_RemoveInfo : presentationData.strings.ChannelRemoved_RemoveInfo)) var index: Int32 = 0 - if !blacklist.restricted.isEmpty { - entries.append(.restrictedHeader(presentationData.theme, presentationData.strings.Channel_BanList_RestrictedTitle)) + if !participants.isEmpty { + entries.append(.bannedHeader(presentationData.theme, presentationData.strings.GroupRemoved_UsersSectionTitle)) } - let canOpen: Bool - if case .group = channel.info { - canOpen = true - } else { - canOpen = false - } - for participant in blacklist.restricted { - var editable = true - if case .creator = participant.participant { - editable = false - } - entries.append(.peerItem(presentationData.theme, presentationData.strings, presentationData.dateTimeFormat, presentationData.nameDisplayOrder, index, .restricted, participant, ItemListPeerItemEditing(editable: editable, editing: state.editing, revealed: participant.peer.id == state.peerIdWithRevealedOptions), state.removingPeerId != participant.peer.id, canOpen)) - index += 1 - } - if !blacklist.banned.isEmpty { - entries.append(.bannedHeader(presentationData.theme, presentationData.strings.Channel_BanList_BlockedTitle)) - } - for participant in blacklist.banned { - var editable = true - if case .creator = participant.participant { - editable = false - } - entries.append(.peerItem(presentationData.theme, presentationData.strings, presentationData.dateTimeFormat, presentationData.nameDisplayOrder, index, .banned, participant, ItemListPeerItemEditing(editable: editable, editing: state.editing, revealed: participant.peer.id == state.peerIdWithRevealedOptions), state.removingPeerId != participant.peer.id, canOpen)) + for participant in participants { + entries.append(.peerItem(presentationData.theme, presentationData.strings, presentationData.dateTimeFormat, presentationData.nameDisplayOrder, index, participant, ItemListPeerItemEditing(editable: true, editing: state.editing, revealed: participant.peer.id == state.peerIdWithRevealedOptions), state.removingPeerId != participant.peer.id)) index += 1 } } @@ -308,8 +257,8 @@ private func channelBlacklistControllerEntries(presentationData: PresentationDat } public func channelBlacklistController(account: Account, peerId: PeerId) -> ViewController { - let statePromise = ValuePromise(ChannelBlacklistControllerState(), ignoreRepeated: true) - let stateValue = Atomic(value: ChannelBlacklistControllerState()) + let statePromise = ValuePromise(ChannelBlacklistControllerState(referenceTimestamp: Int32(Date().timeIntervalSince1970)), ignoreRepeated: true) + let stateValue = Atomic(value: ChannelBlacklistControllerState(referenceTimestamp: Int32(Date().timeIntervalSince1970))) let updateState: ((ChannelBlacklistControllerState) -> ChannelBlacklistControllerState) -> Void = { f in statePromise.set(stateValue.modify { f($0) }) } @@ -325,8 +274,9 @@ public func channelBlacklistController(account: Account, peerId: PeerId) -> View let removePeerDisposable = MetaDisposable() actionsDisposable.add(removePeerDisposable) - let blacklistPromise = Promise(nil) - + let peerView = Promise() + peerView.set(account.viewTracker.peerView(peerId)) + let blacklistPromise = Promise<[RenderedChannelParticipant]?>(nil) let arguments = ChannelBlacklistControllerArguments(account: account, setPeerIdWithRevealedOptions: { peerId, fromPeerId in updateState { state in @@ -337,7 +287,8 @@ public func channelBlacklistController(account: Account, peerId: PeerId) -> View } } }, addPeer: { - presentControllerImpl?(ChannelMembersSearchController(account: account, peerId: peerId, mode: .ban, openPeer: { peer, participant in + var dismissController: (() -> Void)? + let controller = ChannelMembersSearchController(account: account, peerId: peerId, mode: .ban, openPeer: { peer, participant in if let participant = participant { let presentationData = account.telegramApplicationContext.currentPresentationData.with { $0 } switch participant.participant { @@ -355,21 +306,30 @@ public func channelBlacklistController(account: Account, peerId: PeerId) -> View guard let channel = channel as? TelegramChannel else { return } - if case .broadcast = channel.info { - removePeerDisposable.set((account.telegramApplicationContext.peerChannelMemberCategoriesContextsManager.updateMemberBannedRights(account: account, peerId: peerId, memberId: peer.id, bannedRights: TelegramChannelBannedRights(flags: [.banReadMessages], untilDate: Int32.max)) - |> deliverOnMainQueue).start()) - } else { - presentControllerImpl?(channelBannedMemberController(account: account, peerId: peerId, memberId: peer.id, initialParticipant: participant?.participant, updated: { _ in - }), ViewControllerPresentationArguments(presentationAnimation: .modalSheet)) - } + + let presentationData = account.telegramApplicationContext.currentPresentationData.with { $0 } + let progress = OverlayStatusController(theme: presentationData.theme, strings: presentationData.strings, type: .loading(cancelled: nil)) + presentControllerImpl?(progress, nil) + removePeerDisposable.set((account.telegramApplicationContext.peerChannelMemberCategoriesContextsManager.updateMemberBannedRights(account: account, peerId: peerId, memberId: peer.id, bannedRights: TelegramChatBannedRights(flags: [.banReadMessages], untilDate: Int32.max)) + |> deliverOnMainQueue).start(error: { [weak progress] _ in + progress?.dismiss() + dismissController?() + }, completed: {[weak progress] in + progress?.dismiss() + dismissController?() + })) }) - }), ViewControllerPresentationArguments(presentationAnimation: .modalSheet)) + }) + dismissController = { [weak controller] in + controller?.dismiss() + } + presentControllerImpl?(controller, ViewControllerPresentationArguments(presentationAnimation: .modalSheet)) }, removePeer: { memberId in updateState { return $0.withUpdatedRemovingPeerId(memberId) } - removePeerDisposable.set((account.telegramApplicationContext.peerChannelMemberCategoriesContextsManager.updateMemberBannedRights(account: account, peerId: peerId, memberId: memberId, bannedRights: TelegramChannelBannedRights(flags: [], untilDate: 0)) |> deliverOnMainQueue).start(error: { _ in + removePeerDisposable.set((account.telegramApplicationContext.peerChannelMemberCategoriesContextsManager.updateMemberBannedRights(account: account, peerId: peerId, memberId: memberId, bannedRights: nil) |> deliverOnMainQueue).start(error: { _ in updateState { return $0.withUpdatedRemovingPeerId(nil) } @@ -379,118 +339,149 @@ public func channelBlacklistController(account: Account, peerId: PeerId) -> View } })) }, openPeer: { participant in - presentControllerImpl?(channelBannedMemberController(account: account, peerId: peerId, memberId: participant.peerId, initialParticipant: participant, updated: { _ in - }), ViewControllerPresentationArguments(presentationAnimation: .modalSheet)) - }, openPeerInfo: { peer in - if let controller = peerInfoController(account: account, peer: peer) { - pushControllerImpl?(controller) - } + let _ = (peerView.get() + |> take(1) + |> deliverOnMainQueue).start(next: { peerView in + guard let channel = peerView.peers[peerId] as? TelegramChannel else { + return + } + let presentationData = account.telegramApplicationContext.currentPresentationData.with { $0 } + let actionSheet = ActionSheetController(presentationTheme: presentationData.theme) + var items: [ActionSheetItem] = [] + items.append(ActionSheetTextItem(title: participant.peer.displayTitle)) + items.append(ActionSheetButtonItem(title: presentationData.strings.GroupRemoved_ViewUserInfo, action: { [weak actionSheet] in + actionSheet?.dismissAnimated() + if let infoController = peerInfoController(account: account, peer: participant.peer) { + pushControllerImpl?(infoController) + } + })) + if case .group = channel.info, channel.hasPermission(.inviteMembers) { + items.append(ActionSheetButtonItem(title: presentationData.strings.GroupRemoved_AddToGroup, action: { [weak actionSheet] in + actionSheet?.dismissAnimated() + let memberId = participant.peer.id + updateState { + return $0.withUpdatedRemovingPeerId(memberId) + } + let signal = account.telegramApplicationContext.peerChannelMemberCategoriesContextsManager.updateMemberBannedRights(account: account, peerId: peerId, memberId: memberId, bannedRights: nil) + |> ignoreValues + |> then( + account.telegramApplicationContext.peerChannelMemberCategoriesContextsManager.addMember(account: account, peerId: peerId, memberId: memberId) + |> ignoreValues + ) + removePeerDisposable.set((signal |> deliverOnMainQueue).start(error: { _ in + updateState { + return $0.withUpdatedRemovingPeerId(nil) + } + }, completed: { + updateState { + return $0.withUpdatedRemovingPeerId(nil) + } + })) + })) + } + items.append(ActionSheetButtonItem(title: presentationData.strings.GroupRemoved_DeleteUser, color: .destructive, font: .default, enabled: true, action: { [weak actionSheet] in + actionSheet?.dismissAnimated() + let memberId = participant.peer.id + updateState { + return $0.withUpdatedRemovingPeerId(memberId) + } + + removePeerDisposable.set((account.telegramApplicationContext.peerChannelMemberCategoriesContextsManager.updateMemberBannedRights(account: account, peerId: peerId, memberId: memberId, bannedRights: nil) |> deliverOnMainQueue).start(error: { _ in + updateState { + return $0.withUpdatedRemovingPeerId(nil) + } + }, completed: { + updateState { + return $0.withUpdatedRemovingPeerId(nil) + } + })) + })) + actionSheet.setItemGroups([ActionSheetItemGroup(items: items), ActionSheetItemGroup(items: [ + ActionSheetButtonItem(title: presentationData.strings.Common_Cancel, color: .accent, action: { [weak actionSheet] in + actionSheet?.dismissAnimated() + }) + ])]) + presentControllerImpl?(actionSheet, nil) + }) }) - let peerView = account.viewTracker.peerView(peerId) - - let (listDisposable, loadMoreControl) = account.telegramApplicationContext.peerChannelMemberCategoriesContextsManager.restrictedAndBanned(postbox: account.postbox, network: account.network, accountPeerId: account.peerId, peerId: peerId, updated: { listState in + let (listDisposable, loadMoreControl) = account.telegramApplicationContext.peerChannelMemberCategoriesContextsManager.banned(postbox: account.postbox, network: account.network, accountPeerId: account.peerId, peerId: peerId, updated: { listState in if case .loading = listState.loadingState, listState.list.isEmpty { blacklistPromise.set(.single(nil)) } else { - var restricted: [RenderedChannelParticipant] = [] - var banned: [RenderedChannelParticipant] = [] - for member in listState.list { - switch member.participant { - case let .member(_, _, _, banInfo): - if let banInfo = banInfo { - if !banInfo.rights.flags.contains(.banReadMessages) { - restricted.append(member) - } else { - banned.append(member) - } - } else { - assertionFailure() - } - default: - assertionFailure() - break - } - } - blacklistPromise.set(.single(ChannelBlacklist(banned: banned, restricted: restricted))) + blacklistPromise.set(.single(listState.list)) } }) actionsDisposable.add(listDisposable) - var previousBlacklist: ChannelBlacklist? + let previousParticipantsValue = Atomic<[RenderedChannelParticipant]?>(value: nil) - let signal = combineLatest((account.applicationContext as! TelegramApplicationContext).presentationData, statePromise.get(), peerView, blacklistPromise.get()) - |> deliverOnMainQueue - |> map { presentationData, state, view, blacklist -> (ItemListControllerState, (ItemListNodeState, ChannelBlacklistEntry.ItemGenerationArguments)) in - var rightNavigationButton: ItemListNavigationButton? - var secondaryRightNavigationButton: ItemListNavigationButton? - if let blacklist = blacklist, !blacklist.isEmpty { - if state.editing { - rightNavigationButton = ItemListNavigationButton(content: .text(presentationData.strings.Common_Done), style: .bold, enabled: true, action: { - updateState { state in - return state.withUpdatedEditing(false) - } - }) - } else { - rightNavigationButton = ItemListNavigationButton(content: .text(presentationData.strings.Common_Edit), style: .regular, enabled: true, action: { - updateState { state in - return state.withUpdatedEditing(true) - } - }) - } - - if !state.editing { - if rightNavigationButton == nil { - rightNavigationButton = ItemListNavigationButton(content: .icon(.search), style: .regular, enabled: true, action: { - updateState { state in - return state.withUpdatedSearchingMembers(true) - } - }) - } else { - secondaryRightNavigationButton = ItemListNavigationButton(content: .icon(.search), style: .regular, enabled: true, action: { - updateState { state in - return state.withUpdatedSearchingMembers(true) - } - }) - } - } - } - - var emptyStateItem: ItemListControllerEmptyStateItem? - if blacklist == nil { - emptyStateItem = ItemListLoadingIndicatorEmptyStateItem(theme: presentationData.theme) - } - - let previous = previousBlacklist - previousBlacklist = blacklist - - var searchItem: ItemListControllerSearch? - if state.searchingMembers { - searchItem = ChannelMembersSearchItem(account: account, peerId: peerId, searchMode: .searchBanned, cancel: { + let signal = combineLatest(queue: .mainQueue(), (account.applicationContext as! TelegramApplicationContext).presentationData, statePromise.get(), peerView.get(), blacklistPromise.get()) + |> deliverOnMainQueue + |> map { presentationData, state, view, participants -> (ItemListControllerState, (ItemListNodeState, ChannelBlacklistEntry.ItemGenerationArguments)) in + var rightNavigationButton: ItemListNavigationButton? + var secondaryRightNavigationButton: ItemListNavigationButton? + if let participants = participants, !participants.isEmpty { + if state.editing { + rightNavigationButton = ItemListNavigationButton(content: .text(presentationData.strings.Common_Done), style: .bold, enabled: true, action: { updateState { state in - return state.withUpdatedSearchingMembers(false) + return state.withUpdatedEditing(false) } - }, openPeer: { _, rendered in - if let participant = rendered?.participant, case .member = participant, let channel = peerViewMainPeer(view) as? TelegramChannel { - if case .group = channel.info { - arguments.openPeer(participant) - // presentControllerImpl?(channelBannedMemberController(account: account, peerId: peerId, memberId: participant.peerId, initialParticipant: participant, updated: { _ in - // }), ViewControllerPresentationArguments(presentationAnimation: .modalSheet)) - } else if let rendered = rendered { - arguments.openPeerInfo(rendered.peer) - } + }) + } else { + rightNavigationButton = ItemListNavigationButton(content: .text(presentationData.strings.Common_Edit), style: .regular, enabled: true, action: { + updateState { state in + return state.withUpdatedEditing(true) } - }, present: { c, a in - presentControllerImpl?(c, a) }) } - let controllerState = ItemListControllerState(theme: presentationData.theme, title: .text(presentationData.strings.Channel_BlackList_Title), leftNavigationButton: nil, rightNavigationButton: rightNavigationButton, secondaryRightNavigationButton: secondaryRightNavigationButton, backNavigationButton: ItemListBackButton(title: presentationData.strings.Common_Back), animateChanges: true) - let listState = ItemListNodeState(entries: channelBlacklistControllerEntries(presentationData: presentationData, view: view, state: state, blacklist: blacklist), style: .blocks, emptyStateItem: emptyStateItem, searchItem: searchItem, animateChanges: previous != nil && blacklist != nil && (previous!.restricted.count + previous!.banned.count) >= (blacklist!.restricted.count + blacklist!.banned.count)) - - return (controllerState, (listState, arguments)) - } |> afterDisposed { - actionsDisposable.dispose() + if !state.editing { + if rightNavigationButton == nil { + rightNavigationButton = ItemListNavigationButton(content: .icon(.search), style: .regular, enabled: true, action: { + updateState { state in + return state.withUpdatedSearchingMembers(true) + } + }) + } else { + secondaryRightNavigationButton = ItemListNavigationButton(content: .icon(.search), style: .regular, enabled: true, action: { + updateState { state in + return state.withUpdatedSearchingMembers(true) + } + }) + } + } + } + + var emptyStateItem: ItemListControllerEmptyStateItem? + if participants == nil { + emptyStateItem = ItemListLoadingIndicatorEmptyStateItem(theme: presentationData.theme) + } + + let previous = previousParticipantsValue.swap(participants) + + var searchItem: ItemListControllerSearch? + if state.searchingMembers { + searchItem = ChannelMembersSearchItem(account: account, peerId: peerId, searchMode: .searchKicked, cancel: { + updateState { state in + return state.withUpdatedSearchingMembers(false) + } + }, openPeer: { _, rendered in + if let rendered = rendered, case .member = rendered.participant { + arguments.openPeer(rendered) + } + }, present: { c, a in + presentControllerImpl?(c, a) + }) + } + + let controllerState = ItemListControllerState(theme: presentationData.theme, title: .text(presentationData.strings.GroupRemoved_Title), leftNavigationButton: nil, rightNavigationButton: rightNavigationButton, secondaryRightNavigationButton: secondaryRightNavigationButton, backNavigationButton: ItemListBackButton(title: presentationData.strings.Common_Back), animateChanges: true) + let listState = ItemListNodeState(entries: channelBlacklistControllerEntries(presentationData: presentationData, view: view, state: state, participants: participants), style: .blocks, emptyStateItem: emptyStateItem, searchItem: searchItem, animateChanges: previous != nil && participants != nil && previous!.count >= participants!.count) + + return (controllerState, (listState, arguments)) + } + |> afterDisposed { + actionsDisposable.dispose() } let controller = ItemListController(account: account, state: signal) diff --git a/TelegramUI/ChannelInfoController.swift b/TelegramUI/ChannelInfoController.swift index a030b16554..f81f92317f 100644 --- a/TelegramUI/ChannelInfoController.swift +++ b/TelegramUI/ChannelInfoController.swift @@ -54,7 +54,6 @@ private enum ChannelInfoSection: ItemListSectionId { case info case discriptionAndType case sharedMediaAndNotifications - case signMessages case members case reportOrLeave } @@ -71,7 +70,6 @@ private enum ChannelInfoEntry: ItemListNodeEntry { case channelPhotoSetup(theme: PresentationTheme, text: String) case channelTypeSetup(theme: PresentationTheme, text: String, value: String) case channelDescriptionSetup(theme: PresentationTheme, placeholder: String, value: String) - case channelDescriptionSetupInfo(theme: PresentationTheme, text: String) case admins(theme: PresentationTheme, text: String, value: String) case members(theme: PresentationTheme, text: String, value: String) case banned(theme: PresentationTheme, text: String, value: String) @@ -86,16 +84,14 @@ private enum ChannelInfoEntry: ItemListNodeEntry { var section: ItemListSectionId { switch self { - case .info, .about, .addressName, .channelPhotoSetup: + case .info, .about, .addressName, .channelPhotoSetup, .channelDescriptionSetup: return ChannelInfoSection.info.rawValue - case .channelDescriptionSetup, .channelDescriptionSetupInfo, .channelTypeSetup: + case .channelTypeSetup, .signMessages, .signInfo: return ChannelInfoSection.discriptionAndType.rawValue case .admins, .members, .banned: return ChannelInfoSection.members.rawValue case .sharedMedia, .notifications, .notificationSound: return ChannelInfoSection.sharedMediaAndNotifications.rawValue - case .signMessages, .signInfo: - return ChannelInfoSection.signMessages.rawValue case .report, .leave, .deleteChannel: return ChannelInfoSection.reportOrLeave.rawValue } @@ -111,22 +107,20 @@ private enum ChannelInfoEntry: ItemListNodeEntry { return 2 case .about: return 3 - case .channelTypeSetup: - return 4 case .channelDescriptionSetup: + return 4 + case .channelTypeSetup: return 5 - case .channelDescriptionSetupInfo: + case .signMessages: return 6 - case .admins: + case .signInfo: return 7 - case .banned: + case .admins: return 8 case .members: return 9 - case .signMessages: + case .banned: return 10 - case .signInfo: - return 11 case .notifications: return 12 case .notificationSound: @@ -210,12 +204,6 @@ private enum ChannelInfoEntry: ItemListNodeEntry { } else { return false } - case let .channelDescriptionSetupInfo(lhsTheme, lhsText): - if case let .channelDescriptionSetupInfo(rhsTheme, rhsText) = rhs, lhsTheme === rhsTheme, lhsText == rhsText { - return true - } else { - return false - } case let .admins(lhsTheme, lhsText, lhsValue): if case let .admins(rhsTheme, rhsText, rhsValue) = rhs, lhsTheme === rhsTheme, lhsText == rhsText, lhsValue == rhsValue { return true @@ -323,18 +311,16 @@ private enum ChannelInfoEntry: ItemListNodeEntry { }, action: { }) - case let .channelDescriptionSetupInfo(theme, text): - return ItemListTextItem(theme: theme, text: .plain(text), sectionId: self.section, style: .plain) case let .admins(theme, text, value): - return ItemListDisclosureItem(theme: theme, title: text, label: value, sectionId: self.section, style: .plain, action: { + return ItemListDisclosureItem(theme: theme, icon: PresentationResourcesChat.groupInfoAdminsIcon(theme), title: text, label: value, sectionId: self.section, style: .plain, action: { arguments.openAdmins() }) case let .members(theme, text, value): - return ItemListDisclosureItem(theme: theme, title: text, label: value, sectionId: self.section, style: .plain, action: { + return ItemListDisclosureItem(theme: theme, icon: PresentationResourcesChat.groupInfoMembersIcon(theme), title: text, label: value, sectionId: self.section, style: .plain, action: { arguments.openMembers() }) case let .banned(theme, text, value): - return ItemListDisclosureItem(theme: theme, title: text, label: value, sectionId: self.section, style: .plain, action: { + return ItemListDisclosureItem(theme: theme, icon: PresentationResourcesChat.groupInfoPermissionsIcon(theme), title: text, label: value, sectionId: self.section, style: .plain, action: { arguments.openBanned() }) case let .signMessages(theme, text, value): @@ -437,73 +423,64 @@ private func channelInfoEntries(account: Account, presentationData: Presentation var entries: [ChannelInfoEntry] = [] if let peer = view.peers[view.peerId] as? TelegramChannel { - let canEditChannel = peer.hasAdminRights(.canChangeInfo) - let canEditMembers = peer.hasAdminRights(.canBanUsers) + let canEditChannel = peer.hasPermission(.changeInfo) + let canEditMembers = peer.hasPermission(.banMembers) let infoState = ItemListAvatarAndNameInfoItemState(editingName: canEditChannel ? state.editingState?.editingName : nil, updatingName: nil) entries.append(.info(presentationData.theme, presentationData.strings, presentationData.dateTimeFormat, peer: peer, cachedData: view.cachedData, state: infoState, updatingAvatar: state.updatingAvatar)) - if state.editingState != nil && canEditChannel { + if let editingState = state.editingState, canEditChannel { entries.append(.channelPhotoSetup(theme: presentationData.theme, text: presentationData.strings.Channel_UpdatePhotoItem)) + entries.append(.channelDescriptionSetup(theme: presentationData.theme, placeholder: presentationData.strings.Channel_About_Placeholder, value: editingState.editingDescriptionText)) } - if state.editingState != nil && peer.flags.contains(.isCreator) { + if let _ = state.editingState, peer.flags.contains(.isCreator) { let linkText: String if let username = peer.username { linkText = "@\(username)" } else { linkText = presentationData.strings.Channel_Setup_TypePrivate } - entries.append(.channelTypeSetup(theme: presentationData.theme, text: presentationData.strings.Channel_Edit_LinkItem, value: linkText)) + entries.append(.channelTypeSetup(theme: presentationData.theme, text: presentationData.strings.Channel_TypeSetup_Title, value: linkText)) + let messagesShouldHaveSignatures:Bool + switch peer.info { + case let .broadcast(info): + messagesShouldHaveSignatures = info.flags.contains(.messagesShouldHaveSignatures) + default: + messagesShouldHaveSignatures = false + } - + entries.append(.signMessages(theme: presentationData.theme, text: presentationData.strings.Channel_SignMessages, value: messagesShouldHaveSignatures)) + entries.append(.signInfo(theme: presentationData.theme, text: presentationData.strings.Channel_SignMessages_Help)) } else if let username = peer.username, !username.isEmpty, state.editingState == nil { entries.append(.addressName(theme: presentationData.theme, text: presentationData.strings.Channel_LinkItem, value: username)) } if let cachedChannelData = view.cachedData as? CachedChannelData { - if let editingState = state.editingState, canEditChannel { - entries.append(.channelDescriptionSetup(theme: presentationData.theme, placeholder: presentationData.strings.Channel_Edit_AboutItem, value: editingState.editingDescriptionText)) - entries.append(.channelDescriptionSetupInfo(theme: presentationData.theme, text: presentationData.strings.Channel_About_Help)) - - let messagesShouldHaveSignatures:Bool - switch peer.info { - case let .broadcast(info): - messagesShouldHaveSignatures = info.flags.contains(.messagesShouldHaveSignatures) - default: - messagesShouldHaveSignatures = false - } - - entries.append(.signMessages(theme: presentationData.theme, text: presentationData.strings.Channel_SignMessages, value: messagesShouldHaveSignatures)) - entries.append(.signInfo(theme: presentationData.theme, text: presentationData.strings.Channel_SignMessages_Help)) - + if let _ = state.editingState, canEditChannel { } else { if let about = cachedChannelData.about, !about.isEmpty { entries.append(.about(theme: presentationData.theme, text: presentationData.strings.Channel_AboutItem, value: about)) } } - - } - - if let cachedChannelData = view.cachedData as? CachedChannelData { - if state.editingState == nil && canEditMembers { + if state.editingState != nil && canEditMembers { if peer.adminRights != nil || peer.flags.contains(.isCreator) { let adminCount = cachedChannelData.participantsSummary.adminCount ?? 0 - entries.append(.admins(theme: presentationData.theme, text: presentationData.strings.Channel_Info_Management, value: "\(adminCount == 0 ? "" : "\(adminCount)")")) + entries.append(.admins(theme: presentationData.theme, text: presentationData.strings.GroupInfo_Administrators, value: "\(adminCount == 0 ? "" : "\(adminCount)")")) - let bannedCount = cachedChannelData.participantsSummary.kickedCount ?? 0 - entries.append(.banned(theme: presentationData.theme, text: presentationData.strings.Channel_Info_Banned, value: "\(bannedCount == 0 ? "" : "\(bannedCount)")")) - let memberCount = cachedChannelData.participantsSummary.memberCount ?? 0 entries.append(.members(theme: presentationData.theme, text: presentationData.strings.Channel_Info_Subscribers, value: "\(memberCount == 0 ? "" : "\(memberCount)")")) + + let bannedCount = cachedChannelData.participantsSummary.kickedCount ?? 0 + entries.append(.banned(theme: presentationData.theme, text: presentationData.strings.GroupRemoved_Title, value: "\(bannedCount == 0 ? "" : "\(bannedCount)")")) } } } - if let notificationSettings = view.notificationSettings as? TelegramPeerNotificationSettings { + if state.editingState == nil, let notificationSettings = view.notificationSettings as? TelegramPeerNotificationSettings { let notificationsText: String if case let .muted(until) = notificationSettings.muteState, until >= Int32(CFAbsoluteTimeGetCurrent() + NSTimeIntervalSince1970) { if until < Int32.max - 1 { @@ -516,14 +493,7 @@ private func channelInfoEntries(account: Account, presentationData: Presentation } entries.append(ChannelInfoEntry.notifications(theme: presentationData.theme, text: presentationData.strings.GroupInfo_Notifications, value: notificationsText)) } - if state.editingState != nil { - var messageSound: PeerMessageSound = .default - if let settings = view.notificationSettings as? TelegramPeerNotificationSettings { - messageSound = settings.messageSound - } - - entries.append(ChannelInfoEntry.notificationSound(theme: presentationData.theme, text: presentationData.strings.GroupInfo_Sound, value: localizedPeerNotificationSoundString(strings: presentationData.strings, sound: messageSound, default: globalNotificationSettings.effective.channels.sound))) - } else { + if state.editingState == nil { entries.append(ChannelInfoEntry.sharedMedia(theme: presentationData.theme, text: presentationData.strings.GroupInfo_SharedMedia)) } @@ -581,10 +551,6 @@ public func channelInfoController(account: Account, peerId: PeerId) -> ViewContr let actionsDisposable = DisposableSet() - if peerId.namespace == Namespaces.Peer.CloudChannel { - actionsDisposable.add(account.viewTracker.updatedCachedChannelParticipants(peerId, forceImmediateUpdate: true).start()) - } - let updatePeerNameDisposable = MetaDisposable() actionsDisposable.add(updatePeerNameDisposable) @@ -747,7 +713,7 @@ public func channelInfoController(account: Account, peerId: PeerId) -> ViewContr viewSettings = GlobalNotificationSettingsSet.defaultSettings } - let controller = notificationMuteSettingsController(presentationData: presentationData, notificationSettings: viewSettings.channels, updateSettings: { value in + let controller = notificationMuteSettingsController(presentationData: presentationData, notificationSettings: viewSettings.channels, soundSettings: nil, openSoundSettings: {}, updateSettings: { value in changeMuteSettingsDisposable.set(updatePeerMuteSetting(account: account, peerId: peerId, muteInterval: value).start()) }) presentControllerImpl?(controller, ViewControllerPresentationArguments(presentationAnimation: .modalSheet)) diff --git a/TelegramUI/ChannelMemberCategoryListContext.swift b/TelegramUI/ChannelMemberCategoryListContext.swift index ec0de98429..d69dabec5a 100644 --- a/TelegramUI/ChannelMemberCategoryListContext.swift +++ b/TelegramUI/ChannelMemberCategoryListContext.swift @@ -13,7 +13,7 @@ enum ChannelMemberListLoadingState: Equatable { case ready(hasMore: Bool) } -private extension ChannelParticipant { +extension ChannelParticipant { var adminInfo: ChannelParticipantAdminInfo? { switch self { case .creator: @@ -59,13 +59,15 @@ private protocol ChannelMemberCategoryListContext { var listState: Signal { get } func loadMore() func reset(_ force: Bool) - func replayUpdates(_ updates: [(ChannelParticipant?, RenderedChannelParticipant?)]) + func replayUpdates(_ updates: [(ChannelParticipant?, RenderedChannelParticipant?, Bool?)]) func forceUpdateHead() } -private func isParticipantMember(_ participant: ChannelParticipant) -> Bool { +private func isParticipantMember(_ participant: ChannelParticipant, infoIsMember: Bool?) -> Bool { if let banInfo = participant.banInfo { return !banInfo.rights.flags.contains(.banReadMessages) && banInfo.isMember + } else if let infoIsMember = infoIsMember { + return infoIsMember } else { return true } @@ -268,10 +270,10 @@ private final class ChannelMemberSingleCategoryListContext: ChannelMemberCategor } } - fileprivate func replayUpdates(_ updates: [(ChannelParticipant?, RenderedChannelParticipant?)]) { + fileprivate func replayUpdates(_ updates: [(ChannelParticipant?, RenderedChannelParticipant?, Bool?)]) { var list = self.listStateValue.list var updatedList = false - for (maybePrevious, updated) in updates { + for (maybePrevious, updated, infoIsMember) in updates { var previous: ChannelParticipant? = maybePrevious if let participantId = maybePrevious?.peerId ?? updated?.peer.id { inner: for participant in list { @@ -307,7 +309,7 @@ private final class ChannelMemberSingleCategoryListContext: ChannelMemberCategor } } case .restricted: - if let updated = updated, let banInfo = updated.participant.banInfo, !banInfo.rights.flags.isEmpty && !banInfo.rights.flags.contains(.banReadMessages) { + if let updated = updated, let banInfo = updated.participant.banInfo, !banInfo.rights.flags.contains(.banReadMessages) { var found = false loop: for i in 0 ..< list.count { if list[i].peer.id == updated.peer.id { @@ -321,7 +323,7 @@ private final class ChannelMemberSingleCategoryListContext: ChannelMemberCategor list.insert(updated, at: 0) updatedList = true } - } else if let previous = previous, let banInfo = previous.banInfo, !banInfo.rights.flags.isEmpty && !banInfo.rights.flags.contains(.banReadMessages) { + } else if let previous = previous, let banInfo = previous.banInfo, !banInfo.rights.flags.contains(.banReadMessages) { loop: for i in 0 ..< list.count { if list[i].peer.id == previous.peerId { list.remove(at: i) @@ -355,7 +357,7 @@ private final class ChannelMemberSingleCategoryListContext: ChannelMemberCategor } } case .recent: - if let updated = updated, isParticipantMember(updated.participant) { + if let updated = updated, isParticipantMember(updated.participant, infoIsMember: infoIsMember) { var found = false loop: for i in 0 ..< list.count { if list[i].peer.id == updated.peer.id { @@ -369,7 +371,7 @@ private final class ChannelMemberSingleCategoryListContext: ChannelMemberCategor list.insert(updated, at: 0) updatedList = true } - } else if let previous = previous, isParticipantMember(previous) { + } else if let previous = previous, isParticipantMember(previous, infoIsMember: nil) { loop: for i in 0 ..< list.count { if list[i].peer.id == previous.peerId { list.remove(at: i) @@ -379,7 +381,7 @@ private final class ChannelMemberSingleCategoryListContext: ChannelMemberCategor } } case let .recentSearch(query): - if let updated = updated, isParticipantMember(updated.participant), updated.peer.indexName.matchesByTokens(query) { + if let updated = updated, isParticipantMember(updated.participant, infoIsMember: infoIsMember), updated.peer.indexName.matchesByTokens(query) { var found = false loop: for i in 0 ..< list.count { if list[i].peer.id == updated.peer.id { @@ -393,7 +395,7 @@ private final class ChannelMemberSingleCategoryListContext: ChannelMemberCategor list.insert(updated, at: 0) updatedList = true } - } else if let previous = previous, isParticipantMember(previous) { + } else if let previous = previous, isParticipantMember(previous, infoIsMember: nil) { loop: for i in 0 ..< list.count { if list[i].peer.id == previous.peerId { list.remove(at: i) @@ -493,7 +495,7 @@ private final class ChannelMemberMultiCategoryListContext: ChannelMemberCategory } } - func replayUpdates(_ updates: [(ChannelParticipant?, RenderedChannelParticipant?)]) { + func replayUpdates(_ updates: [(ChannelParticipant?, RenderedChannelParticipant?, Bool?)]) { for context in self.contexts { context.replayUpdates(updates) } @@ -615,6 +617,10 @@ final class PeerChannelMemberCategoriesContext { context = ChannelMemberSingleCategoryListContext(postbox: self.postbox, network: self.network, accountPeerId: self.accountPeerId, peerId: self.peerId, category: mappedCategory) case let .restrictedAndBanned(query): context = ChannelMemberMultiCategoryListContext(postbox: self.postbox, network: self.network, accountPeerId: self.accountPeerId, peerId: self.peerId, categories: [.restricted(query), .banned(query)]) + case let .restricted(query): + context = ChannelMemberSingleCategoryListContext(postbox: self.postbox, network: self.network, accountPeerId: self.accountPeerId, peerId: self.peerId, category: .restricted(query)) + 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 assert(Queue.mainQueue().isCurrent()) @@ -633,7 +639,7 @@ final class PeerChannelMemberCategoriesContext { } } - func replayUpdates(_ updates: [(ChannelParticipant?, RenderedChannelParticipant?)]) { + func replayUpdates(_ updates: [(ChannelParticipant?, RenderedChannelParticipant?, Bool?)]) { for (_, context) in self.contexts { context.context.replayUpdates(updates) } diff --git a/TelegramUI/ChannelMembersController.swift b/TelegramUI/ChannelMembersController.swift index 1d95e6589b..5d5a8942ce 100644 --- a/TelegramUI/ChannelMembersController.swift +++ b/TelegramUI/ChannelMembersController.swift @@ -255,7 +255,7 @@ private func ChannelMembersControllerEntries(account: Account, presentationData: if let participants = participants { var canAddMember: Bool = false if let peer = view.peers[view.peerId] as? TelegramChannel { - canAddMember = peer.hasAdminRights(.canInviteUsers) + canAddMember = peer.hasPermission(.inviteMembers) } if canAddMember { @@ -288,7 +288,7 @@ private func ChannelMembersControllerEntries(account: Account, presentationData: var editable = true var canEditMembers = false if let peer = view.peers[view.peerId] as? TelegramChannel { - canEditMembers = peer.hasAdminRights(.canBanUsers) + canEditMembers = peer.hasPermission(.banMembers) } if participant.peer.id == account.peerId { @@ -387,7 +387,7 @@ public func channelMembersController(account: Account, peerId: PeerId) -> ViewCo return $0.withUpdatedRemovingPeerId(memberId) } - removePeerDisposable.set((account.telegramApplicationContext.peerChannelMemberCategoriesContextsManager.updateMemberBannedRights(account: account, peerId: peerId, memberId: memberId, bannedRights: TelegramChannelBannedRights(flags: [.banReadMessages], untilDate: Int32.max)) + removePeerDisposable.set((account.telegramApplicationContext.peerChannelMemberCategoriesContextsManager.updateMemberBannedRights(account: account, peerId: peerId, memberId: memberId, bannedRights: TelegramChatBannedRights(flags: [.banReadMessages], untilDate: Int32.max)) |> deliverOnMainQueue).start(completed: { updateState { return $0.withUpdatedRemovingPeerId(nil) diff --git a/TelegramUI/ChannelMembersSearchContainerNode.swift b/TelegramUI/ChannelMembersSearchContainerNode.swift index 6150a55a96..eb7080da13 100644 --- a/TelegramUI/ChannelMembersSearchContainerNode.swift +++ b/TelegramUI/ChannelMembersSearchContainerNode.swift @@ -9,6 +9,7 @@ enum ChannelMembersSearchMode { case searchMembers case searchAdmins case searchBanned + case searchKicked case banAndPromoteActions case inviteActions } @@ -16,6 +17,7 @@ enum ChannelMembersSearchMode { private enum ChannelMembersSearchSection { case none case members + case banned case contacts case global @@ -25,6 +27,8 @@ private enum ChannelMembersSearchSection { return nil case .members: return .members + case .banned: + return .exceptions case .contacts: return .contacts case .global: @@ -84,11 +88,15 @@ private final class ChannelMembersSearchEntry: Comparable, Identifiable { let index: Int let content: ChannelMembersSearchContent let section: ChannelMembersSearchSection + let dateTimeFormat: PresentationDateTimeFormat + let addIcon: Bool - init(index: Int, content: ChannelMembersSearchContent, section: ChannelMembersSearchSection) { + init(index: Int, content: ChannelMembersSearchContent, section: ChannelMembersSearchSection, dateTimeFormat: PresentationDateTimeFormat, addIcon: Bool = false) { self.index = index self.content = content self.section = section + self.dateTimeFormat = dateTimeFormat + self.addIcon = addIcon } var stableId: PeerId { @@ -96,7 +104,7 @@ private final class ChannelMembersSearchEntry: Comparable, Identifiable { } static func ==(lhs: ChannelMembersSearchEntry, rhs: ChannelMembersSearchEntry) -> Bool { - return lhs.index == rhs.index && lhs.content == rhs.content && lhs.section == rhs.section + return lhs.index == rhs.index && lhs.content == rhs.content && lhs.section == rhs.section && lhs.addIcon == rhs.addIcon } static func <(lhs: ChannelMembersSearchEntry, rhs: ChannelMembersSearchEntry) -> Bool { @@ -113,6 +121,8 @@ private final class ChannelMembersSearchEntry: Comparable, Identifiable { let status: ContactsPeerItemStatus if let label = label { status = .custom(label) + } else if let presence = participant.presences[participant.peer.id], self.addIcon { + status = .presence(presence, dateTimeFormat) } else { status = .none } @@ -133,7 +143,12 @@ private final class ChannelMembersSearchEntry: Comparable, Identifiable { } })) } - return ContactsPeerItem(theme: theme, strings: strings, sortOrder: nameSortOrder, displayOrder: nameDisplayOrder, account: account, peerMode: .peer, peer: .peer(peer: participant.peer, chatPeer: participant.peer), status: status, enabled: enabled, selection: .none, editing: ContactsPeerItemEditing(editable: false, editing: false, revealed: revealed), options: options, index: nil, header: self.section.chatListHeaderType.flatMap({ ChatListSearchItemHeader(type: $0, theme: theme, strings: strings, actionTitle: nil, action: nil) }), action: { _ in + var actionIcon: ContactsPeerItemActionIcon = .none + if self.addIcon { + actionIcon = .add + } + + return ContactsPeerItem(theme: theme, strings: strings, sortOrder: nameSortOrder, displayOrder: nameDisplayOrder, account: account, peerMode: .peer, peer: .peer(peer: participant.peer, chatPeer: participant.peer), status: status, enabled: enabled, selection: .none, editing: ContactsPeerItemEditing(editable: false, editing: false, revealed: revealed), options: options, actionIcon: actionIcon, index: nil, header: self.section.chatListHeaderType.flatMap({ ChatListSearchItemHeader(type: $0, theme: theme, strings: strings, actionTitle: nil, action: nil) }), action: { _ in interaction.peerSelected(participant.peer, participant) }, setPeerIdWithRevealedOptions: { peerId, fromPeerId in interaction.setPeerIdWithRevealedOptions(peerId, fromPeerId) @@ -182,7 +197,7 @@ final class ChannelMembersSearchContainerNode: SearchDisplayControllerContentNod private let removeMemberDisposable = MetaDisposable() - private let themeAndStringsPromise: Promise<(PresentationTheme, PresentationStrings, PresentationPersonNameOrder, PresentationPersonNameOrder)> + private let themeAndStringsPromise: Promise<(PresentationTheme, PresentationStrings, PresentationPersonNameOrder, PresentationPersonNameOrder, PresentationDateTimeFormat)> init(account: Account, peerId: PeerId, mode: ChannelMembersSearchMode, filters: [ChannelMembersSearchFilter], openPeer: @escaping (Peer, RenderedChannelParticipant?) -> Void, updateActivity: @escaping (Bool) -> Void, present: @escaping (ViewController, Any?) -> Void) { self.account = account @@ -190,7 +205,7 @@ final class ChannelMembersSearchContainerNode: SearchDisplayControllerContentNod self.mode = mode self.presentationData = account.telegramApplicationContext.currentPresentationData.with { $0 } - self.themeAndStringsPromise = Promise((self.presentationData.theme, self.presentationData.strings, self.presentationData.nameSortOrder, self.presentationData.nameDisplayOrder)) + self.themeAndStringsPromise = Promise((self.presentationData.theme, self.presentationData.strings, self.presentationData.nameSortOrder, self.presentationData.nameDisplayOrder, self.presentationData.dateTimeFormat)) self.dimNode = ASDisplayNode() self.dimNode.backgroundColor = UIColor.black.withAlphaComponent(0.5) @@ -245,7 +260,7 @@ final class ChannelMembersSearchContainerNode: SearchDisplayControllerContentNod } if peerId.namespace == Namespaces.Peer.CloudChannel { - return account.telegramApplicationContext.peerChannelMemberCategoriesContextsManager.updateMemberBannedRights(account: account, peerId: peerId, memberId: memberId, bannedRights: TelegramChannelBannedRights(flags: [.banReadMessages], untilDate: Int32.max)) + return account.telegramApplicationContext.peerChannelMemberCategoriesContextsManager.updateMemberBannedRights(account: account, peerId: peerId, memberId: memberId, bannedRights: TelegramChatBannedRights(flags: [.banReadMessages], untilDate: Int32.max)) |> afterDisposed { Queue.mainQueue().async { updateState { state in @@ -313,7 +328,27 @@ final class ChannelMembersSearchContainerNode: SearchDisplayControllerContentNod foundMembers = .single([]) case .searchBanned: foundGroupMembers = Signal { subscriber in - let (disposable, _) = account.telegramApplicationContext.peerChannelMemberCategoriesContextsManager.restrictedAndBanned(postbox: account.postbox, network: account.network, accountPeerId: account.peerId, peerId: peerId, searchQuery: query, updated: { state in + let (disposable, _) = account.telegramApplicationContext.peerChannelMemberCategoriesContextsManager.restricted(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()) + foundMembers = Signal { subscriber in + let (disposable, _) = account.telegramApplicationContext.peerChannelMemberCategoriesContextsManager.recent(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) + } + }) + return disposable + } + |> runOn(Queue.mainQueue()) + case .searchKicked: + foundGroupMembers = Signal { subscriber in + let (disposable, _) = account.telegramApplicationContext.peerChannelMemberCategoriesContextsManager.banned(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() @@ -332,7 +367,7 @@ final class ChannelMembersSearchContainerNode: SearchDisplayControllerContentNod foundContacts = account.postbox.searchContacts(query: query.lowercased()) foundRemotePeers = .single(([], [])) |> then(searchPeers(account: account, query: query) |> delay(0.2, queue: Queue.concurrentDefaultQueue())) - case .searchMembers, .searchBanned, .searchAdmins: + case .searchMembers, .searchBanned, .searchKicked, .searchAdmins: foundContacts = .single(([], [:])) foundRemotePeers = .single(([], [])) } @@ -353,7 +388,7 @@ final class ChannelMembersSearchContainerNode: SearchDisplayControllerContentNod switch mode { case .inviteActions, .banAndPromoteActions: existingPeerIds.insert(account.peerId) - case .searchMembers, .searchAdmins, .searchBanned: + case .searchMembers, .searchAdmins, .searchBanned, .searchKicked: break } @@ -366,7 +401,9 @@ final class ChannelMembersSearchContainerNode: SearchDisplayControllerContentNod switch mode { case .inviteActions, .banAndPromoteActions: section = .members - case .searchMembers, .searchBanned, .searchAdmins: + case .searchBanned: + section = .banned + case .searchMembers, .searchKicked, .searchAdmins: section = .none } @@ -377,12 +414,12 @@ final class ChannelMembersSearchContainerNode: SearchDisplayControllerContentNod canPromote = false canRestrict = false case let .member(_, _, adminRights, bannedRights): - if channel.hasAdminRights([.canAddAdmins]) { + if channel.hasPermission(.addAdmins) { canPromote = true } else { canPromote = false } - if channel.hasAdminRights([.canBanUsers]) { + if channel.hasPermission(.banMembers) { canRestrict = true } else { canRestrict = false @@ -449,10 +486,28 @@ final class ChannelMembersSearchContainerNode: SearchDisplayControllerContentNod } } case .searchBanned: + switch participant.participant { + case let .member(_, _, _, banInfo): + if let banInfo = banInfo { + var exceptionsString = "" + for rights in allGroupPermissionList { + if banInfo.rights.flags.contains(rights) { + if !exceptionsString.isEmpty { + exceptionsString.append(", ") + } + exceptionsString.append(compactStringForGroupPermission(strings: themeAndStrings.1, right: rights)) + } + } + label = exceptionsString + } + default: + break + } + case .searchKicked: switch participant.participant { case let .member(_, _, _, banInfo): if let banInfo = banInfo, let peer = participant.peers[banInfo.restrictedBy] { - label = themeAndStrings.1.Channel_Management_RestrictedBy(peer.displayTitle).0 + label = themeAndStrings.1.Channel_Management_RemovedBy(peer.displayTitle).0 } default: break @@ -460,7 +515,7 @@ final class ChannelMembersSearchContainerNode: SearchDisplayControllerContentNod default: break } - entries.append(ChannelMembersSearchEntry(index: index, content: .participant(participant: participant, label: label, revealActions: peerActions, revealed: state.revealedPeerId == participant.peer.id, enabled: enabled), section: section)) + entries.append(ChannelMembersSearchEntry(index: index, content: .participant(participant: participant, label: label, revealActions: peerActions, revealed: state.revealedPeerId == participant.peer.id, enabled: enabled), section: section, dateTimeFormat: themeAndStrings.4)) index += 1 } } @@ -469,10 +524,14 @@ final class ChannelMembersSearchContainerNode: SearchDisplayControllerContentNod if !existingPeerIds.contains(participant.peer.id) { existingPeerIds.insert(participant.peer.id) let section: ChannelMembersSearchSection + var addIcon = false switch mode { case .inviteActions, .banAndPromoteActions: section = .members - case .searchMembers, .searchBanned, .searchAdmins: + case .searchBanned: + section = .members + addIcon = true + case .searchMembers, .searchKicked, .searchAdmins: section = .none } @@ -485,8 +544,7 @@ final class ChannelMembersSearchContainerNode: SearchDisplayControllerContentNod } } - - entries.append(ChannelMembersSearchEntry(index: index, content: .participant(participant: participant, label: label, revealActions: [], revealed: false, enabled: enabled), section: section)) + entries.append(ChannelMembersSearchEntry(index: index, content: .participant(participant: participant, label: label, revealActions: [], revealed: false, enabled: enabled), section: section, dateTimeFormat: themeAndStrings.4, addIcon: addIcon)) index += 1 } } @@ -494,7 +552,7 @@ final class ChannelMembersSearchContainerNode: SearchDisplayControllerContentNod for peer in foundContacts.0 { if !existingPeerIds.contains(peer.id) { existingPeerIds.insert(peer.id) - entries.append(ChannelMembersSearchEntry(index: index, content: .peer(peer), section: .contacts)) + entries.append(ChannelMembersSearchEntry(index: index, content: .peer(peer), section: .contacts, dateTimeFormat: themeAndStrings.4)) index += 1 } } @@ -503,7 +561,7 @@ final class ChannelMembersSearchContainerNode: SearchDisplayControllerContentNod let peer = foundPeer.peer if !existingPeerIds.contains(peer.id) && peer is TelegramUser { existingPeerIds.insert(peer.id) - entries.append(ChannelMembersSearchEntry(index: index, content: .peer(peer), section: .global)) + entries.append(ChannelMembersSearchEntry(index: index, content: .peer(peer), section: .global, dateTimeFormat: themeAndStrings.4)) index += 1 } } @@ -512,7 +570,7 @@ final class ChannelMembersSearchContainerNode: SearchDisplayControllerContentNod let peer = foundPeer.peer if !existingPeerIds.contains(peer.id) && peer is TelegramUser { existingPeerIds.insert(peer.id) - entries.append(ChannelMembersSearchEntry(index: index, content: .peer(peer), section: .global)) + entries.append(ChannelMembersSearchEntry(index: index, content: .peer(peer), section: .global, dateTimeFormat: themeAndStrings.4)) index += 1 } } diff --git a/TelegramUI/ChannelMembersSearchController.swift b/TelegramUI/ChannelMembersSearchController.swift index 8c81ddea88..a51bc2ea95 100644 --- a/TelegramUI/ChannelMembersSearchController.swift +++ b/TelegramUI/ChannelMembersSearchController.swift @@ -67,7 +67,6 @@ final class ChannelMembersSearchController: ViewController { self?.deactivateSearch(animated: true) } self.controllerNode.requestOpenPeerFromSearch = { [weak self] peer, participant in - self?.dismiss() self?.openPeer(peer, participant) } self.controllerNode.present = { [weak self] c, a in diff --git a/TelegramUI/ChannelPermissionsController.swift b/TelegramUI/ChannelPermissionsController.swift new file mode 100644 index 0000000000..f310948bb0 --- /dev/null +++ b/TelegramUI/ChannelPermissionsController.swift @@ -0,0 +1,565 @@ +import Foundation +import Display +import SwiftSignalKit +import Postbox +import TelegramCore + +private final class ChannelPermissionsControllerArguments { + let account: Account + + let updatePermission: (TelegramChatBannedRightsFlags, Bool) -> Void + let setPeerIdWithRevealedOptions: (PeerId?, PeerId?) -> Void + let addPeer: () -> Void + let removePeer: (PeerId) -> Void + let openPeer: (ChannelParticipant) -> Void + let openPeerInfo: (Peer) -> Void + let openKicked: () -> 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) { + self.account = account + self.updatePermission = updatePermission + self.addPeer = addPeer + self.setPeerIdWithRevealedOptions = setPeerIdWithRevealedOptions + self.removePeer = removePeer + self.openPeer = openPeer + self.openPeerInfo = openPeerInfo + self.openKicked = openKicked + } +} + +private enum ChannelPermissionsSection: Int32 { + case permissions + case kicked + case exceptions +} + +private enum ChannelPermissionsEntryStableId: Hashable { + case index(Int) + case peer(PeerId) +} + +private enum ChannelPermissionsEntry: ItemListNodeEntry { + case permissionsHeader(PresentationTheme, String) + case permission(PresentationTheme, Int, String, Bool, TelegramChatBannedRightsFlags) + case kicked(PresentationTheme, String, String) + case exceptionsHeader(PresentationTheme, String) + case add(PresentationTheme, String) + case peerItem(PresentationTheme, PresentationStrings, PresentationDateTimeFormat, PresentationPersonNameOrder, Int32, RenderedChannelParticipant, ItemListPeerItemEditing, Bool, Bool) + + var section: ItemListSectionId { + switch self { + case .permissionsHeader, .permission: + return ChannelPermissionsSection.permissions.rawValue + case .kicked: + return ChannelPermissionsSection.kicked.rawValue + case .exceptionsHeader, .add, .peerItem: + return ChannelPermissionsSection.exceptions.rawValue + } + } + + var stableId: ChannelPermissionsEntryStableId { + switch self { + case .permissionsHeader: + return .index(0) + case let .permission(_, index, _, _, _): + return .index(1 + index) + case .kicked: + return .index(1000) + case .exceptionsHeader: + return .index(1001) + case .add: + return .index(1002) + case let .peerItem(_, _, _, _, _, participant, _, _, _): + return .peer(participant.peer.id) + } + } + + static func ==(lhs: ChannelPermissionsEntry, rhs: ChannelPermissionsEntry) -> Bool { + switch lhs { + case let .permissionsHeader(lhsTheme, lhsText): + if case let .permissionsHeader(rhsTheme, rhsText) = rhs, lhsTheme === rhsTheme, lhsText == rhsText { + return true + } else { + return false + } + case let .permission(theme, index, title, value, rights): + if case .permission(theme, index, title, value, rights) = rhs { + return true + } else { + return false + } + case let .kicked(lhsTheme, lhsText, lhsValue): + if case let .kicked(rhsTheme, rhsText, rhsValue) = rhs, lhsTheme === rhsTheme, lhsText == rhsText, lhsValue == rhsValue { + return true + } else { + return false + } + case let .exceptionsHeader(lhsTheme, lhsText): + if case let .exceptionsHeader(rhsTheme, rhsText) = rhs, lhsTheme === rhsTheme, lhsText == rhsText { + return true + } else { + return false + } + case let .add(lhsTheme, lhsText): + if case let .add(rhsTheme, rhsText) = rhs, lhsTheme === rhsTheme, lhsText == rhsText { + return true + } else { + return false + } + case let .peerItem(lhsTheme, lhsStrings, lhsDateTimeFormat, lhsNameOrder, lhsIndex, lhsParticipant, lhsEditing, lhsEnabled, lhsCanOpen): + if case let .peerItem(rhsTheme, rhsStrings, rhsDateTimeFormat, rhsNameOrder, rhsIndex, rhsParticipant, rhsEditing, rhsEnabled, rhsCanOpen) = rhs { + if lhsTheme !== rhsTheme { + return false + } + if lhsStrings !== rhsStrings { + return false + } + if lhsDateTimeFormat != rhsDateTimeFormat { + return false + } + if lhsNameOrder != rhsNameOrder { + return false + } + if lhsIndex != rhsIndex { + return false + } + if lhsParticipant != rhsParticipant { + return false + } + if lhsEditing != rhsEditing { + return false + } + if lhsEnabled != rhsEnabled { + return false + } + if lhsCanOpen != rhsCanOpen { + return false + } + return true + } else { + return false + } + } + } + + static func <(lhs: ChannelPermissionsEntry, rhs: ChannelPermissionsEntry) -> Bool { + switch lhs { + case let .peerItem(_, _, _, _, index, _, _, _, _): + switch rhs { + case let .peerItem(_, _, _, _, rhsIndex, _, _, _, _): + return index < rhsIndex + default: + return false + } + default: + if case let .index(lhsIndex) = lhs.stableId { + if case let .index(rhsIndex) = rhs.stableId { + return lhsIndex < rhsIndex + } else { + return true + } + } else { + assertionFailure() + return false + } + } + } + + func item(_ arguments: ChannelPermissionsControllerArguments) -> ListViewItem { + switch self { + case let .permissionsHeader(theme, text): + return ItemListSectionHeaderItem(theme: theme, text: text, sectionId: self.section) + case let .permission(theme, _, title, value, rights): + return ItemListSwitchItem(theme: theme, title: title, value: value, type: .icon, sectionId: self.section, style: .blocks, updated: { value in + arguments.updatePermission(rights, value) + }) + case let .kicked(theme, text, value): + return ItemListDisclosureItem(theme: theme, title: text, label: value, sectionId: self.section, style: .blocks, action: { + arguments.openKicked() + }) + case let .exceptionsHeader(theme, text): + return ItemListSectionHeaderItem(theme: theme, text: text, sectionId: self.section) + case let .add(theme, text): + return ItemListPeerActionItem(theme: theme, icon: PresentationResourcesItemList.addPersonIcon(theme), title: text, sectionId: self.section, editing: false, action: { + arguments.addPeer() + }) + case let .peerItem(theme, strings, dateTimeFormat, nameDisplayOrder, _, participant, editing, enabled, canOpen): + var text: ItemListPeerItemText = .none + switch participant.participant { + case let .member(_, _, _, banInfo): + var exceptionsString = "" + if let banInfo = banInfo { + for rights in allGroupPermissionList { + if banInfo.rights.flags.contains(rights) { + if !exceptionsString.isEmpty { + exceptionsString.append(", ") + } + exceptionsString.append(compactStringForGroupPermission(strings: strings, right: rights)) + } + } + text = .text(exceptionsString) + } + default: + break + } + return ItemListPeerItem(theme: theme, strings: strings, dateTimeFormat: dateTimeFormat, nameDisplayOrder: nameDisplayOrder, account: arguments.account, peer: participant.peer, presence: nil, text: text, label: .none, editing: editing, switchValue: nil, enabled: enabled, sectionId: self.section, action: canOpen ? { + arguments.openPeer(participant.participant) + } : { + arguments.openPeerInfo(participant.peer) + }, setPeerIdWithRevealedOptions: { previousId, id in + arguments.setPeerIdWithRevealedOptions(previousId, id) + }, removePeer: { peerId in + arguments.removePeer(peerId) + }) + } + } +} + +private struct ChannelPermissionsControllerState: Equatable { + var peerIdWithRevealedOptions: PeerId? + var removingPeerId: PeerId? + var searchingMembers: Bool = false + var modifiedRightsFlags: TelegramChatBannedRightsFlags? +} + +func stringForGroupPermission(strings: PresentationStrings, right: TelegramChatBannedRightsFlags) -> String { + if right.contains(.banSendMessages) { + return strings.Channel_BanUser_PermissionSendMessages + } else if right.contains(.banSendMedia) { + return strings.Channel_BanUser_PermissionSendMedia + } else if right.contains(.banSendGifs) { + return strings.Channel_BanUser_PermissionSendStickersAndGifs + } else if right.contains(.banEmbedLinks) { + return strings.Channel_BanUser_PermissionEmbedLinks + } else if right.contains(.banSendPolls) { + return strings.Channel_BanUser_PermissionSendPolls + } else if right.contains(.banChangeInfo) { + return strings.Channel_BanUser_PermissionChangeGroupInfo + } else if right.contains(.banAddMembers) { + return strings.Channel_BanUser_PermissionAddMembers + } else if right.contains(.banPinMessages) { + return strings.Channel_EditAdmin_PermissionPinMessages + } else { + return "" + } +} + +func compactStringForGroupPermission(strings: PresentationStrings, right: TelegramChatBannedRightsFlags) -> String { + if right.contains(.banSendMessages) { + return strings.GroupPermission_NoSendMessages + } else if right.contains(.banSendMedia) { + return strings.GroupPermission_NoSendMedia + } else if right.contains(.banSendGifs) { + return strings.GroupPermission_NoSendGifs + } else if right.contains(.banEmbedLinks) { + return strings.GroupPermission_NoSendLinks + } else if right.contains(.banSendPolls) { + return strings.GroupPermission_NoSendPolls + } else if right.contains(.banChangeInfo) { + return strings.GroupPermission_NoChangeInfo + } else if right.contains(.banAddMembers) { + return strings.GroupPermission_NoAddMembers + } else if right.contains(.banPinMessages) { + return strings.GroupPermission_NoPinMessages + } else { + return "" + } +} + +let allGroupPermissionList: [TelegramChatBannedRightsFlags] = [ + .banSendMessages, + .banSendMedia, + .banSendGifs, + .banEmbedLinks, + .banSendPolls, + .banAddMembers, + .banPinMessages, + .banChangeInfo +] + +func groupPermissionDependencies(_ right: TelegramChatBannedRightsFlags) -> TelegramChatBannedRightsFlags { + if right.contains(.banSendMedia) { + return [.banSendMessages] + } else if right.contains(.banSendGifs) { + return [.banSendMessages] + } else if right.contains(.banEmbedLinks) { + return [.banSendMessages] + } else if right.contains(.banSendPolls) { + return [.banSendMessages] + } else if right.contains(.banChangeInfo) { + return [] + } else if right.contains(.banAddMembers) { + return [] + } else if right.contains(.banPinMessages) { + return [] + } else { + return [] + } +} + +private func completeRights(_ flags: TelegramChatBannedRightsFlags) -> TelegramChatBannedRightsFlags { + var result = flags + result.remove(.banReadMessages) + if result.contains(.banSendGifs) { + result.insert(.banSendStickers) + result.insert(.banSendGifs) + result.insert(.banSendGames) + } else { + result.remove(.banSendStickers) + result.remove(.banSendGifs) + result.remove(.banSendGames) + } + if result.contains(.banEmbedLinks) { + result.insert(.banSendInline) + } else { + result.remove(.banSendInline) + } + return result +} + +private func channelPermissionsControllerEntries(presentationData: PresentationData, view: PeerView, state: ChannelPermissionsControllerState, participants: [RenderedChannelParticipant]?) -> [ChannelPermissionsEntry] { + var entries: [ChannelPermissionsEntry] = [] + + if let _ = view.peers[view.peerId] as? TelegramChannel, let participants = participants { + let cachedData = view.cachedData as? CachedChannelData + + let effectiveRightsFlags: TelegramChatBannedRightsFlags + if let modifiedRightsFlags = state.modifiedRightsFlags { + effectiveRightsFlags = modifiedRightsFlags + } else if let defaultBannedRightsFlags = cachedData?.defaultBannedRights?.flags { + effectiveRightsFlags = defaultBannedRightsFlags + } else { + effectiveRightsFlags = TelegramChatBannedRightsFlags() + } + + entries.append(.permissionsHeader(presentationData.theme, presentationData.strings.GroupInfo_Permissions_SectionTitle)) + var rightIndex: Int = 0 + for rights in allGroupPermissionList { + entries.append(.permission(presentationData.theme, rightIndex, stringForGroupPermission(strings: presentationData.strings, right: rights), !effectiveRightsFlags.contains(rights), rights)) + rightIndex += 1 + } + + entries.append(.kicked(presentationData.theme, presentationData.strings.GroupInfo_Permissions_Removed, cachedData?.participantsSummary.kickedCount.flatMap({ "\($0)" }) ?? "")) + entries.append(.exceptionsHeader(presentationData.theme, presentationData.strings.GroupInfo_Permissions_Exceptions)) + entries.append(.add(presentationData.theme, presentationData.strings.GroupInfo_Permissions_AddException)) + + var index: Int32 = 0 + for participant in participants { + 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)) + index += 1 + } + } + + return entries +} + +public func channelPermissionsController(account: Account, peerId: PeerId) -> ViewController { + let statePromise = ValuePromise(ChannelPermissionsControllerState(), ignoreRepeated: true) + let stateValue = Atomic(value: ChannelPermissionsControllerState()) + let updateState: ((ChannelPermissionsControllerState) -> ChannelPermissionsControllerState) -> Void = { f in + statePromise.set(stateValue.modify { f($0) }) + } + + var presentControllerImpl: ((ViewController, Any?) -> Void)? + var pushControllerImpl: ((ViewController) -> Void)? + + let actionsDisposable = DisposableSet() + + let updateBannedDisposable = MetaDisposable() + actionsDisposable.add(updateBannedDisposable) + + let removePeerDisposable = MetaDisposable() + actionsDisposable.add(removePeerDisposable) + + let peersPromise = Promise<[RenderedChannelParticipant]?>(nil) + let (disposable, loadMoreControl) = account.telegramApplicationContext.peerChannelMemberCategoriesContextsManager.restricted(postbox: account.postbox, network: account.network, accountPeerId: account.peerId, peerId: peerId, updated: { state in + peersPromise.set(.single(state.list)) + }) + actionsDisposable.add(disposable) + + let updateDefaultRightsDisposable = MetaDisposable() + actionsDisposable.add(updateDefaultRightsDisposable) + + let peerView = Promise() + peerView.set(account.viewTracker.peerView(peerId)) + + let arguments = ChannelPermissionsControllerArguments(account: account, updatePermission: { rights, value in + let _ = (peerView.get() + |> take(1) + |> deliverOnMainQueue).start(next: { view in + if let cachedData = view.cachedData as? CachedChannelData { + updateState { state in + var state = state + var effectiveRightsFlags: TelegramChatBannedRightsFlags + if let modifiedRightsFlags = state.modifiedRightsFlags { + effectiveRightsFlags = modifiedRightsFlags + } else if let defaultBannedRightsFlags = cachedData.defaultBannedRights?.flags { + effectiveRightsFlags = defaultBannedRightsFlags + } else { + effectiveRightsFlags = TelegramChatBannedRightsFlags() + } + if value { + effectiveRightsFlags.remove(rights) + effectiveRightsFlags = effectiveRightsFlags.subtracting(groupPermissionDependencies(rights)) + } else { + effectiveRightsFlags.insert(rights) + for right in allGroupPermissionList { + if groupPermissionDependencies(right).contains(rights) { + effectiveRightsFlags.insert(right) + } + } + } + state.modifiedRightsFlags = effectiveRightsFlags + return state + } + let state = stateValue.with { $0 } + if let modifiedRightsFlags = state.modifiedRightsFlags { + updateDefaultRightsDisposable.set((updateDefaultChannelMemberBannedRights(account: account, peerId: peerId, rights: TelegramChatBannedRights(flags: completeRights(modifiedRightsFlags), untilDate: Int32.max)) + |> deliverOnMainQueue).start()) + } + } + }) + }, setPeerIdWithRevealedOptions: { peerId, fromPeerId in + updateState { state in + var state = state + if (peerId == nil && fromPeerId == state.peerIdWithRevealedOptions) || (peerId != nil && fromPeerId == nil) { + state.peerIdWithRevealedOptions = peerId + } + return state + } + }, addPeer: { + var dismissController: (() -> Void)? + let controller = ChannelMembersSearchController(account: account, peerId: peerId, mode: .ban, openPeer: { peer, participant in + if let participant = participant { + let presentationData = account.telegramApplicationContext.currentPresentationData.with { $0 } + switch participant.participant { + case .creator: + return + case let .member(_, _, adminInfo, _): + if let adminInfo = adminInfo, adminInfo.promotedBy != account.peerId { + presentControllerImpl?(standardTextAlertController(theme: AlertControllerTheme(presentationTheme: presentationData.theme), title: nil, text: presentationData.strings.Channel_Members_AddBannedErrorAdmin, actions: [TextAlertAction(type: .defaultAction, title: presentationData.strings.Common_OK, action: {})]), nil) + return + } + } + } + let _ = (account.postbox.loadedPeerWithId(peerId) + |> deliverOnMainQueue).start(next: { channel in + dismissController?() + guard let _ = channel as? TelegramChannel else { + return + } + presentControllerImpl?(channelBannedMemberController(account: account, peerId: peerId, memberId: peer.id, initialParticipant: participant?.participant, updated: { _ in + }), ViewControllerPresentationArguments(presentationAnimation: .modalSheet)) + }) + }) + dismissController = { [weak controller] in + controller?.dismiss() + } + presentControllerImpl?(controller, ViewControllerPresentationArguments(presentationAnimation: .modalSheet)) + }, removePeer: { memberId in + updateState { state in + var state = state + state.removingPeerId = memberId + return state + } + + removePeerDisposable.set((account.telegramApplicationContext.peerChannelMemberCategoriesContextsManager.updateMemberBannedRights(account: account, peerId: peerId, memberId: memberId, bannedRights: nil) + |> deliverOnMainQueue).start(error: { _ in + updateState { state in + var state = state + state.removingPeerId = nil + return state + } + }, completed: { + updateState { state in + var state = state + state.removingPeerId = nil + return state + } + })) + }, openPeer: { participant in + presentControllerImpl?(channelBannedMemberController(account: account, peerId: peerId, memberId: participant.peerId, initialParticipant: participant, updated: { _ in + }), ViewControllerPresentationArguments(presentationAnimation: .modalSheet)) + }, openPeerInfo: { peer in + if let controller = peerInfoController(account: account, peer: peer) { + pushControllerImpl?(controller) + } + }, openKicked: { + pushControllerImpl?(channelBlacklistController(account: account, peerId: peerId)) + }) + + let previousParticipants = Atomic<[RenderedChannelParticipant]?>(value: nil) + + let signal = combineLatest(queue: .mainQueue(), (account.applicationContext as! TelegramApplicationContext).presentationData, statePromise.get(), peerView.get(), peersPromise.get()) + |> deliverOnMainQueue + |> map { presentationData, state, view, participants -> (ItemListControllerState, (ItemListNodeState, ChannelPermissionsEntry.ItemGenerationArguments)) in + var rightNavigationButton: ItemListNavigationButton? + if let participants = participants, !participants.isEmpty { + rightNavigationButton = ItemListNavigationButton(content: .icon(.search), style: .bold, enabled: true, action: { + updateState { state in + var state = state + state.searchingMembers = true + return state + } + }) + } + + var emptyStateItem: ItemListControllerEmptyStateItem? + if participants == nil { + emptyStateItem = ItemListLoadingIndicatorEmptyStateItem(theme: presentationData.theme) + } + + let previous = previousParticipants.swap(participants) + + var searchItem: ItemListControllerSearch? + if state.searchingMembers { + searchItem = ChannelMembersSearchItem(account: account, peerId: peerId, searchMode: .searchBanned, cancel: { + updateState { state in + var state = state + state.searchingMembers = false + return state + } + }, openPeer: { _, rendered in + if let participant = rendered?.participant, case .member = participant, let _ = peerViewMainPeer(view) as? TelegramChannel { + updateState { state in + var state = state + state.searchingMembers = false + return state + } + presentControllerImpl?(channelBannedMemberController(account: account, peerId: peerId, memberId: participant.peerId, initialParticipant: participant, updated: { _ in + }), ViewControllerPresentationArguments(presentationAnimation: .modalSheet)) + } + }, present: { c, a in + presentControllerImpl?(c, a) + }) + } + + let controllerState = ItemListControllerState(theme: presentationData.theme, title: .text(presentationData.strings.GroupInfo_Permissions_Title), leftNavigationButton: nil, rightNavigationButton: rightNavigationButton, backNavigationButton: ItemListBackButton(title: presentationData.strings.Common_Back), animateChanges: true) + let listState = ItemListNodeState(entries: channelPermissionsControllerEntries(presentationData: presentationData, view: view, state: state, participants: participants), style: .blocks, emptyStateItem: emptyStateItem, searchItem: searchItem, animateChanges: previous != nil && participants != nil && previous!.count >= participants!.count) + + return (controllerState, (listState, arguments)) + } + |> afterDisposed { + actionsDisposable.dispose() + } + + let controller = ItemListController(account: account, state: signal) + presentControllerImpl = { [weak controller] c, p in + if let controller = controller { + controller.present(c, in: .window(.root), with: p) + controller.view.endEditing(true) + } + } + + pushControllerImpl = { [weak controller] c in + if let controller = controller { + (controller.navigationController as? NavigationController)?.pushViewController(c) + } + } + controller.visibleBottomContentOffsetChanged = { offset in + if case let .known(value) = offset, value < 40.0 { + account.telegramApplicationContext.peerChannelMemberCategoriesContextsManager.loadMore(peerId: peerId, control: loadMoreControl) + } + } + return controller +} diff --git a/TelegramUI/ChatController.swift b/TelegramUI/ChatController.swift index 3b189e3da0..b83a9e38d5 100644 --- a/TelegramUI/ChatController.swift +++ b/TelegramUI/ChatController.swift @@ -2659,11 +2659,7 @@ public final class ChatController: TelegramController, KeyShortcutResponder, Gal if let peer = strongSelf.presentationInterfaceState.renderedPeer?.peer { var canManagePin = false if let channel = peer as? TelegramChannel { - if case .broadcast = channel.info { - canManagePin = channel.hasAdminRights([.canEditMessages]) - } else { - canManagePin = channel.hasAdminRights([.canPinMessages]) - } + canManagePin = channel.hasPermission(.pinMessages) } else if let group = peer as? TelegramGroup { if group.flags.contains(.adminsEnabled) { switch group.role { @@ -2723,11 +2719,7 @@ public final class ChatController: TelegramController, KeyShortcutResponder, Gal if let peer = strongSelf.presentationInterfaceState.renderedPeer?.peer { var canManagePin = false if let channel = peer as? TelegramChannel { - if case .broadcast = channel.info { - canManagePin = channel.hasAdminRights([.canEditMessages]) - } else { - canManagePin = channel.hasAdminRights([.canPinMessages]) - } + canManagePin = channel.hasPermission(.pinMessages) } else if let group = peer as? TelegramGroup { if group.flags.contains(.adminsEnabled) { switch group.role { @@ -3289,7 +3281,6 @@ public final class ChatController: TelegramController, KeyShortcutResponder, Gal super.containerLayoutUpdated(layout, transition: transition) self.validLayout = layout - self.chatTitleView?.layout = layout self.chatDisplayNode.containerLayoutUpdated(layout, navigationBarHeight: self.navigationHeight, transition: transition, listViewTransaction: { updateSizeAndInsets, additionalScrollDistance, scrollToTop in diff --git a/TelegramUI/ChatEmptyNode.swift b/TelegramUI/ChatEmptyNode.swift index c7afe8620f..81cbf8777e 100644 --- a/TelegramUI/ChatEmptyNode.swift +++ b/TelegramUI/ChatEmptyNode.swift @@ -181,6 +181,121 @@ private final class ChatEmptyNodeSecretChatContent: ASDisplayNode, ChatEmptyNode } } +private final class ChatEmptyNodeGroupChatContent: ASDisplayNode, ChatEmptyNodeContent { + private let titleNode: ImmediateTextNode + private let subtitleNode: ImmediateTextNode + private var lineNodes: [(ASImageNode, ImmediateTextNode)] = [] + + private var currentTheme: PresentationTheme? + private var currentStrings: PresentationStrings? + + override init() { + self.titleNode = ImmediateTextNode() + self.titleNode.maximumNumberOfLines = 0 + self.titleNode.lineSpacing = 0.25 + self.titleNode.textAlignment = .center + self.titleNode.isUserInteractionEnabled = false + self.titleNode.displaysAsynchronously = false + + self.subtitleNode = ImmediateTextNode() + self.subtitleNode.maximumNumberOfLines = 0 + self.subtitleNode.lineSpacing = 0.25 + self.subtitleNode.isUserInteractionEnabled = false + self.subtitleNode.displaysAsynchronously = false + + super.init() + + self.addSubnode(self.titleNode) + self.addSubnode(self.subtitleNode) + } + + func updateLayout(interfaceState: ChatPresentationInterfaceState, size: CGSize, transition: ContainedViewLayoutTransition) -> CGSize { + if self.currentTheme !== interfaceState.theme || self.currentStrings !== interfaceState.strings { + self.currentTheme = interfaceState.theme + self.currentStrings = interfaceState.strings + + let titleString: String = interfaceState.strings.EmptyGroupInfo_Title + + let serviceColor = serviceMessageColorComponents(theme: interfaceState.theme, wallpaper: interfaceState.chatWallpaper) + + self.titleNode.attributedText = NSAttributedString(string: titleString, font: titleFont, textColor: serviceColor.primaryText) + + self.subtitleNode.attributedText = NSAttributedString(string: interfaceState.strings.EmptyGroupInfo_Subtitle, font: messageFont, textColor: serviceColor.primaryText) + + let strings: [String] = [ + interfaceState.strings.EmptyGroupInfo_Line1("100,000").0, + interfaceState.strings.EmptyGroupInfo_Line2, + interfaceState.strings.EmptyGroupInfo_Line3, + interfaceState.strings.EmptyGroupInfo_Line4 + ] + + let lines: [NSAttributedString] = strings.map { NSAttributedString(string: $0, font: messageFont, textColor: serviceColor.primaryText) } + + let lockIcon = PresentationResourcesChat.chatEmptyItemLockIcon(interfaceState.theme) + + for i in 0 ..< lines.count { + if i >= self.lineNodes.count { + let iconNode = ASImageNode() + iconNode.isLayerBacked = true + iconNode.displaysAsynchronously = false + iconNode.displayWithoutProcessing = true + let textNode = ImmediateTextNode() + textNode.maximumNumberOfLines = 0 + textNode.isUserInteractionEnabled = false + textNode.displaysAsynchronously = false + self.addSubnode(iconNode) + self.addSubnode(textNode) + self.lineNodes.append((iconNode, textNode)) + } + + self.lineNodes[i].0.image = lockIcon + self.lineNodes[i].1.attributedText = lines[i] + } + } + + let insets = UIEdgeInsets(top: 15.0, left: 15.0, bottom: 15.0, right: 15.0) + let titleSpacing: CGFloat = 5.0 + let subtitleSpacing: CGFloat = 10.0 + let iconInset: CGFloat = 14.0 + + var contentWidth: CGFloat = 100.0 + var contentHeight: CGFloat = 0.0 + + var lineNodes: [(CGSize, ASImageNode, ImmediateTextNode)] = [] + for (iconNode, textNode) in self.lineNodes { + let textSize = textNode.updateLayout(CGSize(width: size.width - insets.left - insets.right - 10.0, height: CGFloat.greatestFiniteMagnitude)) + contentWidth = max(contentWidth, iconInset + textSize.width) + contentHeight += textSize.height + subtitleSpacing + lineNodes.append((textSize, iconNode, textNode)) + } + + let titleSize = self.titleNode.updateLayout(CGSize(width: contentWidth, height: CGFloat.greatestFiniteMagnitude)) + let subtitleSize = self.subtitleNode.updateLayout(CGSize(width: contentWidth, height: CGFloat.greatestFiniteMagnitude)) + + contentWidth = max(contentWidth, max(titleSize.width, subtitleSize.width)) + + contentHeight += titleSize.height + titleSpacing + subtitleSize.height + + let contentRect = CGRect(origin: CGPoint(x: insets.left, y: insets.top), size: CGSize(width: contentWidth, height: contentHeight)) + + let titleFrame = CGRect(origin: CGPoint(x: contentRect.minX + floor((contentRect.width - titleSize.width) / 2.0), y: contentRect.minY), size: titleSize) + transition.updateFrame(node: self.titleNode, frame: titleFrame) + let subtitleFrame = CGRect(origin: CGPoint(x: contentRect.minX, y: titleFrame.maxY + titleSpacing), size: subtitleSize) + transition.updateFrame(node: self.subtitleNode, frame: subtitleFrame) + + var lineOffset = subtitleFrame.maxY + subtitleSpacing / 2.0 + for (textSize, iconNode, textNode) in lineNodes { + if let image = iconNode.image { + transition.updateFrame(node: iconNode, frame: CGRect(origin: CGPoint(x: contentRect.minX, y: lineOffset + 1.0), size: image.size)) + } + transition.updateFrame(node: textNode, frame: CGRect(origin: CGPoint(x: contentRect.minX + iconInset, y: lineOffset), size: textSize)) + lineOffset += textSize.height + subtitleSpacing + } + + return contentRect.insetBy(dx: -insets.left, dy: -insets.top).size + } +} + private final class ChatEmptyNodeCloudChatContent: ASDisplayNode, ChatEmptyNodeContent { private let iconNode: ASImageNode private let titleNode: ImmediateTextNode @@ -296,6 +411,7 @@ private final class ChatEmptyNodeCloudChatContent: ASDisplayNode, ChatEmptyNodeC private enum ChatEmptyNodeContentType { case regular case secret + case group case cloud } @@ -339,6 +455,8 @@ final class ChatEmptyNode: ASDisplayNode { contentType = .cloud } else if let _ = peer as? TelegramSecretChat { contentType = .secret + } else if let group = peer as? TelegramGroup, case .creator = group.role { + contentType = .group } else { contentType = .regular } @@ -357,6 +475,8 @@ final class ChatEmptyNode: ASDisplayNode { node = ChatEmptyNodeRegularChatContent() case .secret: node = ChatEmptyNodeSecretChatContent() + case .group: + node = ChatEmptyNodeGroupChatContent() case .cloud: node = ChatEmptyNodeCloudChatContent() } diff --git a/TelegramUI/ChatHistoryEntriesForView.swift b/TelegramUI/ChatHistoryEntriesForView.swift index edf855367e..fdfc4c1449 100644 --- a/TelegramUI/ChatHistoryEntriesForView.swift +++ b/TelegramUI/ChatHistoryEntriesForView.swift @@ -99,6 +99,11 @@ func chatHistoryEntriesForView(location: ChatLocation, view: MessageHistoryView, if let cachedPeerData = cachedPeerData as? CachedUserData, let botInfo = cachedPeerData.botInfo, !botInfo.description.isEmpty { entries.insert(.ChatInfoEntry(botInfo.description, presentationData), at: 0) } + if case let .MessageEntry(entry) = view.entries[0] { + if let peer = entry.0.peers[entry.0.id.peerId] as? TelegramGroup, case .creator = peer.role { + entries.remove(at: 0) + } + } } } else if includeSearchEntry { if view.laterId == nil { diff --git a/TelegramUI/ChatInterfaceStateContextMenus.swift b/TelegramUI/ChatInterfaceStateContextMenus.swift index b2606cfc68..6cb6443a2d 100644 --- a/TelegramUI/ChatInterfaceStateContextMenus.swift +++ b/TelegramUI/ChatInterfaceStateContextMenus.swift @@ -29,12 +29,7 @@ func canReplyInChat(_ chatPresentationInterfaceState: ChatPresentationInterfaceS case .peer: if let channel = peer as? TelegramChannel { if case .member = channel.participationStatus { - switch channel.info { - case .broadcast: - canReply = channel.hasAdminRights([.canPostMessages]) - case .group: - canReply = !channel.hasBannedRights(.banSendMessages) - } + canReply = channel.hasPermission(.sendMessages) } } else if let group = peer as? TelegramGroup { if case .Member = group.membership { @@ -187,11 +182,16 @@ func contextMenuForChatPresentationIntefaceState(chatPresentationInterfaceState: if let channel = message.peers[message.id.peerId] as? TelegramChannel { if case .broadcast = channel.info { if !message.flags.contains(.Incoming) { - canDeleteMessage = channel.hasAdminRights(.canPostMessages) + canDeleteMessage = channel.hasPermission(.sendMessages) + } + if channel.hasPermission(.deleteAllMessages) { + canDeleteMessage = true + } + } else { + if channel.hasPermission(.deleteAllMessages) || !message.flags.contains(.Incoming) { + canDeleteMessage = true } - canDeleteMessage = channel.hasAdminRights(.canDeleteMessages) } - canDeleteMessage = channel.hasAdminRights(.canDeleteMessages) || !message.flags.contains(.Incoming) } else if message.peers[message.id.peerId] is TelegramSecretChat { canDeleteMessage = true } else { @@ -202,15 +202,8 @@ func contextMenuForChatPresentationIntefaceState(chatPresentationInterfaceState: switch chatPresentationInterfaceState.chatLocation { case .peer: if let channel = messages[0].peers[messages[0].id.peerId] as? TelegramChannel { - switch channel.info { - case .broadcast: - if !isAction { - canPin = channel.hasAdminRights([.canEditMessages]) - } - case .group: - if !isAction { - canPin = channel.hasAdminRights([.canPinMessages]) - } + if !isAction { + canPin = channel.hasPermission(.pinMessages) } } else if let group = messages[0].peers[messages[0].id.peerId] as? TelegramGroup { if !isAction { @@ -257,8 +250,8 @@ func contextMenuForChatPresentationIntefaceState(chatPresentationInterfaceState: var loadResourceStatusSignal: Signal = .single(nil) if let loadCopyMediaResource = loadCopyMediaResource { loadResourceStatusSignal = account.postbox.mediaBox.resourceStatus(loadCopyMediaResource) - |> take(1) - |> map(Optional.init) + |> take(1) + |> map(Optional.init) } let loadLimits = account.postbox.transaction { transaction -> LimitsConfiguration in @@ -278,7 +271,7 @@ func contextMenuForChatPresentationIntefaceState(chatPresentationInterfaceState: hasEditRights = true } else if message.author?.id == message.id.peerId, let peer = message.peers[message.id.peerId] { if let peer = peer as? TelegramChannel, case .broadcast = peer.info { - if peer.hasAdminRights(.canEditMessages) { + if peer.hasPermission(.editAllMessages) { hasEditRights = true } } @@ -287,7 +280,7 @@ func contextMenuForChatPresentationIntefaceState(chatPresentationInterfaceState: var hasUneditableAttributes = false if let peer = message.peers[message.id.peerId] as? TelegramChannel { - if peer.hasBannedRights(.banSendMessages) { + if !peer.hasPermission(.sendMessages) { hasUneditableAttributes = true } } @@ -444,7 +437,7 @@ func contextMenuForChatPresentationIntefaceState(chatPresentationInterfaceState: hasEditRights = true } else if message.author?.id == message.id.peerId, let peer = message.peers[message.id.peerId] { if let peer = peer as? TelegramChannel, case .broadcast = peer.info { - if peer.hasAdminRights(.canEditMessages) { + if peer.hasPermission(.editAllMessages) { hasEditRights = true } } @@ -593,7 +586,7 @@ private func canPerformEditingActions(limits: LimitsConfiguration, accountPeerId } if let peer = message.peers[message.id.peerId] as? TelegramChannel { - if peer.hasAdminRights(.canPinMessages) { + if peer.hasPermission(.pinMessages) { return true } } @@ -640,7 +633,7 @@ func chatAvailableMessageActions(postbox: Postbox, accountPeerId: PeerId, messag if message.flags.contains(.Incoming) { optionsMap[id]!.insert(.report) } - if channel.hasAdminRights(.canBanUsers), case .group = channel.info { + if channel.hasPermission(.banMembers), case .group = channel.info { if message.flags.contains(.Incoming) { if !hadBanPeerId { hadBanPeerId = true @@ -664,7 +657,7 @@ func chatAvailableMessageActions(postbox: Postbox, accountPeerId: PeerId, messag if !message.flags.contains(.Incoming) { optionsMap[id]!.insert(.deleteGlobally) } else { - if channel.hasAdminRights([.canDeleteMessages]) { + if channel.hasPermission(.deleteAllMessages) { optionsMap[id]!.insert(.deleteGlobally) } } diff --git a/TelegramUI/ChatInterfaceStateInputPanels.swift b/TelegramUI/ChatInterfaceStateInputPanels.swift index 71b8bb35b0..faa92f897e 100644 --- a/TelegramUI/ChatInterfaceStateInputPanels.swift +++ b/TelegramUI/ChatInterfaceStateInputPanels.swift @@ -125,9 +125,9 @@ func inputPanelForChatPresentationIntefaceState(_ chatPresentationInterfaceState } switch channel.info { case .broadcast: - if chatPresentationInterfaceState.interfaceState.editMessage != nil, channel.hasAdminRights([.canEditMessages]) { + if chatPresentationInterfaceState.interfaceState.editMessage != nil, channel.hasPermission(.editAllMessages) { displayInputTextPanel = true - } else if !channel.hasAdminRights([.canPostMessages]) { + } else if !channel.hasPermission(.sendMessages) { if let currentPanel = currentPanel as? ChatChannelSubscriberInputPanelNode { return currentPanel } else { diff --git a/TelegramUI/ChatItemGalleryFooterContentNode.swift b/TelegramUI/ChatItemGalleryFooterContentNode.swift index e73749153f..884a14bef5 100644 --- a/TelegramUI/ChatItemGalleryFooterContentNode.swift +++ b/TelegramUI/ChatItemGalleryFooterContentNode.swift @@ -376,7 +376,7 @@ final class ChatItemGalleryFooterContentNode: GalleryFooterContentNode { canDelete = true } else if let channel = peer as? TelegramChannel { if message.flags.contains(.Incoming) { - canDelete = channel.hasAdminRights(.canDeleteMessages) + canDelete = channel.hasPermission(.deleteAllMessages) } else { canDelete = true } diff --git a/TelegramUI/ChatListNode.swift b/TelegramUI/ChatListNode.swift index f49fcbe229..a6dc823dc1 100644 --- a/TelegramUI/ChatListNode.swift +++ b/TelegramUI/ChatListNode.swift @@ -173,7 +173,7 @@ private func mappedInsertEntries(account: Account, nodeInteraction: ChatListNode if filter.contains(.onlyManageable) { if let peer = peer.peers[peer.peerId] { if let peer = peer as? TelegramGroup, peer.role == .creator || peer.role == .admin { - } else if let peer = peer as? TelegramChannel, case .group = peer.info, peer.hasAdminRights(.canInviteUsers) { + } else if let peer = peer as? TelegramChannel, case .group = peer.info, peer.hasPermission(.inviteMembers) { } else { enabled = false } diff --git a/TelegramUI/ChatListSearchItemHeader.swift b/TelegramUI/ChatListSearchItemHeader.swift index eda8d78f33..7517b72b56 100644 --- a/TelegramUI/ChatListSearchItemHeader.swift +++ b/TelegramUI/ChatListSearchItemHeader.swift @@ -10,6 +10,7 @@ enum ChatListSearchItemHeaderType: Int32 { case recentPeers case messages case phoneNumber + case exceptions } final class ChatListSearchItemHeader: ListViewItemHeader { @@ -74,6 +75,8 @@ final class ChatListSearchItemHeaderNode: ListViewItemHeaderNode { self.sectionHeaderNode.title = strings.DialogList_SearchSectionRecent.uppercased() case .phoneNumber: self.sectionHeaderNode.title = strings.Contacts_PhoneNumber.uppercased() + case .exceptions: + self.sectionHeaderNode.title = strings.GroupInfo_Permissions_Exceptions.uppercased() } self.sectionHeaderNode.action = actionTitle diff --git a/TelegramUI/ChatRecentActionsControllerNode.swift b/TelegramUI/ChatRecentActionsControllerNode.swift index 3d9581ae9b..39e9f12404 100644 --- a/TelegramUI/ChatRecentActionsControllerNode.swift +++ b/TelegramUI/ChatRecentActionsControllerNode.swift @@ -659,7 +659,7 @@ final class ChatRecentActionsControllerNode: ViewControllerTracingNode { if let author = message.author, let adminsState = self.adminsState { var canBan = author.id != self.account.peerId if let channel = self.peer as? TelegramChannel { - if !channel.hasAdminRights(.canBanUsers) { + if !channel.hasPermission(.banMembers) { canBan = false } } diff --git a/TelegramUI/ChatRecentActionsHistoryTransition.swift b/TelegramUI/ChatRecentActionsHistoryTransition.swift index 0854b68255..926dae22ab 100644 --- a/TelegramUI/ChatRecentActionsHistoryTransition.swift +++ b/TelegramUI/ChatRecentActionsHistoryTransition.swift @@ -515,7 +515,7 @@ struct ChatRecentActionsEntry: Comparable, Identifiable { let newFlags = newBanInfo?.rights.flags ?? [] var addedRights = newBanInfo?.rights.flags ?? [] - var removedRights:TelegramChannelBannedRightsFlags = [] + var removedRights:TelegramChatBannedRightsFlags = [] if let prevBanInfo = prevBanInfo { addedRights = addedRights.subtracting(prevBanInfo.rights.flags) removedRights = prevBanInfo.rights.flags.subtracting(newBanInfo?.rights.flags ?? []) @@ -577,7 +577,7 @@ struct ChatRecentActionsEntry: Comparable, Identifiable { let prevFlags = prevBanInfo?.rights.flags ?? [] - let order: [(TelegramChannelBannedRightsFlags, String)] = [ + let order: [(TelegramChatBannedRightsFlags, String)] = [ (.banReadMessages, self.presentationData.strings.Channel_AdminLog_BanReadMessages), (.banSendMessages, self.presentationData.strings.Channel_AdminLog_BanSendMessages), (.banSendMedia, self.presentationData.strings.Channel_AdminLog_BanSendMedia), @@ -643,7 +643,7 @@ struct ChatRecentActionsEntry: Comparable, Identifiable { let prevFlags = prevAdminRights?.rights.flags ?? [] let newFlags = newAdminRights?.rights.flags ?? [] - let order: [(TelegramChannelAdminRightsFlags, String)] + let order: [(TelegramChatAdminRightsFlags, String)] if let peer = peer as? TelegramChannel, case .broadcast = peer.info { order = [ diff --git a/TelegramUI/ContactsPeerItem.swift b/TelegramUI/ContactsPeerItem.swift index d5016916a0..66db0209c5 100644 --- a/TelegramUI/ContactsPeerItem.swift +++ b/TelegramUI/ContactsPeerItem.swift @@ -74,6 +74,11 @@ struct ContactsPeerItemBadge { let type: ContactsPeerItemBadgeType } +enum ContactsPeerItemActionIcon { + case none + case add +} + enum ContactsPeerItemPeer: Equatable { case peer(peer: Peer?, chatPeer: Peer?) case deviceContact(stableId: DeviceContactStableId, contact: DeviceContactBasicData) @@ -116,6 +121,7 @@ class ContactsPeerItem: ListViewItem { let selection: ContactsPeerItemSelection let editing: ContactsPeerItemEditing let options: [ItemListPeerItemRevealOption] + let actionIcon: ContactsPeerItemActionIcon let action: (ContactsPeerItemPeer) -> Void let setPeerIdWithRevealedOptions: ((PeerId?, PeerId?) -> Void)? let deletePeer: ((PeerId) -> Void)? @@ -126,7 +132,7 @@ class ContactsPeerItem: ListViewItem { let header: ListViewItemHeader? - init(theme: PresentationTheme, strings: PresentationStrings, sortOrder: PresentationPersonNameOrder, displayOrder: PresentationPersonNameOrder, account: Account, peerMode: ContactsPeerItemPeerMode, peer: ContactsPeerItemPeer, status: ContactsPeerItemStatus, badge: ContactsPeerItemBadge? = nil, enabled: Bool, selection: ContactsPeerItemSelection, editing: ContactsPeerItemEditing, options: [ItemListPeerItemRevealOption] = [], index: PeerNameIndex?, header: ListViewItemHeader?, action: @escaping (ContactsPeerItemPeer) -> Void, setPeerIdWithRevealedOptions: ((PeerId?, PeerId?) -> Void)? = nil, deletePeer: ((PeerId) -> Void)? = nil) { + init(theme: PresentationTheme, strings: PresentationStrings, sortOrder: PresentationPersonNameOrder, displayOrder: PresentationPersonNameOrder, account: Account, peerMode: ContactsPeerItemPeerMode, peer: ContactsPeerItemPeer, status: ContactsPeerItemStatus, badge: ContactsPeerItemBadge? = nil, enabled: Bool, selection: ContactsPeerItemSelection, editing: ContactsPeerItemEditing, options: [ItemListPeerItemRevealOption] = [], actionIcon: ContactsPeerItemActionIcon = .none, index: PeerNameIndex?, header: ListViewItemHeader?, action: @escaping (ContactsPeerItemPeer) -> Void, setPeerIdWithRevealedOptions: ((PeerId?, PeerId?) -> Void)? = nil, deletePeer: ((PeerId) -> Void)? = nil) { self.theme = theme self.strings = strings self.sortOrder = sortOrder @@ -140,6 +146,7 @@ class ContactsPeerItem: ListViewItem { self.selection = selection self.editing = editing self.options = options + self.actionIcon = actionIcon self.action = action self.setPeerIdWithRevealedOptions = setPeerIdWithRevealedOptions self.deletePeer = deletePeer @@ -290,6 +297,7 @@ class ContactsPeerItemNode: ItemListRevealOptionsItemNode { private var badgeBackgroundNode: ASImageNode? private var badgeTextNode: TextNode? private var selectionNode: CheckNode? + private var actionIconNode: ASImageNode? private var avatarState: (Account, Peer?)? @@ -435,6 +443,14 @@ class ContactsPeerItemNode: ItemListRevealOptionsItemNode { verificationIconImage = PresentationResourcesChatList.verifiedIcon(item.theme) } + let actionIconImage: UIImage? + switch item.actionIcon { + case .none: + actionIconImage = nil + case .add: + actionIconImage = PresentationResourcesItemList.plusIconImage(item.theme) + } + var titleAttributedString: NSAttributedString? var statusAttributedString: NSAttributedString? var userPresence: TelegramUserPresence? @@ -555,6 +571,9 @@ class ContactsPeerItemNode: ItemListRevealOptionsItemNode { if let verificationIconImage = verificationIconImage { additionalTitleInset += 3.0 + verificationIconImage.size.width } + if let actionIconImage = actionIconImage { + additionalTitleInset += 3.0 + actionIconImage.size.width + } additionalTitleInset += badgeSize @@ -675,6 +694,25 @@ class ContactsPeerItemNode: ItemListRevealOptionsItemNode { verificationIconNode.removeFromSupernode() } + if let actionIconImage = actionIconImage { + if strongSelf.actionIconNode == nil { + let actionIconNode = ASImageNode() + actionIconNode.isLayerBacked = true + actionIconNode.displayWithoutProcessing = true + actionIconNode.displaysAsynchronously = false + strongSelf.actionIconNode = actionIconNode + strongSelf.addSubnode(actionIconNode) + } + if let actionIconNode = strongSelf.actionIconNode { + actionIconNode.image = actionIconImage + + transition.updateFrame(node: actionIconNode, frame: CGRect(origin: CGPoint(x: revealOffset + params.width - params.rightInset - 12.0 - actionIconImage.size.width, y: floor((nodeLayout.contentSize.height - actionIconImage.size.height) / 2.0)), size: actionIconImage.size)) + } + } else if let actionIconNode = strongSelf.actionIconNode { + strongSelf.actionIconNode = nil + actionIconNode.removeFromSupernode() + } + let badgeBackgroundWidth: CGFloat if let currentBadgeBackgroundImage = currentBadgeBackgroundImage, let (badgeTextLayout, badgeTextApply) = badgeTextLayoutAndApply { let badgeBackgroundNode: ASImageNode diff --git a/TelegramUI/CreatePollController.swift b/TelegramUI/CreatePollController.swift index 22ceb5b9f0..b86e141627 100644 --- a/TelegramUI/CreatePollController.swift +++ b/TelegramUI/CreatePollController.swift @@ -507,6 +507,7 @@ public func createPollController(account: Account, peerId: PeerId, completion: @ return state } } + controller.isOpaqueWhenInOverlay = true controller.experimentalSnapScrollToItem = true return controller diff --git a/TelegramUI/GroupAdminsController.swift b/TelegramUI/GroupAdminsController.swift index b3909fe23a..2311b4453f 100644 --- a/TelegramUI/GroupAdminsController.swift +++ b/TelegramUI/GroupAdminsController.swift @@ -325,7 +325,7 @@ public func groupAdminsController(account: Account, peerId: PeerId) -> ViewContr } if value { - toggleAdminsDisposables.set((addPeerAdmin(account: account, peerId: peerId, adminId: memberId) |> deliverOnMainQueue).start(error: { _ in + toggleAdminsDisposables.set((addGroupAdmin(account: account, peerId: peerId, adminId: memberId) |> deliverOnMainQueue).start(error: { _ in updateState { state in var updatingAdminValue = state.updatingAdminValue updatingAdminValue.removeValue(forKey: memberId) @@ -339,7 +339,7 @@ public func groupAdminsController(account: Account, peerId: PeerId) -> ViewContr } }), forKey: memberId) } else { - toggleAdminsDisposables.set((removePeerAdmin(account: account, peerId: peerId, adminId: memberId) |> deliverOnMainQueue).start(error: { _ in + toggleAdminsDisposables.set((removeGroupAdmin(account: account, peerId: peerId, adminId: memberId) |> deliverOnMainQueue).start(error: { _ in updateState { state in var updatingAdminValue = state.updatingAdminValue updatingAdminValue.removeValue(forKey: memberId) diff --git a/TelegramUI/GroupInfoController.swift b/TelegramUI/GroupInfoController.swift index f8a29e468f..4ef895dc54 100644 --- a/TelegramUI/GroupInfoController.swift +++ b/TelegramUI/GroupInfoController.swift @@ -17,10 +17,10 @@ private final class GroupInfoArguments { let pushController: (ViewController) -> Void let presentController: (ViewController, ViewControllerPresentationArguments) -> Void let changeNotificationMuteSettings: () -> Void - let changeNotificationSoundSettings: () -> Void let openPreHistory: () -> Void let openSharedMedia: () -> Void - let openAdminManagement: () -> Void + let openAdministrators: () -> Void + let openPermissions: () -> Void let updateEditingName: (ItemListAvatarAndNameInfoItemName) -> Void let updateEditingDescriptionText: (String) -> Void let setPeerIdWithRevealedOptions: (PeerId?, PeerId?) -> Void @@ -36,7 +36,7 @@ private final class GroupInfoArguments { let aboutLinkAction: (TextLinkItemActionType, TextLinkItem) -> Void let openStickerPackSetup: () -> 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, changeNotificationSoundSettings: @escaping () -> Void, openPreHistory: @escaping () -> Void, openSharedMedia: @escaping () -> Void, openAdminManagement: @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) { + 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) { self.account = account self.peerId = peerId self.avatarAndNameInfoContext = avatarAndNameInfoContext @@ -45,10 +45,10 @@ private final class GroupInfoArguments { self.pushController = pushController self.presentController = presentController self.changeNotificationMuteSettings = changeNotificationMuteSettings - self.changeNotificationSoundSettings = changeNotificationSoundSettings self.openPreHistory = openPreHistory self.openSharedMedia = openSharedMedia - self.openAdminManagement = openAdminManagement + self.openAdministrators = openAdministrators + self.openPermissions = openPermissions self.updateEditingName = updateEditingName self.updateEditingDescriptionText = updateEditingDescriptionText self.setPeerIdWithRevealedOptions = setPeerIdWithRevealedOptions @@ -134,20 +134,16 @@ private enum GroupInfoEntry: ItemListNodeEntry { case info(PresentationTheme, PresentationStrings, PresentationDateTimeFormat, peer: Peer?, cachedData: CachedPeerData?, state: ItemListAvatarAndNameInfoItemState, updatingAvatar: ItemListAvatarAndNameInfoItemUpdatingAvatar?) case setGroupPhoto(PresentationTheme, String) case groupDescriptionSetup(PresentationTheme, String, String) - case groupDescriptionSetupInfo(PresentationTheme, String) case aboutHeader(PresentationTheme, String) case about(PresentationTheme, String) case link(PresentationTheme, String) case sharedMedia(PresentationTheme, String) case notifications(PresentationTheme, String, String) - case notificationSound(PresentationTheme, String, String) case stickerPack(PresentationTheme, String, String) - case adminManagement(PresentationTheme, String) case groupTypeSetup(PresentationTheme, String, String) case preHistory(PresentationTheme, String, String) - case groupManagementInfoLabel(PresentationTheme, String, String) - case membersAdmins(PresentationTheme, String, String) - case membersBlacklist(PresentationTheme, String, String) + case administrators(PresentationTheme, String, String) + 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) @@ -155,17 +151,17 @@ private enum GroupInfoEntry: ItemListNodeEntry { var section: ItemListSectionId { switch self { - case .info, .setGroupPhoto, .groupDescriptionSetup, .groupDescriptionSetupInfo: + case .info, .setGroupPhoto, .groupDescriptionSetup: return GroupInfoSection.info.rawValue case .aboutHeader, .about, .link: return GroupInfoSection.about.rawValue - case .groupTypeSetup, .preHistory, .groupManagementInfoLabel: + case .groupTypeSetup, .preHistory: return GroupInfoSection.infoManagement.rawValue - case .sharedMedia, .notifications, .notificationSound, .adminManagement: + case .sharedMedia, .notifications: return GroupInfoSection.sharedMediaAndNotifications.rawValue case .stickerPack: return GroupInfoSection.stickerPack.rawValue - case .membersAdmins, .membersBlacklist: + case .permissions, .administrators: return GroupInfoSection.memberManagement.rawValue case .addMember, .member: return GroupInfoSection.members.rawValue @@ -223,12 +219,6 @@ private enum GroupInfoEntry: ItemListNodeEntry { } else { return false } - case let .groupDescriptionSetupInfo(lhsTheme, lhsText): - if case let .groupDescriptionSetupInfo(rhsTheme, rhsText) = rhs, lhsTheme === rhsTheme, lhsText == rhsText { - return true - } else { - return false - } case let .sharedMedia(lhsTheme, lhsText): if case let .sharedMedia(rhsTheme, rhsText) = rhs, lhsTheme === rhsTheme, lhsText == rhsText { return true @@ -247,12 +237,6 @@ private enum GroupInfoEntry: ItemListNodeEntry { } else { return false } - case let .adminManagement(lhsTheme, lhsText): - if case let .adminManagement(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 @@ -286,12 +270,6 @@ private enum GroupInfoEntry: ItemListNodeEntry { } else { return false } - case let .notificationSound(lhsTheme, lhsTitle, lhsValue): - if case let .notificationSound(rhsTheme, rhsTitle, rhsValue) = rhs, lhsTheme === rhsTheme, lhsTitle == rhsTitle, lhsValue == rhsValue { - return true - } else { - return false - } case let .stickerPack(lhsTheme, lhsTitle, lhsValue): if case let .stickerPack(rhsTheme, rhsTitle, rhsValue) = rhs { if lhsTheme !== rhsTheme { @@ -319,20 +297,14 @@ private enum GroupInfoEntry: ItemListNodeEntry { } else { return false } - case let .groupManagementInfoLabel(lhsTheme, lhsTitle, lhsText): - if case let .groupManagementInfoLabel(rhsTheme, rhsTitle, rhsText) = rhs, lhsTheme === rhsTheme, lhsTitle == rhsTitle, lhsText == rhsText { + case let .permissions(lhsTheme, lhsTitle, lhsText): + if case let .permissions(rhsTheme, rhsTitle, rhsText) = rhs, lhsTheme === rhsTheme, lhsTitle == rhsTitle, lhsText == rhsText { return true } else { return false } - case let .membersAdmins(lhsTheme, lhsTitle, lhsText): - if case let .membersAdmins(rhsTheme, rhsTitle, rhsText) = rhs, lhsTheme === rhsTheme, lhsTitle == rhsTitle, lhsText == rhsText { - return true - } else { - return false - } - case let .membersBlacklist(lhsTheme, lhsTitle, lhsText): - if case let .membersBlacklist(rhsTheme, rhsTitle, rhsText) = rhs, lhsTheme === rhsTheme, lhsTitle == rhsTitle, lhsText == rhsText { + case let .administrators(lhsTheme, lhsTitle, lhsText): + if case let .administrators(rhsTheme, rhsTitle, rhsText) = rhs, lhsTheme === rhsTheme, lhsTitle == rhsTitle, lhsText == rhsText { return true } else { return false @@ -412,34 +384,26 @@ private enum GroupInfoEntry: ItemListNodeEntry { return 1 case .groupDescriptionSetup: return 2 - case .groupDescriptionSetupInfo: - return 3 case .aboutHeader: return 4 case .about: return 5 case .link: return 6 - case .adminManagement: - return 7 case .groupTypeSetup: return 8 case .preHistory: return 9 case .notifications: return 10 - case .notificationSound: - return 11 case .stickerPack: return 12 case .sharedMedia: return 13 - case .groupManagementInfoLabel: + case .permissions: return 14 - case .membersAdmins: + case .administrators: return 15 - case .membersBlacklist: - return 16 case .addMember: return 17 case let .member(_, _, _, _, index, _, _, _, _, _, _, _, _): @@ -485,10 +449,6 @@ private enum GroupInfoEntry: ItemListNodeEntry { return ItemListDisclosureItem(theme: theme, title: title, label: text, sectionId: self.section, style: .blocks, action: { arguments.changeNotificationMuteSettings() }) - case let .notificationSound(theme, title, value): - return ItemListDisclosureItem(theme: theme, title: title, label: value, sectionId: self.section, style: .blocks, action: { - arguments.changeNotificationSoundSettings() - }) case let .stickerPack(theme, title, value): return ItemListDisclosureItem(theme: theme, title: title, label: value, sectionId: self.section, style: .blocks, action: { arguments.openStickerPackSetup() @@ -501,10 +461,6 @@ private enum GroupInfoEntry: ItemListNodeEntry { return ItemListDisclosureItem(theme: theme, title: title, label: "", sectionId: self.section, style: .blocks, action: { arguments.openSharedMedia() }) - case let .adminManagement(theme, title): - return ItemListDisclosureItem(theme: theme, title: title, label: "", sectionId: self.section, style: .blocks, action: { - arguments.openAdminManagement() - }) case let .addMember(theme, title, editing): return ItemListPeerActionItem(theme: theme, icon: PresentationResourcesItemList.addPersonIcon(theme), title: title, sectionId: self.section, editing: editing, action: { arguments.addMember() @@ -519,15 +475,13 @@ private enum GroupInfoEntry: ItemListNodeEntry { }, action: { }) - case let .groupDescriptionSetupInfo(theme, text): - return ItemListTextItem(theme: theme, text: .plain(text), sectionId: self.section) - case let .membersAdmins(theme, title, text): - return ItemListDisclosureItem(theme: theme, title: title, label: text, sectionId: self.section, style: .blocks, action: { - arguments.pushController(channelAdminsController(account: arguments.account, peerId: arguments.peerId)) + case let .permissions(theme, title, text): + return ItemListDisclosureItem(theme: theme, icon: PresentationResourcesChat.groupInfoPermissionsIcon(theme), title: title, label: text, sectionId: self.section, style: .blocks, action: { + arguments.openPermissions() }) - case let .membersBlacklist(theme, title, text): - return ItemListDisclosureItem(theme: theme, title: title, label: text, sectionId: self.section, style: .blocks, action: { - arguments.pushController(channelBlacklistController(account: arguments.account, peerId: arguments.peerId)) + case let .administrators(theme, title, text): + return ItemListDisclosureItem(theme: theme, icon: PresentationResourcesChat.groupInfoAdminsIcon(theme), title: title, label: text, sectionId: self.section, style: .blocks, action: { + arguments.openAdministrators() }) case let .member(theme, strings, dateTimeFormat, nameDisplayOrder, _, _, peer, participant, presence, memberStatus, editing, actions, enabled): let label: String? @@ -710,6 +664,32 @@ private func canRemoveParticipant(account: Account, isAdmin: Bool, participantId return isAdmin } +private func canRemoveParticipant(account: Account, channel: TelegramChannel, participant: ChannelParticipant) -> Bool { + if participant.peerId == account.peerId { + return false + } + + if channel.flags.contains(.isCreator) { + return true + } + + switch participant { + case .creator: + return false + case let .member(_, _, adminInfo, _): + if channel.hasPermission(.banMembers) { + if let adminInfo = adminInfo { + return adminInfo.promotedBy == account.peerId + } else { + return false + } + } else { + return false + } + } +} + + private func groupInfoEntries(account: Account, presentationData: PresentationData, view: PeerView, channelMembers: [RenderedChannelParticipant], globalNotificationSettings: GlobalNotificationSettings, state: GroupInfoState) -> [GroupInfoEntry] { var entries: [GroupInfoEntry] = [] @@ -752,15 +732,13 @@ private func groupInfoEntries(account: Account, presentationData: PresentationDa highlightAdmins = true isPublic = channel.username != nil isCreator = channel.flags.contains(.isCreator) - if channel.hasAdminRights(.canChangeInfo) { + if channel.hasPermission(.changeInfo) { canEditGroupInfo = true } - if channel.hasAdminRights(.canBanUsers) { + if channel.hasPermission(.banMembers) { canEditMembers = true } - if channel.hasAdminRights(.canInviteUsers) { - canAddMembers = true - } else if case let .group(info) = channel.info, info.flags.contains(.everyMemberCanInviteMembers) { + if channel.hasPermission(.inviteMembers) { canAddMembers = true } } @@ -788,18 +766,14 @@ private func groupInfoEntries(account: Account, presentationData: PresentationDa entries.append(GroupInfoEntry.setGroupPhoto(presentationData.theme, presentationData.strings.GroupInfo_SetGroupPhoto)) if view.peers[view.peerId] is TelegramChannel { - entries.append(GroupInfoEntry.groupDescriptionSetup(presentationData.theme, presentationData.strings.Channel_Edit_AboutItem, editingState.editingDescriptionText)) - entries.append(GroupInfoEntry.groupDescriptionSetupInfo(presentationData.theme, isGroup ? presentationData.strings.Group_About_Help : presentationData.strings.Channel_About_Help)) + entries.append(GroupInfoEntry.groupDescriptionSetup(presentationData.theme, presentationData.strings.Channel_About_Placeholder, editingState.editingDescriptionText)) } } if let group = view.peers[view.peerId] as? TelegramGroup { if case .creator = group.role { - entries.append(.adminManagement(presentationData.theme, presentationData.strings.GroupInfo_ChatAdmins)) + entries.append(.administrators(presentationData.theme, presentationData.strings.GroupInfo_Administrators, "")) } - - entries.append(GroupInfoEntry.notifications(presentationData.theme, presentationData.strings.GroupInfo_Notifications, notificationsText)) - entries.append(GroupInfoEntry.notificationSound(presentationData.theme, presentationData.strings.GroupInfo_Sound, localizedPeerNotificationSoundString(strings: presentationData.strings, sound: peerNotificationSettings.messageSound, default: globalNotificationSettings.effective.groupChats.sound))) } else if let cachedChannelData = view.cachedData as? CachedChannelData { if isCreator { entries.append(GroupInfoEntry.groupTypeSetup(presentationData.theme, presentationData.strings.GroupInfo_GroupType, isPublic ? presentationData.strings.Channel_Setup_TypePublic : presentationData.strings.Channel_Setup_TypePrivate)) @@ -808,9 +782,6 @@ private func groupInfoEntries(account: Account, presentationData: PresentationDa } } - entries.append(GroupInfoEntry.notifications(presentationData.theme, presentationData.strings.GroupInfo_Notifications, notificationsText)) - entries.append(GroupInfoEntry.notificationSound(presentationData.theme, presentationData.strings.GroupInfo_Sound, localizedPeerNotificationSoundString(strings: presentationData.strings, sound: peerNotificationSettings.messageSound, default: globalNotificationSettings.effective.groupChats.sound))) - if cachedChannelData.flags.contains(.canSetStickerSet) && canEditGroupInfo { entries.append(GroupInfoEntry.stickerPack(presentationData.theme, presentationData.strings.Stickers_GroupStickers, cachedChannelData.stickerPack?.title ?? presentationData.strings.GroupInfo_SharedMediaNone)) } @@ -825,16 +796,18 @@ private func groupInfoEntries(account: Account, presentationData: PresentationDa } if canViewAdminsAndBanned { - entries.append(GroupInfoEntry.membersAdmins(presentationData.theme, presentationData.strings.Channel_Info_Management, cachedChannelData.participantsSummary.adminCount.flatMap { "\($0)" } ?? "")) - - var restrictedAndBannedCount: Int32 = 0 - if let restrictedCount = cachedChannelData.participantsSummary.bannedCount { - restrictedAndBannedCount += restrictedCount + var activePermissionCount: Int? + if let defaultBannedRights = cachedChannelData.defaultBannedRights { + var count = 0 + for right in allGroupPermissionList { + if !defaultBannedRights.flags.contains(right) { + count += 1 + } + } + activePermissionCount = count } - if let bannedCount = cachedChannelData.participantsSummary.kickedCount { - restrictedAndBannedCount += bannedCount - } - entries.append(GroupInfoEntry.membersBlacklist(presentationData.theme, presentationData.strings.Channel_Info_Banned, restrictedAndBannedCount != 0 ? "\(restrictedAndBannedCount)" : "" )) + entries.append(GroupInfoEntry.permissions(presentationData.theme, presentationData.strings.GroupInfo_Permissions, activePermissionCount.flatMap({ "\($0)/\(allGroupPermissionList.count)" }) ?? "")) + entries.append(GroupInfoEntry.administrators(presentationData.theme, presentationData.strings.GroupInfo_Administrators, cachedChannelData.participantsSummary.adminCount.flatMap { "\($0)" } ?? "")) } } } else { @@ -860,9 +833,9 @@ private func groupInfoEntries(account: Account, presentationData: PresentationDa break } } - } else if let cachedChannelData = view.cachedData as? CachedChannelData, let participants = cachedChannelData.topParticipants { - for participant in participants.participants { - if canRemoveParticipant(account: account, isAdmin: canEditMembers, participantId: participant.peerId, invitedBy: nil) { + } else if let channel = view.peers[view.peerId] as? TelegramChannel { + for participant in channelMembers { + if canRemoveParticipant(account: account, channel: channel, participant: participant.participant) { canRemoveAnyMember = true break } @@ -969,7 +942,6 @@ private func groupInfoEntries(account: Account, presentationData: PresentationDa var peerPresences: [PeerId: PeerPresence] = view.peerPresences var peers: [PeerId: Peer] = view.peers - var disabledPeerIds = state.removingParticipantIds if !state.temporaryParticipants.isEmpty { for participant in state.temporaryParticipants { @@ -1047,12 +1019,12 @@ private func groupInfoEntries(account: Account, presentationData: PresentationDa canPromote = false canRestrict = false case let .member(_, _, adminRights, bannedRights): - if channel.hasAdminRights([.canAddAdmins]) { + if channel.hasPermission(.addAdmins) { canPromote = true } else { canPromote = false } - if channel.hasAdminRights([.canBanUsers]) { + if channel.hasPermission(.banMembers) { canRestrict = true } else { canRestrict = false @@ -1081,8 +1053,8 @@ private func groupInfoEntries(account: Account, presentationData: PresentationDa peerActions.append(ParticipantRevealAction(type: .warning, title: presentationData.strings.GroupInfo_ActionRestrict, action: .restrict)) peerActions.append(ParticipantRevealAction(type: .destructive, title: presentationData.strings.Common_Delete, action: .remove)) } - - entries.append(GroupInfoEntry.member(presentationData.theme, presentationData.strings, presentationData.dateTimeFormat, presentationData.nameDisplayOrder, index: i, peerId: participant.peer.id, peer: participant.peer, participant: participant, presence: participant.presences[participant.peer.id], memberStatus: memberStatus, editing: ItemListPeerItemEditing(editable: !peerActions.isEmpty, editing: state.editingState != nil && canRemoveAnyMember, revealed: state.peerIdWithRevealedOptions == participant.peer.id), revealActions: peerActions, enabled: !disabledPeerIds.contains(participant.peer.id))) + + entries.append(GroupInfoEntry.member(presentationData.theme, presentationData.strings, presentationData.dateTimeFormat, presentationData.nameDisplayOrder, index: i, peerId: participant.peer.id, peer: participant.peer, participant: participant, presence: participant.presences[participant.peer.id], memberStatus: memberStatus, editing: ItemListPeerItemEditing(editable: !peerActions.isEmpty, editing: state.editingState != nil && canRemoveAnyMember, revealed: state.peerIdWithRevealedOptions == participant.peer.id), revealActions: peerActions, enabled: true)) } } @@ -1148,10 +1120,6 @@ public func groupInfoController(account: Account, peerId: PeerId) -> ViewControl let actionsDisposable = DisposableSet() - if peerId.namespace == Namespaces.Peer.CloudChannel { - actionsDisposable.add(account.viewTracker.updatedCachedChannelParticipants(peerId, forceImmediateUpdate: true).start()) - } - let updatePeerNameDisposable = MetaDisposable() actionsDisposable.add(updatePeerNameDisposable) @@ -1300,28 +1268,25 @@ public func groupInfoController(account: Account, peerId: PeerId) -> ViewControl presentControllerImpl?(controller, presentationArguments) }, changeNotificationMuteSettings: { let presentationData = account.telegramApplicationContext.currentPresentationData.with { $0 } - actionsDisposable.add((account.postbox.preferencesView(keys: [PreferencesKeys.globalNotifications]) |> take(1) |> deliverOnMainQueue).start(next: { view in - - let viewSettings: GlobalNotificationSettingsSet - if let settings = view.values[PreferencesKeys.globalNotifications] as? GlobalNotificationSettings { - viewSettings = settings.effective - } else { - viewSettings = GlobalNotificationSettingsSet.defaultSettings - } - - let controller = notificationMuteSettingsController(presentationData: presentationData, notificationSettings: viewSettings.groupChats, updateSettings: { value in - changeMuteSettingsDisposable.set(updatePeerMuteSetting(account: account, peerId: peerId, muteInterval: value).start()) - }) - presentControllerImpl?(controller, ViewControllerPresentationArguments(presentationAnimation: .modalSheet)) - })) - }, changeNotificationSoundSettings: { let _ = (account.postbox.transaction { transaction -> (TelegramPeerNotificationSettings, GlobalNotificationSettings) in let peerSettings: TelegramPeerNotificationSettings = (transaction.getPeerNotificationSettings(peerId) as? TelegramPeerNotificationSettings) ?? TelegramPeerNotificationSettings.defaultSettings let globalSettings: GlobalNotificationSettings = (transaction.getPreferencesEntry(key: PreferencesKeys.globalNotifications) as? GlobalNotificationSettings) ?? GlobalNotificationSettings.defaultSettings return (peerSettings, globalSettings) - } |> deliverOnMainQueue).start(next: { settings in - let controller = notificationSoundSelectionController(account: account, isModal: true, currentSound: settings.0.messageSound, defaultSound: settings.1.effective.groupChats.sound, completion: { sound in - let _ = updatePeerNotificationSoundInteractive(account: account, peerId: peerId, sound: sound).start() + } + |> deliverOnMainQueue).start(next: { peerSettings, globalSettings in + let soundSettings: NotificationSoundSettings? + if case .default = peerSettings.messageSound { + soundSettings = NotificationSoundSettings(value: nil) + } else { + soundSettings = NotificationSoundSettings(value: peerSettings.messageSound) + } + let controller = notificationMuteSettingsController(presentationData: presentationData, notificationSettings: globalSettings.effective.groupChats, soundSettings: soundSettings, openSoundSettings: { + let controller = notificationSoundSelectionController(account: account, isModal: true, currentSound: peerSettings.messageSound, defaultSound: globalSettings.effective.groupChats.sound, completion: { sound in + let _ = updatePeerNotificationSoundInteractive(account: account, peerId: peerId, sound: sound).start() + }) + presentControllerImpl?(controller, ViewControllerPresentationArguments(presentationAnimation: .modalSheet)) + }, updateSettings: { value in + changeMuteSettingsDisposable.set(updatePeerMuteSetting(account: account, peerId: peerId, muteInterval: value).start()) }) presentControllerImpl?(controller, ViewControllerPresentationArguments(presentationAnimation: .modalSheet)) }) @@ -1331,8 +1296,17 @@ public func groupInfoController(account: Account, peerId: PeerId) -> ViewControl if let controller = peerSharedMediaController(account: account, peerId: peerId) { pushControllerImpl?(controller) } - }, openAdminManagement: { - pushControllerImpl?(groupAdminsController(account: account, peerId: peerId)) + }, openAdministrators: { + if peerId.namespace == Namespaces.Peer.CloudGroup { + pushControllerImpl?(groupAdminsController(account: account, peerId: peerId)) + } else { + pushControllerImpl?(channelAdminsController(account: account, peerId: peerId)) + } + }, openPermissions: { + if peerId.namespace == Namespaces.Peer.CloudGroup { + } else { + pushControllerImpl?(channelPermissionsController(account: account, peerId: peerId)) + } }, updateEditingName: { editingName in updateState { state in if let editingState = state.editingState { @@ -1369,7 +1343,7 @@ public func groupInfoController(account: Account, peerId: PeerId) -> ViewControl members.set(.single([])) } - let _ = (combineLatest(account.postbox.loadedPeerWithId(peerId) + let _ = (combineLatest(queue: .mainQueue(), account.postbox.loadedPeerWithId(peerId) |> deliverOnMainQueue, members.get() |> take(1) |> deliverOnMainQueue)).start(next: { groupPeer, recentIds in var confirmationImpl: ((PeerId) -> Signal)? var options: [ContactListAdditionalOption] = [] @@ -1382,9 +1356,7 @@ public func groupInfoController(account: Account, peerId: PeerId) -> ViewControl canCreateInviteLink = true } } else if let channel = groupPeer as? TelegramChannel { - if channel.hasAdminRights(.canInviteUsers) { - canCreateInviteLink = true - } else if case let .group(info) = channel.info, info.flags.contains(.everyMemberCanInviteMembers) { + if channel.hasPermission(.manageInviteLink) { canCreateInviteLink = true } } @@ -1461,7 +1433,7 @@ public func groupInfoController(account: Account, peerId: PeerId) -> ViewControl } } - return addPeerMember(account: account, peerId: peerId, memberId: memberId) + return addGroupMember(account: account, peerId: peerId, memberId: memberId) |> deliverOnMainQueue |> afterCompleted { updateState { state in @@ -1543,17 +1515,17 @@ public func groupInfoController(account: Account, peerId: PeerId) -> ViewControl presentControllerImpl?(contactsController, ViewControllerPresentationArguments(presentationAnimation: .modalSheet)) if let contactsController = contactsController as? ContactSelectionController { selectAddMemberDisposable.set((contactsController.result - |> deliverOnMainQueue).start(next: { [weak contactsController] memberPeer in - guard let memberPeer = memberPeer else { - return - } - - contactsController?.displayProgress = true - addMemberDisposable.set((addMember(memberPeer) - |> deliverOnMainQueue).start(completed: { - contactsController?.dismiss() - })) - })) + |> deliverOnMainQueue).start(next: { [weak contactsController] memberPeer in + guard let memberPeer = memberPeer else { + return + } + + contactsController?.displayProgress = true + addMemberDisposable.set((addMember(memberPeer) + |> deliverOnMainQueue).start(completed: { + contactsController?.dismiss() + })) + })) contactsController.dismissed = { selectAddMemberDisposable.set(nil) addMemberDisposable.set(nil) @@ -1623,7 +1595,7 @@ public func groupInfoController(account: Account, peerId: PeerId) -> ViewControl } if peerId.namespace == Namespaces.Peer.CloudChannel { - return account.telegramApplicationContext.peerChannelMemberCategoriesContextsManager.updateMemberBannedRights(account: account, peerId: peerId, memberId: memberId, bannedRights: TelegramChannelBannedRights(flags: [.banReadMessages], untilDate: Int32.max)) + return account.telegramApplicationContext.peerChannelMemberCategoriesContextsManager.updateMemberBannedRights(account: account, peerId: peerId, memberId: memberId, bannedRights: TelegramChatBannedRights(flags: [.banReadMessages], untilDate: Int32.max)) |> afterDisposed { Queue.mainQueue().async { updateState { state in @@ -1707,10 +1679,11 @@ public func groupInfoController(account: Account, peerId: PeerId) -> ViewControl channelMembersPromise.set(.single([])) } + let previousStateValue = Atomic(value: nil) let previousChannelMembers = Atomic<[PeerId]?>(value: nil) let globalNotificationsKey: PostboxViewKey = .preferences(keys: Set([PreferencesKeys.globalNotifications])) - let signal = combineLatest((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(), account.viewTracker.peerView(peerId), account.postbox.combinedView(keys: [globalNotificationsKey]), channelMembersPromise.get()) |> map { presentationData, state, view, combinedView, channelMembers -> (ItemListControllerState, (ItemListNodeState, GroupInfoEntry.ItemGenerationArguments)) in let peer = peerViewMainPeer(view) @@ -1728,6 +1701,9 @@ public func groupInfoController(account: Account, peerId: PeerId) -> ViewControl if let editingName = editingState.editingName, editingName.isEmpty { doneEnabled = false } + if editingState.editingDescriptionText.count > 255 { + doneEnabled = false + } if peer is TelegramChannel { if (view.cachedData as? CachedChannelData) == nil { doneEnabled = false @@ -1830,10 +1806,10 @@ public func groupInfoController(account: Account, peerId: PeerId) -> ViewControl break } } - + let previousState = previousStateValue.swap(state) let previousMembers = previousChannelMembers.swap(memberIds) ?? [] - var animateChanges = previousMembers.count >= memberIds.count + var animateChanges = previousMembers.count > memberIds.count || (previousState != nil && (previousState!.editingState != nil) != (state.editingState != nil)) if presentationData.disableAnimations { if Set(memberIds) == Set(previousMembers) && memberIds != previousMembers { animateChanges = false diff --git a/TelegramUI/GroupInfoSearchItem.swift b/TelegramUI/GroupInfoSearchItem.swift index 65ba371924..dc9e9a9b72 100644 --- a/TelegramUI/GroupInfoSearchItem.swift +++ b/TelegramUI/GroupInfoSearchItem.swift @@ -58,7 +58,7 @@ final class ChannelMembersSearchItem: ItemListControllerSearch { return current } else { let presentationData = self.account.telegramApplicationContext.currentPresentationData.with { $0 } - return GroupInfoSearchNavigationContentNode(theme: presentationData.theme, strings: presentationData.strings, cancel: self.cancel, updateActivity: { [weak self] value in + return GroupInfoSearchNavigationContentNode(theme: presentationData.theme, strings: presentationData.strings, mode: self.searchMode, cancel: self.cancel, updateActivity: { [weak self] value in self?.updateActivity = value }) } diff --git a/TelegramUI/GroupInfoSearchNavigationContentNode.swift b/TelegramUI/GroupInfoSearchNavigationContentNode.swift index 7938b3bc4e..d799351ce0 100644 --- a/TelegramUI/GroupInfoSearchNavigationContentNode.swift +++ b/TelegramUI/GroupInfoSearchNavigationContentNode.swift @@ -21,14 +21,20 @@ final class GroupInfoSearchNavigationContentNode: NavigationBarContentNode, Item searchBar.activity = activity } } - init(theme: PresentationTheme, strings: PresentationStrings, cancel: @escaping () -> Void, updateActivity: @escaping(@escaping(Bool)->Void) -> Void) { + init(theme: PresentationTheme, strings: PresentationStrings, mode: ChannelMembersSearchMode, cancel: @escaping () -> Void, updateActivity: @escaping(@escaping(Bool)->Void) -> Void) { self.theme = theme self.strings = strings self.cancel = cancel self.searchBar = SearchBarNode(theme: SearchBarNodeTheme(theme: theme), strings: strings) - let placeholderText = strings.Conversation_SearchByName_Placeholder + let placeholderText: String + switch mode { + case .searchBanned: + placeholderText = strings.GroupInfo_Permissions_SearchPlaceholder + default: + placeholderText = strings.Conversation_SearchByName_Placeholder + } self.searchBar.placeholderString = NSAttributedString(string: placeholderText, font: searchBarFont, textColor: theme.rootController.activeNavigationSearchBar.inputPlaceholderTextColor) super.init() diff --git a/TelegramUI/ItemListMultilineInputItem.swift b/TelegramUI/ItemListMultilineInputItem.swift index 36e5799cb1..b2791772f4 100644 --- a/TelegramUI/ItemListMultilineInputItem.swift +++ b/TelegramUI/ItemListMultilineInputItem.swift @@ -149,15 +149,23 @@ class ItemListMultilineInputItemNode: ListViewItemNode, ASEditableTextNodeDelega } var limitTextString: NSAttributedString? + var rightInset: CGFloat = params.rightInset + if let maxLength = item.maxLength, maxLength.display { - limitTextString = NSAttributedString(string: "\(max(0, maxLength.value - item.text.count))", font: titleFont, textColor: item.theme.list.itemSecondaryTextColor) + let textLength = item.text.count + let displayTextLimit = textLength > maxLength.value * 70 / 100 + let remainingCount = maxLength.value - textLength + if displayTextLimit { + limitTextString = NSAttributedString(string: "\(remainingCount)", font: Font.regular(13.0), textColor: remainingCount < 0 ? item.theme.list.itemDestructiveColor : item.theme.list.itemSecondaryTextColor) + } + + rightInset += 30.0 + 4.0 } let (limitTextLayout, limitTextApply) = makeLimitTextLayout(TextNodeLayoutArguments(attributedString: limitTextString, backgroundColor: nil, maximumNumberOfLines: 1, truncationType: .end, constrainedSize: CGSize(width: 100.0, height: 100.0), alignment: .left, cutout: nil, insets: UIEdgeInsets())) - var rightInset: CGFloat = params.rightInset - if !limitTextLayout.size.width.isZero { - rightInset += limitTextLayout.size.width + 4.0 + if limitTextLayout.size.width > 30.0 { + rightInset += 30.0 } var measureText = item.text @@ -241,7 +249,7 @@ class ItemListMultilineInputItemNode: ListViewItemNode, ASEditableTextNodeDelega strongSelf.textNode.frame = CGRect(origin: CGPoint(), size: CGSize(width: params.width - leftInset - 16.0 - rightInset, height: textLayout.size.height + 1.0)) let _ = limitTextApply() - strongSelf.limitTextNode.frame = CGRect(origin: CGPoint(x: params.width - params.rightInset - 16.0 - limitTextLayout.size.width, y: textTopInset), size: limitTextLayout.size) + strongSelf.limitTextNode.frame = CGRect(origin: CGPoint(x: params.width - params.rightInset - 16.0 - limitTextLayout.size.width, y: layout.contentSize.height - 15.0 - limitTextLayout.size.height), size: limitTextLayout.size) if limitTextString != nil { if strongSelf.limitTextNode.supernode == nil { strongSelf.addSubnode(strongSelf.limitTextNode) @@ -286,10 +294,7 @@ class ItemListMultilineInputItemNode: ListViewItemNode, ASEditableTextNodeDelega func editableTextNodeDidUpdateText(_ editableTextNode: ASEditableTextNode) { if let item = self.item { if let text = self.textNode.attributedText { - var updatedText = text.string - if let maxLength = item.maxLength, updatedText.count > maxLength.value { - updatedText = String(updatedText[.. Bool { if let item = self.item { let text: String? = UIPasteboard.general.string - if let text = text { - if let maxLength = item.maxLength { - let string = self.textNode.attributedText?.string ?? "" - if string.count + text.count > maxLength.value { - UIPasteboard.general.string = String(text[.. Void) -> ViewController { - - +struct NotificationSoundSettings { + var value: PeerMessageSound? +} + +func notificationMuteSettingsController(presentationData: PresentationData, notificationSettings: MessageNotificationSettings, soundSettings: NotificationSoundSettings?, openSoundSettings: @escaping () -> Void, updateSettings: @escaping (Int32?) -> Void) -> ViewController { let controller = ActionSheetController(presentationTheme: presentationData.theme) let dismissAction: () -> Void = { [weak controller] in controller?.dismissAnimated() @@ -35,10 +37,8 @@ func notificationMuteSettingsController(presentationData: PresentationData, noti } let options: [NotificationMuteOption] = [ - // .default, .enable, .interval(1 * 60 * 60), - .interval(8 * 60 * 60), .interval(2 * 24 * 60 * 60), .disable ] @@ -78,10 +78,16 @@ func notificationMuteSettingsController(presentationData: PresentationData, noti } items.append(item) } + if let soundSettings = soundSettings { + items.append(ActionSheetButtonItem(title: soundSettings.value.flatMap({ presentationData.strings.Notification_Exceptions_Sound(localizedPeerNotificationSoundString(strings: presentationData.strings, sound: $0)).0 }) ?? presentationData.strings.GroupInfo_SetSound, action: { + dismissAction() + openSoundSettings() + })) + } controller.setItemGroups([ ActionSheetItemGroup(items: items), ActionSheetItemGroup(items: [ActionSheetButtonItem(title: presentationData.strings.Common_Cancel, action: { dismissAction() })]) - ]) + ]) return controller } diff --git a/TelegramUI/OpenResolvedUrl.swift b/TelegramUI/OpenResolvedUrl.swift index 805c4c83fe..04bd514b58 100644 --- a/TelegramUI/OpenResolvedUrl.swift +++ b/TelegramUI/OpenResolvedUrl.swift @@ -38,10 +38,17 @@ func openResolvedUrl(_ resolvedUrl: ResolvedUrl, account: Account, context: Open let controller = PeerSelectionController(account: account, filter: [.onlyWriteable, .onlyGroups, .onlyManageable], title: presentationData.strings.UserInfo_InviteBotToGroup) controller.peerSelected = { [weak controller] peerId in if payload.isEmpty { - let _ = (addPeerMember(account: account, peerId: peerId, memberId: botPeerId) - |> deliverOnMainQueue).start(completed: { - controller?.dismiss() - }) + if peerId.namespace == Namespaces.Peer.CloudGroup { + let _ = (addGroupMember(account: account, peerId: peerId, memberId: botPeerId) + |> deliverOnMainQueue).start(completed: { + controller?.dismiss() + }) + } else { + let _ = (addChannelMember(account: account, peerId: peerId, memberId: botPeerId) + |> deliverOnMainQueue).start(completed: { + controller?.dismiss() + }) + } } else { let _ = (requestStartBotInGroup(account: account, botPeerId: botPeerId, groupPeerId: peerId, payload: payload) |> deliverOnMainQueue).start(next: { result in diff --git a/TelegramUI/PeerChannelMemberCategoriesContextsManager.swift b/TelegramUI/PeerChannelMemberCategoriesContextsManager.swift index 9176d9829f..1b76f73ccb 100644 --- a/TelegramUI/PeerChannelMemberCategoriesContextsManager.swift +++ b/TelegramUI/PeerChannelMemberCategoriesContextsManager.swift @@ -8,6 +8,8 @@ enum PeerChannelMemberContextKey: Equatable, Hashable { case recentSearch(String) case admins(String?) case restrictedAndBanned(String?) + case restricted(String?) + case banned(String?) var hashValue: Int { switch self { @@ -19,6 +21,10 @@ enum PeerChannelMemberContextKey: Equatable, Hashable { return query?.hashValue ?? 2 case let .restrictedAndBanned(query): return query?.hashValue ?? 3 + case let .restricted(query): + return query?.hashValue ?? 4 + case let .banned(query): + return query?.hashValue ?? 5 } } } @@ -86,7 +92,7 @@ final class PeerChannelMemberCategoriesContextsManager { self.impl.with { impl in for (contextPeerId, context) in impl.contexts { if contextPeerId == peerId { - context.replayUpdates([(nil, participant)]) + context.replayUpdates([(nil, participant, nil)]) } } } @@ -156,19 +162,27 @@ final class PeerChannelMemberCategoriesContextsManager { return self.getContext(postbox: postbox, network: network, accountPeerId: accountPeerId, peerId: peerId, key: .admins(searchQuery), requestUpdate: true, updated: updated) } + func restricted(postbox: Postbox, network: Network, accountPeerId: PeerId, peerId: PeerId, searchQuery: String? = nil, updated: @escaping (ChannelMemberListState) -> Void) -> (Disposable, PeerChannelMemberCategoryControl?) { + return self.getContext(postbox: postbox, network: network, accountPeerId: accountPeerId, peerId: peerId, key: .restricted(searchQuery), requestUpdate: true, updated: updated) + } + + func banned(postbox: Postbox, network: Network, accountPeerId: PeerId, peerId: PeerId, searchQuery: String? = nil, updated: @escaping (ChannelMemberListState) -> Void) -> (Disposable, PeerChannelMemberCategoryControl?) { + return self.getContext(postbox: postbox, network: network, accountPeerId: accountPeerId, peerId: peerId, key: .banned(searchQuery), requestUpdate: true, updated: updated) + } + func restrictedAndBanned(postbox: Postbox, network: Network, accountPeerId: PeerId, peerId: PeerId, searchQuery: String? = nil, updated: @escaping (ChannelMemberListState) -> Void) -> (Disposable, PeerChannelMemberCategoryControl?) { return self.getContext(postbox: postbox, network: network, accountPeerId: accountPeerId, peerId: peerId, key: .restrictedAndBanned(searchQuery), requestUpdate: true, updated: updated) } - func updateMemberBannedRights(account: Account, peerId: PeerId, memberId: PeerId, bannedRights: TelegramChannelBannedRights?) -> Signal { + func updateMemberBannedRights(account: Account, peerId: PeerId, memberId: PeerId, bannedRights: TelegramChatBannedRights?) -> Signal { return updateChannelMemberBannedRights(account: account, peerId: peerId, memberId: memberId, rights: bannedRights) |> deliverOnMainQueue - |> beforeNext { [weak self] (previous, updated) in + |> beforeNext { [weak self] (previous, updated, isMember) in if let strongSelf = self { strongSelf.impl.with { impl in for (contextPeerId, context) in impl.contexts { if peerId == contextPeerId { - context.replayUpdates([(previous, updated)]) + context.replayUpdates([(previous, updated, isMember)]) } } } @@ -179,8 +193,8 @@ final class PeerChannelMemberCategoriesContextsManager { } } - func updateMemberAdminRights(account: Account, peerId: PeerId, memberId: PeerId, adminRights: TelegramChannelAdminRights) -> Signal { - return updatePeerAdminRights(account: account, peerId: peerId, adminId: memberId, rights: adminRights) + func updateMemberAdminRights(account: Account, peerId: PeerId, memberId: PeerId, adminRights: TelegramChatAdminRights) -> Signal { + return updateChannelAdminRights(account: account, peerId: peerId, adminId: memberId, rights: adminRights) |> map(Optional.init) |> `catch` { _ -> Signal<(ChannelParticipant?, RenderedChannelParticipant)?, NoError> in return .single(nil) @@ -191,7 +205,7 @@ final class PeerChannelMemberCategoriesContextsManager { strongSelf.impl.with { impl in for (contextPeerId, context) in impl.contexts { if peerId == contextPeerId { - context.replayUpdates([(previous, updated)]) + context.replayUpdates([(previous, updated, nil)]) } } } @@ -214,7 +228,7 @@ final class PeerChannelMemberCategoriesContextsManager { strongSelf.impl.with { impl in for (contextPeerId, context) in impl.contexts { if peerId == contextPeerId { - context.replayUpdates([(previous, updated)]) + context.replayUpdates([(previous, updated, nil)]) } } } @@ -226,20 +240,50 @@ final class PeerChannelMemberCategoriesContextsManager { } func addMembers(account: Account, peerId: PeerId, memberIds: [PeerId]) -> Signal { - return addChannelMembers(account: account, peerId: peerId, memberIds: memberIds) |> deliverOnMainQueue - |> beforeNext { [weak self] result in - if let strongSelf = self { - strongSelf.impl.with { impl in - for (contextPeerId, context) in impl.contexts { - if peerId == contextPeerId { - context.reset(.recent) + let signals: [Signal<(ChannelParticipant?, RenderedChannelParticipant)?, NoError>] = memberIds.map({ memberId in + return addChannelMember(account: account, peerId: peerId, memberId: memberId) + |> map(Optional.init) + |> `catch` { _ -> Signal<(ChannelParticipant?, RenderedChannelParticipant)?, NoError> in + return .single(nil) + } + }) + return combineLatest(signals) + |> deliverOnMainQueue + |> beforeNext { [weak self] results in + if let strongSelf = self { + strongSelf.impl.with { impl in + for result in results { + if let (previous, updated) = result { + for (contextPeerId, context) in impl.contexts { + if peerId == contextPeerId { + context.replayUpdates([(previous, updated, nil)]) + } } } } } } - |> mapToSignal { _ -> Signal in - return .single(Void()) } + |> introduceError(AddChannelMemberError.self) + |> mapToSignal { _ -> Signal in + return .complete() + } + + /*return addChannelMembers(account: account, peerId: peerId, memberIds: memberIds) + |> deliverOnMainQueue + |> beforeNext { [weak self] result in + if let strongSelf = self { + strongSelf.impl.with { impl in + for (contextPeerId, context) in impl.contexts { + if peerId == contextPeerId { + context.reset(.recent) + } + } + } + } + } + |> mapToSignal { _ -> Signal in + return .single(Void()) + }*/ } } diff --git a/TelegramUI/PresenceStrings.swift b/TelegramUI/PresenceStrings.swift index a4802fcf37..b4ad6f1174 100644 --- a/TelegramUI/PresenceStrings.swift +++ b/TelegramUI/PresenceStrings.swift @@ -230,6 +230,27 @@ func stringForRelativeLiveLocationTimestamp(strings: PresentationStrings, relati } } +func stringForRelativeSymbolicTimestamp(strings: PresentationStrings, relativeTimestamp: Int32, relativeTo timestamp: Int32, dateTimeFormat: PresentationDateTimeFormat) -> String { + var t: time_t = time_t(relativeTimestamp) + var timeinfo: tm = tm() + localtime_r(&t, &timeinfo) + + var now: time_t = time_t(timestamp) + var timeinfoNow: tm = tm() + localtime_r(&now, &timeinfoNow) + + let dayDifference = timeinfo.tm_yday - timeinfoNow.tm_yday + + let hours = timeinfo.tm_hour + let minutes = timeinfo.tm_min + + if dayDifference == 0 { + return strings.Time_TodayAt(stringForShortTimestamp(hours: hours, minutes: minutes, dateTimeFormat: dateTimeFormat)).0 + } else { + return stringForFullDate(timestamp: relativeTimestamp, strings: strings, dateTimeFormat: dateTimeFormat) + } +} + func stringForRelativeLiveLocationUpdateTimestamp(strings: PresentationStrings, relativeTimestamp: Int32, relativeTo timestamp: Int32, dateTimeFormat: PresentationDateTimeFormat) -> String { var t: time_t = time_t(relativeTimestamp) var timeinfo: tm = tm() diff --git a/TelegramUI/PresentationResourceKey.swift b/TelegramUI/PresentationResourceKey.swift index 828d6d5fba..090999f9c9 100644 --- a/TelegramUI/PresentationResourceKey.swift +++ b/TelegramUI/PresentationResourceKey.swift @@ -215,4 +215,8 @@ enum PresentationResourceKey: Int32 { case inAppNotificationBackground case inAppNotificationSecretChatIcon + + case groupInfoAdminsIcon + case groupInfoPermissionsIcon + case groupInfoMembersIcon } diff --git a/TelegramUI/PresentationResourcesChat.swift b/TelegramUI/PresentationResourcesChat.swift index 002cdbfcbe..03224039c1 100644 --- a/TelegramUI/PresentationResourcesChat.swift +++ b/TelegramUI/PresentationResourcesChat.swift @@ -934,4 +934,22 @@ struct PresentationResourcesChat { }) }) } + + static func groupInfoAdminsIcon(_ theme: PresentationTheme) -> UIImage? { + return theme.image(PresentationResourceKey.groupInfoAdminsIcon.rawValue, { _ in + return UIImage(bundleImageName: "Chat/Info/GroupAdminsIcon")?.precomposed() + }) + } + + static func groupInfoPermissionsIcon(_ theme: PresentationTheme) -> UIImage? { + return theme.image(PresentationResourceKey.groupInfoPermissionsIcon.rawValue, { _ in + return UIImage(bundleImageName: "Chat/Info/GroupPermissionsIcon")?.precomposed() + }) + } + + static func groupInfoMembersIcon(_ theme: PresentationTheme) -> UIImage? { + return theme.image(PresentationResourceKey.groupInfoMembersIcon.rawValue, { _ in + return UIImage(bundleImageName: "Chat/Info/GroupMembersIcon")?.precomposed() + }) + } } diff --git a/TelegramUI/PresentationResourcesItemList.swift b/TelegramUI/PresentationResourcesItemList.swift index c131a88415..ef402ea17e 100644 --- a/TelegramUI/PresentationResourcesItemList.swift +++ b/TelegramUI/PresentationResourcesItemList.swift @@ -31,7 +31,8 @@ private func generatePlusIcon(_ theme: PresentationTheme) -> UIImage? { return generateImage(CGSize(width: 18.0, height: 18.0), rotatedContext: { size, context in context.clear(CGRect(origin: CGPoint(), size: size)) context.setFillColor(theme.list.itemAccentColor.cgColor) - let lineWidth = min(1.5, UIScreenPixel * 4.0) + context.setLineCap(.round) + let lineWidth: CGFloat = 2.0 context.fill(CGRect(x: floorToScreenPixels((18.0 - lineWidth) / 2.0), y: 0.0, width: lineWidth, height: 18.0)) context.fill(CGRect(x: 0.0, y: floorToScreenPixels((18.0 - lineWidth) / 2.0), width: 18.0, height: lineWidth)) }) diff --git a/TelegramUI/PresentationStrings.swift b/TelegramUI/PresentationStrings.swift index 1887a4b04f..4c09102b0f 100644 --- a/TelegramUI/PresentationStrings.swift +++ b/TelegramUI/PresentationStrings.swift @@ -231,3146 +231,3430 @@ public final class PresentationStrings { public var NetworkUsageSettings_MediaAudioDataSection: String { return self._s[49]! } public var AutoNightTheme_UseSunsetSunrise: String { return self._s[50]! } public var FastTwoStepSetup_Title: String { return self._s[51]! } - public var Channel_Info_BlackList: String { return self._s[52]! } - public var Channel_AdminLog_InfoPanelTitle: String { return self._s[53]! } - public var Conversation_OpenFile: String { return self._s[54]! } - public var SecretTimer_ImageDescription: String { return self._s[55]! } - public var StickerSettings_ContextInfo: String { return self._s[56]! } - public var TwoStepAuth_GenericHelp: String { return self._s[58]! } - public var AutoDownloadSettings_Unlimited: String { return self._s[59]! } - public var PrivacyLastSeenSettings_NeverShareWith_Title: String { return self._s[60]! } + public func MESSAGE_INVOICE_SEPARATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[52]!, self._r[52]!, [_1, _2]) + } + public var Channel_Info_BlackList: String { return self._s[53]! } + public var Channel_AdminLog_InfoPanelTitle: String { return self._s[54]! } + public var Conversation_OpenFile: String { return self._s[55]! } + public var SecretTimer_ImageDescription: String { return self._s[56]! } + public var StickerSettings_ContextInfo: String { return self._s[57]! } + public var TwoStepAuth_GenericHelp: String { return self._s[59]! } + public var AutoDownloadSettings_Unlimited: String { return self._s[60]! } + public var PrivacyLastSeenSettings_NeverShareWith_Title: String { return self._s[61]! } public func CHAT_MESSAGE_NOTEXT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[61]!, self._r[61]!, [_1, _2]) + return formatWithArgumentRanges(self._s[62]!, self._r[62]!, [_1, _2]) } - public var Notifications_AddExceptionTitle: String { return self._s[62]! } - public var Watch_MessageView_Reply: String { return self._s[63]! } - public var Tour_Text6: String { return self._s[64]! } - public var TwoStepAuth_SetupPasswordEnterPasswordChange: String { return self._s[65]! } + public var Notifications_AddExceptionTitle: String { return self._s[63]! } + public var Watch_MessageView_Reply: String { return self._s[64]! } + public var Tour_Text6: String { return self._s[65]! } + public var TwoStepAuth_SetupPasswordEnterPasswordChange: String { return self._s[66]! } public func Notification_PinnedAnimationMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[66]!, self._r[66]!, [_0]) - } - public func ShareFileTip_Text(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[67]!, self._r[67]!, [_0]) } - public var AccessDenied_LocationDenied: String { return self._s[68]! } - public var CallSettings_RecentCalls: String { return self._s[69]! } - public var ConversationProfile_LeaveDeleteAndExit: String { return self._s[70]! } - public var Channel_Members_AddAdminErrorBlacklisted: String { return self._s[71]! } - public var Passport_Authorize: String { return self._s[72]! } - public var StickerPacksSettings_ArchivedMasks_Info: String { return self._s[73]! } - public var TwoStepAuth_ReEnterPasswordTitle: String { return self._s[74]! } - public var Tour_StartButton: String { return self._s[75]! } - public var Watch_AppName: String { return self._s[77]! } - public var StickerPack_ErrorNotFound: String { return self._s[78]! } - public var Channel_Info_Subscribers: String { return self._s[79]! } + public func ShareFileTip_Text(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[68]!, self._r[68]!, [_0]) + } + public var AccessDenied_LocationDenied: String { return self._s[69]! } + public var CallSettings_RecentCalls: String { return self._s[70]! } + public var ConversationProfile_LeaveDeleteAndExit: String { return self._s[71]! } + public var Channel_Members_AddAdminErrorBlacklisted: String { return self._s[73]! } + public var Passport_Authorize: String { return self._s[74]! } + public var StickerPacksSettings_ArchivedMasks_Info: String { return self._s[75]! } + public var TwoStepAuth_ReEnterPasswordTitle: String { return self._s[76]! } + public var Tour_StartButton: String { return self._s[77]! } + public var Watch_AppName: String { return self._s[79]! } + public var StickerPack_ErrorNotFound: String { return self._s[80]! } + public var Channel_Info_Subscribers: String { return self._s[82]! } public func Channel_AdminLog_MessageGroupPreHistoryVisible(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[80]!, self._r[80]!, [_0]) + return formatWithArgumentRanges(self._s[83]!, self._r[83]!, [_0]) } public func DialogList_PinLimitError(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[81]!, self._r[81]!, [_0]) + return formatWithArgumentRanges(self._s[84]!, self._r[84]!, [_0]) } - public var Conversation_StopLiveLocation: String { return self._s[83]! } - public var Channel_AdminLogFilter_EventsAll: String { return self._s[84]! } - public var GroupInfo_InviteLink_CopyAlert_Success: String { return self._s[86]! } - public var Username_LinkCopied: String { return self._s[88]! } - public var SecretVideo_Title: String { return self._s[89]! } - public var AccessDenied_PhotosAndVideos: String { return self._s[90]! } - public var Map_OpenInGoogleMaps: String { return self._s[91]! } + public var Conversation_StopLiveLocation: String { return self._s[86]! } + public var Channel_AdminLogFilter_EventsAll: String { return self._s[87]! } + public var GroupInfo_InviteLink_CopyAlert_Success: String { return self._s[89]! } + public var Username_LinkCopied: String { return self._s[91]! } + public var GroupRemoved_Title: String { return self._s[92]! } + public var SecretVideo_Title: String { return self._s[93]! } + public var AccessDenied_PhotosAndVideos: String { return self._s[94]! } + public var Map_OpenInGoogleMaps: String { return self._s[95]! } public func Time_PreciseDate_m12(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[92]!, self._r[92]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[96]!, self._r[96]!, [_1, _2, _3]) } public func Channel_AdminLog_MessageKickedNameUsername(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[93]!, self._r[93]!, [_1, _2]) + return formatWithArgumentRanges(self._s[97]!, self._r[97]!, [_1, _2]) } - public var Call_StatusRinging: String { return self._s[94]! } - public var Group_Username_InvalidStartsWithNumber: String { return self._s[95]! } - public var UserInfo_NotificationsEnabled: String { return self._s[96]! } - public var Map_Search: String { return self._s[97]! } - public var Login_TermsOfServiceHeader: String { return self._s[99]! } + public var Call_StatusRinging: String { return self._s[98]! } + public var Group_Username_InvalidStartsWithNumber: String { return self._s[99]! } + public var UserInfo_NotificationsEnabled: String { return self._s[100]! } + public var Map_Search: String { return self._s[101]! } + public var Login_TermsOfServiceHeader: String { return self._s[103]! } public func Notification_PinnedVideoMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[100]!, self._r[100]!, [_0]) + return formatWithArgumentRanges(self._s[104]!, self._r[104]!, [_0]) } public func Channel_AdminLog_MessageToggleSignaturesOn(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[101]!, self._r[101]!, [_0]) + return formatWithArgumentRanges(self._s[105]!, self._r[105]!, [_0]) } - public var TwoStepAuth_SetupPasswordConfirmPassword: String { return self._s[102]! } - public var Weekday_Today: String { return self._s[103]! } + public func PINNED_GEO_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[106]!, self._r[106]!, [_1]) + } + public var TwoStepAuth_SetupPasswordConfirmPassword: String { return self._s[107]! } + public var Weekday_Today: String { return self._s[108]! } public func InstantPage_AuthorAndDateTitle(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[105]!, self._r[105]!, [_1, _2]) + return formatWithArgumentRanges(self._s[110]!, self._r[110]!, [_1, _2]) } public func Conversation_MessageDialogRetryAll(_ _1: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[106]!, self._r[106]!, ["\(_1)"]) + return formatWithArgumentRanges(self._s[111]!, self._r[111]!, ["\(_1)"]) } - public var Notification_PassportValuePersonalDetails: String { return self._s[108]! } - public var Channel_AdminLog_MessagePreviousLink: String { return self._s[109]! } - public var ChangePhoneNumberNumber_NewNumber: String { return self._s[110]! } - public var ApplyLanguage_LanguageNotSupportedError: String { return self._s[111]! } - public var TwoStepAuth_ChangePasswordDescription: String { return self._s[112]! } - public var PhotoEditor_BlurToolLinear: String { return self._s[113]! } - public var Contacts_PermissionsAllowInSettings: String { return self._s[114]! } - public var Weekday_ShortMonday: String { return self._s[115]! } - public var Cache_KeepMedia: String { return self._s[116]! } - public var Passport_FieldIdentitySelfieHelp: String { return self._s[117]! } - public var Conversation_ClousStorageInfo_Description4: String { return self._s[118]! } - public var Passport_Language_ru: String { return self._s[119]! } + public var Notification_PassportValuePersonalDetails: String { return self._s[113]! } + public func CHAT_CREATED_SEPARATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[114]!, self._r[114]!, [_1, _2]) + } + public var Channel_AdminLog_MessagePreviousLink: String { return self._s[115]! } + public var ChangePhoneNumberNumber_NewNumber: String { return self._s[116]! } + public var ApplyLanguage_LanguageNotSupportedError: String { return self._s[117]! } + public var TwoStepAuth_ChangePasswordDescription: String { return self._s[118]! } + public var PhotoEditor_BlurToolLinear: String { return self._s[119]! } + public var Contacts_PermissionsAllowInSettings: String { return self._s[120]! } + public var Weekday_ShortMonday: String { return self._s[121]! } + public var Cache_KeepMedia: String { return self._s[122]! } + public var Passport_FieldIdentitySelfieHelp: String { return self._s[123]! } + public var Conversation_ClousStorageInfo_Description4: String { return self._s[124]! } + public func CONTACT_JOINED_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[125]!, self._r[125]!, [_1]) + } + public var Passport_Language_ru: String { return self._s[126]! } public func Notification_CreatedChatWithTitle(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[120]!, self._r[120]!, [_0, _1]) + return formatWithArgumentRanges(self._s[127]!, self._r[127]!, [_0, _1]) } public func CHAT_MESSAGES(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[121]!, self._r[121]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[128]!, self._r[128]!, [_1, _2, _3]) } - public var TwoStepAuth_RecoveryUnavailable: String { return self._s[122]! } - public var EnterPasscode_TouchId: String { return self._s[123]! } - public var PhotoEditor_QualityVeryHigh: String { return self._s[126]! } - public var Checkout_NewCard_SaveInfo: String { return self._s[128]! } - public var ChatSettings_AutoDownloadEnabled: String { return self._s[131]! } - public var NetworkUsageSettings_BytesSent: String { return self._s[132]! } - public var Checkout_PasswordEntry_Pay: String { return self._s[133]! } - public var AuthSessions_TerminateSession: String { return self._s[134]! } - public var Message_File: String { return self._s[135]! } - public var MediaPicker_VideoMuteDescription: String { return self._s[136]! } - public var SocksProxySetup_ProxyStatusConnected: String { return self._s[137]! } - public var TwoStepAuth_RecoveryCode: String { return self._s[138]! } - public var EnterPasscode_EnterCurrentPasscode: String { return self._s[139]! } + public var TwoStepAuth_RecoveryUnavailable: String { return self._s[129]! } + public var EnterPasscode_TouchId: String { return self._s[130]! } + public var PhotoEditor_QualityVeryHigh: String { return self._s[133]! } + public var Checkout_NewCard_SaveInfo: String { return self._s[135]! } + public var ChatSettings_AutoDownloadEnabled: String { return self._s[139]! } + public var NetworkUsageSettings_BytesSent: String { return self._s[140]! } + public var Checkout_PasswordEntry_Pay: String { return self._s[141]! } + public var AuthSessions_TerminateSession: String { return self._s[142]! } + public var Message_File: String { return self._s[143]! } + public var MediaPicker_VideoMuteDescription: String { return self._s[144]! } + public var SocksProxySetup_ProxyStatusConnected: String { return self._s[145]! } + public var TwoStepAuth_RecoveryCode: String { return self._s[146]! } + public var EnterPasscode_EnterCurrentPasscode: String { return self._s[147]! } public func TwoStepAuth_EnterPasswordHint(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[140]!, self._r[140]!, [_0]) + return formatWithArgumentRanges(self._s[148]!, self._r[148]!, [_0]) } - public var Conversation_Moderate_Report: String { return self._s[142]! } - public var TwoStepAuth_EmailInvalid: String { return self._s[143]! } - public var Passport_Language_ms: String { return self._s[144]! } - public var Channel_Edit_AboutItem: String { return self._s[146]! } - public var DialogList_SearchSectionGlobal: String { return self._s[150]! } - public var AttachmentMenu_WebSearch: String { return self._s[151]! } - public var PasscodeSettings_TurnPasscodeOn: String { return self._s[152]! } - public var Channel_BanUser_Title: String { return self._s[153]! } - public var ChatSearch_SearchPlaceholder: String { return self._s[155]! } - public var Passport_FieldAddressTranslationHelp: String { return self._s[156]! } - public var NotificationsSound_Aurora: String { return self._s[157]! } + public var Conversation_Moderate_Report: String { return self._s[150]! } + public var TwoStepAuth_EmailInvalid: String { return self._s[151]! } + public var Channel_Edit_AboutItem: String { return self._s[152]! } + public var Passport_Language_ms: String { return self._s[156]! } + public var DialogList_SearchSectionGlobal: String { return self._s[158]! } + public var AttachmentMenu_WebSearch: String { return self._s[159]! } + public var PasscodeSettings_TurnPasscodeOn: String { return self._s[160]! } + public var Channel_BanUser_Title: String { return self._s[161]! } + public var ChatSearch_SearchPlaceholder: String { return self._s[163]! } + public var Passport_FieldAddressTranslationHelp: String { return self._s[164]! } + public var NotificationsSound_Aurora: String { return self._s[165]! } public func FileSize_GB(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[158]!, self._r[158]!, [_0]) + return formatWithArgumentRanges(self._s[166]!, self._r[166]!, [_0]) } - public var AuthSessions_LoggedInWithTelegram: String { return self._s[161]! } + public var AuthSessions_LoggedInWithTelegram: String { return self._s[169]! } public func Privacy_GroupsAndChannels_InviteToGroupError(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[162]!, self._r[162]!, [_0, _1]) + return formatWithArgumentRanges(self._s[170]!, self._r[170]!, [_0, _1]) } - public var Passport_PasswordNext: String { return self._s[163]! } - public var Bot_GroupStatusReadsHistory: String { return self._s[164]! } - public var Settings_FAQ_Intro: String { return self._s[166]! } - public var PrivacySettings_PasscodeAndTouchId: String { return self._s[168]! } - public var FeaturedStickerPacks_Title: String { return self._s[169]! } - public var TwoStepAuth_PasswordRemoveConfirmation: String { return self._s[170]! } - public var Username_Title: String { return self._s[171]! } + public var Passport_PasswordNext: String { return self._s[171]! } + public var Bot_GroupStatusReadsHistory: String { return self._s[172]! } + public var EmptyGroupInfo_Line2: String { return self._s[173]! } + public var Settings_FAQ_Intro: String { return self._s[175]! } + public var PrivacySettings_PasscodeAndTouchId: String { return self._s[177]! } + public var FeaturedStickerPacks_Title: String { return self._s[178]! } + public var TwoStepAuth_PasswordRemoveConfirmation: String { return self._s[179]! } + public var Username_Title: String { return self._s[180]! } public func Message_StickerText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[172]!, self._r[172]!, [_0]) + return formatWithArgumentRanges(self._s[181]!, self._r[181]!, [_0]) } - public var Localization_LanguageOther: String { return self._s[173]! } - public var Stickers_SuggestStickers: String { return self._s[174]! } + public var Localization_LanguageOther: String { return self._s[182]! } + public var Stickers_SuggestStickers: String { return self._s[183]! } public func Channel_AdminLog_MessageRemovedGroupUsername(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[175]!, self._r[175]!, [_0]) + return formatWithArgumentRanges(self._s[184]!, self._r[184]!, [_0]) + } + public var Channel_AdminLogFilter_EventsAdmins: String { return self._s[185]! } + public func AUTH_REGION_SEPARATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[186]!, self._r[186]!, [_1, _2]) } - public var Channel_AdminLogFilter_EventsAdmins: String { return self._s[176]! } public func Notification_PinnedDeletedMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[177]!, self._r[177]!, [_0]) + return formatWithArgumentRanges(self._s[187]!, self._r[187]!, [_0]) } - public var Group_UpgradeConfirmation: String { return self._s[179]! } - public var DialogList_Unpin: String { return self._s[180]! } - public var Passport_Identity_DateOfBirth: String { return self._s[181]! } - public var Month_ShortOctober: String { return self._s[182]! } - public var Notification_CallCanceledShort: String { return self._s[183]! } - public var Passport_Phone_Help: String { return self._s[184]! } - public var Passport_Language_az: String { return self._s[186]! } - public var CreatePoll_TextPlaceholder: String { return self._s[188]! } - public var Passport_Identity_DocumentNumber: String { return self._s[189]! } - public var PhotoEditor_CurvesRed: String { return self._s[190]! } - public var PhoneNumberHelp_Alert: String { return self._s[192]! } - public var SocksProxySetup_Port: String { return self._s[193]! } - public var Checkout_PayNone: String { return self._s[194]! } - public var AutoDownloadSettings_WiFi: String { return self._s[195]! } - public var GroupInfo_GroupType: String { return self._s[196]! } - public var StickerSettings_ContextHide: String { return self._s[197]! } - public var Passport_Address_OneOfTypeTemporaryRegistration: String { return self._s[198]! } + public var Group_UpgradeConfirmation: String { return self._s[190]! } + public var DialogList_Unpin: String { return self._s[191]! } + public var Passport_Identity_DateOfBirth: String { return self._s[192]! } + public var Month_ShortOctober: String { return self._s[193]! } + public func CHANNEL_MESSAGE_NOTEXT_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[194]!, self._r[194]!, [_1]) + } + public var Notification_CallCanceledShort: String { return self._s[195]! } + public var Passport_Phone_Help: String { return self._s[196]! } + public var Passport_Language_az: String { return self._s[198]! } + public var CreatePoll_TextPlaceholder: String { return self._s[200]! } + public var Passport_Identity_DocumentNumber: String { return self._s[201]! } + public var PhotoEditor_CurvesRed: String { return self._s[202]! } + public var PhoneNumberHelp_Alert: String { return self._s[204]! } + public var SocksProxySetup_Port: String { return self._s[205]! } + public var Checkout_PayNone: String { return self._s[206]! } + public var AutoDownloadSettings_WiFi: String { return self._s[207]! } + public var GroupInfo_GroupType: String { return self._s[208]! } + public var StickerSettings_ContextHide: String { return self._s[209]! } + public var Passport_Address_OneOfTypeTemporaryRegistration: String { return self._s[210]! } public func CHAT_RETURNED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[199]!, self._r[199]!, [_1, _2]) + return formatWithArgumentRanges(self._s[211]!, self._r[211]!, [_1, _2]) } - public var Group_Setup_HistoryTitle: String { return self._s[201]! } - public var Passport_Identity_FilesUploadNew: String { return self._s[202]! } - public var PasscodeSettings_AutoLock: String { return self._s[203]! } - public var Passport_Title: String { return self._s[204]! } - public var Channel_AdminLogFilter_EventsNewSubscribers: String { return self._s[205]! } - public var State_WaitingForNetwork: String { return self._s[207]! } + public var Group_Setup_HistoryTitle: String { return self._s[213]! } + public var Passport_Identity_FilesUploadNew: String { return self._s[214]! } + public var PasscodeSettings_AutoLock: String { return self._s[215]! } + public var Passport_Title: String { return self._s[216]! } + public var Channel_AdminLogFilter_EventsNewSubscribers: String { return self._s[217]! } + public var GroupPermission_NoSendGifs: String { return self._s[218]! } + public var State_WaitingForNetwork: String { return self._s[220]! } public func Notification_Invited(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[208]!, self._r[208]!, [_0, _1]) + return formatWithArgumentRanges(self._s[221]!, self._r[221]!, [_0, _1]) } - public var Calls_NotNow: String { return self._s[210]! } - public var UserInfo_SendMessage: String { return self._s[211]! } - public var TwoStepAuth_PasswordSet: String { return self._s[212]! } - public var Passport_DeleteDocument: String { return self._s[213]! } - public var SocksProxySetup_AddProxyTitle: String { return self._s[214]! } - public var Passport_FieldIdentity: String { return self._s[215]! } + public var Calls_NotNow: String { return self._s[223]! } + public var UserInfo_SendMessage: String { return self._s[224]! } + public var TwoStepAuth_PasswordSet: String { return self._s[225]! } + public var Passport_DeleteDocument: String { return self._s[226]! } + public var SocksProxySetup_AddProxyTitle: String { return self._s[227]! } + public var GroupRemoved_Remove: String { return self._s[228]! } + public var Passport_FieldIdentity: String { return self._s[229]! } public func CHAT_MESSAGE_FWDS(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[216]!, self._r[216]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[230]!, self._r[230]!, [_1, _2, _3]) } - public var Group_Setup_TypePrivateHelp: String { return self._s[217]! } - public var Conversation_Processing: String { return self._s[219]! } + public var Group_Setup_TypePrivateHelp: String { return self._s[231]! } + public var Conversation_Processing: String { return self._s[233]! } public func MESSAGE_CONTACT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[220]!, self._r[220]!, [_1]) + return formatWithArgumentRanges(self._s[234]!, self._r[234]!, [_1]) } public func MESSAGE_ROUND(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[222]!, self._r[222]!, [_1]) + return formatWithArgumentRanges(self._s[236]!, self._r[236]!, [_1]) } - public var ChatSettings_AutoPlayAnimations: String { return self._s[223]! } - public var AuthSessions_LogOutApplicationsHelp: String { return self._s[226]! } - public var Month_GenFebruary: String { return self._s[227]! } + public var ChatSettings_AutoPlayAnimations: String { return self._s[237]! } + public var AuthSessions_LogOutApplicationsHelp: String { return self._s[240]! } + public var Month_GenFebruary: String { return self._s[241]! } public func Login_InvalidPhoneEmailBody(_ _1: String, _ _2: String, _ _3: String, _ _4: String, _ _5: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[229]!, self._r[229]!, [_1, _2, _3, _4, _5]) + return formatWithArgumentRanges(self._s[243]!, self._r[243]!, [_1, _2, _3, _4, _5]) } - public var Passport_Identity_TypeIdentityCard: String { return self._s[230]! } - public var GroupInfo_AddParticipant: String { return self._s[232]! } - public var KeyCommand_SendMessage: String { return self._s[233]! } - public var Map_LiveLocationShowAll: String { return self._s[235]! } - public var Checkout_Receipt_Title: String { return self._s[237]! } - public var Message_Contact: String { return self._s[238]! } - public var Call_StatusIncoming: String { return self._s[239]! } + public var Passport_Identity_TypeIdentityCard: String { return self._s[244]! } + public var GroupInfo_AddParticipant: String { return self._s[246]! } + public var KeyCommand_SendMessage: String { return self._s[247]! } + public var Map_LiveLocationShowAll: String { return self._s[249]! } + public var Checkout_Receipt_Title: String { return self._s[251]! } + public var Message_Contact: String { return self._s[252]! } + public var Call_StatusIncoming: String { return self._s[253]! } public func Channel_AdminLog_MessageKickedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[240]!, self._r[240]!, [_1]) + return formatWithArgumentRanges(self._s[254]!, self._r[254]!, [_1]) } - public var Passport_FieldIdentityDetailsHelp: String { return self._s[242]! } - public var Conversation_ViewChannel: String { return self._s[243]! } + public var Passport_FieldIdentityDetailsHelp: String { return self._s[256]! } + public var Conversation_ViewChannel: String { return self._s[257]! } public func Time_TodayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[244]!, self._r[244]!, [_0]) + return formatWithArgumentRanges(self._s[258]!, self._r[258]!, [_0]) } - public var Passport_Language_nl: String { return self._s[246]! } - public var Camera_Retake: String { return self._s[247]! } - public var ApplyLanguage_ApplySuccess: String { return self._s[248]! } - public var AuthSessions_LogOutApplications: String { return self._s[249]! } - public var Tour_Title6: String { return self._s[250]! } - public var Map_ChooseAPlace: String { return self._s[251]! } - public var CallSettings_Never: String { return self._s[253]! } + public var Passport_Language_nl: String { return self._s[260]! } + public var Camera_Retake: String { return self._s[261]! } + public var AuthSessions_LogOutApplications: String { return self._s[262]! } + public var ApplyLanguage_ApplySuccess: String { return self._s[263]! } + public var Tour_Title6: String { return self._s[264]! } + public var Map_ChooseAPlace: String { return self._s[265]! } + public var CallSettings_Never: String { return self._s[267]! } public func Notification_ChangedGroupPhoto(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[254]!, self._r[254]!, [_0]) + return formatWithArgumentRanges(self._s[268]!, self._r[268]!, [_0]) } - public var GroupInfo_InviteLink_Title: String { return self._s[255]! } + public var ChannelRemoved_RemoveInfo: String { return self._s[269]! } + public var GroupInfo_InviteLink_Title: String { return self._s[270]! } public func Channel_AdminLog_MessageUnkickedNameUsername(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[256]!, self._r[256]!, [_1, _2]) + return formatWithArgumentRanges(self._s[271]!, self._r[271]!, [_1, _2]) } - public var KeyCommand_ScrollUp: String { return self._s[257]! } - public var ContactInfo_URLLabelHomepage: String { return self._s[258]! } + public var KeyCommand_ScrollUp: String { return self._s[272]! } + public var ContactInfo_URLLabelHomepage: String { return self._s[273]! } public func Conversation_EncryptedPlaceholderTitleOutgoing(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[259]!, self._r[259]!, [_0]) + return formatWithArgumentRanges(self._s[274]!, self._r[274]!, [_0]) + } + public var Watch_LastSeen_WithinAWeek: String { return self._s[275]! } + public var Weekday_Tuesday: String { return self._s[276]! } + public var UserInfo_StartSecretChat: String { return self._s[278]! } + public var Passport_Identity_FilesTitle: String { return self._s[279]! } + public var Permissions_NotificationsAllow_v0: String { return self._s[280]! } + public var DialogList_DeleteConversationConfirmation: String { return self._s[282]! } + public var AuthSessions_Sessions: String { return self._s[283]! } + public var TwoStepAuth_RecoveryEmailChangeDescription: String { return self._s[285]! } + public var Call_StatusWaiting: String { return self._s[286]! } + public var CreateGroup_SoftUserLimitAlert: String { return self._s[287]! } + public var FastTwoStepSetup_HintHelp: String { return self._s[288]! } + public func CHAT_ADD_YOU_SEPARATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[289]!, self._r[289]!, [_1, _2]) } - public var Watch_LastSeen_WithinAWeek: String { return self._s[260]! } - public var Weekday_Tuesday: String { return self._s[261]! } - public var UserInfo_StartSecretChat: String { return self._s[263]! } - public var Passport_Identity_FilesTitle: String { return self._s[264]! } - public var Permissions_NotificationsAllow_v0: String { return self._s[265]! } - public var DialogList_DeleteConversationConfirmation: String { return self._s[267]! } - public var AuthSessions_Sessions: String { return self._s[268]! } - public var TwoStepAuth_RecoveryEmailChangeDescription: String { return self._s[270]! } - public var Call_StatusWaiting: String { return self._s[271]! } - public var CreateGroup_SoftUserLimitAlert: String { return self._s[272]! } - public var FastTwoStepSetup_HintHelp: String { return self._s[273]! } public func MESSAGE_VIDEO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[274]!, self._r[274]!, [_1]) + return formatWithArgumentRanges(self._s[290]!, self._r[290]!, [_1]) } - public var Settings_LogoutConfirmationText: String { return self._s[275]! } - public var Passport_Identity_TypePassport: String { return self._s[277]! } - public var SocksProxySetup_SaveProxy: String { return self._s[280]! } - public var AccessDenied_SaveMedia: String { return self._s[281]! } - public var Checkout_ErrorInvoiceAlreadyPaid: String { return self._s[283]! } - public var Settings_Title: String { return self._s[285]! } - public var Contacts_InviteSearchLabel: String { return self._s[287]! } - public var ConvertToSupergroup_Title: String { return self._s[288]! } + public var Settings_LogoutConfirmationText: String { return self._s[291]! } + public var Passport_Identity_TypePassport: String { return self._s[293]! } + public var SocksProxySetup_SaveProxy: String { return self._s[296]! } + public var AccessDenied_SaveMedia: String { return self._s[297]! } + public var Checkout_ErrorInvoiceAlreadyPaid: String { return self._s[299]! } + public var Settings_Title: String { return self._s[301]! } + public var Contacts_InviteSearchLabel: String { return self._s[303]! } + public var ConvertToSupergroup_Title: String { return self._s[304]! } public func Channel_AdminLog_CaptionEdited(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[289]!, self._r[289]!, [_0]) + return formatWithArgumentRanges(self._s[305]!, self._r[305]!, [_0]) + } + public var InfoPlist_NSSiriUsageDescription: String { return self._s[306]! } + public var ChatSettings_AutomaticPhotoDownload: String { return self._s[307]! } + public var UserInfo_BotHelp: String { return self._s[308]! } + public var PrivacySettings_LastSeenEverybody: String { return self._s[309]! } + public var Checkout_Name: String { return self._s[310]! } + public var Channel_BanUser_BlockFor: String { return self._s[311]! } + public var Checkout_ShippingAddress: String { return self._s[312]! } + public var Privacy_PaymentsClearInfoDoneHelp: String { return self._s[313]! } + public var Channel_BanUser_PermissionSendPolls: String { return self._s[314]! } + public func CHAT_MESSAGE_AUDIO_SEPARATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[315]!, self._r[315]!, [_1, _2]) } - public var InfoPlist_NSSiriUsageDescription: String { return self._s[290]! } - public var ChatSettings_AutomaticPhotoDownload: String { return self._s[291]! } - public var UserInfo_BotHelp: String { return self._s[292]! } - public var PrivacySettings_LastSeenEverybody: String { return self._s[293]! } - public var Checkout_Name: String { return self._s[294]! } - public var Channel_BanUser_BlockFor: String { return self._s[295]! } - public var Checkout_ShippingAddress: String { return self._s[296]! } - public var Privacy_PaymentsClearInfoDoneHelp: String { return self._s[297]! } public func SecretVideo_NotViewedYet(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[300]!, self._r[300]!, [_0]) + return formatWithArgumentRanges(self._s[318]!, self._r[318]!, [_0]) } - public var Group_LeaveGroup: String { return self._s[301]! } - public var Settings_UsernameEmpty: String { return self._s[302]! } + public var Group_LeaveGroup: String { return self._s[319]! } + public var Settings_UsernameEmpty: String { return self._s[320]! } public func Notification_PinnedPollMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[303]!, self._r[303]!, [_0]) + return formatWithArgumentRanges(self._s[321]!, self._r[321]!, [_0]) } public func TwoStepAuth_ConfirmEmailDescription(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[304]!, self._r[304]!, [_1]) + return formatWithArgumentRanges(self._s[322]!, self._r[322]!, [_1]) } - public var Message_ImageExpired: String { return self._s[305]! } - public var TwoStepAuth_RecoveryFailed: String { return self._s[307]! } - public var UserInfo_AddToExisting: String { return self._s[308]! } - public var TwoStepAuth_EnabledSuccess: String { return self._s[309]! } - public var Notifications_GroupNotificationsAlert: String { return self._s[310]! } - public var Passport_Language_km: String { return self._s[311]! } - public var SocksProxySetup_AdNoticeHelp: String { return self._s[313]! } - public var Notification_CallMissedShort: String { return self._s[314]! } - public var ReportPeer_ReasonOther_Send: String { return self._s[315]! } - public var Watch_Compose_Send: String { return self._s[316]! } - public var Passport_Identity_TypeInternalPassportUploadScan: String { return self._s[319]! } - public var Conversation_HoldForVideo: String { return self._s[320]! } - public var CheckoutInfo_ErrorCityInvalid: String { return self._s[322]! } - public var Appearance_AutoNightThemeDisabled: String { return self._s[324]! } - public var Channel_LinkItem: String { return self._s[325]! } + public var Message_ImageExpired: String { return self._s[323]! } + public var TwoStepAuth_RecoveryFailed: String { return self._s[325]! } + public var UserInfo_AddToExisting: String { return self._s[326]! } + public var TwoStepAuth_EnabledSuccess: String { return self._s[327]! } + public func MESSAGE_GAME_SEPARATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[328]!, self._r[328]!, [_1, _2]) + } + public var Notifications_GroupNotificationsAlert: String { return self._s[329]! } + public var Passport_Language_km: String { return self._s[330]! } + public var SocksProxySetup_AdNoticeHelp: String { return self._s[332]! } + public var Notification_CallMissedShort: String { return self._s[333]! } + public var ReportPeer_ReasonOther_Send: String { return self._s[334]! } + public var Watch_Compose_Send: String { return self._s[335]! } + public var Passport_Identity_TypeInternalPassportUploadScan: String { return self._s[338]! } + public var Conversation_HoldForVideo: String { return self._s[339]! } + public var CheckoutInfo_ErrorCityInvalid: String { return self._s[341]! } + public var Appearance_AutoNightThemeDisabled: String { return self._s[343]! } + public var Channel_LinkItem: String { return self._s[344]! } public func PrivacySettings_LastSeenContactsMinusPlus(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[326]!, self._r[326]!, [_0, _1]) + return formatWithArgumentRanges(self._s[345]!, self._r[345]!, [_0, _1]) } public func Passport_Identity_NativeNameTitle(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[329]!, self._r[329]!, [_0]) - } - public var Passport_Language_dv: String { return self._s[330]! } - public var Notifications_ExceptionsMuted: String { return self._s[331]! } - public var Conversation_ContextMenuShare: String { return self._s[332]! } - public var Conversation_ContextMenuStickerPackInfo: String { return self._s[333]! } - public var ShareFileTip_Title: String { return self._s[334]! } - public var NotificationsSound_Chord: String { return self._s[335]! } - public var Passport_Address_EditTemporaryRegistration: String { return self._s[336]! } - public func Notification_Joined(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[337]!, self._r[337]!, [_0]) - } - public var Notification_CallOutgoingShort: String { return self._s[339]! } - public func Watch_Time_ShortFullAt(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[340]!, self._r[340]!, [_1, _2]) - } - public var Passport_Address_TypeUtilityBill: String { return self._s[341]! } - public func MESSAGE_VIDEO_SECRET(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[342]!, self._r[342]!, [_1]) - } - public var ReportPeer_Report: String { return self._s[343]! } - public var GroupInfo_DeactivatedStatus: String { return self._s[344]! } - public var StickerPack_Send: String { return self._s[345]! } - public var Login_CodeSentInternal: String { return self._s[346]! } - public var GroupInfo_InviteLink_LinkSection: String { return self._s[347]! } - public func Channel_AdminLog_MessageDeleted(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[348]!, self._r[348]!, [_0]) } + public var Passport_Language_dv: String { return self._s[349]! } + public var Notifications_ExceptionsMuted: String { return self._s[350]! } + public var Conversation_ContextMenuShare: String { return self._s[351]! } + public var Conversation_ContextMenuStickerPackInfo: String { return self._s[352]! } + public var ShareFileTip_Title: String { return self._s[353]! } + public var NotificationsSound_Chord: String { return self._s[354]! } + public var Passport_Address_EditTemporaryRegistration: String { return self._s[355]! } + public func Notification_Joined(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[356]!, self._r[356]!, [_0]) + } + public var Notification_CallOutgoingShort: String { return self._s[358]! } + public func Watch_Time_ShortFullAt(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[359]!, self._r[359]!, [_1, _2]) + } + public var Passport_Address_TypeUtilityBill: String { return self._s[360]! } + public func MESSAGE_VIDEO_SECRET(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[361]!, self._r[361]!, [_1]) + } + public var ReportPeer_Report: String { return self._s[362]! } + public var GroupInfo_DeactivatedStatus: String { return self._s[363]! } + public var StickerPack_Send: String { return self._s[364]! } + public var Login_CodeSentInternal: String { return self._s[365]! } + public var GroupInfo_InviteLink_LinkSection: String { return self._s[366]! } + public func Channel_AdminLog_MessageDeleted(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[367]!, self._r[367]!, [_0]) + } public func Conversation_EncryptionWaiting(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[350]!, self._r[350]!, [_0]) - } - public var Channel_BanUser_PermissionSendStickersAndGifs: String { return self._s[351]! } - public var ReportPeer_ReasonViolence: String { return self._s[353]! } - public var Map_Locating: String { return self._s[354]! } - public var AutoDownloadSettings_GroupChats: String { return self._s[356]! } - public var CheckoutInfo_SaveInfo: String { return self._s[357]! } - public var SharedMedia_EmptyLinksText: String { return self._s[359]! } - public var Passport_Address_CityPlaceholder: String { return self._s[360]! } - public var CheckoutInfo_ErrorStateInvalid: String { return self._s[361]! } - public var Channel_AdminLog_CanAddAdmins: String { return self._s[363]! } - public var GroupInfo_InviteLink_RevokeAlert_Success: String { return self._s[364]! } - public func Time_MonthOfYear_m8(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[365]!, self._r[365]!, [_0]) - } - public var InfoPlist_NSLocationWhenInUseUsageDescription: String { return self._s[366]! } - public func PINNED_VIDEO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[367]!, self._r[367]!, [_1]) - } - public var ChangePhoneNumberCode_Code: String { return self._s[368]! } - public func UserInfo_NotificationsDefaultSound(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[369]!, self._r[369]!, [_0]) } - public var TwoStepAuth_SetupEmail: String { return self._s[370]! } - public var HashtagSearch_AllChats: String { return self._s[371]! } + public var Channel_BanUser_PermissionSendStickersAndGifs: String { return self._s[370]! } + public var ReportPeer_ReasonViolence: String { return self._s[372]! } + public var Map_Locating: String { return self._s[373]! } + public var AutoDownloadSettings_GroupChats: String { return self._s[375]! } + public var CheckoutInfo_SaveInfo: String { return self._s[376]! } + public var SharedMedia_EmptyLinksText: String { return self._s[378]! } + public var Passport_Address_CityPlaceholder: String { return self._s[379]! } + public var CheckoutInfo_ErrorStateInvalid: String { return self._s[380]! } + public var Channel_AdminLog_CanAddAdmins: String { return self._s[382]! } + public var GroupInfo_InviteLink_RevokeAlert_Success: String { return self._s[383]! } + public func Time_MonthOfYear_m8(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[384]!, self._r[384]!, [_0]) + } + public var InfoPlist_NSLocationWhenInUseUsageDescription: String { return self._s[385]! } + public func PINNED_VIDEO(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[386]!, self._r[386]!, [_1]) + } + public var ChangePhoneNumberCode_Code: String { return self._s[387]! } + public func UserInfo_NotificationsDefaultSound(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[388]!, self._r[388]!, [_0]) + } + public var TwoStepAuth_SetupEmail: String { return self._s[389]! } + public var HashtagSearch_AllChats: String { return self._s[390]! } public func CHANNEL_MESSAGE_GIF(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[372]!, self._r[372]!, [_1]) + return formatWithArgumentRanges(self._s[391]!, self._r[391]!, [_1]) } - public var PhotoEditor_QualityHigh: String { return self._s[375]! } + public var PhotoEditor_QualityHigh: String { return self._s[394]! } public func Passport_Phone_UseTelegramNumber(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[376]!, self._r[376]!, [_0]) + return formatWithArgumentRanges(self._s[395]!, self._r[395]!, [_0]) } - public var ApplyLanguage_ApplyLanguageAction: String { return self._s[377]! } - public var Message_LiveLocation: String { return self._s[378]! } - public var Conversation_SendMessage: String { return self._s[379]! } - public var AuthSessions_EmptyTitle: String { return self._s[380]! } - public var CallSettings_UseLessData: String { return self._s[381]! } - public var NetworkUsageSettings_MediaDocumentDataSection: String { return self._s[382]! } - public var Stickers_AddToFavorites: String { return self._s[383]! } - public var PhotoEditor_QualityLow: String { return self._s[384]! } - public var Watch_UserInfo_Unblock: String { return self._s[385]! } - public var Settings_Logout: String { return self._s[386]! } - public var ContactInfo_PhoneLabelWork: String { return self._s[387]! } + public var ApplyLanguage_ApplyLanguageAction: String { return self._s[396]! } + public func MESSAGE_SCREENSHOT_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[397]!, self._r[397]!, [_1]) + } + public func PINNED_NOTEXT_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[398]!, self._r[398]!, [_1]) + } + public var Message_LiveLocation: String { return self._s[399]! } + public var Conversation_SendMessage: String { return self._s[400]! } + public var AuthSessions_EmptyTitle: String { return self._s[401]! } + public var CallSettings_UseLessData: String { return self._s[402]! } + public var NetworkUsageSettings_MediaDocumentDataSection: String { return self._s[403]! } + public var Stickers_AddToFavorites: String { return self._s[404]! } + public var PhotoEditor_QualityLow: String { return self._s[405]! } + public var Watch_UserInfo_Unblock: String { return self._s[406]! } + public var Settings_Logout: String { return self._s[407]! } + public var ContactInfo_PhoneLabelWork: String { return self._s[408]! } public func Date_ChatDateHeader(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[388]!, self._r[388]!, [_1, _2]) + return formatWithArgumentRanges(self._s[409]!, self._r[409]!, [_1, _2]) + } + public func PINNED_GAME_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[410]!, self._r[410]!, [_1]) } public func Message_ForwardedMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[389]!, self._r[389]!, [_0]) + return formatWithArgumentRanges(self._s[411]!, self._r[411]!, [_0]) } - public var Watch_Notification_Joined: String { return self._s[390]! } - public var Group_Setup_TypePublicHelp: String { return self._s[391]! } - public var Passport_Scans_UploadNew: String { return self._s[392]! } - public var Checkout_LiabilityAlertTitle: String { return self._s[393]! } - public var DialogList_Title: String { return self._s[394]! } - public var NotificationSettings_ContactJoined: String { return self._s[395]! } - public var GroupInfo_LabelAdmin: String { return self._s[396]! } - public var KeyCommand_ChatInfo: String { return self._s[397]! } - public var Conversation_EditingCaptionPanelTitle: String { return self._s[398]! } - public var Call_ReportIncludeLog: String { return self._s[399]! } + public var Watch_Notification_Joined: String { return self._s[412]! } + public var Group_Setup_TypePublicHelp: String { return self._s[413]! } + public var Passport_Scans_UploadNew: String { return self._s[414]! } + public var Checkout_LiabilityAlertTitle: String { return self._s[415]! } + public var DialogList_Title: String { return self._s[416]! } + public var NotificationSettings_ContactJoined: String { return self._s[417]! } + public var GroupInfo_LabelAdmin: String { return self._s[418]! } + public var KeyCommand_ChatInfo: String { return self._s[419]! } + public var Conversation_EditingCaptionPanelTitle: String { return self._s[420]! } + public var Call_ReportIncludeLog: String { return self._s[421]! } public func Notifications_ExceptionsChangeSound(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[402]!, self._r[402]!, [_0]) + return formatWithArgumentRanges(self._s[424]!, self._r[424]!, [_0]) } - public var ChatAdmins_AllMembersAreAdmins: String { return self._s[403]! } - public var Message_Sticker: String { return self._s[404]! } - public var LastSeen_JustNow: String { return self._s[406]! } - public var Passport_Email_EmailPlaceholder: String { return self._s[408]! } - public var Channel_AdminLogFilter_EventsEditedMessages: String { return self._s[409]! } - public var Channel_EditAdmin_PermissionsHeader: String { return self._s[410]! } - public var TwoStepAuth_Email: String { return self._s[411]! } - public var PhotoEditor_BlurToolOff: String { return self._s[412]! } - public var Message_PinnedStickerMessage: String { return self._s[413]! } - public var ContactInfo_PhoneLabelPager: String { return self._s[414]! } - public var Passport_DiscardMessageTitle: String { return self._s[415]! } - public var Privacy_PaymentsTitle: String { return self._s[416]! } + public var ChatAdmins_AllMembersAreAdmins: String { return self._s[425]! } + public var Message_Sticker: String { return self._s[426]! } + public var LastSeen_JustNow: String { return self._s[428]! } + public var Passport_Email_EmailPlaceholder: String { return self._s[430]! } + public var Channel_AdminLogFilter_EventsEditedMessages: String { return self._s[431]! } + public var Channel_EditAdmin_PermissionsHeader: String { return self._s[432]! } + public var TwoStepAuth_Email: String { return self._s[433]! } + public var PhotoEditor_BlurToolOff: String { return self._s[434]! } + public var Message_PinnedStickerMessage: String { return self._s[435]! } + public var ContactInfo_PhoneLabelPager: String { return self._s[436]! } + public var Passport_DiscardMessageTitle: String { return self._s[437]! } + public var Privacy_PaymentsTitle: String { return self._s[438]! } public func MESSAGE_FWDS(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[418]!, self._r[418]!, [_1, _2]) + return formatWithArgumentRanges(self._s[440]!, self._r[440]!, [_1, _2]) } - public var Appearance_ColorTheme: String { return self._s[419]! } - public var UserInfo_ShareContact: String { return self._s[420]! } - public var Watch_Message_Call: String { return self._s[421]! } - public var Common_More: String { return self._s[422]! } - public var Passport_Address_TypePassportRegistration: String { return self._s[423]! } - public var Profile_EncryptionKey: String { return self._s[426]! } - public var Privacy_TopPeers: String { return self._s[427]! } - public var Conversation_StopPollConfirmation: String { return self._s[428]! } + public var Appearance_ColorTheme: String { return self._s[441]! } + public var UserInfo_ShareContact: String { return self._s[442]! } + public var Passport_Address_TypePassportRegistration: String { return self._s[443]! } + public var Common_More: String { return self._s[444]! } + public var Watch_Message_Call: String { return self._s[445]! } + public var Profile_EncryptionKey: String { return self._s[448]! } + public var Privacy_TopPeers: String { return self._s[449]! } + public var Conversation_StopPollConfirmation: String { return self._s[450]! } public func CHANNEL_MESSAGE_TEXT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[429]!, self._r[429]!, [_1, _2]) + return formatWithArgumentRanges(self._s[451]!, self._r[451]!, [_1, _2]) } - public var Privacy_TopPeersWarning: String { return self._s[431]! } - public var DialogList_SearchSectionMessages: String { return self._s[434]! } - public var Notifications_ChannelNotifications: String { return self._s[435]! } - public var CheckoutInfo_ShippingInfoAddress1Placeholder: String { return self._s[436]! } - public var Passport_Language_sk: String { return self._s[437]! } - public var Notification_MessageLifetime1h: String { return self._s[438]! } - public var Call_ReportSkip: String { return self._s[440]! } - public var Cache_ServiceFiles: String { return self._s[441]! } - public var Group_ErrorAddTooMuchAdmins: String { return self._s[442]! } - public var Map_Hybrid: String { return self._s[443]! } - public var ChatSettings_AutoDownloadVideos: String { return self._s[446]! } - public var Channel_BanUser_PermissionEmbedLinks: String { return self._s[447]! } - public var InfoPlist_NSLocationAlwaysAndWhenInUseUsageDescription: String { return self._s[448]! } - public var SocksProxySetup_ProxyTelegram: String { return self._s[451]! } - public var Channel_Username_CreatePrivateLinkHelp: String { return self._s[453]! } - public var Conversation_LiveLocationYou: String { return self._s[454]! } - public var UserInfo_ShareBot: String { return self._s[457]! } - public var PhotoEditor_ShadowsTint: String { return self._s[458]! } - public var Message_Audio: String { return self._s[459]! } - public var Passport_Language_lt: String { return self._s[460]! } + public var Privacy_TopPeersWarning: String { return self._s[453]! } + public var DialogList_SearchSectionMessages: String { return self._s[456]! } + public var Notifications_ChannelNotifications: String { return self._s[457]! } + public var CheckoutInfo_ShippingInfoAddress1Placeholder: String { return self._s[458]! } + public var Notification_MessageLifetime1h: String { return self._s[459]! } + public var Passport_Language_sk: String { return self._s[460]! } + public var Call_ReportSkip: String { return self._s[462]! } + public var Cache_ServiceFiles: String { return self._s[463]! } + public var Group_ErrorAddTooMuchAdmins: String { return self._s[464]! } + public var Map_Hybrid: String { return self._s[465]! } + public var ChatSettings_AutoDownloadVideos: String { return self._s[468]! } + public var Channel_BanUser_PermissionEmbedLinks: String { return self._s[469]! } + public var InfoPlist_NSLocationAlwaysAndWhenInUseUsageDescription: String { return self._s[470]! } + public var SocksProxySetup_ProxyTelegram: String { return self._s[473]! } + public var Channel_Username_CreatePrivateLinkHelp: String { return self._s[475]! } + public var Conversation_LiveLocationYou: String { return self._s[476]! } + public var UserInfo_ShareBot: String { return self._s[479]! } + public var PhotoEditor_ShadowsTint: String { return self._s[480]! } + public var Message_Audio: String { return self._s[481]! } + public var Passport_Language_lt: String { return self._s[482]! } public func Message_PinnedTextMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[461]!, self._r[461]!, [_0]) - } - public var Permissions_SiriText_v0: String { return self._s[462]! } - public var Conversation_FileICloudDrive: String { return self._s[463]! } - public var Notifications_Badge_IncludeMutedChats: String { return self._s[464]! } - public func Notification_NewAuthDetected(_ _1: String, _ _2: String, _ _3: String, _ _4: String, _ _5: String, _ _6: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[465]!, self._r[465]!, [_1, _2, _3, _4, _5, _6]) - } - public var DialogList_ProxyConnectionIssuesTooltip: String { return self._s[466]! } - public func Time_MonthOfYear_m5(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[467]!, self._r[467]!, [_0]) - } - public var Channel_SignMessages: String { return self._s[468]! } - public var Compose_ChannelTokenListPlaceholder: String { return self._s[469]! } - public var Passport_ScanPassport: String { return self._s[470]! } - public var Watch_Message_Invoice: String { return self._s[471]! } - public var Watch_Suggestion_Thanks: String { return self._s[472]! } - public var BlockedUsers_AddNew: String { return self._s[473]! } - public var Month_GenJuly: String { return self._s[474]! } - public var SocksProxySetup_ProxySocks5: String { return self._s[475]! } - public func CHAT_MESSAGE_PHOTO(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[476]!, self._r[476]!, [_1, _2]) - } - public var Notification_ChannelInviterSelf: String { return self._s[478]! } - public var CheckoutInfo_ReceiverInfoEmail: String { return self._s[479]! } - public func ApplyLanguage_ChangeLanguageUnofficialText(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[480]!, self._r[480]!, [_1, _2]) - } - public var CheckoutInfo_Title: String { return self._s[481]! } - public var Watch_Stickers_RecentPlaceholder: String { return self._s[482]! } - public func Map_DistanceAway(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[483]!, self._r[483]!, [_0]) } - public var TwoStepAuth_ConfirmEmailResendCode: String { return self._s[484]! } - public var Passport_Identity_MainPage: String { return self._s[485]! } - public var Passport_Language_de: String { return self._s[486]! } - public var Update_Title: String { return self._s[487]! } - public var ContactInfo_PhoneLabelWorkFax: String { return self._s[488]! } - public var Channel_AdminLog_BanEmbedLinks: String { return self._s[489]! } - public var Passport_Email_UseTelegramEmailHelp: String { return self._s[490]! } - public var Notifications_ChannelNotificationsPreview: String { return self._s[491]! } - public var NotificationsSound_Telegraph: String { return self._s[492]! } - public var Watch_LastSeen_ALongTimeAgo: String { return self._s[493]! } - public var ChannelMembers_WhoCanAddMembers: String { return self._s[494]! } + public var Permissions_SiriText_v0: String { return self._s[484]! } + public var Conversation_FileICloudDrive: String { return self._s[485]! } + public var Notifications_Badge_IncludeMutedChats: String { return self._s[486]! } + public func Notification_NewAuthDetected(_ _1: String, _ _2: String, _ _3: String, _ _4: String, _ _5: String, _ _6: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[487]!, self._r[487]!, [_1, _2, _3, _4, _5, _6]) + } + public var DialogList_ProxyConnectionIssuesTooltip: String { return self._s[488]! } + public func Time_MonthOfYear_m5(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[489]!, self._r[489]!, [_0]) + } + public var Channel_SignMessages: String { return self._s[490]! } + public var Compose_ChannelTokenListPlaceholder: String { return self._s[491]! } + public var Passport_ScanPassport: String { return self._s[492]! } + public var Watch_Suggestion_Thanks: String { return self._s[493]! } + public var BlockedUsers_AddNew: String { return self._s[494]! } + public var Watch_Message_Invoice: String { return self._s[495]! } + public var Month_GenJuly: String { return self._s[496]! } + public var SocksProxySetup_ProxySocks5: String { return self._s[497]! } + public func PINNED_INVOICE_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[498]!, self._r[498]!, [_1]) + } + public func CHAT_MESSAGE_PHOTO(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[500]!, self._r[500]!, [_1, _2]) + } + public func CHANNEL_MESSAGE_TEXT_SEPARATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[501]!, self._r[501]!, [_1, _2]) + } + public var Notification_ChannelInviterSelf: String { return self._s[502]! } + public var CheckoutInfo_ReceiverInfoEmail: String { return self._s[503]! } + public func ApplyLanguage_ChangeLanguageUnofficialText(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[504]!, self._r[504]!, [_1, _2]) + } + public var CheckoutInfo_Title: String { return self._s[505]! } + public var Watch_Stickers_RecentPlaceholder: String { return self._s[506]! } + public func Map_DistanceAway(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[507]!, self._r[507]!, [_0]) + } + public var Passport_Identity_MainPage: String { return self._s[508]! } + public var TwoStepAuth_ConfirmEmailResendCode: String { return self._s[509]! } + public var Passport_Language_de: String { return self._s[510]! } + public var Update_Title: String { return self._s[511]! } + public var ContactInfo_PhoneLabelWorkFax: String { return self._s[512]! } + public var Channel_AdminLog_BanEmbedLinks: String { return self._s[513]! } + public var Passport_Email_UseTelegramEmailHelp: String { return self._s[514]! } + public var Notifications_ChannelNotificationsPreview: String { return self._s[515]! } + public var NotificationsSound_Telegraph: String { return self._s[516]! } + public var Watch_LastSeen_ALongTimeAgo: String { return self._s[517]! } + public var ChannelMembers_WhoCanAddMembers: String { return self._s[518]! } public func AutoDownloadSettings_UpTo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[495]!, self._r[495]!, [_0]) + return formatWithArgumentRanges(self._s[519]!, self._r[519]!, [_0]) } - public var Stickers_SuggestAll: String { return self._s[496]! } - public var Conversation_ForwardTitle: String { return self._s[497]! } + public var Stickers_SuggestAll: String { return self._s[520]! } + public var Conversation_ForwardTitle: String { return self._s[521]! } public func Notification_JoinedChannel(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[498]!, self._r[498]!, [_0]) + return formatWithArgumentRanges(self._s[522]!, self._r[522]!, [_0]) } - public var Calls_NewCall: String { return self._s[499]! } - public var Call_StatusEnded: String { return self._s[500]! } - public var Settings_ProxyConnected: String { return self._s[501]! } - public var Channel_AdminLogFilter_EventsPinned: String { return self._s[502]! } - public var PhotoEditor_QualityVeryLow: String { return self._s[503]! } - public var Channel_AdminLogFilter_EventsDeletedMessages: String { return self._s[504]! } - public var Passport_PasswordPlaceholder: String { return self._s[505]! } - public var Message_PinnedInvoice: String { return self._s[506]! } - public var Passport_Identity_IssueDate: String { return self._s[507]! } - public var Passport_Language_pl: String { return self._s[508]! } + public var Calls_NewCall: String { return self._s[523]! } + public var Call_StatusEnded: String { return self._s[524]! } + public var Settings_ProxyConnected: String { return self._s[525]! } + public var Channel_AdminLogFilter_EventsPinned: String { return self._s[526]! } + public var PhotoEditor_QualityVeryLow: String { return self._s[527]! } + public var Channel_AdminLogFilter_EventsDeletedMessages: String { return self._s[528]! } + public var Passport_PasswordPlaceholder: String { return self._s[529]! } + public var Message_PinnedInvoice: String { return self._s[530]! } + public var Passport_Identity_IssueDate: String { return self._s[531]! } public func ChannelInfo_ChannelForbidden(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[509]!, self._r[509]!, [_0]) + return formatWithArgumentRanges(self._s[532]!, self._r[532]!, [_0]) } - public var SocksProxySetup_PasteFromClipboard: String { return self._s[510]! } - public var Call_StatusConnecting: String { return self._s[511]! } + public var Passport_Language_pl: String { return self._s[533]! } + public var Call_StatusConnecting: String { return self._s[534]! } + public var SocksProxySetup_PasteFromClipboard: String { return self._s[535]! } public func Username_UsernameIsAvailable(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[512]!, self._r[512]!, [_0]) + return formatWithArgumentRanges(self._s[536]!, self._r[536]!, [_0]) } - public var ChatSettings_ConnectionType_UseProxy: String { return self._s[514]! } - public var Common_Edit: String { return self._s[515]! } - public var PrivacySettings_LastSeenNobody: String { return self._s[516]! } + public var ChatSettings_ConnectionType_UseProxy: String { return self._s[538]! } + public var Common_Edit: String { return self._s[539]! } + public var PrivacySettings_LastSeenNobody: String { return self._s[540]! } public func Notification_LeftChat(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[517]!, self._r[517]!, [_0]) + return formatWithArgumentRanges(self._s[541]!, self._r[541]!, [_0]) } - public var GroupInfo_ChatAdmins: String { return self._s[518]! } - public var PrivateDataSettings_Title: String { return self._s[519]! } - public var Login_CancelPhoneVerificationStop: String { return self._s[520]! } - public var ChatList_Read: String { return self._s[521]! } - public var Checkout_ErrorPaymentFailed: String { return self._s[523]! } - public var Update_UpdateApp: String { return self._s[524]! } - public var Group_Username_RevokeExistingUsernamesInfo: String { return self._s[525]! } - public var Settings_Appearance: String { return self._s[526]! } - public var Watch_Location_Access: String { return self._s[527]! } - public var ShareMenu_CopyShareLink: String { return self._s[529]! } - public var TwoStepAuth_SetupHintTitle: String { return self._s[530]! } + public var GroupInfo_ChatAdmins: String { return self._s[542]! } + public var PrivateDataSettings_Title: String { return self._s[543]! } + public func AUTH_UNKNOWN_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[544]!, self._r[544]!, [_1]) + } + public var Login_CancelPhoneVerificationStop: String { return self._s[545]! } + public var ChatList_Read: String { return self._s[546]! } + public var GroupPermission_SectionTitle: String { return self._s[547]! } + public var Checkout_ErrorPaymentFailed: String { return self._s[549]! } + public var Update_UpdateApp: String { return self._s[550]! } + public var Group_Username_RevokeExistingUsernamesInfo: String { return self._s[551]! } + public var Settings_Appearance: String { return self._s[552]! } + public var Watch_Location_Access: String { return self._s[553]! } + public var ShareMenu_CopyShareLink: String { return self._s[555]! } + public var TwoStepAuth_SetupHintTitle: String { return self._s[556]! } public func PHONE_CALL_MISSED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[532]!, self._r[532]!, [_1]) + return formatWithArgumentRanges(self._s[558]!, self._r[558]!, [_1]) } public func CHAT_MESSAGE_PHOTOS(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[533]!, self._r[533]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[559]!, self._r[559]!, [_1, _2, _3]) } public func DialogList_SingleRecordingVideoMessageSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[534]!, self._r[534]!, [_0]) + return formatWithArgumentRanges(self._s[560]!, self._r[560]!, [_0]) + } + public var Notifications_ClassicTones: String { return self._s[561]! } + public var Weekday_ShortWednesday: String { return self._s[562]! } + public func PHONE_CALL_REQUEST_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[563]!, self._r[563]!, [_1]) } - public var Notifications_ClassicTones: String { return self._s[535]! } - public var Weekday_ShortWednesday: String { return self._s[536]! } public func CHANNEL_MESSAGE_POLL(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[539]!, self._r[539]!, [_1]) + return formatWithArgumentRanges(self._s[566]!, self._r[566]!, [_1]) } - public var Conversation_LinkDialogCopy: String { return self._s[540]! } - public var KeyCommand_FocusOnInputField: String { return self._s[541]! } - public var Contacts_SelectAll: String { return self._s[542]! } - public var Preview_SaveToCameraRoll: String { return self._s[543]! } + public var Conversation_LinkDialogCopy: String { return self._s[567]! } + public var KeyCommand_FocusOnInputField: String { return self._s[568]! } + public var Contacts_SelectAll: String { return self._s[569]! } + public var Preview_SaveToCameraRoll: String { return self._s[570]! } public func CHANNEL_MESSAGE_GAME(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[544]!, self._r[544]!, [_1, _2]) + return formatWithArgumentRanges(self._s[571]!, self._r[571]!, [_1, _2]) } - public var Wallpaper_Title: String { return self._s[545]! } - public var Conversation_FilePhotoOrVideo: String { return self._s[546]! } - public var AccessDenied_Camera: String { return self._s[547]! } - public var Watch_Compose_CurrentLocation: String { return self._s[548]! } + public var Wallpaper_Title: String { return self._s[572]! } + public var Conversation_FilePhotoOrVideo: String { return self._s[573]! } + public var AccessDenied_Camera: String { return self._s[574]! } + public var Watch_Compose_CurrentLocation: String { return self._s[575]! } public func SecretImage_NotViewedYet(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[550]!, self._r[550]!, [_0]) + return formatWithArgumentRanges(self._s[577]!, self._r[577]!, [_0]) } - public var GroupInfo_InvitationLinkDoesNotExist: String { return self._s[551]! } - public var Passport_Language_ro: String { return self._s[552]! } - public var CheckoutInfo_SaveInfoHelp: String { return self._s[553]! } + public var GroupInfo_InvitationLinkDoesNotExist: String { return self._s[578]! } + public var Passport_Language_ro: String { return self._s[579]! } + public var CheckoutInfo_SaveInfoHelp: String { return self._s[580]! } public func Notification_SecretChatMessageScreenshot(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[554]!, self._r[554]!, [_0]) + return formatWithArgumentRanges(self._s[581]!, self._r[581]!, [_0]) } - public var Login_CancelPhoneVerification: String { return self._s[555]! } - public var State_ConnectingToProxy: String { return self._s[556]! } - public var Calls_RatingTitle: String { return self._s[557]! } - public var Generic_ErrorMoreInfo: String { return self._s[558]! } - public var Appearance_PreviewReplyText: String { return self._s[559]! } - public var CheckoutInfo_ShippingInfoPostcodePlaceholder: String { return self._s[560]! } - public var SharedMedia_CategoryLinks: String { return self._s[561]! } - public var Calls_Missed: String { return self._s[562]! } - public var Cache_Photos: String { return self._s[566]! } + public var Login_CancelPhoneVerification: String { return self._s[582]! } + public var State_ConnectingToProxy: String { return self._s[583]! } + public var Calls_RatingTitle: String { return self._s[584]! } + public var Generic_ErrorMoreInfo: String { return self._s[585]! } + public var Appearance_PreviewReplyText: String { return self._s[586]! } + public var CheckoutInfo_ShippingInfoPostcodePlaceholder: String { return self._s[587]! } + public var SharedMedia_CategoryLinks: String { return self._s[588]! } + public var Calls_Missed: String { return self._s[589]! } + public var Cache_Photos: String { return self._s[593]! } + public var GroupPermission_NoAddMembers: String { return self._s[594]! } public func Channel_AdminLog_MessageUnpinned(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[567]!, self._r[567]!, [_0]) + return formatWithArgumentRanges(self._s[595]!, self._r[595]!, [_0]) } - public var Conversation_ShareBotLocationConfirmationTitle: String { return self._s[568]! } - public var Settings_ProxyDisabled: String { return self._s[569]! } + public var Conversation_ShareBotLocationConfirmationTitle: String { return self._s[596]! } + public var Settings_ProxyDisabled: String { return self._s[597]! } public func Settings_ApplyProxyAlertCredentials(_ _1: String, _ _2: String, _ _3: String, _ _4: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[570]!, self._r[570]!, [_1, _2, _3, _4]) + return formatWithArgumentRanges(self._s[598]!, self._r[598]!, [_1, _2, _3, _4]) } public func Conversation_RestrictedMediaTimed(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[571]!, self._r[571]!, [_0]) + return formatWithArgumentRanges(self._s[599]!, self._r[599]!, [_0]) } - public var Appearance_Title: String { return self._s[572]! } + public var Appearance_Title: String { return self._s[600]! } public func Time_MonthOfYear_m2(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[574]!, self._r[574]!, [_0]) - } - public func CHANNEL_MESSAGE_DOC(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[575]!, self._r[575]!, [_1]) - } - public func PINNED_DOC(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[576]!, self._r[576]!, [_1]) - } - public var StickerPacksSettings_ShowStickersButtonHelp: String { return self._s[577]! } - public var Channel_EditMessageErrorGeneric: String { return self._s[578]! } - public var Privacy_Calls_IntegrationHelp: String { return self._s[579]! } - public var Preview_DeletePhoto: String { return self._s[580]! } - public var PrivacySettings_PrivacyTitle: String { return self._s[581]! } - public func Conversation_BotInteractiveUrlAlert(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[582]!, self._r[582]!, [_0]) - } - public var Coub_TapForSound: String { return self._s[584]! } - public var Map_LocatingError: String { return self._s[585]! } - public func CHAT_MESSAGE_TEXT(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[587]!, self._r[587]!, [_1, _2, _3]) - } - public var TwoStepAuth_EmailChangeSuccess: String { return self._s[588]! } - public var Passport_ForgottenPassword: String { return self._s[589]! } - public var GroupInfo_InviteLink_RevokeLink: String { return self._s[590]! } - public var StickerPacksSettings_ArchivedPacks: String { return self._s[591]! } - public func PINNED_STICKER(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[593]!, self._r[593]!, [_1, _2]) - } - public var Login_TermsOfServiceSignupDecline: String { return self._s[594]! } - public var Channel_Moderator_AccessLevelRevoke: String { return self._s[595]! } - public var Message_Location: String { return self._s[596]! } - public var Passport_Identity_NamePlaceholder: String { return self._s[597]! } - public var Channel_Management_Title: String { return self._s[598]! } - public var DialogList_SearchSectionDialogs: String { return self._s[600]! } - public var Compose_NewChannel_Members: String { return self._s[601]! } - public func DialogList_SingleUploadingFileSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[602]!, self._r[602]!, [_0]) } - public var AutoNightTheme_ScheduledFrom: String { return self._s[603]! } - public var PhotoEditor_WarmthTool: String { return self._s[604]! } - public var Passport_Language_tr: String { return self._s[605]! } - public var Login_ResetAccountProtected_Reset: String { return self._s[607]! } - public var Watch_PhotoView_Title: String { return self._s[608]! } + public func CHANNEL_MESSAGE_DOC(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[603]!, self._r[603]!, [_1]) + } + public func PINNED_DOC(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[604]!, self._r[604]!, [_1]) + } + public var StickerPacksSettings_ShowStickersButtonHelp: String { return self._s[605]! } + public func CHANNEL_MESSAGE_DOC_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[606]!, self._r[606]!, [_1]) + } + public var Channel_EditMessageErrorGeneric: String { return self._s[607]! } + public var Privacy_Calls_IntegrationHelp: String { return self._s[608]! } + public var Preview_DeletePhoto: String { return self._s[609]! } + public var PrivacySettings_PrivacyTitle: String { return self._s[610]! } + public func Conversation_BotInteractiveUrlAlert(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[611]!, self._r[611]!, [_0]) + } + public var Coub_TapForSound: String { return self._s[613]! } + public var Map_LocatingError: String { return self._s[614]! } + public func CHAT_MESSAGE_TEXT(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[616]!, self._r[616]!, [_1, _2, _3]) + } + public var TwoStepAuth_EmailChangeSuccess: String { return self._s[617]! } + public var Passport_ForgottenPassword: String { return self._s[618]! } + public var GroupInfo_InviteLink_RevokeLink: String { return self._s[619]! } + public var StickerPacksSettings_ArchivedPacks: String { return self._s[620]! } + public func PINNED_STICKER(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[622]!, self._r[622]!, [_1, _2]) + } + public var Login_TermsOfServiceSignupDecline: String { return self._s[623]! } + public var Channel_Moderator_AccessLevelRevoke: String { return self._s[624]! } + public var Message_Location: String { return self._s[625]! } + public var Passport_Identity_NamePlaceholder: String { return self._s[626]! } + public var Channel_Management_Title: String { return self._s[627]! } + public var DialogList_SearchSectionDialogs: String { return self._s[629]! } + public var Compose_NewChannel_Members: String { return self._s[630]! } + public func DialogList_SingleUploadingFileSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[631]!, self._r[631]!, [_0]) + } + public var AutoNightTheme_ScheduledFrom: String { return self._s[632]! } + public var PhotoEditor_WarmthTool: String { return self._s[633]! } + public var Passport_Language_tr: String { return self._s[634]! } + public var Login_ResetAccountProtected_Reset: String { return self._s[636]! } + public var Watch_PhotoView_Title: String { return self._s[637]! } + public var Passport_Phone_Delete: String { return self._s[639]! } public func MESSAGES(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[609]!, self._r[609]!, [_1, _2]) + return formatWithArgumentRanges(self._s[640]!, self._r[640]!, [_1, _2]) } - public var Passport_Phone_Delete: String { return self._s[610]! } - public var Conversation_EditingMessageMediaEditCurrentPhoto: String { return self._s[611]! } - public var PasscodeSettings_TurnPasscodeOff: String { return self._s[612]! } - public var Profile_ShareContactButton: String { return self._s[613]! } - public var ChatSettings_Other: String { return self._s[614]! } - public var UserInfo_NotificationsDisabled: String { return self._s[615]! } - public var CheckoutInfo_ShippingInfoCity: String { return self._s[616]! } - public var LastSeen_WithinAMonth: String { return self._s[617]! } - public var Channel_AdminLog_BanSendStickers: String { return self._s[618]! } - public var Conversation_EncryptionCanceled: String { return self._s[619]! } - public var MediaPicker_GroupDescription: String { return self._s[620]! } - public var WebSearch_Images: String { return self._s[621]! } + public var Conversation_EditingMessageMediaEditCurrentPhoto: String { return self._s[641]! } + public var GroupInfo_Permissions: String { return self._s[642]! } + public var PasscodeSettings_TurnPasscodeOff: String { return self._s[643]! } + public var Profile_ShareContactButton: String { return self._s[644]! } + public func CHAT_LEFT_SEPARATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[645]!, self._r[645]!, [_1, _2]) + } + public var ChatSettings_Other: String { return self._s[646]! } + public var UserInfo_NotificationsDisabled: String { return self._s[647]! } + public var CheckoutInfo_ShippingInfoCity: String { return self._s[648]! } + public var LastSeen_WithinAMonth: String { return self._s[649]! } + public var Channel_AdminLog_BanSendStickers: String { return self._s[650]! } + public var Conversation_EncryptionCanceled: String { return self._s[651]! } + public var MediaPicker_GroupDescription: String { return self._s[652]! } + public var WebSearch_Images: String { return self._s[653]! } public func Channel_Management_PromotedBy(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[622]!, self._r[622]!, [_0]) + return formatWithArgumentRanges(self._s[654]!, self._r[654]!, [_0]) } - public var Message_Photo: String { return self._s[623]! } - public var PasscodeSettings_HelpBottom: String { return self._s[624]! } - public var AutoDownloadSettings_VideosTitle: String { return self._s[625]! } - public var Passport_Identity_AddDriversLicense: String { return self._s[626]! } - public var TwoStepAuth_EnterPasswordPassword: String { return self._s[627]! } - public var NotificationsSound_Calypso: String { return self._s[628]! } - public var Map_Map: String { return self._s[629]! } - public var CheckoutInfo_ReceiverInfoTitle: String { return self._s[631]! } - public var ChatSettings_TextSizeUnits: String { return self._s[632]! } - public var Common_of: String { return self._s[633]! } - public var Conversation_ForwardContacts: String { return self._s[635]! } - public var Passport_Language_hy: String { return self._s[636]! } - public var Notifications_MessageNotificationsHelp: String { return self._s[637]! } - public var AutoDownloadSettings_Reset: String { return self._s[638]! } - public var Paint_ClearConfirm: String { return self._s[639]! } - public var Camera_VideoMode: String { return self._s[640]! } + public var Message_Photo: String { return self._s[655]! } + public var PasscodeSettings_HelpBottom: String { return self._s[656]! } + public var AutoDownloadSettings_VideosTitle: String { return self._s[657]! } + public var Passport_Identity_AddDriversLicense: String { return self._s[658]! } + public var TwoStepAuth_EnterPasswordPassword: String { return self._s[659]! } + public var NotificationsSound_Calypso: String { return self._s[660]! } + public var Map_Map: String { return self._s[661]! } + public var CheckoutInfo_ReceiverInfoTitle: String { return self._s[663]! } + public var ChatSettings_TextSizeUnits: String { return self._s[664]! } + public var Common_of: String { return self._s[665]! } + public var Conversation_ForwardContacts: String { return self._s[667]! } + public var Passport_Language_hy: String { return self._s[668]! } + public var Notifications_MessageNotificationsHelp: String { return self._s[669]! } + public var AutoDownloadSettings_Reset: String { return self._s[670]! } + public var Paint_ClearConfirm: String { return self._s[671]! } + public var Camera_VideoMode: String { return self._s[672]! } public func MESSAGE_NOTEXT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[641]!, self._r[641]!, [_1]) + return formatWithArgumentRanges(self._s[673]!, self._r[673]!, [_1]) } - public var Privacy_Calls_AlwaysAllow_Placeholder: String { return self._s[642]! } + public var Privacy_Calls_AlwaysAllow_Placeholder: String { return self._s[674]! } public func Conversation_RestrictedStickersTimed(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[643]!, self._r[643]!, [_0]) + return formatWithArgumentRanges(self._s[675]!, self._r[675]!, [_0]) } - public var Passport_Language_el: String { return self._s[644]! } - public var PhotoEditor_Original: String { return self._s[645]! } - public var Settings_FAQ_Button: String { return self._s[646]! } - public var Channel_Setup_PublicNoLink: String { return self._s[648]! } - public var Conversation_UnsupportedMedia: String { return self._s[649]! } - public var Conversation_SlideToCancel: String { return self._s[650]! } - public var Passport_Identity_OneOfTypeInternalPassport: String { return self._s[651]! } - public var CheckoutInfo_ShippingInfoPostcode: String { return self._s[652]! } - public var AutoNightTheme_NotAvailable: String { return self._s[653]! } - public var Common_Create: String { return self._s[654]! } - public var Settings_ApplyProxyAlertEnable: String { return self._s[655]! } - public var Localization_ChooseLanguage: String { return self._s[657]! } - public var Settings_Proxy: String { return self._s[660]! } - public var Privacy_TopPeersHelp: String { return self._s[661]! } - public var CheckoutInfo_ShippingInfoCountryPlaceholder: String { return self._s[662]! } - public var TwoStepAuth_ConfirmationAbort: String { return self._s[663]! } + public var Passport_Language_el: String { return self._s[676]! } + public var PhotoEditor_Original: String { return self._s[677]! } + public var Settings_FAQ_Button: String { return self._s[678]! } + public var Channel_Setup_PublicNoLink: String { return self._s[680]! } + public var Conversation_UnsupportedMedia: String { return self._s[681]! } + public var Conversation_SlideToCancel: String { return self._s[682]! } + public var Passport_Identity_OneOfTypeInternalPassport: String { return self._s[683]! } + public var CheckoutInfo_ShippingInfoPostcode: String { return self._s[684]! } + public var AutoNightTheme_NotAvailable: String { return self._s[685]! } + public var Common_Create: String { return self._s[686]! } + public var Settings_ApplyProxyAlertEnable: String { return self._s[687]! } + public var Localization_ChooseLanguage: String { return self._s[689]! } + public func PINNED_ROUND_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[691]!, self._r[691]!, [_1]) + } + public var Privacy_TopPeersHelp: String { return self._s[693]! } + public var Settings_Proxy: String { return self._s[694]! } + public var CheckoutInfo_ShippingInfoCountryPlaceholder: String { return self._s[695]! } + public var TwoStepAuth_ConfirmationAbort: String { return self._s[696]! } public func Contacts_AccessDeniedHelpPortrait(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[665]!, self._r[665]!, [_0]) + return formatWithArgumentRanges(self._s[698]!, self._r[698]!, [_0]) } - public var Passport_Identity_SurnamePlaceholder: String { return self._s[666]! } - public var Cache_Title: String { return self._s[667]! } + public var Passport_Identity_SurnamePlaceholder: String { return self._s[699]! } + public var Cache_Title: String { return self._s[700]! } public func Login_PhoneBannedEmailSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[668]!, self._r[668]!, [_0]) - } - public var TwoStepAuth_EmailCodeExpired: String { return self._s[669]! } - public var Channel_Moderator_Title: String { return self._s[670]! } - public var InstantPage_AutoNightTheme: String { return self._s[672]! } - public var Passport_Scans_Upload: String { return self._s[676]! } - public var Contacts_AccessDeniedHelpON: String { return self._s[677]! } - public var TwoStepAuth_RemovePassword: String { return self._s[678]! } - public var Common_Delete: String { return self._s[679]! } - public var Conversation_ContextMenuDelete: String { return self._s[681]! } - public var SocksProxySetup_Credentials: String { return self._s[682]! } - public var PasscodeSettings_AutoLock_Disabled: String { return self._s[684]! } - public var Passport_Address_OneOfTypeRentalAgreement: String { return self._s[687]! } - public var Conversation_ShareBotContactConfirmationTitle: String { return self._s[688]! } - public var Passport_Language_id: String { return self._s[690]! } - public var ChannelIntro_Title: String { return self._s[691]! } - public func Channel_AdminLog_MessageToggleSignaturesOff(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[692]!, self._r[692]!, [_0]) - } - public func PINNED_NOTEXT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[694]!, self._r[694]!, [_1]) - } - public var Channel_Info_Description: String { return self._s[695]! } - public var Stickers_FavoriteStickers: String { return self._s[696]! } - public var Notifications_DisplayNamesOnLockScreen: String { return self._s[697]! } - public var Calls_NoMissedCallsPlacehoder: String { return self._s[698]! } - public var Notifications_ExceptionsDefaultSound: String { return self._s[699]! } - public func DialogList_SearchSubtitleFormat(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[700]!, self._r[700]!, [_1, _2]) - } - public func Channel_AdminLog_MessageRemovedGroupStickerPack(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[701]!, self._r[701]!, [_0]) } - public var Passport_Language_uk: String { return self._s[702]! } - public var StickerPack_HideStickers: String { return self._s[704]! } - public var ChangePhoneNumberNumber_NumberPlaceholder: String { return self._s[705]! } - public var Activity_UploadingVideoMessage: String { return self._s[706]! } - public var Channel_TitleInfo: String { return self._s[707]! } - public var StickerPacksSettings_ArchivedPacks_Info: String { return self._s[708]! } - public var Settings_CallSettings: String { return self._s[709]! } - public var Camera_SquareMode: String { return self._s[710]! } - public var GroupInfo_SharedMediaNone: String { return self._s[711]! } - public var Contacts_PermissionsKeepDisabled: String { return self._s[712]! } - public var Bot_GenericBotStatus: String { return self._s[713]! } - public var Application_Update: String { return self._s[715]! } - public var Month_ShortJanuary: String { return self._s[716]! } - public var Channel_AdminLog_BanReadMessages: String { return self._s[717]! } - public var Settings_AppLanguage_Unofficial: String { return self._s[718]! } - public var Passport_Address_Street2Placeholder: String { return self._s[719]! } + public var TwoStepAuth_EmailCodeExpired: String { return self._s[702]! } + public var Channel_Moderator_Title: String { return self._s[703]! } + public var InstantPage_AutoNightTheme: String { return self._s[705]! } + public var Passport_Scans_Upload: String { return self._s[709]! } + public var Contacts_AccessDeniedHelpON: String { return self._s[710]! } + public var TwoStepAuth_RemovePassword: String { return self._s[711]! } + public var Common_Delete: String { return self._s[712]! } + public var Conversation_ContextMenuDelete: String { return self._s[714]! } + public var SocksProxySetup_Credentials: String { return self._s[715]! } + public var PasscodeSettings_AutoLock_Disabled: String { return self._s[717]! } + public var Passport_Address_OneOfTypeRentalAgreement: String { return self._s[720]! } + public var Conversation_ShareBotContactConfirmationTitle: String { return self._s[721]! } + public var Passport_Language_id: String { return self._s[723]! } + public var ChannelIntro_Title: String { return self._s[724]! } + public func Channel_AdminLog_MessageToggleSignaturesOff(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[725]!, self._r[725]!, [_0]) + } + public func PINNED_NOTEXT(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[727]!, self._r[727]!, [_1]) + } + public var Channel_Info_Description: String { return self._s[728]! } + public var Stickers_FavoriteStickers: String { return self._s[729]! } + public var Channel_BanUser_PermissionAddMembers: String { return self._s[730]! } + public var Notifications_DisplayNamesOnLockScreen: String { return self._s[731]! } + public var Calls_NoMissedCallsPlacehoder: String { return self._s[732]! } + public var Notifications_ExceptionsDefaultSound: String { return self._s[733]! } + public func DialogList_SearchSubtitleFormat(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[734]!, self._r[734]!, [_1, _2]) + } + public func Channel_AdminLog_MessageRemovedGroupStickerPack(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[735]!, self._r[735]!, [_0]) + } + public var GroupPermission_Delete: String { return self._s[736]! } + public var Passport_Language_uk: String { return self._s[737]! } + public var StickerPack_HideStickers: String { return self._s[739]! } + public var ChangePhoneNumberNumber_NumberPlaceholder: String { return self._s[740]! } + public var Activity_UploadingVideoMessage: String { return self._s[741]! } + public func GroupPermission_ApplyAlertText(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[742]!, self._r[742]!, [_0]) + } + public var Channel_TitleInfo: String { return self._s[743]! } + public var StickerPacksSettings_ArchivedPacks_Info: String { return self._s[744]! } + public var Settings_CallSettings: String { return self._s[745]! } + public var Camera_SquareMode: String { return self._s[746]! } + public var GroupInfo_SharedMediaNone: String { return self._s[747]! } + public var Contacts_PermissionsKeepDisabled: String { return self._s[748]! } + public var Bot_GenericBotStatus: String { return self._s[749]! } + public func CHANNEL_MESSAGE_ROUND_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[751]!, self._r[751]!, [_1]) + } + public var Month_ShortJanuary: String { return self._s[752]! } + public var Application_Update: String { return self._s[753]! } + public var Channel_AdminLog_BanReadMessages: String { return self._s[754]! } + public var Settings_AppLanguage_Unofficial: String { return self._s[756]! } + public var Passport_Address_Street2Placeholder: String { return self._s[757]! } public func Map_LiveLocationShortHour(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[720]!, self._r[720]!, [_0]) + return formatWithArgumentRanges(self._s[758]!, self._r[758]!, [_0]) } - public var NetworkUsageSettings_Cellular: String { return self._s[721]! } - public var Appearance_PreviewOutgoingText: String { return self._s[722]! } - public var Notifications_PermissionsAllowInSettings: String { return self._s[723]! } - public var Map_Directions: String { return self._s[724]! } - public var Passport_FieldIdentityTranslationHelp: String { return self._s[726]! } - public var Appearance_ThemeDay: String { return self._s[727]! } - public var Passport_Identity_AddPassport: String { return self._s[728]! } - public var Call_Message: String { return self._s[729]! } - public var PhotoEditor_ExposureTool: String { return self._s[730]! } - public var Passport_FieldOneOf_Delimeter: String { return self._s[732]! } - public var Channel_AdminLog_CanBanUsers: String { return self._s[734]! } + public var NetworkUsageSettings_Cellular: String { return self._s[759]! } + public var Appearance_PreviewOutgoingText: String { return self._s[760]! } + public var Notifications_PermissionsAllowInSettings: String { return self._s[761]! } + public var Map_Directions: String { return self._s[762]! } + public var Passport_FieldIdentityTranslationHelp: String { return self._s[764]! } + public var Appearance_ThemeDay: String { return self._s[765]! } + public func CHAT_MESSAGE_ROUND_SEPARATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[766]!, self._r[766]!, [_1, _2]) + } + public var Passport_Identity_AddPassport: String { return self._s[767]! } + public var Call_Message: String { return self._s[768]! } + public var PhotoEditor_ExposureTool: String { return self._s[769]! } + public var Passport_FieldOneOf_Delimeter: String { return self._s[771]! } + public var Channel_AdminLog_CanBanUsers: String { return self._s[773]! } public func PINNED_CONTACT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[735]!, self._r[735]!, [_1]) + return formatWithArgumentRanges(self._s[774]!, self._r[774]!, [_1]) } - public var Appearance_Preview: String { return self._s[736]! } - public var Compose_ChannelMembers: String { return self._s[737]! } - public var Conversation_DeleteManyMessages: String { return self._s[738]! } - public var ReportPeer_ReasonOther_Title: String { return self._s[739]! } - public var Checkout_ErrorProviderAccountTimeout: String { return self._s[740]! } - public var TwoStepAuth_ResetAccountConfirmation: String { return self._s[741]! } - public var Conversation_UpdateTelegram: String { return self._s[743]! } - public var Channel_Stickers_CreateYourOwn: String { return self._s[744]! } + public var Appearance_Preview: String { return self._s[775]! } + public var Compose_ChannelMembers: String { return self._s[776]! } + public var Conversation_DeleteManyMessages: String { return self._s[777]! } + public var ReportPeer_ReasonOther_Title: String { return self._s[778]! } + public var Checkout_ErrorProviderAccountTimeout: String { return self._s[779]! } + public var TwoStepAuth_ResetAccountConfirmation: String { return self._s[780]! } + public var Conversation_UpdateTelegram: String { return self._s[782]! } + public var Channel_Stickers_CreateYourOwn: String { return self._s[783]! } public func Notification_PinnedPhotoMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[745]!, self._r[745]!, [_0]) + return formatWithArgumentRanges(self._s[784]!, self._r[784]!, [_0]) } + public var GroupInfo_Administrators_Title: String { return self._s[785]! } public func MESSAGE_GAME(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[746]!, self._r[746]!, [_1, _2]) + return formatWithArgumentRanges(self._s[786]!, self._r[786]!, [_1, _2]) } public func PrivacySettings_LastSeenNobodyPlus(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[747]!, self._r[747]!, [_0]) - } - public var Tour_Title3: String { return self._s[748]! } - public var Clipboard_SendPhoto: String { return self._s[752]! } - public var MediaPicker_Videos: String { return self._s[753]! } - public var Passport_Email_Title: String { return self._s[754]! } - public func PrivacySettings_LastSeenEverybodyMinus(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[755]!, self._r[755]!, [_0]) - } - public var StickerPacksSettings_Title: String { return self._s[756]! } - public var Conversation_MessageDialogDelete: String { return self._s[757]! } - public var Privacy_Calls_CustomHelp: String { return self._s[759]! } - public var Core_ServiceUserStatus: String { return self._s[760]! } - public var LiveLocationUpdated_JustNow: String { return self._s[761]! } - public func CHAT_DELETE_YOU(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[762]!, self._r[762]!, [_1, _2]) - } - public var Call_StatusFailed: String { return self._s[763]! } - public var TwoStepAuth_SetupPasswordDescription: String { return self._s[764]! } - public var TwoStepAuth_SetPassword: String { return self._s[765]! } - public func SocksProxySetup_ProxyStatusPing(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[767]!, self._r[767]!, [_0]) - } - public var Calls_SubmitRating: String { return self._s[768]! } - public var Profile_Username: String { return self._s[769]! } - public var Bot_DescriptionTitle: String { return self._s[770]! } - public var MaskStickerSettings_Title: String { return self._s[771]! } - public var SharedMedia_CategoryOther: String { return self._s[772]! } - public var GroupInfo_SetGroupPhoto: String { return self._s[773]! } - public var Common_NotNow: String { return self._s[774]! } - public var Map_Location: String { return self._s[775]! } - public var Invitation_JoinGroup: String { return self._s[776]! } - public var AutoDownloadSettings_Title: String { return self._s[777]! } - public var Conversation_DiscardVoiceMessageDescription: String { return self._s[778]! } - public var Channel_ErrorAddBlocked: String { return self._s[779]! } - public var Conversation_UnblockUser: String { return self._s[780]! } - public var Watch_Bot_Restart: String { return self._s[781]! } - public var TwoStepAuth_Title: String { return self._s[782]! } - public var Channel_AdminLog_BanSendMessages: String { return self._s[783]! } - public var Checkout_ShippingMethod: String { return self._s[784]! } - public var Passport_Identity_OneOfTypeIdentityCard: String { return self._s[785]! } - public func Channel_Username_LinkHint(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[787]!, self._r[787]!, [_0]) } - public var AuthSessions_TerminateOtherSessions: String { return self._s[788]! } - public var Contacts_FailedToSendInvitesMessage: String { return self._s[789]! } - public var PrivacySettings_TwoStepAuth: String { return self._s[790]! } - public var Conversation_EditingMessagePanelMedia: String { return self._s[791]! } - public var Checkout_PaymentMethod_Title: String { return self._s[792]! } - public var SocksProxySetup_Connection: String { return self._s[793]! } - public var Group_MessagePhotoRemoved: String { return self._s[794]! } - public var Channel_Stickers_NotFound: String { return self._s[796]! } - public var Group_About_Help: String { return self._s[797]! } - public var Notification_PassportValueProofOfIdentity: String { return self._s[798]! } - public func ApplyLanguage_ChangeLanguageOfficialText(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[800]!, self._r[800]!, [_1]) + public var Tour_Title3: String { return self._s[788]! } + public var Clipboard_SendPhoto: String { return self._s[792]! } + public var MediaPicker_Videos: String { return self._s[793]! } + public var Passport_Email_Title: String { return self._s[794]! } + public func PrivacySettings_LastSeenEverybodyMinus(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[795]!, self._r[795]!, [_0]) } - public var CheckoutInfo_ShippingInfoStatePlaceholder: String { return self._s[802]! } - public var Notifications_GroupNotificationsExceptionsHelp: String { return self._s[803]! } - public var SocksProxySetup_Password: String { return self._s[804]! } - public var Notifications_PermissionsEnable: String { return self._s[805]! } - public var TwoStepAuth_ChangeEmail: String { return self._s[807]! } + public var StickerPacksSettings_Title: String { return self._s[796]! } + public var Conversation_MessageDialogDelete: String { return self._s[797]! } + public var Privacy_Calls_CustomHelp: String { return self._s[799]! } + public var GroupInfo_SetSound: String { return self._s[800]! } + public var Core_ServiceUserStatus: String { return self._s[801]! } + public var LiveLocationUpdated_JustNow: String { return self._s[802]! } + public func CHAT_DELETE_YOU(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[803]!, self._r[803]!, [_1, _2]) + } + public var Call_StatusFailed: String { return self._s[804]! } + public var TwoStepAuth_SetupPasswordDescription: String { return self._s[805]! } + public var TwoStepAuth_SetPassword: String { return self._s[806]! } + public func SocksProxySetup_ProxyStatusPing(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[808]!, self._r[808]!, [_0]) + } + public var Calls_SubmitRating: String { return self._s[809]! } + public var Profile_Username: String { return self._s[810]! } + public var Bot_DescriptionTitle: String { return self._s[811]! } + public var MaskStickerSettings_Title: String { return self._s[812]! } + public var SharedMedia_CategoryOther: String { return self._s[813]! } + public var GroupInfo_SetGroupPhoto: String { return self._s[814]! } + public var Common_NotNow: String { return self._s[815]! } + public var Map_Location: String { return self._s[816]! } + public var Invitation_JoinGroup: String { return self._s[817]! } + public var AutoDownloadSettings_Title: String { return self._s[818]! } + public var Conversation_DiscardVoiceMessageDescription: String { return self._s[819]! } + public var Channel_ErrorAddBlocked: String { return self._s[820]! } + public var Conversation_UnblockUser: String { return self._s[821]! } + public var Watch_Bot_Restart: String { return self._s[822]! } + public var TwoStepAuth_Title: String { return self._s[823]! } + public var Channel_AdminLog_BanSendMessages: String { return self._s[824]! } + public var Checkout_ShippingMethod: String { return self._s[825]! } + public var Passport_Identity_OneOfTypeIdentityCard: String { return self._s[826]! } + public func Channel_Username_LinkHint(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[828]!, self._r[828]!, [_0]) + } + public var AuthSessions_TerminateOtherSessions: String { return self._s[829]! } + public var Contacts_FailedToSendInvitesMessage: String { return self._s[830]! } + public var PrivacySettings_TwoStepAuth: String { return self._s[831]! } + public var Conversation_EditingMessagePanelMedia: String { return self._s[832]! } + public var Checkout_PaymentMethod_Title: String { return self._s[833]! } + public var SocksProxySetup_Connection: String { return self._s[834]! } + public var Group_MessagePhotoRemoved: String { return self._s[835]! } + public func CHAT_DELETE_YOU_SEPARATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[837]!, self._r[837]!, [_1, _2]) + } + public var Channel_Stickers_NotFound: String { return self._s[838]! } + public var Group_About_Help: String { return self._s[839]! } + public var Notification_PassportValueProofOfIdentity: String { return self._s[840]! } + public func ApplyLanguage_ChangeLanguageOfficialText(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[842]!, self._r[842]!, [_1]) + } + public var CheckoutInfo_ShippingInfoStatePlaceholder: String { return self._s[844]! } + public var Notifications_GroupNotificationsExceptionsHelp: String { return self._s[845]! } + public var SocksProxySetup_Password: String { return self._s[846]! } + public var Notifications_PermissionsEnable: String { return self._s[847]! } + public var TwoStepAuth_ChangeEmail: String { return self._s[849]! } public func MESSAGE_TEXT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[808]!, self._r[808]!, [_1, _2]) + return formatWithArgumentRanges(self._s[850]!, self._r[850]!, [_1, _2]) } public func Channel_AdminLog_MessageInvitedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[809]!, self._r[809]!, [_1]) + return formatWithArgumentRanges(self._s[851]!, self._r[851]!, [_1]) } public func Time_MonthOfYear_m10(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[811]!, self._r[811]!, [_0]) + return formatWithArgumentRanges(self._s[853]!, self._r[853]!, [_0]) } - public var Passport_Identity_TypeDriversLicense: String { return self._s[812]! } - public var ArchivedPacksAlert_Title: String { return self._s[813]! } + public var Passport_Identity_TypeDriversLicense: String { return self._s[854]! } + public var ArchivedPacksAlert_Title: String { return self._s[855]! } public func Time_PreciseDate_m7(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[814]!, self._r[814]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[856]!, self._r[856]!, [_1, _2, _3]) } - public var PrivacyLastSeenSettings_GroupsAndChannelsHelp: String { return self._s[815]! } - public var Privacy_Calls_NeverAllow_Placeholder: String { return self._s[816]! } - public var Conversation_StatusTyping: String { return self._s[817]! } - public var Broadcast_AdminLog_EmptyText: String { return self._s[818]! } - public var Notification_PassportValueProofOfAddress: String { return self._s[819]! } - public var UserInfo_CreateNewContact: String { return self._s[820]! } - public var Passport_Identity_FrontSide: String { return self._s[821]! } - public var Calls_CallTabTitle: String { return self._s[822]! } - public var Channel_AdminLog_ChannelEmptyText: String { return self._s[823]! } + public var PrivacyLastSeenSettings_GroupsAndChannelsHelp: String { return self._s[857]! } + public var Privacy_Calls_NeverAllow_Placeholder: String { return self._s[858]! } + public var Conversation_StatusTyping: String { return self._s[859]! } + public var Broadcast_AdminLog_EmptyText: String { return self._s[860]! } + public var Notification_PassportValueProofOfAddress: String { return self._s[861]! } + public var UserInfo_CreateNewContact: String { return self._s[862]! } + public var Passport_Identity_FrontSide: String { return self._s[863]! } + public var Calls_CallTabTitle: String { return self._s[865]! } + public var Channel_AdminLog_ChannelEmptyText: String { return self._s[866]! } public func Login_BannedPhoneBody(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[824]!, self._r[824]!, [_0]) + return formatWithArgumentRanges(self._s[867]!, self._r[867]!, [_0]) } - public var Watch_UserInfo_MuteTitle: String { return self._s[825]! } - public var SharedMedia_EmptyMusicText: String { return self._s[826]! } - public var PasscodeSettings_AutoLock_IfAwayFor_1minute: String { return self._s[827]! } - public var Paint_Stickers: String { return self._s[828]! } - public var Privacy_GroupsAndChannels: String { return self._s[829]! } - public var UserInfo_AddContact: String { return self._s[831]! } + public var Watch_UserInfo_MuteTitle: String { return self._s[868]! } + public var SharedMedia_EmptyMusicText: String { return self._s[869]! } + public var PasscodeSettings_AutoLock_IfAwayFor_1minute: String { return self._s[870]! } + public var Paint_Stickers: String { return self._s[871]! } + public var Privacy_GroupsAndChannels: String { return self._s[872]! } + public var UserInfo_AddContact: String { return self._s[874]! } public func Conversation_MessageViaUser(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[832]!, self._r[832]!, [_0]) + return formatWithArgumentRanges(self._s[875]!, self._r[875]!, [_0]) } - public var PhoneNumberHelp_ChangeNumber: String { return self._s[834]! } - public var DialogList_NoMessagesTitle: String { return self._s[836]! } - public var EditProfile_NameAndPhotoHelp: String { return self._s[837]! } - public var BlockedUsers_BlockUser: String { return self._s[838]! } - public var Notifications_PermissionsOpenSettings: String { return self._s[839]! } - public var MediaPicker_UngroupDescription: String { return self._s[840]! } - public var Watch_NoConnection: String { return self._s[841]! } - public var Month_GenSeptember: String { return self._s[842]! } - public var Conversation_ViewGroup: String { return self._s[843]! } - public var Channel_AdminLogFilter_EventsLeavingSubscribers: String { return self._s[846]! } - public var Passport_FieldOneOf_FinalDelimeter: String { return self._s[847]! } - public var MediaPicker_CameraRoll: String { return self._s[849]! } - public var Month_GenAugust: String { return self._s[850]! } - public var AccessDenied_VideoMessageMicrophone: String { return self._s[851]! } - public var SharedMedia_EmptyText: String { return self._s[852]! } - public var Map_ShareLiveLocation: String { return self._s[853]! } - public var Calls_All: String { return self._s[854]! } - public var Appearance_ThemeNight: String { return self._s[857]! } - public var Conversation_HoldForAudio: String { return self._s[858]! } - public var GroupInfo_GroupHistoryHidden: String { return self._s[861]! } - public var SocksProxySetup_Secret: String { return self._s[862]! } - public var Channel_BanList_RestrictedTitle: String { return self._s[864]! } - public var Conversation_Location: String { return self._s[865]! } - public var ChatSettings_AutoDownloadPhotos: String { return self._s[867]! } - public var Notifications_PermissionsText: String { return self._s[868]! } - public var SocksProxySetup_ProxyStatusConnecting: String { return self._s[869]! } - public var Channel_EditAdmin_PermissionPinMessages: String { return self._s[871]! } - public var TwoStepAuth_ReEnterPasswordDescription: String { return self._s[872]! } - public var Passport_DeletePassportConfirmation: String { return self._s[875]! } - public var Login_InvalidCodeError: String { return self._s[876]! } - public var StickerPacksSettings_FeaturedPacks: String { return self._s[877]! } + public var PhoneNumberHelp_ChangeNumber: String { return self._s[877]! } + public var DialogList_NoMessagesTitle: String { return self._s[879]! } + public var EditProfile_NameAndPhotoHelp: String { return self._s[880]! } + public var BlockedUsers_BlockUser: String { return self._s[881]! } + public var Notifications_PermissionsOpenSettings: String { return self._s[882]! } + public var MediaPicker_UngroupDescription: String { return self._s[883]! } + public var Watch_NoConnection: String { return self._s[884]! } + public var Month_GenSeptember: String { return self._s[885]! } + public var Conversation_ViewGroup: String { return self._s[886]! } + public var Channel_AdminLogFilter_EventsLeavingSubscribers: String { return self._s[889]! } + public var Passport_FieldOneOf_FinalDelimeter: String { return self._s[890]! } + public var MediaPicker_CameraRoll: String { return self._s[892]! } + public var Month_GenAugust: String { return self._s[893]! } + public var AccessDenied_VideoMessageMicrophone: String { return self._s[894]! } + public var SharedMedia_EmptyText: String { return self._s[895]! } + public var Map_ShareLiveLocation: String { return self._s[896]! } + public var Calls_All: String { return self._s[897]! } + public var Appearance_ThemeNight: String { return self._s[900]! } + public var Conversation_HoldForAudio: String { return self._s[901]! } + public var GroupInfo_GroupHistoryHidden: String { return self._s[904]! } + public var SocksProxySetup_Secret: String { return self._s[905]! } + public var Channel_BanList_RestrictedTitle: String { return self._s[907]! } + public var Conversation_Location: String { return self._s[908]! } + public var ChatSettings_AutoDownloadPhotos: String { return self._s[910]! } + public var Notifications_PermissionsText: String { return self._s[911]! } + public var SocksProxySetup_ProxyStatusConnecting: String { return self._s[912]! } + public var Channel_EditAdmin_PermissionPinMessages: String { return self._s[914]! } + public var TwoStepAuth_ReEnterPasswordDescription: String { return self._s[916]! } + public var Passport_DeletePassportConfirmation: String { return self._s[918]! } + public var Login_InvalidCodeError: String { return self._s[919]! } + public var StickerPacksSettings_FeaturedPacks: String { return self._s[920]! } public func GroupInfo_InvitationLinkAcceptChannel(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[878]!, self._r[878]!, [_0]) + return formatWithArgumentRanges(self._s[921]!, self._r[921]!, [_0]) } - public var Call_CallInProgressTitle: String { return self._s[879]! } - public var Month_ShortSeptember: String { return self._s[880]! } - public var Watch_ChannelInfo_Title: String { return self._s[881]! } - public var DialogList_PasscodeLockHelp: String { return self._s[884]! } - public var Notifications_Badge_IncludePublicGroups: String { return self._s[885]! } - public var Channel_AdminLogFilter_EventsTitle: String { return self._s[886]! } - public var PhotoEditor_CropReset: String { return self._s[887]! } - public var Group_Username_CreatePrivateLinkHelp: String { return self._s[889]! } - public var Channel_Management_LabelEditor: String { return self._s[890]! } - public var Passport_Identity_LatinNameHelp: String { return self._s[892]! } - public var PhotoEditor_HighlightsTool: String { return self._s[893]! } - public var UserInfo_Title: String { return self._s[894]! } - public var AccessDenied_Title: String { return self._s[895]! } - public var DialogList_SearchLabel: String { return self._s[896]! } - public var Group_Setup_HistoryHidden: String { return self._s[897]! } - public var TwoStepAuth_PasswordChangeSuccess: String { return self._s[898]! } - public var State_Updating: String { return self._s[900]! } - public var Contacts_TabTitle: String { return self._s[901]! } - public var Notifications_Badge_CountUnreadMessages: String { return self._s[903]! } - public var GroupInfo_GroupHistory: String { return self._s[904]! } - public var Conversation_UnsupportedMediaPlaceholder: String { return self._s[905]! } - public var CheckoutInfo_ShippingInfoCountry: String { return self._s[906]! } - public var Passport_Identity_OneOfTypeDriversLicense: String { return self._s[907]! } - public var Contacts_NotRegisteredSection: String { return self._s[908]! } + public var Call_CallInProgressTitle: String { return self._s[922]! } + public var Month_ShortSeptember: String { return self._s[923]! } + public var Watch_ChannelInfo_Title: String { return self._s[924]! } + public var DialogList_PasscodeLockHelp: String { return self._s[927]! } + public var Notifications_Badge_IncludePublicGroups: String { return self._s[928]! } + public var Channel_AdminLogFilter_EventsTitle: String { return self._s[929]! } + public var PhotoEditor_CropReset: String { return self._s[930]! } + public var Group_Username_CreatePrivateLinkHelp: String { return self._s[932]! } + public var Channel_Management_LabelEditor: String { return self._s[933]! } + public var Passport_Identity_LatinNameHelp: String { return self._s[935]! } + public var PhotoEditor_HighlightsTool: String { return self._s[936]! } + public var UserInfo_Title: String { return self._s[937]! } + public var AccessDenied_Title: String { return self._s[938]! } + public var DialogList_SearchLabel: String { return self._s[939]! } + public var Group_Setup_HistoryHidden: String { return self._s[940]! } + public var TwoStepAuth_PasswordChangeSuccess: String { return self._s[941]! } + public var State_Updating: String { return self._s[943]! } + public var Contacts_TabTitle: String { return self._s[944]! } + public var Notifications_Badge_CountUnreadMessages: String { return self._s[946]! } + public var GroupInfo_GroupHistory: String { return self._s[947]! } + public var Conversation_UnsupportedMediaPlaceholder: String { return self._s[948]! } + public var CheckoutInfo_ShippingInfoCountry: String { return self._s[949]! } + public var Passport_Identity_OneOfTypeDriversLicense: String { return self._s[950]! } + public var Contacts_NotRegisteredSection: String { return self._s[951]! } public func Time_PreciseDate_m4(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[909]!, self._r[909]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[952]!, self._r[952]!, [_1, _2, _3]) } - public var Paint_Clear: String { return self._s[910]! } - public var StickerPacksSettings_ArchivedMasks: String { return self._s[911]! } - public var SocksProxySetup_Connecting: String { return self._s[912]! } - public var ExplicitContent_AlertChannel: String { return self._s[913]! } - public var CreatePoll_AllOptionsAdded: String { return self._s[914]! } - public var Conversation_Contact: String { return self._s[915]! } - public var Login_CodeExpired: String { return self._s[916]! } - public var Passport_DiscardMessageAction: String { return self._s[917]! } - public var Channel_AdminLog_MessagePreviousDescription: String { return self._s[918]! } - public var Channel_AdminLog_EmptyMessageText: String { return self._s[919]! } - public var Month_ShortApril: String { return self._s[920]! } - public var AuthSessions_CurrentSession: String { return self._s[921]! } - public var PrivacySettings_DeleteAccountIfAwayFor: String { return self._s[925]! } - public var CheckoutInfo_ShippingInfoTitle: String { return self._s[926]! } - public var Channel_Setup_TypePrivate: String { return self._s[928]! } - public var Forward_ChannelReadOnly: String { return self._s[931]! } - public var PhotoEditor_CurvesBlue: String { return self._s[932]! } - public var UserInfo_BotPrivacy: String { return self._s[933]! } - public var Notification_PassportValueEmail: String { return self._s[934]! } - public var Channel_SignMessages_Help: String { return self._s[936]! } + public var Paint_Clear: String { return self._s[953]! } + public var StickerPacksSettings_ArchivedMasks: String { return self._s[954]! } + public var SocksProxySetup_Connecting: String { return self._s[955]! } + public var ExplicitContent_AlertChannel: String { return self._s[956]! } + public var CreatePoll_AllOptionsAdded: String { return self._s[957]! } + public var Conversation_Contact: String { return self._s[958]! } + public var Login_CodeExpired: String { return self._s[959]! } + public var Passport_DiscardMessageAction: String { return self._s[960]! } + public var Channel_AdminLog_MessagePreviousDescription: String { return self._s[961]! } + public var Channel_AdminLog_EmptyMessageText: String { return self._s[962]! } + public var Month_ShortApril: String { return self._s[963]! } + public var AuthSessions_CurrentSession: String { return self._s[964]! } + public var PrivacySettings_DeleteAccountIfAwayFor: String { return self._s[968]! } + public var CheckoutInfo_ShippingInfoTitle: String { return self._s[969]! } + public var Channel_Setup_TypePrivate: String { return self._s[971]! } + public var Forward_ChannelReadOnly: String { return self._s[974]! } + public var PhotoEditor_CurvesBlue: String { return self._s[975]! } + public var UserInfo_BotPrivacy: String { return self._s[976]! } + public var Notification_PassportValueEmail: String { return self._s[977]! } + public var EmptyGroupInfo_Subtitle: String { return self._s[978]! } + public var GroupPermission_NewTitle: String { return self._s[979]! } + public var GroupInfo_Permissions_AddException: String { return self._s[980]! } + public var Channel_SignMessages_Help: String { return self._s[982]! } public func CHAT_LEFT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[938]!, self._r[938]!, [_1, _2]) + return formatWithArgumentRanges(self._s[984]!, self._r[984]!, [_1, _2]) } - public var ChannelMembers_WhoCanAddMembers_Admins: String { return self._s[939]! } - public var FastTwoStepSetup_EmailPlaceholder: String { return self._s[940]! } - public var Passport_Language_pt: String { return self._s[941]! } - public var NotificationsSound_Popcorn: String { return self._s[944]! } - public var AutoNightTheme_Disabled: String { return self._s[945]! } - public var BlockedUsers_LeavePrefix: String { return self._s[946]! } - public var Contacts_PermissionsSuppressWarningText: String { return self._s[947]! } + public var ChannelMembers_WhoCanAddMembers_Admins: String { return self._s[985]! } + public var FastTwoStepSetup_EmailPlaceholder: String { return self._s[986]! } + public var Passport_Language_pt: String { return self._s[987]! } + public var NotificationsSound_Popcorn: String { return self._s[990]! } + public var AutoNightTheme_Disabled: String { return self._s[991]! } + public var BlockedUsers_LeavePrefix: String { return self._s[992]! } + public var Contacts_PermissionsSuppressWarningText: String { return self._s[993]! } public func CancelResetAccount_TextSMS(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[948]!, self._r[948]!, [_0]) + return formatWithArgumentRanges(self._s[994]!, self._r[994]!, [_0]) } - public var CheckoutInfo_ErrorNameInvalid: String { return self._s[949]! } - public var SocksProxySetup_UseForCalls: String { return self._s[950]! } - public var Passport_DeleteDocumentConfirmation: String { return self._s[951]! } + public var CheckoutInfo_ErrorNameInvalid: String { return self._s[995]! } + public var SocksProxySetup_UseForCalls: String { return self._s[996]! } + public var Passport_DeleteDocumentConfirmation: String { return self._s[997]! } public func Conversation_Megabytes(_ _0: Float) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[952]!, self._r[952]!, ["\(_0)"]) + return formatWithArgumentRanges(self._s[998]!, self._r[998]!, ["\(_0)"]) } - public var SocksProxySetup_Hostname: String { return self._s[954]! } - public var Compose_NewEncryptedChat: String { return self._s[955]! } - public var Login_CodeFloodError: String { return self._s[956]! } - public var Calls_TabTitle: String { return self._s[957]! } - public var Passport_Language_he: String { return self._s[958]! } + public var SocksProxySetup_Hostname: String { return self._s[1000]! } + public var Compose_NewEncryptedChat: String { return self._s[1001]! } + public var Login_CodeFloodError: String { return self._s[1002]! } + public var Calls_TabTitle: String { return self._s[1003]! } + public var Passport_Language_he: String { return self._s[1004]! } public func Channel_AdminLog_MessageGroupPreHistoryHidden(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[959]!, self._r[959]!, [_0]) + return formatWithArgumentRanges(self._s[1006]!, self._r[1006]!, [_0]) } - public var Tour_Text1: String { return self._s[960]! } - public var Month_ShortFebruary: String { return self._s[961]! } - public var TwoStepAuth_EmailSkip: String { return self._s[962]! } - public var NotificationsSound_Glass: String { return self._s[963]! } - public var Appearance_ThemeNightBlue: String { return self._s[964]! } - public var CheckoutInfo_Pay: String { return self._s[965]! } - public var Invite_LargeRecipientsCountWarning: String { return self._s[967]! } - public var Call_CallAgain: String { return self._s[969]! } - public var AttachmentMenu_SendAsFile: String { return self._s[970]! } - public var Watch_Message_Game: String { return self._s[971]! } - public var AccessDenied_MicrophoneRestricted: String { return self._s[972]! } - public var Passport_InvalidPasswordError: String { return self._s[973]! } + public var GroupPermission_Title: String { return self._s[1007]! } + public var GroupPermission_NoChangeInfo: String { return self._s[1008]! } + public var Tour_Text1: String { return self._s[1009]! } + public var Month_ShortFebruary: String { return self._s[1010]! } + public var TwoStepAuth_EmailSkip: String { return self._s[1011]! } + public var NotificationsSound_Glass: String { return self._s[1012]! } + public var Appearance_ThemeNightBlue: String { return self._s[1013]! } + public var CheckoutInfo_Pay: String { return self._s[1014]! } + public var Invite_LargeRecipientsCountWarning: String { return self._s[1016]! } + public var Call_CallAgain: String { return self._s[1018]! } + public var AttachmentMenu_SendAsFile: String { return self._s[1019]! } + public var AccessDenied_MicrophoneRestricted: String { return self._s[1020]! } + public var Passport_InvalidPasswordError: String { return self._s[1021]! } + public var Watch_Message_Game: String { return self._s[1022]! } public func PINNED_PHOTO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[974]!, self._r[974]!, [_1]) + return formatWithArgumentRanges(self._s[1023]!, self._r[1023]!, [_1]) } - public var Stickers_Install: String { return self._s[975]! } - public var PrivacyLastSeenSettings_NeverShareWith: String { return self._s[976]! } - public var Passport_Identity_ResidenceCountry: String { return self._s[978]! } - public var Notifications_GroupNotificationsHelp: String { return self._s[979]! } - public var AuthSessions_OtherSessions: String { return self._s[980]! } - public var Channel_Username_Help: String { return self._s[981]! } - public var Camera_Title: String { return self._s[982]! } - public var GroupInfo_SetGroupPhotoDelete: String { return self._s[984]! } - public var Channel_AdminLog_TitleAllEvents: String { return self._s[985]! } - public var Contacts_MemberSearchSectionTitleGroup: String { return self._s[986]! } - public var Conversation_RestrictedStickers: String { return self._s[987]! } - public var Notifications_ExceptionsResetToDefaults: String { return self._s[989]! } - public var UserInfo_TelegramCall: String { return self._s[991]! } - public var TwoStepAuth_SetupResendEmailCode: String { return self._s[992]! } - public var CreatePoll_OptionsHeader: String { return self._s[993]! } - public var Privacy_GroupsAndChannels_AlwaysAllow_Title: String { return self._s[994]! } - public var Passport_Identity_EditPersonalDetails: String { return self._s[995]! } + public var Stickers_Install: String { return self._s[1024]! } + public var PrivacyLastSeenSettings_NeverShareWith: String { return self._s[1025]! } + public var Passport_Identity_ResidenceCountry: String { return self._s[1027]! } + public var Notifications_GroupNotificationsHelp: String { return self._s[1028]! } + public var AuthSessions_OtherSessions: String { return self._s[1029]! } + public var Channel_Username_Help: String { return self._s[1030]! } + public var Camera_Title: String { return self._s[1031]! } + public var GroupInfo_SetGroupPhotoDelete: String { return self._s[1033]! } + public var Channel_AdminLog_TitleAllEvents: String { return self._s[1034]! } + public var Contacts_MemberSearchSectionTitleGroup: String { return self._s[1035]! } + public var Conversation_RestrictedStickers: String { return self._s[1036]! } + public var Notifications_ExceptionsResetToDefaults: String { return self._s[1038]! } + public var UserInfo_TelegramCall: String { return self._s[1040]! } + public var TwoStepAuth_SetupResendEmailCode: String { return self._s[1041]! } + public var CreatePoll_OptionsHeader: String { return self._s[1042]! } + public var Privacy_GroupsAndChannels_AlwaysAllow_Title: String { return self._s[1043]! } + public var Passport_Identity_EditPersonalDetails: String { return self._s[1044]! } public func Time_PreciseDate_m1(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[996]!, self._r[996]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1045]!, self._r[1045]!, [_1, _2, _3]) } - public var Settings_SaveEditedPhotos: String { return self._s[997]! } - public var TwoStepAuth_ConfirmationTitle: String { return self._s[998]! } - public var Privacy_GroupsAndChannels_NeverAllow_Title: String { return self._s[999]! } - public var Conversation_MessageDialogRetry: String { return self._s[1000]! } - public var Conversation_DiscardVoiceMessageAction: String { return self._s[1001]! } - public var Group_Setup_TypeHeader: String { return self._s[1002]! } - public var Paint_RecentStickers: String { return self._s[1003]! } - public var PhotoEditor_GrainTool: String { return self._s[1004]! } - public var CheckoutInfo_ShippingInfoState: String { return self._s[1005]! } - public var Watch_AuthRequired: String { return self._s[1007]! } + public var Settings_SaveEditedPhotos: String { return self._s[1046]! } + public var TwoStepAuth_ConfirmationTitle: String { return self._s[1047]! } + public var Privacy_GroupsAndChannels_NeverAllow_Title: String { return self._s[1048]! } + public var Conversation_MessageDialogRetry: String { return self._s[1049]! } + public var Conversation_DiscardVoiceMessageAction: String { return self._s[1050]! } + public var Group_Setup_TypeHeader: String { return self._s[1051]! } + public var Paint_RecentStickers: String { return self._s[1052]! } + public var PhotoEditor_GrainTool: String { return self._s[1053]! } + public var CheckoutInfo_ShippingInfoState: String { return self._s[1054]! } + public var EmptyGroupInfo_Line4: String { return self._s[1055]! } + public var Watch_AuthRequired: String { return self._s[1058]! } public func Passport_Email_UseTelegramEmail(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1008]!, self._r[1008]!, [_0]) + return formatWithArgumentRanges(self._s[1060]!, self._r[1060]!, [_0]) } public func CHANNEL_MESSAGE_PHOTOS(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1009]!, self._r[1009]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1061]!, self._r[1061]!, [_1, _2]) } - public var Conversation_EncryptedDescriptionTitle: String { return self._s[1010]! } - public var ChannelIntro_Text: String { return self._s[1011]! } - public var DialogList_DeleteBotConfirmation: String { return self._s[1012]! } - public var Calls_AddTab: String { return self._s[1013]! } - public var Message_ReplyActionButtonShowReceipt: String { return self._s[1014]! } - public var Channel_AdminLog_EmptyFilterText: String { return self._s[1015]! } - public var Notification_MessageLifetime1d: String { return self._s[1016]! } - public var Notifications_ChannelNotificationsExceptionsHelp: String { return self._s[1017]! } - public var Channel_BanUser_PermissionsHeader: String { return self._s[1018]! } - public var Passport_Identity_GenderFemale: String { return self._s[1019]! } - public var BlockedUsers_BlockTitle: String { return self._s[1020]! } + public var Conversation_EncryptedDescriptionTitle: String { return self._s[1062]! } + public var ChannelIntro_Text: String { return self._s[1063]! } + public var DialogList_DeleteBotConfirmation: String { return self._s[1064]! } + public var GroupPermission_NoSendMedia: String { return self._s[1065]! } + public var Calls_AddTab: String { return self._s[1066]! } + public var Message_ReplyActionButtonShowReceipt: String { return self._s[1067]! } + public var Channel_AdminLog_EmptyFilterText: String { return self._s[1068]! } + public var Notification_MessageLifetime1d: String { return self._s[1069]! } + public var Notifications_ChannelNotificationsExceptionsHelp: String { return self._s[1070]! } + public var Channel_BanUser_PermissionsHeader: String { return self._s[1071]! } + public var Passport_Identity_GenderFemale: String { return self._s[1072]! } + public var BlockedUsers_BlockTitle: String { return self._s[1073]! } public func MESSAGE_AUDIO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1021]!, self._r[1021]!, [_1]) + return formatWithArgumentRanges(self._s[1074]!, self._r[1074]!, [_1]) } - public var Weekday_Yesterday: String { return self._s[1022]! } - public var AutoNightTheme_Scheduled: String { return self._s[1023]! } + public var Weekday_Yesterday: String { return self._s[1075]! } + public var AutoNightTheme_Scheduled: String { return self._s[1076]! } public func Login_PhoneGenericEmailBody(_ _1: String, _ _2: String, _ _3: String, _ _4: String, _ _5: String, _ _6: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1024]!, self._r[1024]!, [_1, _2, _3, _4, _5, _6]) + return formatWithArgumentRanges(self._s[1077]!, self._r[1077]!, [_1, _2, _3, _4, _5, _6]) } - public var PrivacyPolicy_DeclineDeleteNow: String { return self._s[1025]! } - public var CreatePoll_Create: String { return self._s[1026]! } - public var Channel_Members_AddBannedErrorAdmin: String { return self._s[1027]! } + public var PrivacyPolicy_DeclineDeleteNow: String { return self._s[1078]! } + public var CreatePoll_Create: String { return self._s[1079]! } + public var Channel_Members_AddBannedErrorAdmin: String { return self._s[1080]! } public func Notification_CallFormat(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1028]!, self._r[1028]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1081]!, self._r[1081]!, [_1, _2]) } - public var Checkout_ErrorProviderAccountInvalid: String { return self._s[1029]! } - public var Notifications_InAppNotificationsSounds: String { return self._s[1030]! } - public var Preview_OpenInInstagram: String { return self._s[1031]! } - public var Notification_MessageLifetimeRemovedOutgoing: String { return self._s[1032]! } + public var Checkout_ErrorProviderAccountInvalid: String { return self._s[1082]! } + public var Notifications_InAppNotificationsSounds: String { return self._s[1083]! } + public var Preview_OpenInInstagram: String { return self._s[1084]! } + public var Notification_MessageLifetimeRemovedOutgoing: String { return self._s[1085]! } + public func CHANNEL_MESSAGE_GIF_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1086]!, self._r[1086]!, [_1]) + } + public var Channel_AdminLog_InfoPanelAlertTitle: String { return self._s[1087]! } public func Passport_PrivacyPolicy(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1033]!, self._r[1033]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1088]!, self._r[1088]!, [_1, _2]) + } + public var NetworkUsageSettings_TotalSection: String { return self._s[1089]! } + public func PINNED_PHOTO_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1090]!, self._r[1090]!, [_1]) + } + public var Channel_Setup_TypePrivateHelp: String { return self._s[1091]! } + public var Wallpaper_PhotoLibrary: String { return self._s[1093]! } + public var Privacy_GroupsAndChannels_NeverAllow_Placeholder: String { return self._s[1094]! } + public func MESSAGE_PHOTO_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1095]!, self._r[1095]!, [_1]) + } + public var FastTwoStepSetup_HintSection: String { return self._s[1096]! } + public var TwoStepAuth_SetupResendEmailCodeAlert: String { return self._s[1097]! } + public var Watch_LastSeen_WithinAMonth: String { return self._s[1098]! } + public var GroupInfo_ActionPromote: String { return self._s[1099]! } + public var PasscodeSettings_SimplePasscode: String { return self._s[1100]! } + public var GroupInfo_Permissions_Title: String { return self._s[1101]! } + public var Permissions_ContactsText_v0: String { return self._s[1102]! } + public var PrivacySettings_DataSettingsHelp: String { return self._s[1105]! } + public var Passport_FieldEmailHelp: String { return self._s[1106]! } + public var Passport_Identity_GenderPlaceholder: String { return self._s[1107]! } + public var Weekday_ShortSaturday: String { return self._s[1108]! } + public var ContactInfo_PhoneLabelMain: String { return self._s[1109]! } + public var Watch_Conversation_UserInfo: String { return self._s[1110]! } + public var CheckoutInfo_ShippingInfoCityPlaceholder: String { return self._s[1111]! } + public var PrivacyLastSeenSettings_Title: String { return self._s[1112]! } + public var Conversation_ShareBotLocationConfirmation: String { return self._s[1113]! } + public var PhotoEditor_VignetteTool: String { return self._s[1114]! } + public var Passport_Address_Street1Placeholder: String { return self._s[1115]! } + public var Passport_Language_et: String { return self._s[1116]! } + public var Passport_Language_bg: String { return self._s[1118]! } + public var Stickers_NoStickersFound: String { return self._s[1120]! } + public var Settings_About: String { return self._s[1122]! } + public func CHAT_MESSAGE_POLL_SEPARATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1123]!, self._r[1123]!, [_1, _2]) } - public var Channel_AdminLog_InfoPanelAlertTitle: String { return self._s[1034]! } - public var NetworkUsageSettings_TotalSection: String { return self._s[1035]! } - public var Channel_Setup_TypePrivateHelp: String { return self._s[1036]! } - public var Wallpaper_PhotoLibrary: String { return self._s[1038]! } - public var Privacy_GroupsAndChannels_NeverAllow_Placeholder: String { return self._s[1039]! } - public var FastTwoStepSetup_HintSection: String { return self._s[1040]! } - public var TwoStepAuth_SetupResendEmailCodeAlert: String { return self._s[1041]! } - public var Watch_LastSeen_WithinAMonth: String { return self._s[1042]! } - public var GroupInfo_ActionPromote: String { return self._s[1043]! } - public var PasscodeSettings_SimplePasscode: String { return self._s[1044]! } - public var Permissions_ContactsText_v0: String { return self._s[1045]! } - public var PrivacySettings_DataSettingsHelp: String { return self._s[1048]! } - public var Passport_FieldEmailHelp: String { return self._s[1049]! } - public var Passport_Identity_GenderPlaceholder: String { return self._s[1050]! } - public var Weekday_ShortSaturday: String { return self._s[1051]! } - public var ContactInfo_PhoneLabelMain: String { return self._s[1052]! } - public var Watch_Conversation_UserInfo: String { return self._s[1053]! } - public var CheckoutInfo_ShippingInfoCityPlaceholder: String { return self._s[1054]! } - public var PrivacyLastSeenSettings_Title: String { return self._s[1055]! } - public var Conversation_ShareBotLocationConfirmation: String { return self._s[1056]! } - public var PhotoEditor_VignetteTool: String { return self._s[1057]! } - public var Passport_Address_Street1Placeholder: String { return self._s[1058]! } - public var Passport_Language_et: String { return self._s[1059]! } - public var Passport_Language_bg: String { return self._s[1061]! } - public var Stickers_NoStickersFound: String { return self._s[1063]! } - public var Settings_About: String { return self._s[1064]! } public func Channel_AdminLog_MessageRestricted(_ _0: String, _ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1065]!, self._r[1065]!, [_0, _1, _2]) + return formatWithArgumentRanges(self._s[1124]!, self._r[1124]!, [_0, _1, _2]) } - public var KeyCommand_NewMessage: String { return self._s[1067]! } - public var Group_ErrorAddBlocked: String { return self._s[1068]! } + public var KeyCommand_NewMessage: String { return self._s[1126]! } + public var Group_ErrorAddBlocked: String { return self._s[1127]! } public func Message_PaymentSent(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1069]!, self._r[1069]!, [_0]) + return formatWithArgumentRanges(self._s[1128]!, self._r[1128]!, [_0]) } - public var Map_LocationTitle: String { return self._s[1070]! } - public var CallSettings_UseLessDataLongDescription: String { return self._s[1071]! } - public var Cache_ClearProgress: String { return self._s[1072]! } + public var Map_LocationTitle: String { return self._s[1129]! } + public var CallSettings_UseLessDataLongDescription: String { return self._s[1130]! } + public var Cache_ClearProgress: String { return self._s[1131]! } public func Channel_Management_ErrorNotMember(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1073]!, self._r[1073]!, [_0]) + return formatWithArgumentRanges(self._s[1132]!, self._r[1132]!, [_0]) } - public var Passport_UpdateRequiredError: String { return self._s[1074]! } - public var Notifications_PermissionsSuppressWarningText: String { return self._s[1076]! } - public var Passport_Identity_MainPageHelp: String { return self._s[1077]! } - public var Conversation_StatusKickedFromGroup: String { return self._s[1078]! } - public var Passport_Language_ka: String { return self._s[1079]! } - public var Call_Decline: String { return self._s[1080]! } - public var SocksProxySetup_ProxyEnabled: String { return self._s[1081]! } + public var GroupRemoved_AddToGroup: String { return self._s[1133]! } + public var Passport_UpdateRequiredError: String { return self._s[1134]! } + public var Notifications_PermissionsSuppressWarningText: String { return self._s[1136]! } + public var Passport_Identity_MainPageHelp: String { return self._s[1137]! } + public var Conversation_StatusKickedFromGroup: String { return self._s[1138]! } + public var Passport_Language_ka: String { return self._s[1139]! } + public var Call_Decline: String { return self._s[1140]! } + public var SocksProxySetup_ProxyEnabled: String { return self._s[1141]! } public func AuthCode_Alert(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1084]!, self._r[1084]!, [_0]) + return formatWithArgumentRanges(self._s[1144]!, self._r[1144]!, [_0]) + } + public func CHANNEL_MESSAGE_POLL_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1145]!, self._r[1145]!, [_1]) } public func Channel_AdminLog_MessagePromotedNameUsername(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1085]!, self._r[1085]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1146]!, self._r[1146]!, [_1, _2]) } - public var Passport_Phone_UseTelegramNumberHelp: String { return self._s[1086]! } - public var Passport_DeletePassport: String { return self._s[1088]! } - public var Privacy_Calls_P2PAlways: String { return self._s[1089]! } - public var Month_ShortDecember: String { return self._s[1090]! } - public var Channel_AdminLog_CanEditMessages: String { return self._s[1092]! } + public var Passport_Phone_UseTelegramNumberHelp: String { return self._s[1147]! } + public var Passport_DeletePassport: String { return self._s[1149]! } + public var Privacy_Calls_P2PAlways: String { return self._s[1150]! } + public var Month_ShortDecember: String { return self._s[1151]! } + public var Channel_AdminLog_CanEditMessages: String { return self._s[1153]! } public func Contacts_AccessDeniedHelpLandscape(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1093]!, self._r[1093]!, [_0]) + return formatWithArgumentRanges(self._s[1154]!, self._r[1154]!, [_0]) } - public var Channel_Stickers_Searching: String { return self._s[1094]! } - public var Conversation_EncryptedDescription1: String { return self._s[1095]! } - public var Conversation_EncryptedDescription2: String { return self._s[1096]! } - public var Conversation_EncryptedDescription3: String { return self._s[1097]! } - public var PhotoEditor_SharpenTool: String { return self._s[1098]! } + public var Channel_Stickers_Searching: String { return self._s[1155]! } + public var Conversation_EncryptedDescription1: String { return self._s[1156]! } + public var Conversation_EncryptedDescription2: String { return self._s[1157]! } + public var Conversation_EncryptedDescription3: String { return self._s[1158]! } + public var PhotoEditor_SharpenTool: String { return self._s[1159]! } public func ENCRYPTED_MESSAGE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1099]!, self._r[1099]!, [_1]) + return formatWithArgumentRanges(self._s[1160]!, self._r[1160]!, [_1]) } - public var Conversation_EncryptedDescription4: String { return self._s[1101]! } - public var Channel_Members_AddMembers: String { return self._s[1102]! } - public var Weekday_Friday: String { return self._s[1103]! } - public var Privacy_ContactsSync: String { return self._s[1104]! } - public var ApplyLanguage_ChangeLanguageAction: String { return self._s[1105]! } + public var Conversation_EncryptedDescription4: String { return self._s[1162]! } + public var Channel_Members_AddMembers: String { return self._s[1163]! } + public func CHANNEL_MESSAGE_GAME_SEPARATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1164]!, self._r[1164]!, [_1, _2]) + } + public func CHAT_MESSAGE_GEOLIVE_SEPARATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1165]!, self._r[1165]!, [_1, _2]) + } + public var Weekday_Friday: String { return self._s[1166]! } + public var Privacy_ContactsSync: String { return self._s[1167]! } + public var ApplyLanguage_ChangeLanguageAction: String { return self._s[1168]! } public func Channel_Management_RestrictedBy(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1106]!, self._r[1106]!, [_0]) + return formatWithArgumentRanges(self._s[1169]!, self._r[1169]!, [_0]) } - public var Passport_Identity_GenderMale: String { return self._s[1107]! } + public var GroupInfo_Permissions_Removed: String { return self._s[1170]! } + public var Passport_Identity_GenderMale: String { return self._s[1171]! } public func Call_StatusBar(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1108]!, self._r[1108]!, [_0]) + return formatWithArgumentRanges(self._s[1172]!, self._r[1172]!, [_0]) } - public var Notifications_PermissionsKeepDisabled: String { return self._s[1109]! } - public var Conversation_JumpToDate: String { return self._s[1110]! } - public var Contacts_GlobalSearch: String { return self._s[1111]! } - public var AutoDownloadSettings_ResetHelp: String { return self._s[1112]! } - public var Profile_MessageLifetime1d: String { return self._s[1113]! } + public var Notifications_PermissionsKeepDisabled: String { return self._s[1173]! } + public var Conversation_JumpToDate: String { return self._s[1174]! } + public var Contacts_GlobalSearch: String { return self._s[1175]! } + public var AutoDownloadSettings_ResetHelp: String { return self._s[1176]! } + public var Profile_MessageLifetime1d: String { return self._s[1177]! } public func MESSAGE_INVOICE(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1114]!, self._r[1114]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1178]!, self._r[1178]!, [_1, _2]) } - public var StickerPack_BuiltinPackName: String { return self._s[1117]! } - public var Passport_InfoTitle: String { return self._s[1119]! } - public var Notifications_PermissionsUnreachableText: String { return self._s[1120]! } + public var StickerPack_BuiltinPackName: String { return self._s[1181]! } + public var Passport_InfoTitle: String { return self._s[1183]! } + public var Notifications_PermissionsUnreachableText: String { return self._s[1184]! } public func NetworkUsageSettings_CellularUsageSince(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1124]!, self._r[1124]!, [_0]) + return formatWithArgumentRanges(self._s[1188]!, self._r[1188]!, [_0]) } - public var Passport_Address_TypePassportRegistrationUploadScan: String { return self._s[1125]! } - public var Profile_BotInfo: String { return self._s[1126]! } - public var Watch_Compose_CreateMessage: String { return self._s[1127]! } - public var Month_ShortNovember: String { return self._s[1128]! } + public var Passport_Address_TypePassportRegistrationUploadScan: String { return self._s[1189]! } + public var Profile_BotInfo: String { return self._s[1190]! } + public var Watch_Compose_CreateMessage: String { return self._s[1191]! } + public var Month_ShortNovember: String { return self._s[1192]! } public func PHONE_CALL_REQUEST(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1129]!, self._r[1129]!, [_1]) + return formatWithArgumentRanges(self._s[1193]!, self._r[1193]!, [_1]) } public func ENCRYPTION_REQUEST(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1130]!, self._r[1130]!, [_1]) + return formatWithArgumentRanges(self._s[1194]!, self._r[1194]!, [_1]) } - public var Passport_Identity_TranslationsHelp: String { return self._s[1131]! } - public var NotificationsSound_Chime: String { return self._s[1132]! } - public var Passport_Language_ko: String { return self._s[1134]! } - public var InviteText_URL: String { return self._s[1135]! } - public var TextFormat_Monospace: String { return self._s[1136]! } + public var Passport_Identity_TranslationsHelp: String { return self._s[1195]! } + public var NotificationsSound_Chime: String { return self._s[1196]! } + public var Passport_Language_ko: String { return self._s[1198]! } + public var InviteText_URL: String { return self._s[1199]! } + public var TextFormat_Monospace: String { return self._s[1200]! } public func Time_PreciseDate_m11(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1137]!, self._r[1137]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1201]!, self._r[1201]!, [_1, _2, _3]) } public func Login_WillSendSms(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1138]!, self._r[1138]!, [_0]) + return formatWithArgumentRanges(self._s[1202]!, self._r[1202]!, [_0]) } public func Watch_Time_ShortWeekdayAt(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1139]!, self._r[1139]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1203]!, self._r[1203]!, [_1, _2]) } - public var Passport_InfoLearnMore: String { return self._s[1141]! } - public var TwoStepAuth_EmailPlaceholder: String { return self._s[1142]! } - public var Passport_Identity_AddIdentityCard: String { return self._s[1143]! } - public var Your_card_has_expired: String { return self._s[1144]! } - public var StickerPacksSettings_StickerPacksSection: String { return self._s[1145]! } - public var GroupInfo_InviteLink_Help: String { return self._s[1146]! } - public var Conversation_Report: String { return self._s[1149]! } - public var Notifications_MessageNotificationsSound: String { return self._s[1150]! } - public var Notification_MessageLifetime1m: String { return self._s[1151]! } - public var Privacy_ContactsTitle: String { return self._s[1152]! } - public var Conversation_ShareMyContactInfo: String { return self._s[1153]! } - public var ChannelMembers_WhoCanAddMembersAdminsHelp: String { return self._s[1154]! } - public var Channel_Members_Title: String { return self._s[1155]! } - public var Map_OpenInWaze: String { return self._s[1156]! } - public var Login_PhoneBannedError: String { return self._s[1157]! } + public var Passport_InfoLearnMore: String { return self._s[1205]! } + public var TwoStepAuth_EmailPlaceholder: String { return self._s[1206]! } + public var Passport_Identity_AddIdentityCard: String { return self._s[1207]! } + public var Your_card_has_expired: String { return self._s[1208]! } + public var StickerPacksSettings_StickerPacksSection: String { return self._s[1209]! } + public var GroupInfo_InviteLink_Help: String { return self._s[1210]! } + public var Conversation_Report: String { return self._s[1213]! } + public var Notifications_MessageNotificationsSound: String { return self._s[1214]! } + public var Notification_MessageLifetime1m: String { return self._s[1215]! } + public var Privacy_ContactsTitle: String { return self._s[1216]! } + public var Conversation_ShareMyContactInfo: String { return self._s[1217]! } + public var ChannelMembers_WhoCanAddMembersAdminsHelp: String { return self._s[1218]! } + public var Channel_Members_Title: String { return self._s[1219]! } + public var Map_OpenInWaze: String { return self._s[1220]! } + public var Login_PhoneBannedError: String { return self._s[1221]! } public func LiveLocationUpdated_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1158]!, self._r[1158]!, [_0]) + return formatWithArgumentRanges(self._s[1222]!, self._r[1222]!, [_0]) } public func MESSAGE_PHOTO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1159]!, self._r[1159]!, [_1]) + return formatWithArgumentRanges(self._s[1223]!, self._r[1223]!, [_1]) } - public var Group_Management_AddModeratorHelp: String { return self._s[1160]! } - public var Common_OK: String { return self._s[1161]! } - public var Passport_Address_TypeBankStatementUploadScan: String { return self._s[1162]! } - public var Cache_Music: String { return self._s[1163]! } - public var PasscodeSettings_UnlockWithTouchId: String { return self._s[1164]! } - public var TwoStepAuth_HintPlaceholder: String { return self._s[1165]! } + public var Group_Management_AddModeratorHelp: String { return self._s[1224]! } + public var Common_OK: String { return self._s[1225]! } + public var Passport_Address_TypeBankStatementUploadScan: String { return self._s[1226]! } + public var Cache_Music: String { return self._s[1227]! } + public func CHAT_TITLE_EDITED_SEPARATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1228]!, self._r[1228]!, [_1, _2]) + } + public func PINNED_AUDIO_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1229]!, self._r[1229]!, [_1]) + } + public var PasscodeSettings_UnlockWithTouchId: String { return self._s[1230]! } + public var TwoStepAuth_HintPlaceholder: String { return self._s[1231]! } public func Passport_RequestHeader(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1166]!, self._r[1166]!, [_0]) + return formatWithArgumentRanges(self._s[1232]!, self._r[1232]!, [_0]) } - public var Watch_MessageView_ViewOnPhone: String { return self._s[1168]! } - public var Privacy_Calls_CustomShareHelp: String { return self._s[1169]! } - public var ChangePhoneNumberNumber_Title: String { return self._s[1171]! } - public var State_ConnectingToProxyInfo: String { return self._s[1172]! } - public var Message_VideoMessage: String { return self._s[1174]! } - public var ChannelInfo_DeleteChannel: String { return self._s[1175]! } + public var Watch_MessageView_ViewOnPhone: String { return self._s[1234]! } + public var Privacy_Calls_CustomShareHelp: String { return self._s[1235]! } + public var ChangePhoneNumberNumber_Title: String { return self._s[1237]! } + public var State_ConnectingToProxyInfo: String { return self._s[1238]! } + public var Message_VideoMessage: String { return self._s[1240]! } + public var ChannelInfo_DeleteChannel: String { return self._s[1241]! } public func CHAT_MESSAGE_POLL(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1176]!, self._r[1176]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1242]!, self._r[1242]!, [_1, _2]) } - public var ContactInfo_PhoneLabelOther: String { return self._s[1177]! } - public var Channel_EditAdmin_CannotEdit: String { return self._s[1178]! } - public var Passport_DeleteAddressConfirmation: String { return self._s[1179]! } - public var Activity_RecordingAudio: String { return self._s[1180]! } - public var PasscodeSettings_TryAgainIn1Minute: String { return self._s[1181]! } + public var ContactInfo_PhoneLabelOther: String { return self._s[1243]! } + public var Channel_EditAdmin_CannotEdit: String { return self._s[1244]! } + public var Passport_DeleteAddressConfirmation: String { return self._s[1245]! } + public var Activity_RecordingAudio: String { return self._s[1246]! } + public var PasscodeSettings_TryAgainIn1Minute: String { return self._s[1247]! } public func Notification_ChangedGroupName(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1183]!, self._r[1183]!, [_0, _1]) + return formatWithArgumentRanges(self._s[1249]!, self._r[1249]!, [_0, _1]) } - public var Conversation_ApplyLocalization: String { return self._s[1186]! } - public var UserInfo_AddPhone: String { return self._s[1187]! } - public var Map_ShareLiveLocationHelp: String { return self._s[1188]! } + public func EmptyGroupInfo_Line1(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1252]!, self._r[1252]!, [_0]) + } + public var Conversation_ApplyLocalization: String { return self._s[1253]! } + public var UserInfo_AddPhone: String { return self._s[1254]! } + public var Map_ShareLiveLocationHelp: String { return self._s[1255]! } public func Passport_Identity_NativeNameGenericHelp(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1189]!, self._r[1189]!, [_0]) + return formatWithArgumentRanges(self._s[1256]!, self._r[1256]!, [_0]) } - public var Passport_Scans: String { return self._s[1191]! } - public var BlockedUsers_Unblock: String { return self._s[1192]! } - public var Channel_Management_LabelCreator: String { return self._s[1193]! } - public var Passport_Identity_NativeNameGenericTitle: String { return self._s[1194]! } + public var Passport_Scans: String { return self._s[1258]! } + public var BlockedUsers_Unblock: String { return self._s[1259]! } + public var Channel_Management_LabelCreator: String { return self._s[1260]! } + public var Passport_Identity_NativeNameGenericTitle: String { return self._s[1261]! } public func Login_EmailPhoneBody(_ _0: String, _ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1195]!, self._r[1195]!, [_0, _1, _2]) + return formatWithArgumentRanges(self._s[1262]!, self._r[1262]!, [_0, _1, _2]) } - public var Login_PhoneNumberHelp: String { return self._s[1196]! } - public var LastSeen_ALongTimeAgo: String { return self._s[1197]! } - public var Channel_AdminLog_CanPinMessages: String { return self._s[1198]! } - public var ChannelIntro_CreateChannel: String { return self._s[1199]! } - public var Conversation_UnreadMessages: String { return self._s[1200]! } - public var Channel_AdminLog_EmptyText: String { return self._s[1201]! } - public var Notification_GroupActivated: String { return self._s[1202]! } + public var Login_PhoneNumberHelp: String { return self._s[1263]! } + public var LastSeen_ALongTimeAgo: String { return self._s[1264]! } + public var Channel_AdminLog_CanPinMessages: String { return self._s[1265]! } + public var ChannelIntro_CreateChannel: String { return self._s[1266]! } + public var Conversation_UnreadMessages: String { return self._s[1267]! } + public var Channel_AdminLog_EmptyText: String { return self._s[1268]! } + public var Notification_GroupActivated: String { return self._s[1269]! } public func Notification_PinnedContactMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1203]!, self._r[1203]!, [_0]) + return formatWithArgumentRanges(self._s[1270]!, self._r[1270]!, [_0]) } public func DownloadingStatus(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1204]!, self._r[1204]!, [_0, _1]) + return formatWithArgumentRanges(self._s[1271]!, self._r[1271]!, [_0, _1]) } - public var GroupInfo_ConvertToSupergroup: String { return self._s[1206]! } + public var GroupInfo_ConvertToSupergroup: String { return self._s[1273]! } public func PrivacyPolicy_AgeVerificationMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1207]!, self._r[1207]!, [_0]) + return formatWithArgumentRanges(self._s[1274]!, self._r[1274]!, [_0]) } - public var Document_TargetConfirmationFormat: String { return self._s[1208]! } + public var Document_TargetConfirmationFormat: String { return self._s[1275]! } public func Call_StatusOngoing(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1209]!, self._r[1209]!, [_0]) + return formatWithArgumentRanges(self._s[1276]!, self._r[1276]!, [_0]) } public func CHAT_MESSAGE_INVOICE(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1211]!, self._r[1211]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1278]!, self._r[1278]!, [_1, _2, _3]) } - public var Conversation_ClearSelfHistory: String { return self._s[1212]! } - public var Checkout_NewCard_PostcodePlaceholder: String { return self._s[1213]! } - public var Stickers_SuggestNone: String { return self._s[1214]! } - public var ChatSettings_Cache: String { return self._s[1215]! } - public var Settings_SaveIncomingPhotos: String { return self._s[1216]! } - public var Media_ShareThisPhoto: String { return self._s[1217]! } - public var InfoPlist_NSContactsUsageDescription: String { return self._s[1218]! } - public var Conversation_ContextMenuCopyLink: String { return self._s[1219]! } - public var PrivacyPolicy_AgeVerificationTitle: String { return self._s[1220]! } - public var TwoStepAuth_SetupPasswordEnterPasswordNew: String { return self._s[1221]! } - public var Permissions_CellularDataTitle_v0: String { return self._s[1222]! } - public var Map_OpenIn: String { return self._s[1223]! } + public var Conversation_ClearSelfHistory: String { return self._s[1279]! } + public var Checkout_NewCard_PostcodePlaceholder: String { return self._s[1280]! } + public var Stickers_SuggestNone: String { return self._s[1281]! } + public var ChatSettings_Cache: String { return self._s[1282]! } + public var Settings_SaveIncomingPhotos: String { return self._s[1283]! } + public var Media_ShareThisPhoto: String { return self._s[1284]! } + public var InfoPlist_NSContactsUsageDescription: String { return self._s[1285]! } + public var Conversation_ContextMenuCopyLink: String { return self._s[1286]! } + public var PrivacyPolicy_AgeVerificationTitle: String { return self._s[1287]! } + public var TwoStepAuth_SetupPasswordEnterPasswordNew: String { return self._s[1288]! } + public var Permissions_CellularDataTitle_v0: String { return self._s[1289]! } + public var Map_OpenIn: String { return self._s[1290]! } public func ChannelInfo_AddParticipantConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1226]!, self._r[1226]!, [_0]) + return formatWithArgumentRanges(self._s[1293]!, self._r[1293]!, [_0]) } - public var MessagePoll_LabelClosed: String { return self._s[1227]! } - public var Passport_Identity_MiddleNamePlaceholder: String { return self._s[1229]! } - public var UserInfo_FirstNamePlaceholder: String { return self._s[1230]! } - public var PrivacyLastSeenSettings_WhoCanSeeMyTimestamp: String { return self._s[1231]! } - public var Login_SelectCountry_Title: String { return self._s[1232]! } - public var Channel_EditAdmin_PermissionBanUsers: String { return self._s[1233]! } - public var Watch_Suggestion_BRB: String { return self._s[1234]! } - public var Contacts_PermissionsTitle: String { return self._s[1235]! } - public var Passport_Identity_EditIdentityCard: String { return self._s[1236]! } - public var Conversation_RestrictedInline: String { return self._s[1237]! } - public var StickerPack_ViewPack: String { return self._s[1239]! } + public var MessagePoll_LabelClosed: String { return self._s[1294]! } + public var Passport_Identity_MiddleNamePlaceholder: String { return self._s[1296]! } + public var UserInfo_FirstNamePlaceholder: String { return self._s[1297]! } + public var PrivacyLastSeenSettings_WhoCanSeeMyTimestamp: String { return self._s[1298]! } + public var Login_SelectCountry_Title: String { return self._s[1299]! } + public var Channel_EditAdmin_PermissionBanUsers: String { return self._s[1300]! } + public var Watch_Suggestion_BRB: String { return self._s[1301]! } + public var Contacts_PermissionsTitle: String { return self._s[1302]! } + public var Passport_Identity_EditIdentityCard: String { return self._s[1303]! } + public var Conversation_RestrictedInline: String { return self._s[1304]! } + public var StickerPack_ViewPack: String { return self._s[1306]! } public func Update_AppVersion(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1240]!, self._r[1240]!, [_0]) + return formatWithArgumentRanges(self._s[1307]!, self._r[1307]!, [_0]) } - public var Compose_NewChannel: String { return self._s[1242]! } - public var Channel_Info_Stickers: String { return self._s[1246]! } - public var AutoNightTheme_PreferredTheme: String { return self._s[1247]! } - public var PrivacyPolicy_AgeVerificationAgree: String { return self._s[1248]! } - public var Passport_DeletePersonalDetails: String { return self._s[1249]! } - public var Conversation_SearchNoResults: String { return self._s[1251]! } - public var MessagePoll_LabelAnonymous: String { return self._s[1252]! } - public var Channel_Members_AddAdminErrorNotAMember: String { return self._s[1253]! } - public var Login_Code: String { return self._s[1254]! } - public var Watch_Suggestion_WhatsUp: String { return self._s[1255]! } - public var Weekday_ShortThursday: String { return self._s[1256]! } - public var Resolve_ErrorNotFound: String { return self._s[1258]! } - public var LastSeen_Offline: String { return self._s[1259]! } - public var Privacy_Calls_AlwaysAllow_Title: String { return self._s[1260]! } - public var Channel_AdminLog_CanChangeInviteLink: String { return self._s[1261]! } - public var GroupInfo_Title: String { return self._s[1262]! } - public var NotificationsSound_Note: String { return self._s[1263]! } - public var Conversation_EditingMessagePanelTitle: String { return self._s[1264]! } - public var Privacy_Calls: String { return self._s[1265]! } - public var Month_ShortAugust: String { return self._s[1266]! } - public var TwoStepAuth_SetPasswordHelp: String { return self._s[1267]! } - public var Notifications_Reset: String { return self._s[1268]! } - public var Conversation_Pin: String { return self._s[1269]! } - public var Passport_Language_lv: String { return self._s[1270]! } - public var BlockedUsers_Info: String { return self._s[1271]! } - public var Watch_Conversation_Unblock: String { return self._s[1274]! } + public var Compose_NewChannel: String { return self._s[1309]! } + public var Channel_Info_Stickers: String { return self._s[1313]! } + public var AutoNightTheme_PreferredTheme: String { return self._s[1314]! } + public var PrivacyPolicy_AgeVerificationAgree: String { return self._s[1315]! } + public var Passport_DeletePersonalDetails: String { return self._s[1316]! } + public var Conversation_SearchNoResults: String { return self._s[1318]! } + public var MessagePoll_LabelAnonymous: String { return self._s[1319]! } + public var Channel_Members_AddAdminErrorNotAMember: String { return self._s[1320]! } + public var Login_Code: String { return self._s[1321]! } + public var Watch_Suggestion_WhatsUp: String { return self._s[1322]! } + public var Weekday_ShortThursday: String { return self._s[1323]! } + public var Resolve_ErrorNotFound: String { return self._s[1325]! } + public var LastSeen_Offline: String { return self._s[1326]! } + public var Privacy_Calls_AlwaysAllow_Title: String { return self._s[1327]! } + public var Channel_AdminLog_CanChangeInviteLink: String { return self._s[1328]! } + public var GroupInfo_Title: String { return self._s[1329]! } + public var NotificationsSound_Note: String { return self._s[1330]! } + public var Conversation_EditingMessagePanelTitle: String { return self._s[1331]! } + public var Privacy_Calls: String { return self._s[1332]! } + public func CHANNEL_MESSAGE_PHOTO_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1333]!, self._r[1333]!, [_1]) + } + public var Month_ShortAugust: String { return self._s[1334]! } + public var TwoStepAuth_SetPasswordHelp: String { return self._s[1335]! } + public var Notifications_Reset: String { return self._s[1336]! } + public var Conversation_Pin: String { return self._s[1337]! } + public var Passport_Language_lv: String { return self._s[1338]! } + public var BlockedUsers_Info: String { return self._s[1339]! } + public var Watch_Conversation_Unblock: String { return self._s[1342]! } public func Time_MonthOfYear_m9(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1275]!, self._r[1275]!, [_0]) + return formatWithArgumentRanges(self._s[1343]!, self._r[1343]!, [_0]) } - public var CloudStorage_Title: String { return self._s[1276]! } - public var GroupInfo_DeleteAndExitConfirmation: String { return self._s[1277]! } - public var TwoStepAuth_RecoveryEmailTitle: String { return self._s[1278]! } + public var CloudStorage_Title: String { return self._s[1344]! } + public var GroupInfo_DeleteAndExitConfirmation: String { return self._s[1345]! } public func NetworkUsageSettings_WifiUsageSince(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1279]!, self._r[1279]!, [_0]) + return formatWithArgumentRanges(self._s[1346]!, self._r[1346]!, [_0]) } - public var Watch_Suggestion_OnMyWay: String { return self._s[1280]! } - public var Channel_AdminLogFilter_AdminsTitle: String { return self._s[1281]! } - public var Passport_Address_EditBankStatement: String { return self._s[1282]! } - public var ChatSettings_DownloadInBackgroundInfo: String { return self._s[1283]! } - public var ShareMenu_Comment: String { return self._s[1284]! } - public var Permissions_ContactsTitle_v0: String { return self._s[1285]! } - public var Notifications_PermissionsTitle: String { return self._s[1286]! } - public var Settings_Support: String { return self._s[1287]! } - public var Notifications_ChannelNotificationsSound: String { return self._s[1288]! } - public var Channel_AdminLog_BanSendGifs: String { return self._s[1289]! } - public var Watch_Stickers_StickerPacks: String { return self._s[1290]! } - public var Common_Select: String { return self._s[1292]! } - public var CheckoutInfo_ErrorEmailInvalid: String { return self._s[1293]! } - public var ChatAdmins_AllMembersAreAdminsOffHelp: String { return self._s[1295]! } - public var PasscodeSettings_AutoLock_IfAwayFor_5hours: String { return self._s[1296]! } - public var Appearance_PreviewReplyAuthor: String { return self._s[1297]! } - public var TwoStepAuth_RecoveryTitle: String { return self._s[1298]! } - public var Widget_AuthRequired: String { return self._s[1299]! } - public var Camera_FlashOn: String { return self._s[1300]! } - public var Channel_Stickers_NotFoundHelp: String { return self._s[1301]! } - public var Watch_Suggestion_OK: String { return self._s[1302]! } + public var Channel_AdminLogFilter_AdminsTitle: String { return self._s[1347]! } + public var Watch_Suggestion_OnMyWay: String { return self._s[1348]! } + public var TwoStepAuth_RecoveryEmailTitle: String { return self._s[1349]! } + public func MESSAGE_CONTACT_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1350]!, self._r[1350]!, [_1]) + } + public var Passport_Address_EditBankStatement: String { return self._s[1351]! } + public var ChatSettings_DownloadInBackgroundInfo: String { return self._s[1352]! } + public var ShareMenu_Comment: String { return self._s[1353]! } + public var Permissions_ContactsTitle_v0: String { return self._s[1354]! } + public var Notifications_PermissionsTitle: String { return self._s[1355]! } + public var GroupPermission_NoSendLinks: String { return self._s[1356]! } + public var Settings_Support: String { return self._s[1357]! } + public var Notifications_ChannelNotificationsSound: String { return self._s[1358]! } + public func CHAT_RETURNED_SEPARATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1359]!, self._r[1359]!, [_1, _2]) + } + public var GroupPermission_ApplyAlertAction: String { return self._s[1360]! } + public var Channel_AdminLog_BanSendGifs: String { return self._s[1361]! } + public var Watch_Stickers_StickerPacks: String { return self._s[1362]! } + public var Common_Select: String { return self._s[1364]! } + public var CheckoutInfo_ErrorEmailInvalid: String { return self._s[1365]! } + public var ChatAdmins_AllMembersAreAdminsOffHelp: String { return self._s[1367]! } + public var PasscodeSettings_AutoLock_IfAwayFor_5hours: String { return self._s[1368]! } + public var Appearance_PreviewReplyAuthor: String { return self._s[1369]! } + public var TwoStepAuth_RecoveryTitle: String { return self._s[1370]! } + public var Widget_AuthRequired: String { return self._s[1371]! } + public var Camera_FlashOn: String { return self._s[1372]! } + public var Channel_Stickers_NotFoundHelp: String { return self._s[1373]! } + public var Watch_Suggestion_OK: String { return self._s[1374]! } public func Username_LinkHint(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1304]!, self._r[1304]!, [_0]) + return formatWithArgumentRanges(self._s[1376]!, self._r[1376]!, [_0]) } public func Notification_PinnedLiveLocationMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1305]!, self._r[1305]!, [_0]) + return formatWithArgumentRanges(self._s[1377]!, self._r[1377]!, [_0]) } - public var DialogList_AdLabel: String { return self._s[1306]! } - public var WatchRemote_NotificationText: String { return self._s[1307]! } - public var Conversation_ReportSpam: String { return self._s[1308]! } - public var Settings_LogoutConfirmationTitle: String { return self._s[1310]! } - public var PhoneLabel_Title: String { return self._s[1311]! } - public var Passport_Address_EditRentalAgreement: String { return self._s[1312]! } - public var Notifications_ExceptionsTitle: String { return self._s[1313]! } + public var DialogList_AdLabel: String { return self._s[1378]! } + public var WatchRemote_NotificationText: String { return self._s[1379]! } + public var Conversation_ReportSpam: String { return self._s[1380]! } + public var Settings_LogoutConfirmationTitle: String { return self._s[1382]! } + public var PhoneLabel_Title: String { return self._s[1383]! } + public var Passport_Address_EditRentalAgreement: String { return self._s[1384]! } + public var Notifications_ExceptionsTitle: String { return self._s[1385]! } public func CHANNEL_MESSAGE_PHOTO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1314]!, self._r[1314]!, [_1]) + return formatWithArgumentRanges(self._s[1386]!, self._r[1386]!, [_1]) } - public var Notifications_AlertTones: String { return self._s[1315]! } - public var Call_ReportIncludeLogDescription: String { return self._s[1316]! } + public var Notifications_AlertTones: String { return self._s[1387]! } + public var Call_ReportIncludeLogDescription: String { return self._s[1388]! } public func CHAT_ADD_MEMBER(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1317]!, self._r[1317]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1389]!, self._r[1389]!, [_1, _2, _3]) } - public var AutoDownloadSettings_PrivateChats: String { return self._s[1318]! } - public var TwoStepAuth_AddHintTitle: String { return self._s[1320]! } - public var ReportPeer_ReasonOther: String { return self._s[1321]! } - public var KeyCommand_ScrollDown: String { return self._s[1323]! } + public var AutoDownloadSettings_PrivateChats: String { return self._s[1390]! } + public var TwoStepAuth_AddHintTitle: String { return self._s[1392]! } + public var ReportPeer_ReasonOther: String { return self._s[1393]! } + public var KeyCommand_ScrollDown: String { return self._s[1395]! } public func Login_BannedPhoneSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1324]!, self._r[1324]!, [_0]) + return formatWithArgumentRanges(self._s[1396]!, self._r[1396]!, [_0]) } - public var NetworkUsageSettings_MediaVideoDataSection: String { return self._s[1325]! } - public var ChannelInfo_DeleteGroupConfirmation: String { return self._s[1326]! } - public var AuthSessions_LogOut: String { return self._s[1327]! } - public var Passport_Identity_TypeInternalPassport: String { return self._s[1328]! } - public var ChatSettings_AutoDownloadVoiceMessages: String { return self._s[1329]! } + public var NetworkUsageSettings_MediaVideoDataSection: String { return self._s[1397]! } + public var ChannelInfo_DeleteGroupConfirmation: String { return self._s[1398]! } + public var AuthSessions_LogOut: String { return self._s[1399]! } + public func CHAT_PHOTO_EDITED_SEPARATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1400]!, self._r[1400]!, [_1, _2]) + } + public var Passport_Identity_TypeInternalPassport: String { return self._s[1401]! } + public var ChatSettings_AutoDownloadVoiceMessages: String { return self._s[1402]! } public func CHAT_MESSAGE_DOC(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1330]!, self._r[1330]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1403]!, self._r[1403]!, [_1, _2]) } - public var Passport_Phone_Title: String { return self._s[1331]! } - public var Settings_PhoneNumber: String { return self._s[1332]! } - public var NotificationsSound_Alert: String { return self._s[1333]! } - public var PhotoEditor_CurvesTool: String { return self._s[1335]! } - public var Checkout_PaymentMethod: String { return self._s[1337]! } - public var Contacts_AccessDeniedError: String { return self._s[1338]! } - public var Camera_PhotoMode: String { return self._s[1341]! } - public var Passport_Address_AddUtilityBill: String { return self._s[1342]! } - public var CallSettings_OnMobile: String { return self._s[1343]! } - public var Tour_Text2: String { return self._s[1344]! } - public var DialogList_EncryptionProcessing: String { return self._s[1346]! } - public var Permissions_Skip: String { return self._s[1347]! } - public var SecretImage_Title: String { return self._s[1348]! } - public var Watch_MessageView_Title: String { return self._s[1349]! } - public var AttachmentMenu_Poll: String { return self._s[1350]! } + public var Passport_Phone_Title: String { return self._s[1404]! } + public var Settings_PhoneNumber: String { return self._s[1405]! } + public var NotificationsSound_Alert: String { return self._s[1406]! } + public var PhotoEditor_CurvesTool: String { return self._s[1408]! } + public var Checkout_PaymentMethod: String { return self._s[1410]! } + public var Contacts_AccessDeniedError: String { return self._s[1411]! } + public var Camera_PhotoMode: String { return self._s[1414]! } + public var Passport_Address_AddUtilityBill: String { return self._s[1415]! } + public var CallSettings_OnMobile: String { return self._s[1416]! } + public var Tour_Text2: String { return self._s[1417]! } + public func MESSAGE_STICKER_SEPARATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1419]!, self._r[1419]!, [_1, _2]) + } + public var DialogList_EncryptionProcessing: String { return self._s[1420]! } + public var Permissions_Skip: String { return self._s[1421]! } + public var SecretImage_Title: String { return self._s[1422]! } + public var Watch_MessageView_Title: String { return self._s[1423]! } + public var AttachmentMenu_Poll: String { return self._s[1424]! } public func Notification_GroupInviter(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1351]!, self._r[1351]!, [_0]) - } - public var Notification_CallCanceled: String { return self._s[1352]! } - public var Privacy_PaymentsClear_PaymentInfo: String { return self._s[1353]! } - public func MESSAGE_SCREENSHOT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1354]!, self._r[1354]!, [_1]) - } - public var Settings_ProxyConnecting: String { return self._s[1355]! } - public var Profile_MessageLifetime5s: String { return self._s[1357]! } - public var Username_InvalidCharacters: String { return self._s[1358]! } - public var AutoDownloadSettings_LimitBySize: String { return self._s[1359]! } - public var Notification_CreatedChannel: String { return self._s[1361]! } - public var Passcode_AppLockedAlert: String { return self._s[1363]! } - public var Contacts_TopSection: String { return self._s[1364]! } - public func Time_MonthOfYear_m6(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1365]!, self._r[1365]!, [_0]) - } - public var ReportPeer_ReasonSpam: String { return self._s[1366]! } - public var UserInfo_TapToCall: String { return self._s[1367]! } - public var Common_Search: String { return self._s[1369]! } - public var AuthSessions_IncompleteAttemptsInfo: String { return self._s[1370]! } - public var Message_InvoiceLabel: String { return self._s[1371]! } - public var Conversation_InputTextPlaceholder: String { return self._s[1372]! } - public var NetworkUsageSettings_MediaImageDataSection: String { return self._s[1373]! } - public func Passport_Address_UploadOneOfScan(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1374]!, self._r[1374]!, [_0]) - } - public func MESSAGE_DOC(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1375]!, self._r[1375]!, [_1]) - } - public var Conversation_Info: String { return self._s[1376]! } - public var Login_InfoDeletePhoto: String { return self._s[1377]! } - public var Passport_Language_vi: String { return self._s[1379]! } - public var Conversation_Search: String { return self._s[1380]! } - public var DialogList_DeleteBotConversationConfirmation: String { return self._s[1381]! } - public var ReportPeer_ReasonPornography: String { return self._s[1382]! } - public var AutoDownloadSettings_PhotosTitle: String { return self._s[1383]! } - public var Conversation_SendMessageErrorGroupRestricted: String { return self._s[1384]! } - public var Map_LiveLocationGroupDescription: String { return self._s[1385]! } - public var Channel_Setup_TypeHeader: String { return self._s[1386]! } - public var AuthSessions_LoggedIn: String { return self._s[1387]! } - public var Login_SmsRequestState3: String { return self._s[1388]! } - public var Passport_Address_EditUtilityBill: String { return self._s[1389]! } - public var Appearance_ReduceMotionInfo: String { return self._s[1390]! } - public var Channel_Edit_LinkItem: String { return self._s[1391]! } - public var Privacy_Calls_P2PNever: String { return self._s[1392]! } - public var Conversation_AddToReadingList: String { return self._s[1394]! } - public func MESSAGE_GEO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1395]!, self._r[1395]!, [_1]) - } - public var Message_Animation: String { return self._s[1396]! } - public var Map_Unknown: String { return self._s[1397]! } - public var Call_StatusRequesting: String { return self._s[1398]! } - public func Passport_FieldOneOf_Or(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1399]!, self._r[1399]!, [_1, _2]) - } - public var Conversation_SecretChatContextBotAlert: String { return self._s[1400]! } - public var SocksProxySetup_ProxyStatusChecking: String { return self._s[1401]! } - public func MESSAGE_PHOTO_SECRET(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1402]!, self._r[1402]!, [_1]) - } - public var Weekday_Monday: String { return self._s[1403]! } - public var Update_Skip: String { return self._s[1404]! } - public var Group_Username_RemoveExistingUsernamesInfo: String { return self._s[1405]! } - public var Message_PinnedPollMessage: String { return self._s[1406]! } - public var BlockedUsers_Title: String { return self._s[1407]! } - public func Notification_PinnedLocationMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1408]!, self._r[1408]!, [_0]) - } - public var Username_CheckingUsername: String { return self._s[1409]! } - public var NotificationsSound_Bell: String { return self._s[1410]! } - public var Conversation_SendMessageErrorFlood: String { return self._s[1411]! } - public var ChannelMembers_ChannelAdminsTitle: String { return self._s[1412]! } - public var ChatSettings_Groups: String { return self._s[1413]! } - public var Your_card_was_declined: String { return self._s[1414]! } - public var TwoStepAuth_EnterPasswordHelp: String { return self._s[1416]! } - public var ChatList_Unmute: String { return self._s[1417]! } - public func PINNED_GEO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1418]!, self._r[1418]!, [_1]) - } - public var PhotoEditor_CurvesAll: String { return self._s[1419]! } - public var Weekday_ShortTuesday: String { return self._s[1420]! } - public var DialogList_Read: String { return self._s[1421]! } - public func PINNED_TEXT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1422]!, self._r[1422]!, [_1, _2]) - } - public var ChannelMembers_WhoCanAddMembers_AllMembers: String { return self._s[1423]! } - public var Passport_Identity_Gender: String { return self._s[1424]! } - public func Target_ShareGameConfirmationPrivate(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[1425]!, self._r[1425]!, [_0]) } - public var Target_SelectGroup: String { return self._s[1426]! } + public var Notification_CallCanceled: String { return self._s[1426]! } + public var Privacy_PaymentsClear_PaymentInfo: String { return self._s[1427]! } + public func MESSAGE_SCREENSHOT(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1428]!, self._r[1428]!, [_1]) + } + public func CHAT_JOINED_SEPARATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1429]!, self._r[1429]!, [_1, _2]) + } + public var Settings_ProxyConnecting: String { return self._s[1430]! } + public var Profile_MessageLifetime5s: String { return self._s[1432]! } + public var Username_InvalidCharacters: String { return self._s[1433]! } + public var AutoDownloadSettings_LimitBySize: String { return self._s[1434]! } + public func CHAT_MESSAGE_GAME_SEPARATED(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1435]!, self._r[1435]!, [_1, _2, _3]) + } + public var Notification_CreatedChannel: String { return self._s[1437]! } + public var Passcode_AppLockedAlert: String { return self._s[1439]! } + public var Contacts_TopSection: String { return self._s[1440]! } + public func Time_MonthOfYear_m6(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1441]!, self._r[1441]!, [_0]) + } + public func CHAT_MESSAGE_DOC_SEPARATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1442]!, self._r[1442]!, [_1, _2]) + } + public var ReportPeer_ReasonSpam: String { return self._s[1443]! } + public var UserInfo_TapToCall: String { return self._s[1444]! } + public var Common_Search: String { return self._s[1446]! } + public var AuthSessions_IncompleteAttemptsInfo: String { return self._s[1447]! } + public var Message_InvoiceLabel: String { return self._s[1448]! } + public var Conversation_InputTextPlaceholder: String { return self._s[1449]! } + public var NetworkUsageSettings_MediaImageDataSection: String { return self._s[1450]! } + public func Passport_Address_UploadOneOfScan(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1451]!, self._r[1451]!, [_0]) + } + public func MESSAGE_DOC(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1452]!, self._r[1452]!, [_1]) + } + public var Conversation_Info: String { return self._s[1453]! } + public var Login_InfoDeletePhoto: String { return self._s[1454]! } + public var Passport_Language_vi: String { return self._s[1456]! } + public var Conversation_Search: String { return self._s[1457]! } + public var DialogList_DeleteBotConversationConfirmation: String { return self._s[1458]! } + public func MESSAGE_AUDIO_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1459]!, self._r[1459]!, [_1]) + } + public var ReportPeer_ReasonPornography: String { return self._s[1460]! } + public var AutoDownloadSettings_PhotosTitle: String { return self._s[1461]! } + public func CHAT_MESSAGE_PHOTO_SEPARATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1462]!, self._r[1462]!, [_1, _2]) + } + public var Conversation_SendMessageErrorGroupRestricted: String { return self._s[1463]! } + public var Map_LiveLocationGroupDescription: String { return self._s[1464]! } + public var Channel_Setup_TypeHeader: String { return self._s[1465]! } + public var AuthSessions_LoggedIn: String { return self._s[1466]! } + public var Login_SmsRequestState3: String { return self._s[1467]! } + public var Passport_Address_EditUtilityBill: String { return self._s[1468]! } + public var Appearance_ReduceMotionInfo: String { return self._s[1469]! } + public var Channel_Edit_LinkItem: String { return self._s[1470]! } + public var Privacy_Calls_P2PNever: String { return self._s[1471]! } + public var Conversation_AddToReadingList: String { return self._s[1473]! } + public func MESSAGE_GEO(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1474]!, self._r[1474]!, [_1]) + } + public var Message_Animation: String { return self._s[1475]! } + public var Map_Unknown: String { return self._s[1476]! } + public var Call_StatusRequesting: String { return self._s[1477]! } + public func Passport_FieldOneOf_Or(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1478]!, self._r[1478]!, [_1, _2]) + } + public var Conversation_SecretChatContextBotAlert: String { return self._s[1479]! } + public var SocksProxySetup_ProxyStatusChecking: String { return self._s[1480]! } + public func MESSAGE_PHOTO_SECRET(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1481]!, self._r[1481]!, [_1]) + } + public func Notification_PinnedLocationMessage(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1482]!, self._r[1482]!, [_0]) + } + public var Update_Skip: String { return self._s[1483]! } + public var Group_Username_RemoveExistingUsernamesInfo: String { return self._s[1484]! } + public var Message_PinnedPollMessage: String { return self._s[1485]! } + public var BlockedUsers_Title: String { return self._s[1486]! } + public var Weekday_Monday: String { return self._s[1487]! } + public var Username_CheckingUsername: String { return self._s[1488]! } + public var NotificationsSound_Bell: String { return self._s[1489]! } + public var Conversation_SendMessageErrorFlood: String { return self._s[1490]! } + public var ChannelMembers_ChannelAdminsTitle: String { return self._s[1491]! } + public var ChatSettings_Groups: String { return self._s[1492]! } + public var Your_card_was_declined: String { return self._s[1493]! } + public var TwoStepAuth_EnterPasswordHelp: String { return self._s[1495]! } + public var ChatList_Unmute: String { return self._s[1496]! } + public func PINNED_GEO(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1497]!, self._r[1497]!, [_1]) + } + public var PhotoEditor_CurvesAll: String { return self._s[1498]! } + public var Weekday_ShortTuesday: String { return self._s[1499]! } + public var DialogList_Read: String { return self._s[1500]! } + public func PINNED_TEXT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1501]!, self._r[1501]!, [_1, _2]) + } + public var ChannelMembers_WhoCanAddMembers_AllMembers: String { return self._s[1502]! } + public var Passport_Identity_Gender: String { return self._s[1503]! } + public func Target_ShareGameConfirmationPrivate(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1504]!, self._r[1504]!, [_0]) + } + public var Target_SelectGroup: String { return self._s[1505]! } public func DialogList_EncryptedChatStartedIncoming(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1428]!, self._r[1428]!, [_0]) + return formatWithArgumentRanges(self._s[1507]!, self._r[1507]!, [_0]) } - public var Passport_Language_en: String { return self._s[1429]! } - public var Channel_Username_CreatePublicLinkHelp: String { return self._s[1430]! } - public var Login_CancelPhoneVerificationContinue: String { return self._s[1431]! } + public var Passport_Language_en: String { return self._s[1508]! } + public var Channel_Username_CreatePublicLinkHelp: String { return self._s[1509]! } + public var Login_CancelPhoneVerificationContinue: String { return self._s[1510]! } public func AUTH_REGION(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1432]!, self._r[1432]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1511]!, self._r[1511]!, [_1, _2]) } - public var Checkout_NewCard_PaymentCard: String { return self._s[1434]! } - public var Login_InfoHelp: String { return self._s[1435]! } - public var Contacts_PermissionsSuppressWarningTitle: String { return self._s[1436]! } - public var SocksProxySetup_AddProxy: String { return self._s[1439]! } - public var CreatePoll_Title: String { return self._s[1440]! } - public var PasscodeSettings_SimplePasscodeHelp: String { return self._s[1441]! } - public var UserInfo_GroupsInCommon: String { return self._s[1442]! } - public var Call_AudioRouteHide: String { return self._s[1443]! } - public var ContactInfo_PhoneLabelMobile: String { return self._s[1445]! } - public var TextFormat_Bold: String { return self._s[1446]! } - public var FastTwoStepSetup_EmailSection: String { return self._s[1447]! } - public var Notifications_Title: String { return self._s[1448]! } - public var Group_Username_InvalidTooShort: String { return self._s[1449]! } - public var Channel_ErrorAddTooMuch: String { return self._s[1450]! } + public var Checkout_NewCard_PaymentCard: String { return self._s[1513]! } + public var Login_InfoHelp: String { return self._s[1514]! } + public var Contacts_PermissionsSuppressWarningTitle: String { return self._s[1515]! } + public var SocksProxySetup_AddProxy: String { return self._s[1518]! } + public var CreatePoll_Title: String { return self._s[1519]! } + public var PasscodeSettings_SimplePasscodeHelp: String { return self._s[1520]! } + public var UserInfo_GroupsInCommon: String { return self._s[1521]! } + public var Call_AudioRouteHide: String { return self._s[1522]! } + public var ContactInfo_PhoneLabelMobile: String { return self._s[1524]! } + public var TextFormat_Bold: String { return self._s[1525]! } + public var FastTwoStepSetup_EmailSection: String { return self._s[1526]! } + public var Notifications_Title: String { return self._s[1527]! } + public var Group_Username_InvalidTooShort: String { return self._s[1528]! } + public var Channel_ErrorAddTooMuch: String { return self._s[1529]! } public func DialogList_MultipleTypingSuffix(_ _0: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1451]!, self._r[1451]!, ["\(_0)"]) + return formatWithArgumentRanges(self._s[1530]!, self._r[1530]!, ["\(_0)"]) } - public var Stickers_SuggestAdded: String { return self._s[1453]! } - public var Login_CountryCode: String { return self._s[1454]! } - public var Map_GetDirections: String { return self._s[1455]! } - public var Login_PhoneFloodError: String { return self._s[1456]! } + public var Stickers_SuggestAdded: String { return self._s[1532]! } + public var Login_CountryCode: String { return self._s[1533]! } + public var Map_GetDirections: String { return self._s[1534]! } + public var Login_PhoneFloodError: String { return self._s[1535]! } public func Time_MonthOfYear_m3(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1457]!, self._r[1457]!, [_0]) + return formatWithArgumentRanges(self._s[1536]!, self._r[1536]!, [_0]) } - public var Settings_SetUsername: String { return self._s[1459]! } - public var Notification_GroupInviterSelf: String { return self._s[1460]! } - public var InstantPage_TapToOpenLink: String { return self._s[1461]! } + public var Settings_SetUsername: String { return self._s[1538]! } + public func CHAT_MESSAGE_NOTEXT_SEPARATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1539]!, self._r[1539]!, [_1, _2]) + } + public var Notification_GroupInviterSelf: String { return self._s[1540]! } + public var InstantPage_TapToOpenLink: String { return self._s[1541]! } public func Notification_ChannelInviter(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1462]!, self._r[1462]!, [_0]) + return formatWithArgumentRanges(self._s[1542]!, self._r[1542]!, [_0]) } - public var Watch_Suggestion_TalkLater: String { return self._s[1463]! } - public var SecretChat_Title: String { return self._s[1464]! } - public var Group_UpgradeNoticeText1: String { return self._s[1465]! } - public var AuthSessions_Title: String { return self._s[1466]! } - public var PhotoEditor_CropAuto: String { return self._s[1467]! } - public var Channel_About_Title: String { return self._s[1468]! } - public var FastTwoStepSetup_EmailHelp: String { return self._s[1469]! } + public var Watch_Suggestion_TalkLater: String { return self._s[1543]! } + public var SecretChat_Title: String { return self._s[1544]! } + public var Group_UpgradeNoticeText1: String { return self._s[1545]! } + public var AuthSessions_Title: String { return self._s[1546]! } + public var PhotoEditor_CropAuto: String { return self._s[1547]! } + public var Channel_About_Title: String { return self._s[1548]! } + public var FastTwoStepSetup_EmailHelp: String { return self._s[1549]! } public func CHAT_ADD_YOU(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1470]!, self._r[1470]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1550]!, self._r[1550]!, [_1, _2]) } public func Conversation_Bytes(_ _0: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1471]!, self._r[1471]!, ["\(_0)"]) + return formatWithArgumentRanges(self._s[1551]!, self._r[1551]!, ["\(_0)"]) } - public var Conversation_PinMessageAlert_OnlyPin: String { return self._s[1474]! } - public var Group_Setup_HistoryVisibleHelp: String { return self._s[1475]! } + public var Conversation_PinMessageAlert_OnlyPin: String { return self._s[1554]! } + public var Group_Setup_HistoryVisibleHelp: String { return self._s[1555]! } public func SharedMedia_SearchNoResultsDescription(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1477]!, self._r[1477]!, [_0]) - } - public func TwoStepAuth_RecoveryEmailUnavailable(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1478]!, self._r[1478]!, [_0]) - } - public var Privacy_PaymentsClearInfoHelp: String { return self._s[1479]! } - public var Presence_online: String { return self._s[1481]! } - public var PasscodeSettings_Title: String { return self._s[1482]! } - public var Passport_Identity_ExpiryDatePlaceholder: String { return self._s[1483]! } - public var Web_OpenExternal: String { return self._s[1484]! } - public func AutoNightTheme_AutomaticHelp(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1486]!, self._r[1486]!, [_0]) - } - public var FastTwoStepSetup_PasswordConfirmationPlaceholder: String { return self._s[1487]! } - public var Map_YouAreHere: String { return self._s[1488]! } - public func MESSAGE_GIF(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1489]!, self._r[1489]!, [_1]) - } - public func AuthSessions_Message(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1490]!, self._r[1490]!, [_0]) - } - public var PrivacyLastSeenSettings_AlwaysShareWith: String { return self._s[1491]! } - public var Target_InviteToGroupErrorAlreadyInvited: String { return self._s[1492]! } - public func AuthSessions_AppUnofficial(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1493]!, self._r[1493]!, [_0]) - } - public func DialogList_LiveLocationSharingTo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1494]!, self._r[1494]!, [_0]) - } - public var SocksProxySetup_Username: String { return self._s[1495]! } - public var Bot_Start: String { return self._s[1496]! } - public func Channel_AdminLog_EmptyFilterQueryText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1497]!, self._r[1497]!, [_0]) - } - public func Channel_AdminLog_MessagePinned(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1498]!, self._r[1498]!, [_0]) - } - public func PINNED_GEOLIVE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1500]!, self._r[1500]!, [_1]) - } - public var Conversation_DiscardVoiceMessageTitle: String { return self._s[1501]! } - public func PrivacySettings_LastSeenContactsMinus(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1502]!, self._r[1502]!, [_0]) - } - public var Passport_Email_EnterOtherEmail: String { return self._s[1503]! } - public var Login_InfoAvatarPhoto: String { return self._s[1504]! } - public var Privacy_PaymentsClear_ShippingInfo: String { return self._s[1505]! } - public var Tour_Title4: String { return self._s[1506]! } - public var Passport_Identity_Translation: String { return self._s[1507]! } - public var Login_TermsOfServiceLabel: String { return self._s[1509]! } - public var Passport_Language_it: String { return self._s[1510]! } - public var KeyCommand_JumpToNextUnreadChat: String { return self._s[1511]! } - public var Passport_Identity_SelfieHelp: String { return self._s[1512]! } - public var Conversation_ClearAll: String { return self._s[1514]! } - public func MESSAGE_PHOTOS(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1516]!, self._r[1516]!, [_1, _2]) - } - public var TwoStepAuth_FloodError: String { return self._s[1517]! } - public var Paint_Delete: String { return self._s[1518]! } - public func Passport_AcceptHelp(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1519]!, self._r[1519]!, [_1, _2]) - } - public var Message_PinnedAudioMessage: String { return self._s[1520]! } - public func Watch_Time_ShortTodayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1521]!, self._r[1521]!, [_0]) - } - public var Notification_Mute1hMin: String { return self._s[1522]! } - public var Notifications_GroupNotificationsSound: String { return self._s[1523]! } - public var SocksProxySetup_ShareProxyList: String { return self._s[1524]! } - public var Conversation_MessageEditedLabel: String { return self._s[1525]! } - public var Notification_Exceptions_AlwaysOff: String { return self._s[1526]! } - public func Channel_AdminLog_MessageAdmin(_ _0: String, _ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1527]!, self._r[1527]!, [_0, _1, _2]) - } - public var NetworkUsageSettings_ResetStats: String { return self._s[1528]! } - public var AccessDenied_LocationTracking: String { return self._s[1529]! } - public var Month_GenOctober: String { return self._s[1530]! } - public var GroupInfo_InviteLink_RevokeAlert_Revoke: String { return self._s[1531]! } - public var EnterPasscode_EnterPasscode: String { return self._s[1532]! } - public var MediaPicker_TimerTooltip: String { return self._s[1534]! } - public var SharedMedia_TitleAll: String { return self._s[1535]! } - public var Conversation_RestrictedMedia: String { return self._s[1537]! } - public var AccessDenied_PhotosRestricted: String { return self._s[1538]! } - public var ChangePhoneNumberCode_Called: String { return self._s[1540]! } - public func Notification_PinnedDocumentMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1541]!, self._r[1541]!, [_0]) - } - public var Conversation_SavedMessages: String { return self._s[1544]! } - public var Your_cards_expiration_month_is_invalid: String { return self._s[1546]! } - public var FastTwoStepSetup_PasswordPlaceholder: String { return self._s[1547]! } - public func Target_ShareGameConfirmationGroup(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1549]!, self._r[1549]!, [_0]) - } - public var ReportPeer_AlertSuccess: String { return self._s[1550]! } - public func InstantPage_RelatedArticleAuthorAndDateTitle(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1551]!, self._r[1551]!, [_1, _2]) - } - public var PhotoEditor_CropAspectRatioOriginal: String { return self._s[1552]! } - public var Checkout_PasswordEntry_Title: String { return self._s[1553]! } - public var PhotoEditor_FadeTool: String { return self._s[1554]! } - public var Privacy_ContactsReset: String { return self._s[1555]! } - public func Channel_AdminLog_MessageRestrictedUntil(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[1557]!, self._r[1557]!, [_0]) } - public var Message_PinnedVideoMessage: String { return self._s[1558]! } - public var ChatList_Mute: String { return self._s[1559]! } - public var Permissions_CellularDataText_v0: String { return self._s[1560]! } - public var ShareMenu_SelectChats: String { return self._s[1562]! } - public var MusicPlayer_VoiceNote: String { return self._s[1563]! } - public var Conversation_RestrictedText: String { return self._s[1564]! } - public var TwoStepAuth_DisableSuccess: String { return self._s[1565]! } - public var Cache_Videos: String { return self._s[1566]! } - public var FeatureDisabled_Oops: String { return self._s[1568]! } - public var Passport_Address_PostcodePlaceholder: String { return self._s[1569]! } + public func TwoStepAuth_RecoveryEmailUnavailable(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1558]!, self._r[1558]!, [_0]) + } + public var Privacy_PaymentsClearInfoHelp: String { return self._s[1559]! } + public var Presence_online: String { return self._s[1561]! } + public var PasscodeSettings_Title: String { return self._s[1562]! } + public var Passport_Identity_ExpiryDatePlaceholder: String { return self._s[1563]! } + public var Web_OpenExternal: String { return self._s[1564]! } + public func AutoNightTheme_AutomaticHelp(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1566]!, self._r[1566]!, [_0]) + } + public var FastTwoStepSetup_PasswordConfirmationPlaceholder: String { return self._s[1567]! } + public var Map_YouAreHere: String { return self._s[1568]! } + public func MESSAGE_GIF(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1569]!, self._r[1569]!, [_1]) + } + public func AuthSessions_Message(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1570]!, self._r[1570]!, [_0]) + } + public var PrivacyLastSeenSettings_AlwaysShareWith: String { return self._s[1571]! } + public var Target_InviteToGroupErrorAlreadyInvited: String { return self._s[1572]! } + public func AuthSessions_AppUnofficial(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1573]!, self._r[1573]!, [_0]) + } + public func CHANNEL_MESSAGE_GEO_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1574]!, self._r[1574]!, [_1]) + } + public var SocksProxySetup_Username: String { return self._s[1575]! } + public func DialogList_LiveLocationSharingTo(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1576]!, self._r[1576]!, [_0]) + } + public var Bot_Start: String { return self._s[1577]! } + public func Channel_AdminLog_EmptyFilterQueryText(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1578]!, self._r[1578]!, [_0]) + } + public func Channel_AdminLog_MessagePinned(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1579]!, self._r[1579]!, [_0]) + } + public func PINNED_GEOLIVE(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1581]!, self._r[1581]!, [_1]) + } + public var Conversation_DiscardVoiceMessageTitle: String { return self._s[1582]! } + public func PrivacySettings_LastSeenContactsMinus(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1583]!, self._r[1583]!, [_0]) + } + public func MESSAGE_DOC_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1584]!, self._r[1584]!, [_1]) + } + public var Passport_Email_EnterOtherEmail: String { return self._s[1585]! } + public var Login_InfoAvatarPhoto: String { return self._s[1586]! } + public var Privacy_PaymentsClear_ShippingInfo: String { return self._s[1587]! } + public var Tour_Title4: String { return self._s[1588]! } + public var Passport_Identity_Translation: String { return self._s[1589]! } + public var Login_TermsOfServiceLabel: String { return self._s[1591]! } + public var Passport_Language_it: String { return self._s[1592]! } + public var KeyCommand_JumpToNextUnreadChat: String { return self._s[1593]! } + public var Passport_Identity_SelfieHelp: String { return self._s[1594]! } + public var Conversation_ClearAll: String { return self._s[1596]! } + public func MESSAGE_PHOTOS(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1598]!, self._r[1598]!, [_1, _2]) + } + public var TwoStepAuth_FloodError: String { return self._s[1599]! } + public var Paint_Delete: String { return self._s[1600]! } + public func Passport_AcceptHelp(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1601]!, self._r[1601]!, [_1, _2]) + } + public var Message_PinnedAudioMessage: String { return self._s[1602]! } + public func Watch_Time_ShortTodayAt(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1603]!, self._r[1603]!, [_0]) + } + public var Notification_Mute1hMin: String { return self._s[1604]! } + public var Notifications_GroupNotificationsSound: String { return self._s[1605]! } + public var SocksProxySetup_ShareProxyList: String { return self._s[1606]! } + public var Conversation_MessageEditedLabel: String { return self._s[1607]! } + public var Notification_Exceptions_AlwaysOff: String { return self._s[1608]! } + public func Channel_AdminLog_MessageAdmin(_ _0: String, _ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1609]!, self._r[1609]!, [_0, _1, _2]) + } + public var NetworkUsageSettings_ResetStats: String { return self._s[1610]! } + public var AccessDenied_LocationTracking: String { return self._s[1611]! } + public var Month_GenOctober: String { return self._s[1612]! } + public var GroupInfo_InviteLink_RevokeAlert_Revoke: String { return self._s[1613]! } + public func CHAT_MESSAGE_INVOICE_SEPARATED(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1614]!, self._r[1614]!, [_1, _2, _3]) + } + public var EnterPasscode_EnterPasscode: String { return self._s[1616]! } + public var MediaPicker_TimerTooltip: String { return self._s[1617]! } + public var SharedMedia_TitleAll: String { return self._s[1618]! } + public var Conversation_RestrictedMedia: String { return self._s[1620]! } + public var AccessDenied_PhotosRestricted: String { return self._s[1621]! } + public var ChangePhoneNumberCode_Called: String { return self._s[1623]! } + public func Notification_PinnedDocumentMessage(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1624]!, self._r[1624]!, [_0]) + } + public var Conversation_SavedMessages: String { return self._s[1627]! } + public var Your_cards_expiration_month_is_invalid: String { return self._s[1629]! } + public var FastTwoStepSetup_PasswordPlaceholder: String { return self._s[1630]! } + public func Target_ShareGameConfirmationGroup(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1632]!, self._r[1632]!, [_0]) + } + public var ReportPeer_AlertSuccess: String { return self._s[1633]! } + public var PhotoEditor_CropAspectRatioOriginal: String { return self._s[1634]! } + public func MESSAGE_PHOTO_SECRET_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1635]!, self._r[1635]!, [_1]) + } + public func InstantPage_RelatedArticleAuthorAndDateTitle(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1636]!, self._r[1636]!, [_1, _2]) + } + public var Checkout_PasswordEntry_Title: String { return self._s[1637]! } + public var PhotoEditor_FadeTool: String { return self._s[1638]! } + public var Privacy_ContactsReset: String { return self._s[1639]! } + public func Channel_AdminLog_MessageRestrictedUntil(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1641]!, self._r[1641]!, [_0]) + } + public var Message_PinnedVideoMessage: String { return self._s[1642]! } + public var ChatList_Mute: String { return self._s[1643]! } + public var Permissions_CellularDataText_v0: String { return self._s[1644]! } + public var ShareMenu_SelectChats: String { return self._s[1646]! } + public var MusicPlayer_VoiceNote: String { return self._s[1647]! } + public var Conversation_RestrictedText: String { return self._s[1648]! } + public var TwoStepAuth_DisableSuccess: String { return self._s[1649]! } + public var Cache_Videos: String { return self._s[1650]! } + public var FeatureDisabled_Oops: String { return self._s[1652]! } + public var Passport_Address_PostcodePlaceholder: String { return self._s[1653]! } public func CHAT_MESSAGE_VIDEO(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1570]!, self._r[1570]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1654]!, self._r[1654]!, [_1, _2]) } - public var Stickers_GroupStickersHelp: String { return self._s[1571]! } - public var Message_VideoExpired: String { return self._s[1573]! } - public var Notifications_Badge: String { return self._s[1574]! } - public var GroupInfo_GroupHistoryVisible: String { return self._s[1575]! } - public var CreatePoll_OptionPlaceholder: String { return self._s[1576]! } - public var Username_InvalidTooShort: String { return self._s[1577]! } - public var EnterPasscode_EnterNewPasscodeChange: String { return self._s[1578]! } + public var Stickers_GroupStickersHelp: String { return self._s[1655]! } + public var GroupPermission_NoSendPolls: String { return self._s[1656]! } + public var Message_VideoExpired: String { return self._s[1658]! } + public var GroupInfo_GroupHistoryVisible: String { return self._s[1659]! } + public var Notifications_Badge: String { return self._s[1660]! } + public var CreatePoll_OptionPlaceholder: String { return self._s[1661]! } + public var Username_InvalidTooShort: String { return self._s[1662]! } + public var EnterPasscode_EnterNewPasscodeChange: String { return self._s[1663]! } public func Notification_MessageLifetimeRemoved(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1579]!, self._r[1579]!, [_1]) + return formatWithArgumentRanges(self._s[1664]!, self._r[1664]!, [_1]) + } + public var Permissions_SiriAllowInSettings_v0: String { return self._s[1665]! } + public var SharedMedia_CategoryDocs: String { return self._s[1668]! } + public func CHAT_MESSAGE_STICKER_SEPARATED(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1669]!, self._r[1669]!, [_1, _2, _3]) } - public var Permissions_SiriAllowInSettings_v0: String { return self._s[1580]! } - public var SharedMedia_CategoryDocs: String { return self._s[1583]! } public func Notification_MessageLifetimeChangedOutgoing(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1585]!, self._r[1585]!, [_1]) + return formatWithArgumentRanges(self._s[1671]!, self._r[1671]!, [_1]) } - public var CheckoutInfo_ErrorShippingNotAvailable: String { return self._s[1586]! } + public var CheckoutInfo_ErrorShippingNotAvailable: String { return self._s[1672]! } public func Time_MonthOfYear_m12(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1587]!, self._r[1587]!, [_0]) + return formatWithArgumentRanges(self._s[1673]!, self._r[1673]!, [_0]) } - public var ChatSettings_PrivateChats: String { return self._s[1588]! } - public var Channel_UpdatePhotoItem: String { return self._s[1589]! } - public var GroupInfo_LeftStatus: String { return self._s[1590]! } - public var Watch_MessageView_Forward: String { return self._s[1592]! } - public var ReportPeer_ReasonChildAbuse: String { return self._s[1593]! } - public var Cache_ClearEmpty: String { return self._s[1595]! } - public var Localization_LanguageName: String { return self._s[1596]! } - public var WebSearch_GIFs: String { return self._s[1597]! } - public var Notifications_DisplayNamesOnLockScreenInfoWithLink: String { return self._s[1598]! } - public var Username_InvalidStartsWithNumber: String { return self._s[1599]! } - public var Common_Back: String { return self._s[1600]! } - public var Passport_Identity_DateOfBirthPlaceholder: String { return self._s[1601]! } + public var ChatSettings_PrivateChats: String { return self._s[1674]! } + public var Channel_UpdatePhotoItem: String { return self._s[1675]! } + public var GroupInfo_LeftStatus: String { return self._s[1676]! } + public var Watch_MessageView_Forward: String { return self._s[1678]! } + public var ReportPeer_ReasonChildAbuse: String { return self._s[1679]! } + public var Cache_ClearEmpty: String { return self._s[1681]! } + public func MESSAGE_VIDEO_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1682]!, self._r[1682]!, [_1]) + } + public var Localization_LanguageName: String { return self._s[1683]! } + public var WebSearch_GIFs: String { return self._s[1684]! } + public var Notifications_DisplayNamesOnLockScreenInfoWithLink: String { return self._s[1685]! } + public var Username_InvalidStartsWithNumber: String { return self._s[1686]! } + public var Common_Back: String { return self._s[1687]! } + public var Passport_Identity_DateOfBirthPlaceholder: String { return self._s[1688]! } public func CHANNEL_MESSAGE_AUDIO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1602]!, self._r[1602]!, [_1]) + return formatWithArgumentRanges(self._s[1689]!, self._r[1689]!, [_1]) } public func CHANNEL_MESSAGE_ROUND(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1603]!, self._r[1603]!, [_1]) + return formatWithArgumentRanges(self._s[1690]!, self._r[1690]!, [_1]) } - public var Passport_Email_Help: String { return self._s[1604]! } - public var Watch_Conversation_Reply: String { return self._s[1605]! } - public var Conversation_EditingMessageMediaChange: String { return self._s[1607]! } - public var Passport_Identity_IssueDatePlaceholder: String { return self._s[1608]! } - public var Channel_BanUser_Unban: String { return self._s[1610]! } - public var Channel_EditAdmin_PermissionPostMessages: String { return self._s[1611]! } - public var Group_Username_CreatePublicLinkHelp: String { return self._s[1612]! } - public var TwoStepAuth_ConfirmEmailCodePlaceholder: String { return self._s[1613]! } - public var Passport_Identity_Name: String { return self._s[1615]! } - public var Conversation_BlockUser: String { return self._s[1616]! } - public var Month_GenJanuary: String { return self._s[1617]! } - public var ChatSettings_TextSize: String { return self._s[1618]! } - public var Notification_PassportValuePhone: String { return self._s[1619]! } - public var Passport_Language_ne: String { return self._s[1620]! } - public var Notification_CallBack: String { return self._s[1621]! } - public var TwoStepAuth_EmailHelp: String { return self._s[1622]! } + public var Passport_Email_Help: String { return self._s[1691]! } + public var Watch_Conversation_Reply: String { return self._s[1692]! } + public var Conversation_EditingMessageMediaChange: String { return self._s[1694]! } + public var Passport_Identity_IssueDatePlaceholder: String { return self._s[1695]! } + public var Channel_BanUser_Unban: String { return self._s[1697]! } + public var Channel_EditAdmin_PermissionPostMessages: String { return self._s[1698]! } + public var Group_Username_CreatePublicLinkHelp: String { return self._s[1699]! } + public var TwoStepAuth_ConfirmEmailCodePlaceholder: String { return self._s[1701]! } + public var Passport_Identity_Name: String { return self._s[1702]! } + public var GroupRemoved_ViewUserInfo: String { return self._s[1703]! } + public var Conversation_BlockUser: String { return self._s[1704]! } + public var Month_GenJanuary: String { return self._s[1705]! } + public var ChatSettings_TextSize: String { return self._s[1706]! } + public var Notification_PassportValuePhone: String { return self._s[1707]! } + public var Passport_Language_ne: String { return self._s[1708]! } + public var Notification_CallBack: String { return self._s[1709]! } + public var TwoStepAuth_EmailHelp: String { return self._s[1710]! } public func Time_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1623]!, self._r[1623]!, [_0]) + return formatWithArgumentRanges(self._s[1711]!, self._r[1711]!, [_0]) } - public var Channel_Info_Management: String { return self._s[1624]! } - public var Passport_FieldIdentityUploadHelp: String { return self._s[1625]! } - public var Stickers_FrequentlyUsed: String { return self._s[1626]! } - public var Channel_BanUser_PermissionSendMessages: String { return self._s[1627]! } - public var Passport_Address_OneOfTypeUtilityBill: String { return self._s[1629]! } - public var Passport_Address_EditResidentialAddress: String { return self._s[1630]! } - public var PrivacyPolicy_DeclineTitle: String { return self._s[1631]! } - public var CreatePoll_TextHeader: String { return self._s[1632]! } + public var Channel_Info_Management: String { return self._s[1712]! } + public var Passport_FieldIdentityUploadHelp: String { return self._s[1713]! } + public var Stickers_FrequentlyUsed: String { return self._s[1714]! } + public var Channel_BanUser_PermissionSendMessages: String { return self._s[1715]! } + public var Passport_Address_OneOfTypeUtilityBill: String { return self._s[1717]! } + public var Passport_Address_EditResidentialAddress: String { return self._s[1718]! } + public var PrivacyPolicy_DeclineTitle: String { return self._s[1719]! } + public var CreatePoll_TextHeader: String { return self._s[1720]! } public func Checkout_SavePasswordTimeoutAndTouchId(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1633]!, self._r[1633]!, [_0]) + return formatWithArgumentRanges(self._s[1721]!, self._r[1721]!, [_0]) } - public var PhotoEditor_QualityMedium: String { return self._s[1634]! } - public var InfoPlist_NSMicrophoneUsageDescription: String { return self._s[1635]! } + public var PhotoEditor_QualityMedium: String { return self._s[1722]! } + public var InfoPlist_NSMicrophoneUsageDescription: String { return self._s[1723]! } public func Conversation_RestrictedInlineTimed(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1636]!, self._r[1636]!, [_0]) + return formatWithArgumentRanges(self._s[1724]!, self._r[1724]!, [_0]) } - public var Conversation_StatusKickedFromChannel: String { return self._s[1637]! } - public var CheckoutInfo_ReceiverInfoName: String { return self._s[1638]! } - public var Group_ErrorSendRestrictedStickers: String { return self._s[1639]! } - public var Conversation_LinkDialogOpen: String { return self._s[1641]! } - public var Settings_Username: String { return self._s[1642]! } - public var Wallpaper_Wallpaper: String { return self._s[1644]! } + public var Conversation_StatusKickedFromChannel: String { return self._s[1725]! } + public var CheckoutInfo_ReceiverInfoName: String { return self._s[1726]! } + public var Group_ErrorSendRestrictedStickers: String { return self._s[1727]! } + public var Conversation_LinkDialogOpen: String { return self._s[1729]! } + public var Settings_Username: String { return self._s[1730]! } + public func PINNED_GEOLIVE_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1732]!, self._r[1732]!, [_1]) + } + public var Wallpaper_Wallpaper: String { return self._s[1733]! } public func PINNED_GIF(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1646]!, self._r[1646]!, [_1]) + return formatWithArgumentRanges(self._s[1735]!, self._r[1735]!, [_1]) } - public var SocksProxySetup_UseProxy: String { return self._s[1647]! } - public var UserInfo_ShareMyContactInfo: String { return self._s[1648]! } - public var MessageTimer_Forever: String { return self._s[1649]! } - public var Privacy_Calls_WhoCanCallMe: String { return self._s[1650]! } - public var PhotoEditor_DiscardChanges: String { return self._s[1651]! } - public var AuthSessions_TerminateOtherSessionsHelp: String { return self._s[1652]! } - public var Passport_Language_da: String { return self._s[1653]! } - public var SocksProxySetup_PortPlaceholder: String { return self._s[1654]! } + public var SocksProxySetup_UseProxy: String { return self._s[1736]! } + public var UserInfo_ShareMyContactInfo: String { return self._s[1737]! } + public var MessageTimer_Forever: String { return self._s[1738]! } + public var Privacy_Calls_WhoCanCallMe: String { return self._s[1739]! } + public var PhotoEditor_DiscardChanges: String { return self._s[1740]! } + public var AuthSessions_TerminateOtherSessionsHelp: String { return self._s[1741]! } + public var Passport_Language_da: String { return self._s[1742]! } + public var SocksProxySetup_PortPlaceholder: String { return self._s[1743]! } public func SecretGIF_NotViewedYet(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1655]!, self._r[1655]!, [_0]) + return formatWithArgumentRanges(self._s[1744]!, self._r[1744]!, [_0]) } - public var Passport_Address_EditPassportRegistration: String { return self._s[1656]! } + public var Passport_Address_EditPassportRegistration: String { return self._s[1745]! } public func Channel_AdminLog_MessageChangedGroupAbout(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1658]!, self._r[1658]!, [_0]) + return formatWithArgumentRanges(self._s[1747]!, self._r[1747]!, [_0]) } - public var Passport_Identity_ResidenceCountryPlaceholder: String { return self._s[1660]! } - public var Conversation_SearchByName_Prefix: String { return self._s[1661]! } + public var Passport_Identity_ResidenceCountryPlaceholder: String { return self._s[1749]! } + public var Conversation_SearchByName_Prefix: String { return self._s[1750]! } public func PINNED_AUDIO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1662]!, self._r[1662]!, [_1]) + return formatWithArgumentRanges(self._s[1751]!, self._r[1751]!, [_1]) } - public var Conversation_PinnedPoll: String { return self._s[1663]! } - public var Conversation_EmptyGifPanelPlaceholder: String { return self._s[1664]! } - public var Cache_ByPeerHeader: String { return self._s[1665]! } + public var Conversation_PinnedPoll: String { return self._s[1752]! } + public var Conversation_EmptyGifPanelPlaceholder: String { return self._s[1753]! } + public var Cache_ByPeerHeader: String { return self._s[1754]! } public func Conversation_EncryptedPlaceholderTitleIncoming(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1666]!, self._r[1666]!, [_0]) + return formatWithArgumentRanges(self._s[1755]!, self._r[1755]!, [_0]) } - public var ChatSettings_AutoDownloadDocuments: String { return self._s[1667]! } - public var Notification_PinnedMessage: String { return self._s[1670]! } - public var Call_EncryptionKey_Title: String { return self._s[1673]! } - public var Watch_UserInfo_Service: String { return self._s[1674]! } - public var Conversation_Unpin: String { return self._s[1677]! } - public var CancelResetAccount_Title: String { return self._s[1678]! } - public var Map_LiveLocationFor15Minutes: String { return self._s[1679]! } + public var ChatSettings_AutoDownloadDocuments: String { return self._s[1756]! } + public var Notification_PinnedMessage: String { return self._s[1759]! } + public var Call_EncryptionKey_Title: String { return self._s[1762]! } + public var Watch_UserInfo_Service: String { return self._s[1763]! } + public var Conversation_Unpin: String { return self._s[1766]! } + public var CancelResetAccount_Title: String { return self._s[1767]! } + public var Map_LiveLocationFor15Minutes: String { return self._s[1768]! } public func Time_PreciseDate_m8(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1681]!, self._r[1681]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1770]!, self._r[1770]!, [_1, _2, _3]) } - public var Group_Members_AddMemberBotErrorNotAllowed: String { return self._s[1682]! } - public var CallSettings_Title: String { return self._s[1683]! } - public var PasscodeSettings_EncryptDataHelp: String { return self._s[1685]! } - public var AutoDownloadSettings_Contacts: String { return self._s[1686]! } - public var Passport_Identity_DocumentDetails: String { return self._s[1687]! } - public var LoginPassword_PasswordHelp: String { return self._s[1688]! } - public var PrivacyLastSeenSettings_CustomShareSettings_Delete: String { return self._s[1689]! } - public var Checkout_TotalPaidAmount: String { return self._s[1690]! } + public var Group_Members_AddMemberBotErrorNotAllowed: String { return self._s[1771]! } + public var CallSettings_Title: String { return self._s[1772]! } + public var PasscodeSettings_EncryptDataHelp: String { return self._s[1774]! } + public var AutoDownloadSettings_Contacts: String { return self._s[1775]! } + public var Passport_Identity_DocumentDetails: String { return self._s[1776]! } + public var LoginPassword_PasswordHelp: String { return self._s[1777]! } + public var PrivacyLastSeenSettings_CustomShareSettings_Delete: String { return self._s[1778]! } + public var Checkout_TotalPaidAmount: String { return self._s[1779]! } public func FileSize_KB(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1691]!, self._r[1691]!, [_0]) + return formatWithArgumentRanges(self._s[1780]!, self._r[1780]!, [_0]) } - public var PasscodeSettings_ChangePasscode: String { return self._s[1692]! } - public var Conversation_SecretLinkPreviewAlert: String { return self._s[1694]! } - public var Privacy_SecretChatsLinkPreviews: String { return self._s[1695]! } - public var Contacts_InviteFriends: String { return self._s[1697]! } - public var Map_ChooseLocationTitle: String { return self._s[1698]! } - public var Conversation_StopPoll: String { return self._s[1700]! } - public var Calls_RatingFeedback: String { return self._s[1701]! } - public var GroupInfo_BroadcastListNamePlaceholder: String { return self._s[1702]! } - public var NotificationsSound_Pulse: String { return self._s[1703]! } - public var Watch_LastSeen_Lately: String { return self._s[1704]! } - public var Widget_NoUsers: String { return self._s[1707]! } - public var Conversation_UnvotePoll: String { return self._s[1708]! } - public var NotificationsSound_Circles: String { return self._s[1710]! } - public var PrivacyLastSeenSettings_AlwaysShareWith_Title: String { return self._s[1712]! } - public func CHANNEL_MESSAGE_GEOLIVE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1713]!, self._r[1713]!, [_1]) - } - public var TwoStepAuth_RecoveryCodeExpired: String { return self._s[1714]! } - public func CHAT_MESSAGE_GIF(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1715]!, self._r[1715]!, [_1, _2]) - } - public var Passport_Identity_CountryPlaceholder: String { return self._s[1717]! } - public var Conversation_FileDropbox: String { return self._s[1719]! } - public var Notifications_ExceptionsUnmuted: String { return self._s[1720]! } - public var Tour_Text3: String { return self._s[1722]! } - public var Login_ResetAccountProtected_Title: String { return self._s[1724]! } - public var ChatAdmins_AllMembersAreAdminsOnHelp: String { return self._s[1725]! } - public func Conversation_LiveLocationYouAnd(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1727]!, self._r[1727]!, [_0]) - } - public var GroupInfo_AddParticipantTitle: String { return self._s[1728]! } - public var Checkout_ShippingOption_Title: String { return self._s[1729]! } - public var ChatSettings_AutoDownloadTitle: String { return self._s[1730]! } - public func DialogList_SingleTypingSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1731]!, self._r[1731]!, [_0]) - } - public func CHAT_MESSAGE_ROUND(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1732]!, self._r[1732]!, [_1, _2]) - } - public var PrivacyLastSeenSettings_NeverShareWith_Placeholder: String { return self._s[1733]! } - public var Appearance_PreviewIncomingText: String { return self._s[1735]! } - public var ChannelInfo_ConfirmLeave: String { return self._s[1736]! } - public var MediaPicker_MomentsDateRangeSameMonthYearFormat: String { return self._s[1737]! } - public var Passport_Identity_DocumentNumberPlaceholder: String { return self._s[1738]! } - public var Channel_AdminLogFilter_EventsNewMembers: String { return self._s[1739]! } - public var PasscodeSettings_AutoLock_IfAwayFor_5minutes: String { return self._s[1740]! } - public var GroupInfo_SetGroupPhotoStop: String { return self._s[1741]! } - public var Notification_SecretChatScreenshot: String { return self._s[1742]! } - public var Passport_Address_City: String { return self._s[1744]! } - public var InfoPlist_NSPhotoLibraryAddUsageDescription: String { return self._s[1745]! } - public var SocksProxySetup_SecretPlaceholder: String { return self._s[1746]! } - public var AccessDenied_LocationDisabled: String { return self._s[1747]! } - public var SocksProxySetup_HostnamePlaceholder: String { return self._s[1749]! } - public var GroupInfo_Sound: String { return self._s[1750]! } - public var Stickers_RemoveFromFavorites: String { return self._s[1751]! } - public var Contacts_Title: String { return self._s[1752]! } - public var Passport_Language_fr: String { return self._s[1753]! } - public func CHAT_TITLE_EDITED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1754]!, self._r[1754]!, [_1, _2]) - } - public var Notifications_ResetAllNotifications: String { return self._s[1755]! } - public var PrivacySettings_SecurityTitle: String { return self._s[1758]! } - public var Checkout_NewCard_Title: String { return self._s[1759]! } - public var Login_HaveNotReceivedCodeInternal: String { return self._s[1760]! } - public var Conversation_ForwardChats: String { return self._s[1761]! } - public var Settings_FAQ: String { return self._s[1764]! } - public var AutoDownloadSettings_DocumentsTitle: String { return self._s[1765]! } - public var Conversation_ContextMenuForward: String { return self._s[1766]! } - public var PrivacyPolicy_Title: String { return self._s[1771]! } - public var Notifications_TextTone: String { return self._s[1772]! } - public var Profile_CreateNewContact: String { return self._s[1773]! } - public var AutoNightTheme_AutomaticSection: String { return self._s[1775]! } - public var Channel_Username_InvalidCharacters: String { return self._s[1777]! } - public func Channel_AdminLog_MessageChangedChannelUsername(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1778]!, self._r[1778]!, [_0]) - } - public var PrivacySettings_LastSeenTitle: String { return self._s[1779]! } - public var Channel_AdminLog_CanInviteUsers: String { return self._s[1780]! } - public var Conversation_MessageDeliveryFailed: String { return self._s[1781]! } - public var TextFormat_Italic: String { return self._s[1782]! } - public var Bot_Unblock: String { return self._s[1783]! } - public var Watch_ChatList_NoConversationsText: String { return self._s[1784]! } - public var Weekday_Wednesday: String { return self._s[1785]! } - public var Settings_About_Help: String { return self._s[1786]! } - public var SearchImages_Title: String { return self._s[1787]! } - public var Conversation_ClousStorageInfo_Description1: String { return self._s[1788]! } - public var ExplicitContent_AlertTitle: String { return self._s[1789]! } - public func Time_PreciseDate_m5(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1790]!, self._r[1790]!, [_1, _2, _3]) - } - public var Weekday_Thursday: String { return self._s[1791]! } - public var Channel_Members_AddMembersHelp: String { return self._s[1792]! } - public func Checkout_SavePasswordTimeout(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1793]!, self._r[1793]!, [_0]) - } - public var Passport_RequestedInformation: String { return self._s[1794]! } - public var Login_PhoneAndCountryHelp: String { return self._s[1795]! } - public func CHAT_MESSAGE_AUDIO(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + public var PasscodeSettings_ChangePasscode: String { return self._s[1781]! } + public var Conversation_SecretLinkPreviewAlert: String { return self._s[1783]! } + public var Privacy_SecretChatsLinkPreviews: String { return self._s[1784]! } + public var Contacts_InviteFriends: String { return self._s[1786]! } + public var Map_ChooseLocationTitle: String { return self._s[1787]! } + public var Conversation_StopPoll: String { return self._s[1789]! } + public var Calls_RatingFeedback: String { return self._s[1790]! } + public var GroupInfo_BroadcastListNamePlaceholder: String { return self._s[1791]! } + public var NotificationsSound_Pulse: String { return self._s[1792]! } + public var Watch_LastSeen_Lately: String { return self._s[1793]! } + public func CHAT_MESSAGE_VIDEO_SEPARATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[1796]!, self._r[1796]!, [_1, _2]) } - public var Conversation_EncryptionProcessing: String { return self._s[1797]! } - public var PhotoEditor_EnhanceTool: String { return self._s[1800]! } - public var Notifications_PermissionsSuppressWarningTitle: String { return self._s[1801]! } - public var Channel_Setup_Title: String { return self._s[1802]! } - public var Conversation_SearchPlaceholder: String { return self._s[1803]! } - public var AccessDenied_LocationAlwaysDenied: String { return self._s[1804]! } - public var Checkout_ErrorGeneric: String { return self._s[1805]! } - public var Passport_Language_hu: String { return self._s[1806]! } + public var Widget_NoUsers: String { return self._s[1797]! } + public var Conversation_UnvotePoll: String { return self._s[1798]! } + public var NotificationsSound_Circles: String { return self._s[1800]! } + public var PrivacyLastSeenSettings_AlwaysShareWith_Title: String { return self._s[1802]! } + public func CHANNEL_MESSAGE_GEOLIVE(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1803]!, self._r[1803]!, [_1]) + } + public var TwoStepAuth_RecoveryCodeExpired: String { return self._s[1804]! } + public func CHAT_MESSAGE_GIF(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1805]!, self._r[1805]!, [_1, _2]) + } + public var Passport_Identity_CountryPlaceholder: String { return self._s[1807]! } + public var Conversation_FileDropbox: String { return self._s[1809]! } + public var Notifications_ExceptionsUnmuted: String { return self._s[1810]! } + public var Tour_Text3: String { return self._s[1812]! } + public var Login_ResetAccountProtected_Title: String { return self._s[1814]! } + public var GroupPermission_NoSendMessages: String { return self._s[1815]! } + public var ChatAdmins_AllMembersAreAdminsOnHelp: String { return self._s[1816]! } + public func Conversation_LiveLocationYouAnd(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1818]!, self._r[1818]!, [_0]) + } + public var GroupInfo_AddParticipantTitle: String { return self._s[1819]! } + public var Checkout_ShippingOption_Title: String { return self._s[1820]! } + public var ChatSettings_AutoDownloadTitle: String { return self._s[1821]! } + public func DialogList_SingleTypingSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1822]!, self._r[1822]!, [_0]) + } + public func CHAT_MESSAGE_ROUND(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1823]!, self._r[1823]!, [_1, _2]) + } + public var PrivacyLastSeenSettings_NeverShareWith_Placeholder: String { return self._s[1824]! } + public var Appearance_PreviewIncomingText: String { return self._s[1826]! } + public var ChannelInfo_ConfirmLeave: String { return self._s[1827]! } + public var MediaPicker_MomentsDateRangeSameMonthYearFormat: String { return self._s[1828]! } + public var Passport_Identity_DocumentNumberPlaceholder: String { return self._s[1829]! } + public var Channel_AdminLogFilter_EventsNewMembers: String { return self._s[1830]! } + public var PasscodeSettings_AutoLock_IfAwayFor_5minutes: String { return self._s[1831]! } + public var GroupInfo_SetGroupPhotoStop: String { return self._s[1832]! } + public var Notification_SecretChatScreenshot: String { return self._s[1833]! } + public var Passport_Address_City: String { return self._s[1835]! } + public var InfoPlist_NSPhotoLibraryAddUsageDescription: String { return self._s[1836]! } + public var SocksProxySetup_SecretPlaceholder: String { return self._s[1837]! } + public var AccessDenied_LocationDisabled: String { return self._s[1838]! } + public var SocksProxySetup_HostnamePlaceholder: String { return self._s[1840]! } + public var GroupInfo_Sound: String { return self._s[1841]! } + public var Stickers_RemoveFromFavorites: String { return self._s[1842]! } + public var Contacts_Title: String { return self._s[1843]! } + public var Passport_Language_fr: String { return self._s[1844]! } + public func CHAT_TITLE_EDITED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1845]!, self._r[1845]!, [_1, _2]) + } + public var Notifications_ResetAllNotifications: String { return self._s[1846]! } + public var PrivacySettings_SecurityTitle: String { return self._s[1849]! } + public var Checkout_NewCard_Title: String { return self._s[1850]! } + public var Login_HaveNotReceivedCodeInternal: String { return self._s[1851]! } + public var Conversation_ForwardChats: String { return self._s[1852]! } + public var Settings_FAQ: String { return self._s[1855]! } + public var AutoDownloadSettings_DocumentsTitle: String { return self._s[1856]! } + public var Conversation_ContextMenuForward: String { return self._s[1857]! } + public var PrivacyPolicy_Title: String { return self._s[1862]! } + public var Notifications_TextTone: String { return self._s[1863]! } + public var Profile_CreateNewContact: String { return self._s[1864]! } + public var AutoNightTheme_AutomaticSection: String { return self._s[1866]! } + public var Channel_Username_InvalidCharacters: String { return self._s[1868]! } + public func Channel_AdminLog_MessageChangedChannelUsername(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1869]!, self._r[1869]!, [_0]) + } + public var PrivacySettings_LastSeenTitle: String { return self._s[1870]! } + public var Channel_AdminLog_CanInviteUsers: String { return self._s[1871]! } + public var Conversation_MessageDeliveryFailed: String { return self._s[1872]! } + public var Watch_ChatList_NoConversationsText: String { return self._s[1873]! } + public var Bot_Unblock: String { return self._s[1874]! } + public var TextFormat_Italic: String { return self._s[1875]! } + public var Settings_About_Help: String { return self._s[1876]! } + public var SearchImages_Title: String { return self._s[1877]! } + public var Weekday_Wednesday: String { return self._s[1878]! } + public var Conversation_ClousStorageInfo_Description1: String { return self._s[1879]! } + public var ExplicitContent_AlertTitle: String { return self._s[1880]! } + public func Time_PreciseDate_m5(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1881]!, self._r[1881]!, [_1, _2, _3]) + } + public var Weekday_Thursday: String { return self._s[1882]! } + public var Channel_BanUser_PermissionChangeGroupInfo: String { return self._s[1883]! } + public var Channel_Members_AddMembersHelp: String { return self._s[1884]! } + public func Checkout_SavePasswordTimeout(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1885]!, self._r[1885]!, [_0]) + } + public var Passport_RequestedInformation: String { return self._s[1886]! } + public var Login_PhoneAndCountryHelp: String { return self._s[1887]! } + public func CHAT_MESSAGE_AUDIO(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1888]!, self._r[1888]!, [_1, _2]) + } + public var Conversation_EncryptionProcessing: String { return self._s[1889]! } + public var PhotoEditor_EnhanceTool: String { return self._s[1892]! } + public var Notifications_PermissionsSuppressWarningTitle: String { return self._s[1893]! } + public var Channel_Setup_Title: String { return self._s[1894]! } + public func PINNED_GIF_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1895]!, self._r[1895]!, [_1]) + } + public var Conversation_SearchPlaceholder: String { return self._s[1896]! } + public var AccessDenied_LocationAlwaysDenied: String { return self._s[1897]! } + public var Checkout_ErrorGeneric: String { return self._s[1898]! } + public var Passport_Language_hu: String { return self._s[1899]! } public func Passport_Identity_UploadOneOfScan(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1808]!, self._r[1808]!, [_0]) + return formatWithArgumentRanges(self._s[1901]!, self._r[1901]!, [_0]) } - public var Conversation_CloudStorageInfo_Title: String { return self._s[1811]! } - public var PhotoEditor_CropAspectRatioSquare: String { return self._s[1812]! } + public var Conversation_CloudStorageInfo_Title: String { return self._s[1904]! } + public var PhotoEditor_CropAspectRatioSquare: String { return self._s[1905]! } public func Notification_Exceptions_MutedUntil(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1813]!, self._r[1813]!, [_0]) - } - public var Conversation_ClearPrivateHistory: String { return self._s[1814]! } - public var ContactInfo_PhoneLabelHome: String { return self._s[1815]! } - public var PrivacySettings_LastSeenContacts: String { return self._s[1816]! } - public func ChangePhone_ErrorOccupied(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1817]!, self._r[1817]!, [_0]) - } - public var Passport_Language_cs: String { return self._s[1818]! } - public var Message_PinnedAnimationMessage: String { return self._s[1819]! } - public var Passport_Identity_ReverseSideHelp: String { return self._s[1821]! } - public var Embed_PlayingInPIP: String { return self._s[1823]! } - public var AutoNightTheme_ScheduleSection: String { return self._s[1824]! } - public func Call_EmojiDescription(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1825]!, self._r[1825]!, [_0]) - } - public var MediaPicker_LivePhotoDescription: String { return self._s[1826]! } - public func Channel_AdminLog_MessageRestrictedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1827]!, self._r[1827]!, [_1]) - } - public var Notification_PaymentSent: String { return self._s[1828]! } - public var PhotoEditor_CurvesGreen: String { return self._s[1829]! } - public var SaveIncomingPhotosSettings_Title: String { return self._s[1830]! } - public func ApplyLanguage_UnsufficientDataText(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1831]!, self._r[1831]!, [_1]) - } - public func CHAT_MESSAGE_GEOLIVE(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1832]!, self._r[1832]!, [_1, _2]) - } - public var NetworkUsageSettings_CallDataSection: String { return self._s[1833]! } - public var PasscodeSettings_HelpTop: String { return self._s[1834]! } - public var Passport_Address_TypeRentalAgreement: String { return self._s[1836]! } - public var ReportPeer_ReasonOther_Placeholder: String { return self._s[1837]! } - public var CheckoutInfo_ErrorPhoneInvalid: String { return self._s[1838]! } - public var Call_Accept: String { return self._s[1840]! } - public var Month_GenMarch: String { return self._s[1841]! } - public var PhotoEditor_ShadowsTool: String { return self._s[1842]! } - public var LoginPassword_Title: String { return self._s[1843]! } - public var Watch_Conversation_GroupInfo: String { return self._s[1844]! } - public var CallSettings_Always: String { return self._s[1845]! } - public var TwoStepAuth_SetupHint: String { return self._s[1846]! } - public var ConversationProfile_UsersTooMuchError: String { return self._s[1847]! } - public var Login_PhoneTitle: String { return self._s[1848]! } - public var Passport_FieldPhoneHelp: String { return self._s[1849]! } - public var Weekday_ShortSunday: String { return self._s[1850]! } - public var Passport_InfoFAQ_URL: String { return self._s[1851]! } - public var ContactInfo_Job: String { return self._s[1853]! } - public var UserInfo_InviteBotToGroup: String { return self._s[1854]! } - public var TwoStepAuth_PasswordRemovePassportConfirmation: String { return self._s[1855]! } - public var Passport_DeletePersonalDetailsConfirmation: String { return self._s[1856]! } - public var Passport_Identity_AddInternalPassport: String { return self._s[1858]! } - public var MediaPicker_AddCaption: String { return self._s[1859]! } - public var CallSettings_TabIconDescription: String { return self._s[1860]! } - public var Privacy_GroupsAndChannels_AlwaysAllow: String { return self._s[1861]! } - public var Passport_Identity_TypePersonalDetails: String { return self._s[1862]! } - public var DialogList_SearchSectionRecent: String { return self._s[1863]! } - public var PrivacyPolicy_DeclineMessage: String { return self._s[1864]! } - public var LastSeen_WithinAWeek: String { return self._s[1867]! } - public var ChannelMembers_GroupAdminsTitle: String { return self._s[1868]! } - public var Conversation_CloudStorage_ChatStatus: String { return self._s[1870]! } - public var Passport_Address_TypeResidentialAddress: String { return self._s[1871]! } - public var Conversation_StatusLeftGroup: String { return self._s[1872]! } - public var SocksProxySetup_ProxyDetailsTitle: String { return self._s[1873]! } - public var PhotoEditor_BlurToolRadial: String { return self._s[1876]! } - public var Conversation_ContextMenuCopy: String { return self._s[1877]! } - public var AccessDenied_CallMicrophone: String { return self._s[1878]! } - public func Time_PreciseDate_m2(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1879]!, self._r[1879]!, [_1, _2, _3]) - } - public var Login_InvalidFirstNameError: String { return self._s[1880]! } - public var Notifications_Badge_CountUnreadMessages_InfoOn: String { return self._s[1881]! } - public var Checkout_PaymentMethod_New: String { return self._s[1882]! } - public var ShareMenu_CopyShareLinkGame: String { return self._s[1883]! } - public var PhotoEditor_QualityTool: String { return self._s[1884]! } - public var Login_SendCodeViaSms: String { return self._s[1885]! } - public func CHAT_MESSAGE_CONTACT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1886]!, self._r[1886]!, [_1, _2]) - } - public var Login_EmailNotConfiguredError: String { return self._s[1887]! } - public var PrivacyPolicy_Accept: String { return self._s[1888]! } - public var Notifications_ExceptionsMessagePlaceholder: String { return self._s[1889]! } - public var InfoPlist_NSLocationAlwaysUsageDescription: String { return self._s[1890]! } - public var AutoNightTheme_Automatic: String { return self._s[1891]! } - public var Channel_Username_InvalidStartsWithNumber: String { return self._s[1892]! } - public var Privacy_ContactsSyncHelp: String { return self._s[1893]! } - public var Cache_Help: String { return self._s[1894]! } - public var Passport_Language_fa: String { return self._s[1895]! } - public var Login_ResetAccountProtected_TimerTitle: String { return self._s[1896]! } - public var PrivacySettings_LastSeen: String { return self._s[1897]! } - public func DialogList_MultipleTyping(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1898]!, self._r[1898]!, [_0, _1]) - } - public var Channel_EditAdmin_PermissionInviteUsers: String { return self._s[1900]! } - public var Preview_SaveGif: String { return self._s[1902]! } - public var Profile_About: String { return self._s[1903]! } - public var Channel_About_Placeholder: String { return self._s[1904]! } - public var Login_InfoTitle: String { return self._s[1905]! } - public func TwoStepAuth_SetupPendingEmail(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[1906]!, self._r[1906]!, [_0]) } - public var Watch_Suggestion_CantTalk: String { return self._s[1908]! } - public var ContactInfo_Title: String { return self._s[1909]! } - public var Media_ShareThisVideo: String { return self._s[1910]! } - public var Weekday_ShortFriday: String { return self._s[1911]! } - public var AccessDenied_Contacts: String { return self._s[1912]! } - public var Notification_CallIncomingShort: String { return self._s[1913]! } - public var Group_Setup_TypePublic: String { return self._s[1914]! } - public var Notifications_MessageNotificationsExceptions: String { return self._s[1915]! } - public var Notifications_Badge_IncludeChannels: String { return self._s[1916]! } - public var Notifications_MessageNotificationsPreview: String { return self._s[1919]! } - public var ConversationProfile_ErrorCreatingConversation: String { return self._s[1920]! } - public var Group_ErrorAddTooMuchBots: String { return self._s[1921]! } - public var Privacy_GroupsAndChannels_CustomShareHelp: String { return self._s[1922]! } - public var Permissions_CellularDataAllowInSettings_v0: String { return self._s[1923]! } - public var DialogList_Typing: String { return self._s[1924]! } - public var Checkout_Phone: String { return self._s[1927]! } - public var Login_InfoFirstNamePlaceholder: String { return self._s[1930]! } - public func PINNED_POLL(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1931]!, self._r[1931]!, [_1]) + public var Conversation_ClearPrivateHistory: String { return self._s[1907]! } + public var ContactInfo_PhoneLabelHome: String { return self._s[1908]! } + public var PrivacySettings_LastSeenContacts: String { return self._s[1909]! } + public func ChangePhone_ErrorOccupied(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1910]!, self._r[1910]!, [_0]) } - public var Privacy_Calls_Integration: String { return self._s[1932]! } - public var Notifications_PermissionsAllow: String { return self._s[1934]! } - public var TwoStepAuth_AddHintDescription: String { return self._s[1937]! } - public var Settings_ChatSettings: String { return self._s[1938]! } - public func Channel_AdminLog_MessageInvitedNameUsername(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1939]!, self._r[1939]!, [_1, _2]) + public var Passport_Language_cs: String { return self._s[1911]! } + public var Message_PinnedAnimationMessage: String { return self._s[1912]! } + public var Passport_Identity_ReverseSideHelp: String { return self._s[1914]! } + public var Embed_PlayingInPIP: String { return self._s[1916]! } + public var AutoNightTheme_ScheduleSection: String { return self._s[1917]! } + public func Call_EmojiDescription(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1918]!, self._r[1918]!, [_0]) } - public var Login_ContinueWithLocalization: String { return self._s[1941]! } - public var Watch_Message_ForwardedFrom: String { return self._s[1942]! } - public var TwoStepAuth_EnterEmailCode: String { return self._s[1944]! } - public var Conversation_Unblock: String { return self._s[1945]! } - public var PrivacySettings_DataSettings: String { return self._s[1946]! } - public var Notifications_InAppNotificationsVibrate: String { return self._s[1947]! } - public func Privacy_GroupsAndChannels_InviteToChannelError(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1948]!, self._r[1948]!, [_0, _1]) + public var MediaPicker_LivePhotoDescription: String { return self._s[1919]! } + public func Channel_AdminLog_MessageRestrictedName(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1920]!, self._r[1920]!, [_1]) } - public var PrivacySettings_Passcode: String { return self._s[1951]! } - public func ENCRYPTION_ACCEPT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1952]!, self._r[1952]!, [_1]) + public var Notification_PaymentSent: String { return self._s[1921]! } + public var PhotoEditor_CurvesGreen: String { return self._s[1922]! } + public var SaveIncomingPhotosSettings_Title: String { return self._s[1923]! } + public func ApplyLanguage_UnsufficientDataText(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1924]!, self._r[1924]!, [_1]) } - public var Passport_Language_dz: String { return self._s[1953]! } - public var Passport_Language_tk: String { return self._s[1954]! } - public func Login_EmailCodeSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1955]!, self._r[1955]!, [_0]) + public func CHAT_MESSAGE_GEOLIVE(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1925]!, self._r[1925]!, [_1, _2]) } - public var InfoPlist_NSPhotoLibraryUsageDescription: String { return self._s[1956]! } - public var Conversation_ContextMenuReply: String { return self._s[1957]! } - public var Tour_Title1: String { return self._s[1958]! } - public func MESSAGE_STICKER(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1959]!, self._r[1959]!, [_1, _2]) + public var NetworkUsageSettings_CallDataSection: String { return self._s[1926]! } + public var PasscodeSettings_HelpTop: String { return self._s[1927]! } + public var Passport_Address_TypeRentalAgreement: String { return self._s[1929]! } + public var ReportPeer_ReasonOther_Placeholder: String { return self._s[1930]! } + public var CheckoutInfo_ErrorPhoneInvalid: String { return self._s[1931]! } + public var Call_Accept: String { return self._s[1933]! } + public var GroupRemoved_RemoveInfo: String { return self._s[1934]! } + public var Month_GenMarch: String { return self._s[1935]! } + public var PhotoEditor_ShadowsTool: String { return self._s[1936]! } + public var LoginPassword_Title: String { return self._s[1937]! } + public var Watch_Conversation_GroupInfo: String { return self._s[1938]! } + public var CallSettings_Always: String { return self._s[1939]! } + public var TwoStepAuth_SetupHint: String { return self._s[1940]! } + public var ConversationProfile_UsersTooMuchError: String { return self._s[1941]! } + public func MESSAGE_GEOLIVE_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1942]!, self._r[1942]!, [_1]) } - public var Conversation_ClearGroupHistory: String { return self._s[1961]! } - public func Checkout_PasswordEntry_Text(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1962]!, self._r[1962]!, [_0]) + public var Login_PhoneTitle: String { return self._s[1943]! } + public var Passport_FieldPhoneHelp: String { return self._s[1944]! } + public var Weekday_ShortSunday: String { return self._s[1945]! } + public var Passport_InfoFAQ_URL: String { return self._s[1946]! } + public var ContactInfo_Job: String { return self._s[1948]! } + public var UserInfo_InviteBotToGroup: String { return self._s[1949]! } + public var TwoStepAuth_PasswordRemovePassportConfirmation: String { return self._s[1950]! } + public var Passport_DeletePersonalDetailsConfirmation: String { return self._s[1952]! } + public var Passport_Identity_AddInternalPassport: String { return self._s[1954]! } + public var MediaPicker_AddCaption: String { return self._s[1955]! } + public var CallSettings_TabIconDescription: String { return self._s[1956]! } + public var Privacy_GroupsAndChannels_AlwaysAllow: String { return self._s[1957]! } + public var Passport_Identity_TypePersonalDetails: String { return self._s[1958]! } + public var DialogList_SearchSectionRecent: String { return self._s[1959]! } + public var PrivacyPolicy_DeclineMessage: String { return self._s[1960]! } + public var LastSeen_WithinAWeek: String { return self._s[1963]! } + public var ChannelMembers_GroupAdminsTitle: String { return self._s[1964]! } + public var Conversation_CloudStorage_ChatStatus: String { return self._s[1966]! } + public var Passport_Address_TypeResidentialAddress: String { return self._s[1967]! } + public var Conversation_StatusLeftGroup: String { return self._s[1968]! } + public var SocksProxySetup_ProxyDetailsTitle: String { return self._s[1969]! } + public func CHANNEL_MESSAGE_AUDIO_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1971]!, self._r[1971]!, [_1]) } - public var Call_RateCall: String { return self._s[1963]! } - public var Passport_PasswordCompleteSetup: String { return self._s[1964]! } - public var Conversation_InputTextSilentBroadcastPlaceholder: String { return self._s[1965]! } - public var UserInfo_LastNamePlaceholder: String { return self._s[1967]! } - public func Login_WillCallYou(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1969]!, self._r[1969]!, [_0]) + public var GroupPermission_AddSuccess: String { return self._s[1972]! } + public var PhotoEditor_BlurToolRadial: String { return self._s[1974]! } + public var Conversation_ContextMenuCopy: String { return self._s[1975]! } + public var AccessDenied_CallMicrophone: String { return self._s[1976]! } + public func Time_PreciseDate_m2(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1977]!, self._r[1977]!, [_1, _2, _3]) } - public var Compose_Create: String { return self._s[1970]! } - public var Contacts_InviteToTelegram: String { return self._s[1971]! } - public var GroupInfo_Notifications: String { return self._s[1972]! } - public var Message_PinnedLiveLocationMessage: String { return self._s[1974]! } - public var Month_GenApril: String { return self._s[1975]! } - public var Appearance_AutoNightTheme: String { return self._s[1976]! } - public var ChatSettings_AutomaticAudioDownload: String { return self._s[1978]! } - public var Login_CodeSentSms: String { return self._s[1980]! } - public func UserInfo_UnblockConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1981]!, self._r[1981]!, [_0]) + public var Login_InvalidFirstNameError: String { return self._s[1978]! } + public var Notifications_Badge_CountUnreadMessages_InfoOn: String { return self._s[1979]! } + public var Checkout_PaymentMethod_New: String { return self._s[1980]! } + public var ShareMenu_CopyShareLinkGame: String { return self._s[1981]! } + public var PhotoEditor_QualityTool: String { return self._s[1982]! } + public var Login_SendCodeViaSms: String { return self._s[1983]! } + public func CHAT_MESSAGE_CONTACT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1984]!, self._r[1984]!, [_1, _2]) } - public var Passport_Language_hr: String { return self._s[1982]! } - public func Channel_AdminLog_MessageRestrictedNewSetting(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1983]!, self._r[1983]!, [_0]) + public var Login_EmailNotConfiguredError: String { return self._s[1985]! } + public var PrivacyPolicy_Accept: String { return self._s[1986]! } + public var Notifications_ExceptionsMessagePlaceholder: String { return self._s[1987]! } + public var InfoPlist_NSLocationAlwaysUsageDescription: String { return self._s[1988]! } + public var AutoNightTheme_Automatic: String { return self._s[1989]! } + public var Channel_Username_InvalidStartsWithNumber: String { return self._s[1990]! } + public var Privacy_ContactsSyncHelp: String { return self._s[1991]! } + public var Cache_Help: String { return self._s[1992]! } + public var Passport_Language_fa: String { return self._s[1993]! } + public var Login_ResetAccountProtected_TimerTitle: String { return self._s[1994]! } + public var PrivacySettings_LastSeen: String { return self._s[1995]! } + public func DialogList_MultipleTyping(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1996]!, self._r[1996]!, [_0, _1]) } - public var GroupInfo_InviteLink_CopyLink: String { return self._s[1984]! } - public var Conversation_InputTextBroadcastPlaceholder: String { return self._s[1985]! } - public var Privacy_SecretChatsTitle: String { return self._s[1986]! } - public var Notification_SecretChatMessageScreenshotSelf: String { return self._s[1988]! } - public var GroupInfo_AddUserLeftError: String { return self._s[1989]! } - public var Preview_DeleteGif: String { return self._s[1990]! } - public var Group_ErrorNotMutualContact: String { return self._s[1991]! } - public var Notification_MessageLifetime5s: String { return self._s[1992]! } - public func Watch_LastSeen_AtDate(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1993]!, self._r[1993]!, [_0]) - } - public var Passport_Address_AddBankStatement: String { return self._s[1995]! } - public var Notification_CallIncoming: String { return self._s[1996]! } - public var Compose_NewGroupTitle: String { return self._s[1997]! } - public var TwoStepAuth_RecoveryCodeHelp: String { return self._s[1999]! } - public var Passport_Address_Postcode: String { return self._s[2001]! } - public func LastSeen_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2002]!, self._r[2002]!, [_0]) - } - public var Checkout_NewCard_SaveInfoHelp: String { return self._s[2003]! } - public func Cache_Clear(_ _0: String) -> (String, [(Int, NSRange)]) { + public var Channel_EditAdmin_PermissionInviteUsers: String { return self._s[1998]! } + public var Preview_SaveGif: String { return self._s[2000]! } + public var Profile_About: String { return self._s[2001]! } + public var Channel_About_Placeholder: String { return self._s[2002]! } + public var Login_InfoTitle: String { return self._s[2003]! } + public func TwoStepAuth_SetupPendingEmail(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2004]!, self._r[2004]!, [_0]) } - public var Bot_GroupStatusDoesNotReadHistory: String { return self._s[2005]! } - public var Username_Placeholder: String { return self._s[2006]! } - public var Passport_FieldAddressUploadHelp: String { return self._s[2007]! } - public var Permissions_NotificationsAllowInSettings_v0: String { return self._s[2008]! } - public var Passport_PasswordDescription: String { return self._s[2010]! } - public var Channel_MessagePhotoUpdated: String { return self._s[2011]! } - public var MediaPicker_TapToUngroupDescription: String { return self._s[2012]! } - public var AttachmentMenu_PhotoOrVideo: String { return self._s[2013]! } - public var Conversation_ContextMenuMore: String { return self._s[2014]! } - public var Privacy_PaymentsClearInfo: String { return self._s[2015]! } - public var CallSettings_TabIcon: String { return self._s[2016]! } - public var KeyCommand_Find: String { return self._s[2017]! } - public var Message_PinnedGame: String { return self._s[2018]! } - public var Notifications_Badge_CountUnreadMessages_InfoOff: String { return self._s[2019]! } - public var Login_CallRequestState2: String { return self._s[2021]! } - public var CheckoutInfo_ReceiverInfoNamePlaceholder: String { return self._s[2023]! } - public func Checkout_PayPrice(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2025]!, self._r[2025]!, [_0]) + public var Watch_Suggestion_CantTalk: String { return self._s[2006]! } + public var ContactInfo_Title: String { return self._s[2007]! } + public var Media_ShareThisVideo: String { return self._s[2008]! } + public var Weekday_ShortFriday: String { return self._s[2009]! } + public var AccessDenied_Contacts: String { return self._s[2010]! } + public var Notification_CallIncomingShort: String { return self._s[2011]! } + public var Group_Setup_TypePublic: String { return self._s[2012]! } + public var Notifications_MessageNotificationsExceptions: String { return self._s[2013]! } + public var Notifications_Badge_IncludeChannels: String { return self._s[2014]! } + public var Notifications_MessageNotificationsPreview: String { return self._s[2017]! } + public var ConversationProfile_ErrorCreatingConversation: String { return self._s[2018]! } + public var Group_ErrorAddTooMuchBots: String { return self._s[2019]! } + public var Privacy_GroupsAndChannels_CustomShareHelp: String { return self._s[2020]! } + public var Permissions_CellularDataAllowInSettings_v0: String { return self._s[2021]! } + public var DialogList_Typing: String { return self._s[2022]! } + public var Checkout_Phone: String { return self._s[2025]! } + public var Login_InfoFirstNamePlaceholder: String { return self._s[2028]! } + public func PINNED_POLL(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2029]!, self._r[2029]!, [_1]) } - public var Conversation_InstantPagePreview: String { return self._s[2026]! } - public func DialogList_SingleUploadingVideoSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2027]!, self._r[2027]!, [_0]) + public var Privacy_Calls_Integration: String { return self._s[2030]! } + public var Notifications_PermissionsAllow: String { return self._s[2032]! } + public var TwoStepAuth_AddHintDescription: String { return self._s[2035]! } + public var Settings_ChatSettings: String { return self._s[2036]! } + public func Channel_AdminLog_MessageInvitedNameUsername(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2037]!, self._r[2037]!, [_1, _2]) } - public var SecretTimer_VideoDescription: String { return self._s[2030]! } - public var Passport_Language_es: String { return self._s[2031]! } - public var Permissions_ContactsAllow_v0: String { return self._s[2033]! } - public var Conversation_EditingMessageMediaEditCurrentVideo: String { return self._s[2034]! } - public var WebPreview_GettingLinkInfo: String { return self._s[2035]! } - public var Watch_UserInfo_Unmute: String { return self._s[2036]! } - public var GroupInfo_ChannelListNamePlaceholder: String { return self._s[2037]! } - public var ChatList_ReadAll: String { return self._s[2039]! } - public var AccessDenied_CameraRestricted: String { return self._s[2040]! } - public func Conversation_Kilobytes(_ _0: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2042]!, self._r[2042]!, ["\(_0)"]) + public var GroupRemoved_DeleteUser: String { return self._s[2039]! } + public var Login_ContinueWithLocalization: String { return self._s[2040]! } + public var Watch_Message_ForwardedFrom: String { return self._s[2041]! } + public var TwoStepAuth_EnterEmailCode: String { return self._s[2043]! } + public var Conversation_Unblock: String { return self._s[2044]! } + public var PrivacySettings_DataSettings: String { return self._s[2045]! } + public var Notifications_InAppNotificationsVibrate: String { return self._s[2046]! } + public func Privacy_GroupsAndChannels_InviteToChannelError(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2047]!, self._r[2047]!, [_0, _1]) } - public var Settings_CopyUsername: String { return self._s[2043]! } - public var Contacts_SearchLabel: String { return self._s[2044]! } - public func MESSAGE_GEOLIVE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2046]!, self._r[2046]!, [_1]) + public var PrivacySettings_Passcode: String { return self._s[2050]! } + public func ENCRYPTION_ACCEPT(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2051]!, self._r[2051]!, [_1]) } - public var Map_OpenInYandexNavigator: String { return self._s[2047]! } - public var PasscodeSettings_EncryptData: String { return self._s[2048]! } - public var Notifications_GroupNotificationsPreview: String { return self._s[2049]! } - public var DialogList_AdNoticeAlert: String { return self._s[2050]! } - public func CHAT_DELETE_MEMBER(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2052]!, self._r[2052]!, [_1, _2, _3]) + public var Passport_Language_dz: String { return self._s[2052]! } + public var Passport_Language_tk: String { return self._s[2053]! } + public func Login_EmailCodeSubject(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2054]!, self._r[2054]!, [_0]) } - public var CheckoutInfo_ShippingInfoAddress1: String { return self._s[2053]! } - public var CheckoutInfo_ShippingInfoAddress2: String { return self._s[2054]! } - public var Localization_LanguageCustom: String { return self._s[2055]! } - public var Passport_Identity_TypeDriversLicenseUploadScan: String { return self._s[2056]! } - public func CHAT_CREATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + public var InfoPlist_NSPhotoLibraryUsageDescription: String { return self._s[2055]! } + public var Conversation_ContextMenuReply: String { return self._s[2056]! } + public var Tour_Title1: String { return self._s[2057]! } + public func MESSAGE_STICKER(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2058]!, self._r[2058]!, [_1, _2]) } - public var Passport_Address_OneOfTypePassportRegistration: String { return self._s[2060]! } - public var Conversation_InfoGroup: String { return self._s[2061]! } - public var Compose_NewMessage: String { return self._s[2062]! } - public var FastTwoStepSetup_HintPlaceholder: String { return self._s[2063]! } - public var ChatSettings_AutoDownloadVideoMessages: String { return self._s[2064]! } + public var Conversation_ClearGroupHistory: String { return self._s[2060]! } + public func Checkout_PasswordEntry_Text(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2061]!, self._r[2061]!, [_0]) + } + public var Call_RateCall: String { return self._s[2062]! } + public var Passport_PasswordCompleteSetup: String { return self._s[2063]! } + public var Conversation_InputTextSilentBroadcastPlaceholder: String { return self._s[2064]! } + public var UserInfo_LastNamePlaceholder: String { return self._s[2066]! } + public func Login_WillCallYou(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2068]!, self._r[2068]!, [_0]) + } + public var Compose_Create: String { return self._s[2069]! } + public var Contacts_InviteToTelegram: String { return self._s[2070]! } + public var GroupInfo_Notifications: String { return self._s[2071]! } + public var Message_PinnedLiveLocationMessage: String { return self._s[2073]! } + public var Month_GenApril: String { return self._s[2074]! } + public var Appearance_AutoNightTheme: String { return self._s[2075]! } + public var ChatSettings_AutomaticAudioDownload: String { return self._s[2077]! } + public var Login_CodeSentSms: String { return self._s[2079]! } + public func UserInfo_UnblockConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2080]!, self._r[2080]!, [_0]) + } + public var EmptyGroupInfo_Line3: String { return self._s[2081]! } + public var Passport_Language_hr: String { return self._s[2082]! } + public func Channel_AdminLog_MessageRestrictedNewSetting(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2083]!, self._r[2083]!, [_0]) + } + public var GroupInfo_InviteLink_CopyLink: String { return self._s[2084]! } + public var Conversation_InputTextBroadcastPlaceholder: String { return self._s[2085]! } + public var Privacy_SecretChatsTitle: String { return self._s[2086]! } + public var Notification_SecretChatMessageScreenshotSelf: String { return self._s[2088]! } + public var GroupInfo_AddUserLeftError: String { return self._s[2089]! } + public func CHANNEL_MESSAGE_VIDEO_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2090]!, self._r[2090]!, [_1]) + } + public var Preview_DeleteGif: String { return self._s[2091]! } + public var GroupInfo_Permissions_Exceptions: String { return self._s[2092]! } + public var Group_ErrorNotMutualContact: String { return self._s[2093]! } + public var Notification_MessageLifetime5s: String { return self._s[2094]! } + public func Watch_LastSeen_AtDate(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2095]!, self._r[2095]!, [_0]) + } + public var Passport_Address_AddBankStatement: String { return self._s[2097]! } + public var Notification_CallIncoming: String { return self._s[2098]! } + public var Compose_NewGroupTitle: String { return self._s[2099]! } + public var TwoStepAuth_RecoveryCodeHelp: String { return self._s[2101]! } + public var Passport_Address_Postcode: String { return self._s[2103]! } + public func LastSeen_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2104]!, self._r[2104]!, [_0]) + } + public var Checkout_NewCard_SaveInfoHelp: String { return self._s[2105]! } + public var GroupPermission_Duration: String { return self._s[2106]! } + public func Cache_Clear(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2107]!, self._r[2107]!, [_0]) + } + public var Bot_GroupStatusDoesNotReadHistory: String { return self._s[2108]! } + public var Username_Placeholder: String { return self._s[2109]! } + public var Passport_FieldAddressUploadHelp: String { return self._s[2110]! } + public var Permissions_NotificationsAllowInSettings_v0: String { return self._s[2111]! } + public func CHAT_ADD_MEMBER_SEPARATED(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2112]!, self._r[2112]!, [_1, _2, _3]) + } + public var Passport_PasswordDescription: String { return self._s[2114]! } + public var Channel_MessagePhotoUpdated: String { return self._s[2115]! } + public var MediaPicker_TapToUngroupDescription: String { return self._s[2116]! } + public var AttachmentMenu_PhotoOrVideo: String { return self._s[2117]! } + public var Conversation_ContextMenuMore: String { return self._s[2118]! } + public var Privacy_PaymentsClearInfo: String { return self._s[2119]! } + public var CallSettings_TabIcon: String { return self._s[2120]! } + public var KeyCommand_Find: String { return self._s[2121]! } + public var Message_PinnedGame: String { return self._s[2122]! } + public var Notifications_Badge_CountUnreadMessages_InfoOff: String { return self._s[2123]! } + public var Login_CallRequestState2: String { return self._s[2125]! } + public var CheckoutInfo_ReceiverInfoNamePlaceholder: String { return self._s[2127]! } + public func Checkout_PayPrice(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2129]!, self._r[2129]!, [_0]) + } + public var Conversation_InstantPagePreview: String { return self._s[2130]! } + public func DialogList_SingleUploadingVideoSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2131]!, self._r[2131]!, [_0]) + } + public var SecretTimer_VideoDescription: String { return self._s[2134]! } + public var GroupPermission_NoPinMessages: String { return self._s[2135]! } + public var Passport_Language_es: String { return self._s[2136]! } + public var Permissions_ContactsAllow_v0: String { return self._s[2138]! } + public var Conversation_EditingMessageMediaEditCurrentVideo: String { return self._s[2139]! } + public var WebPreview_GettingLinkInfo: String { return self._s[2140]! } + public var Watch_UserInfo_Unmute: String { return self._s[2141]! } + public var GroupInfo_ChannelListNamePlaceholder: String { return self._s[2142]! } + public var AccessDenied_CameraRestricted: String { return self._s[2144]! } + public func Conversation_Kilobytes(_ _0: Int) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2145]!, self._r[2145]!, ["\(_0)"]) + } + public var ChatList_ReadAll: String { return self._s[2147]! } + public var Settings_CopyUsername: String { return self._s[2148]! } + public var Contacts_SearchLabel: String { return self._s[2149]! } + public func MESSAGE_GEOLIVE(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2151]!, self._r[2151]!, [_1]) + } + public var Map_OpenInYandexNavigator: String { return self._s[2152]! } + public var PasscodeSettings_EncryptData: String { return self._s[2153]! } + public var Notifications_GroupNotificationsPreview: String { return self._s[2155]! } + public var DialogList_AdNoticeAlert: String { return self._s[2156]! } + public func CHAT_DELETE_MEMBER(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2158]!, self._r[2158]!, [_1, _2, _3]) + } + public var CheckoutInfo_ShippingInfoAddress1: String { return self._s[2159]! } + public var CheckoutInfo_ShippingInfoAddress2: String { return self._s[2160]! } + public var Localization_LanguageCustom: String { return self._s[2161]! } + public var Passport_Identity_TypeDriversLicenseUploadScan: String { return self._s[2162]! } + public func CHAT_CREATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2164]!, self._r[2164]!, [_1, _2]) + } + public var Passport_Address_OneOfTypePassportRegistration: String { return self._s[2166]! } + public var Conversation_InfoGroup: String { return self._s[2167]! } + public var Compose_NewMessage: String { return self._s[2168]! } + public var FastTwoStepSetup_HintPlaceholder: String { return self._s[2170]! } + public var ChatSettings_AutoDownloadVideoMessages: String { return self._s[2171]! } public func Passport_Scans_ScanIndex(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2065]!, self._r[2065]!, [_0]) + return formatWithArgumentRanges(self._s[2172]!, self._r[2172]!, [_0]) } - public var Channel_AdminLog_CanDeleteMessages: String { return self._s[2066]! } - public var Login_CancelSignUpConfirmation: String { return self._s[2067]! } - public var ChangePhoneNumberCode_Help: String { return self._s[2068]! } - public var PrivacySettings_DeleteAccountHelp: String { return self._s[2069]! } - public var Channel_BlackList_Title: String { return self._s[2070]! } - public var UserInfo_PhoneCall: String { return self._s[2071]! } - public var Passport_Address_OneOfTypeBankStatement: String { return self._s[2073]! } - public var State_connecting: String { return self._s[2074]! } + public var Channel_AdminLog_CanDeleteMessages: String { return self._s[2173]! } + public var Login_CancelSignUpConfirmation: String { return self._s[2174]! } + public var ChangePhoneNumberCode_Help: String { return self._s[2175]! } + public var PrivacySettings_DeleteAccountHelp: String { return self._s[2176]! } + public var Channel_BlackList_Title: String { return self._s[2177]! } + public var UserInfo_PhoneCall: String { return self._s[2178]! } + public var Passport_Address_OneOfTypeBankStatement: String { return self._s[2180]! } + public var State_connecting: String { return self._s[2181]! } public func DialogList_SingleRecordingAudioSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2075]!, self._r[2075]!, [_0]) + return formatWithArgumentRanges(self._s[2182]!, self._r[2182]!, [_0]) } - public var Notifications_GroupNotifications: String { return self._s[2076]! } - public var Passport_Identity_EditPassport: String { return self._s[2077]! } - public var EnterPasscode_RepeatNewPasscode: String { return self._s[2079]! } - public var Localization_EnglishLanguageName: String { return self._s[2080]! } - public var Share_AuthDescription: String { return self._s[2081]! } - public var Passport_Identity_Surname: String { return self._s[2082]! } - public var Compose_TokenListPlaceholder: String { return self._s[2083]! } - public var Passport_Identity_OneOfTypePassport: String { return self._s[2084]! } - public var Settings_AboutEmpty: String { return self._s[2085]! } - public var Conversation_Unmute: String { return self._s[2086]! } - public var Login_CodeSentCall: String { return self._s[2089]! } - public var ContactInfo_PhoneLabelHomeFax: String { return self._s[2090]! } - public var ChatSettings_Appearance: String { return self._s[2091]! } - public var Appearance_PickAccentColor: String { return self._s[2092]! } - public var Notification_CallMissed: String { return self._s[2093]! } - public var Channel_AdminLogFilter_EventsInfo: String { return self._s[2094]! } - public var ChatAdmins_AdminLabel: String { return self._s[2096]! } - public var KeyCommand_JumpToNextChat: String { return self._s[2097]! } - public var Conversation_StopPollConfirmationTitle: String { return self._s[2099]! } - public var ChangePhoneNumberCode_CodePlaceholder: String { return self._s[2100]! } - public var Month_GenJune: String { return self._s[2101]! } - public var Watch_Location_Current: String { return self._s[2102]! } - public var Conversation_TitleMute: String { return self._s[2103]! } + public var Notifications_GroupNotifications: String { return self._s[2183]! } + public var Passport_Identity_EditPassport: String { return self._s[2184]! } + public var EnterPasscode_RepeatNewPasscode: String { return self._s[2186]! } + public var Localization_EnglishLanguageName: String { return self._s[2187]! } + public var Share_AuthDescription: String { return self._s[2188]! } + public var Passport_Identity_Surname: String { return self._s[2189]! } + public var Compose_TokenListPlaceholder: String { return self._s[2190]! } + public var Passport_Identity_OneOfTypePassport: String { return self._s[2191]! } + public var Settings_AboutEmpty: String { return self._s[2192]! } + public var Conversation_Unmute: String { return self._s[2193]! } + public var Login_CodeSentCall: String { return self._s[2196]! } + public var ContactInfo_PhoneLabelHomeFax: String { return self._s[2197]! } + public var ChatSettings_Appearance: String { return self._s[2198]! } + public var Appearance_PickAccentColor: String { return self._s[2199]! } + public var Notification_CallMissed: String { return self._s[2200]! } + public var Channel_AdminLogFilter_EventsInfo: String { return self._s[2201]! } + public var ChatAdmins_AdminLabel: String { return self._s[2203]! } + public var KeyCommand_JumpToNextChat: String { return self._s[2204]! } + public var Conversation_StopPollConfirmationTitle: String { return self._s[2206]! } + public var ChangePhoneNumberCode_CodePlaceholder: String { return self._s[2207]! } + public var Month_GenJune: String { return self._s[2208]! } + public var Watch_Location_Current: String { return self._s[2209]! } + public var Conversation_TitleMute: String { return self._s[2210]! } public func PINNED_ROUND(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2104]!, self._r[2104]!, [_1]) + return formatWithArgumentRanges(self._s[2211]!, self._r[2211]!, [_1]) } - public var GroupInfo_DeleteAndExit: String { return self._s[2105]! } + public var GroupInfo_DeleteAndExit: String { return self._s[2212]! } public func Conversation_Moderate_DeleteAllMessages(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2106]!, self._r[2106]!, [_0]) + return formatWithArgumentRanges(self._s[2213]!, self._r[2213]!, [_0]) } - public var Call_ReportPlaceholder: String { return self._s[2107]! } - public var MaskStickerSettings_Info: String { return self._s[2108]! } + public var Call_ReportPlaceholder: String { return self._s[2214]! } + public var MaskStickerSettings_Info: String { return self._s[2215]! } public func GroupInfo_AddParticipantConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2109]!, self._r[2109]!, [_0]) - } - public var Checkout_NewCard_PostcodeTitle: String { return self._s[2110]! } - public var Passport_Address_RegionPlaceholder: String { return self._s[2112]! } - public var Contacts_ShareTelegram: String { return self._s[2113]! } - public var EnterPasscode_EnterNewPasscodeNew: String { return self._s[2114]! } - public var Channel_ErrorAccessDenied: String { return self._s[2115]! } - public var Stickers_GroupChooseStickerPack: String { return self._s[2117]! } - public var Call_ConnectionErrorTitle: String { return self._s[2118]! } - public var UserInfo_NotificationsEnable: String { return self._s[2119]! } - public var Tour_Text4: String { return self._s[2122]! } - public func CHANNEL_MESSAGE_NOTEXT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2124]!, self._r[2124]!, [_1]) - } - public var Profile_MessageLifetime2s: String { return self._s[2125]! } - public var Notification_MessageLifetime2s: String { return self._s[2126]! } - public func Time_PreciseDate_m10(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2127]!, self._r[2127]!, [_1, _2, _3]) - } - public var Cache_ClearCache: String { return self._s[2128]! } - public var AutoNightTheme_UpdateLocation: String { return self._s[2129]! } - public var Permissions_NotificationsUnreachableText_v0: String { return self._s[2130]! } - public func Channel_AdminLog_MessageChangedGroupUsername(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2132]!, self._r[2132]!, [_0]) - } - public var Channel_AdminLog_EmptyFilterTitle: String { return self._s[2134]! } - public var SocksProxySetup_TypeSocks: String { return self._s[2135]! } - public var AutoNightTheme_Title: String { return self._s[2136]! } - public var InstantPage_FeedbackButton: String { return self._s[2137]! } - public var Passport_FieldAddress: String { return self._s[2138]! } - public var Month_ShortMarch: String { return self._s[2139]! } - public var SocksProxySetup_UsernamePlaceholder: String { return self._s[2140]! } - public var Conversation_ShareInlineBotLocationConfirmation: String { return self._s[2141]! } - public var Passport_FloodError: String { return self._s[2142]! } - public var SecretGif_Title: String { return self._s[2143]! } - public var Passport_Language_th: String { return self._s[2145]! } - public var Passport_Address_Address: String { return self._s[2146]! } - public var Login_InvalidLastNameError: String { return self._s[2147]! } - public var Notifications_InAppNotificationsPreview: String { return self._s[2148]! } - public var Notifications_PermissionsUnreachableTitle: String { return self._s[2149]! } - public var ShareMenu_Send: String { return self._s[2150]! } - public var Month_GenNovember: String { return self._s[2153]! } - public var Checkout_Email: String { return self._s[2155]! } - public var NotificationsSound_Tritone: String { return self._s[2156]! } - public var StickerPacksSettings_ManagingHelp: String { return self._s[2158]! } - public var ChangePhoneNumberNumber_Help: String { return self._s[2161]! } - public func Checkout_LiabilityAlert(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2162]!, self._r[2162]!, [_1, _1, _1, _2]) - } - public var DialogList_You: String { return self._s[2163]! } - public var MediaPicker_Send: String { return self._s[2166]! } - public var Call_AudioRouteSpeaker: String { return self._s[2167]! } - public var Watch_UserInfo_Title: String { return self._s[2168]! } - public var Appearance_AccentColor: String { return self._s[2169]! } - public func Login_EmailPhoneSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2170]!, self._r[2170]!, [_0]) - } - public var Permissions_ContactsAllowInSettings_v0: String { return self._s[2171]! } - public var Conversation_ClousStorageInfo_Description2: String { return self._s[2172]! } - public var WebSearch_RecentClearConfirmation: String { return self._s[2173]! } - public var Notification_CallOutgoing: String { return self._s[2174]! } - public var PrivacySettings_PasscodeAndFaceId: String { return self._s[2175]! } - public var Call_RecordingDisabledMessage: String { return self._s[2176]! } - public var PrivacyLastSeenSettings_CustomHelp: String { return self._s[2177]! } - public var Channel_EditAdmin_PermissionAddAdmins: String { return self._s[2178]! } - public var Date_DialogDateFormat: String { return self._s[2179]! } - public var Notifications_InAppNotifications: String { return self._s[2180]! } - public func Settings_ApplyProxyAlert(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2181]!, self._r[2181]!, [_1, _2]) - } - public var NewContact_Title: String { return self._s[2182]! } - public var Conversation_ViewContactDetails: String { return self._s[2183]! } - public var Checkout_NewCard_CardholderNameTitle: String { return self._s[2185]! } - public var Passport_Identity_ExpiryDateNone: String { return self._s[2186]! } - public var PrivacySettings_Title: String { return self._s[2187]! } - public var Conversation_SilentBroadcastTooltipOff: String { return self._s[2190]! } - public func CHANNEL_MESSAGE_CONTACT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2191]!, self._r[2191]!, [_1]) - } - public var Contacts_PhoneNumber: String { return self._s[2192]! } - public var Map_ShowPlaces: String { return self._s[2194]! } - public var ChatAdmins_Title: String { return self._s[2195]! } - public var InstantPage_Reference: String { return self._s[2197]! } - public var Camera_FlashOff: String { return self._s[2198]! } - public var Watch_UserInfo_Block: String { return self._s[2199]! } - public var ChatSettings_Stickers: String { return self._s[2200]! } - public var ChatSettings_DownloadInBackground: String { return self._s[2201]! } - public func UserInfo_BlockConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2202]!, self._r[2202]!, [_0]) - } - public var Login_CheckOtherSessionMessages: String { return self._s[2203]! } - public var Settings_ViewPhoto: String { return self._s[2204]! } - public var AutoDownloadSettings_Cellular: String { return self._s[2205]! } - public func Target_InviteToGroupConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2207]!, self._r[2207]!, [_0]) - } - public var Privacy_DeleteDrafts: String { return self._s[2208]! } - public func LastSeen_AtDate(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2209]!, self._r[2209]!, [_0]) - } - public var DialogList_SavedMessagesHelp: String { return self._s[2210]! } - public var DialogList_SavedMessages: String { return self._s[2211]! } - public var GroupInfo_UpgradeButton: String { return self._s[2212]! } - public func CHAT_MESSAGE_GAME(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2213]!, self._r[2213]!, [_1, _2, _3]) - } - public var DialogList_Pin: String { return self._s[2214]! } - public func ForwardedAuthors2(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2215]!, self._r[2215]!, [_0, _1]) - } - public func Login_PhoneGenericEmailSubject(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2216]!, self._r[2216]!, [_0]) } - public var Notification_Exceptions_AlwaysOn: String { return self._s[2217]! } - public var UserInfo_NotificationsDisable: String { return self._s[2218]! } - public var Paint_Outlined: String { return self._s[2219]! } - public var Activity_PlayingGame: String { return self._s[2220]! } - public var SearchImages_NoImagesFound: String { return self._s[2221]! } - public var SocksProxySetup_ProxyType: String { return self._s[2222]! } - public var AppleWatch_ReplyPresetsHelp: String { return self._s[2224]! } - public var Settings_AppLanguage: String { return self._s[2225]! } - public var TwoStepAuth_ResetAccountHelp: String { return self._s[2226]! } - public var Common_ChoosePhoto: String { return self._s[2227]! } - public var Privacy_Calls_AlwaysAllow: String { return self._s[2228]! } - public var Activity_UploadingVideo: String { return self._s[2229]! } - public var ChannelInfo_DeleteChannelConfirmation: String { return self._s[2230]! } - public var NetworkUsageSettings_Wifi: String { return self._s[2231]! } - public var Channel_BanUser_PermissionReadMessages: String { return self._s[2232]! } - public var Checkout_PayWithTouchId: String { return self._s[2233]! } - public var Notifications_ExceptionsNone: String { return self._s[2235]! } + public var Checkout_NewCard_PostcodeTitle: String { return self._s[2217]! } + public var Passport_Address_RegionPlaceholder: String { return self._s[2219]! } + public var Contacts_ShareTelegram: String { return self._s[2220]! } + public func CHAT_MESSAGE_GIF_SEPARATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2221]!, self._r[2221]!, [_1, _2]) + } + public var EnterPasscode_EnterNewPasscodeNew: String { return self._s[2222]! } + public var Channel_ErrorAccessDenied: String { return self._s[2223]! } + public var Stickers_GroupChooseStickerPack: String { return self._s[2225]! } + public var Call_ConnectionErrorTitle: String { return self._s[2226]! } + public var UserInfo_NotificationsEnable: String { return self._s[2227]! } + public var Tour_Text4: String { return self._s[2230]! } + public func CHANNEL_MESSAGE_NOTEXT(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2232]!, self._r[2232]!, [_1]) + } + public var Profile_MessageLifetime2s: String { return self._s[2233]! } + public var Notification_MessageLifetime2s: String { return self._s[2234]! } + public func Time_PreciseDate_m10(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2235]!, self._r[2235]!, [_1, _2, _3]) + } + public var Cache_ClearCache: String { return self._s[2236]! } + public var AutoNightTheme_UpdateLocation: String { return self._s[2237]! } + public var Permissions_NotificationsUnreachableText_v0: String { return self._s[2238]! } + public func Channel_AdminLog_MessageChangedGroupUsername(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2240]!, self._r[2240]!, [_0]) + } + public var Channel_AdminLog_EmptyFilterTitle: String { return self._s[2242]! } + public var SocksProxySetup_TypeSocks: String { return self._s[2243]! } + public var AutoNightTheme_Title: String { return self._s[2244]! } + public var InstantPage_FeedbackButton: String { return self._s[2245]! } + public var Passport_FieldAddress: String { return self._s[2246]! } + public var Month_ShortMarch: String { return self._s[2247]! } + public var SocksProxySetup_UsernamePlaceholder: String { return self._s[2248]! } + public var Conversation_ShareInlineBotLocationConfirmation: String { return self._s[2249]! } + public var Passport_FloodError: String { return self._s[2250]! } + public var SecretGif_Title: String { return self._s[2251]! } + public var Passport_Language_th: String { return self._s[2253]! } + public var Passport_Address_Address: String { return self._s[2254]! } + public var Login_InvalidLastNameError: String { return self._s[2255]! } + public var Notifications_InAppNotificationsPreview: String { return self._s[2256]! } + public var Notifications_PermissionsUnreachableTitle: String { return self._s[2257]! } + public var ShareMenu_Send: String { return self._s[2258]! } + public var Month_GenNovember: String { return self._s[2261]! } + public var Checkout_Email: String { return self._s[2263]! } + public var NotificationsSound_Tritone: String { return self._s[2264]! } + public var StickerPacksSettings_ManagingHelp: String { return self._s[2266]! } + public var ChangePhoneNumberNumber_Help: String { return self._s[2269]! } + public func Checkout_LiabilityAlert(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2270]!, self._r[2270]!, [_1, _1, _1, _2]) + } + public var DialogList_You: String { return self._s[2271]! } + public var MediaPicker_Send: String { return self._s[2274]! } + public var Call_AudioRouteSpeaker: String { return self._s[2275]! } + public var Watch_UserInfo_Title: String { return self._s[2276]! } + public var Appearance_AccentColor: String { return self._s[2277]! } + public func PINNED_STICKER_SEPARATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2278]!, self._r[2278]!, [_1, _2]) + } + public func Login_EmailPhoneSubject(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2279]!, self._r[2279]!, [_0]) + } + public var Permissions_ContactsAllowInSettings_v0: String { return self._s[2280]! } + public var Conversation_ClousStorageInfo_Description2: String { return self._s[2281]! } + public var WebSearch_RecentClearConfirmation: String { return self._s[2282]! } + public var Notification_CallOutgoing: String { return self._s[2283]! } + public var PrivacySettings_PasscodeAndFaceId: String { return self._s[2284]! } + public var Call_RecordingDisabledMessage: String { return self._s[2285]! } + public var PrivacyLastSeenSettings_CustomHelp: String { return self._s[2286]! } + public var Channel_EditAdmin_PermissionAddAdmins: String { return self._s[2287]! } + public var Date_DialogDateFormat: String { return self._s[2288]! } + public var Notifications_InAppNotifications: String { return self._s[2289]! } + public func Channel_Management_RemovedBy(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2290]!, self._r[2290]!, [_0]) + } + public func Settings_ApplyProxyAlert(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2291]!, self._r[2291]!, [_1, _2]) + } + public var NewContact_Title: String { return self._s[2292]! } + public var Conversation_ViewContactDetails: String { return self._s[2293]! } + public var Checkout_NewCard_CardholderNameTitle: String { return self._s[2295]! } + public var Passport_Identity_ExpiryDateNone: String { return self._s[2296]! } + public var PrivacySettings_Title: String { return self._s[2297]! } + public var Conversation_SilentBroadcastTooltipOff: String { return self._s[2300]! } + public func CHANNEL_MESSAGE_CONTACT(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2301]!, self._r[2301]!, [_1]) + } + public var GroupRemoved_UsersSectionTitle: String { return self._s[2302]! } + public var Contacts_PhoneNumber: String { return self._s[2303]! } + public func CHANNEL_MESSAGE_CONTACT_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2305]!, self._r[2305]!, [_1]) + } + public var Map_ShowPlaces: String { return self._s[2306]! } + public var ChatAdmins_Title: String { return self._s[2307]! } + public var InstantPage_Reference: String { return self._s[2309]! } + public var Camera_FlashOff: String { return self._s[2310]! } + public var Watch_UserInfo_Block: String { return self._s[2311]! } + public var ChatSettings_Stickers: String { return self._s[2312]! } + public var ChatSettings_DownloadInBackground: String { return self._s[2313]! } + public func UserInfo_BlockConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2314]!, self._r[2314]!, [_0]) + } + public var Settings_ViewPhoto: String { return self._s[2315]! } + public var Login_CheckOtherSessionMessages: String { return self._s[2316]! } + public var AutoDownloadSettings_Cellular: String { return self._s[2317]! } + public func Target_InviteToGroupConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2319]!, self._r[2319]!, [_0]) + } + public var Privacy_DeleteDrafts: String { return self._s[2320]! } + public func LastSeen_AtDate(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2321]!, self._r[2321]!, [_0]) + } + public var DialogList_SavedMessagesHelp: String { return self._s[2322]! } + public var DialogList_SavedMessages: String { return self._s[2323]! } + public var GroupInfo_UpgradeButton: String { return self._s[2324]! } + public func CHAT_MESSAGE_GAME(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2325]!, self._r[2325]!, [_1, _2, _3]) + } + public var DialogList_Pin: String { return self._s[2326]! } + public func ForwardedAuthors2(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2327]!, self._r[2327]!, [_0, _1]) + } + public func Login_PhoneGenericEmailSubject(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2328]!, self._r[2328]!, [_0]) + } + public var Notification_Exceptions_AlwaysOn: String { return self._s[2329]! } + public var UserInfo_NotificationsDisable: String { return self._s[2330]! } + public var Paint_Outlined: String { return self._s[2331]! } + public var Activity_PlayingGame: String { return self._s[2332]! } + public var SearchImages_NoImagesFound: String { return self._s[2333]! } + public var SocksProxySetup_ProxyType: String { return self._s[2334]! } + public var AppleWatch_ReplyPresetsHelp: String { return self._s[2336]! } + public var Settings_AppLanguage: String { return self._s[2337]! } + public var TwoStepAuth_ResetAccountHelp: String { return self._s[2338]! } + public var Common_ChoosePhoto: String { return self._s[2339]! } + public var Privacy_Calls_AlwaysAllow: String { return self._s[2340]! } + public var Activity_UploadingVideo: String { return self._s[2341]! } + public var ChannelInfo_DeleteChannelConfirmation: String { return self._s[2342]! } + public var NetworkUsageSettings_Wifi: String { return self._s[2343]! } + public var Channel_BanUser_PermissionReadMessages: String { return self._s[2344]! } + public var Checkout_PayWithTouchId: String { return self._s[2345]! } + public var Notifications_ExceptionsNone: String { return self._s[2347]! } public func Message_ForwardedMessageShort(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2236]!, self._r[2236]!, [_0]) + return formatWithArgumentRanges(self._s[2348]!, self._r[2348]!, [_0]) } - public var AuthSessions_IncompleteAttempts: String { return self._s[2237]! } - public var Passport_Address_Region: String { return self._s[2241]! } - public var PhotoEditor_TiltShift: String { return self._s[2242]! } - public var Settings_FAQ_URL: String { return self._s[2243]! } - public var Passport_Language_sl: String { return self._s[2244]! } - public var Settings_PrivacySettings: String { return self._s[2246]! } - public var SharedMedia_TitleLink: String { return self._s[2247]! } - public var Passport_Identity_TypePassportUploadScan: String { return self._s[2248]! } - public var Settings_SetProfilePhoto: String { return self._s[2249]! } - public var Channel_About_Help: String { return self._s[2250]! } - public var Contacts_PermissionsEnable: String { return self._s[2251]! } - public var AttachmentMenu_SendAsFiles: String { return self._s[2252]! } - public var Passport_Address_AddTemporaryRegistration: String { return self._s[2254]! } - public var PrivacySettings_DeleteAccountTitle: String { return self._s[2255]! } - public var AccessDenied_VideoMessageCamera: String { return self._s[2257]! } - public var Map_OpenInYandexMaps: String { return self._s[2259]! } - public var PhotoEditor_SaturationTool: String { return self._s[2260]! } - public var Notification_Exceptions_NewException_NotificationHeader: String { return self._s[2261]! } - public var Appearance_TextSize: String { return self._s[2262]! } - public var Channel_Username_InvalidTooShort: String { return self._s[2264]! } - public var Passport_PassportInformation: String { return self._s[2267]! } - public var WatchRemote_AlertTitle: String { return self._s[2268]! } - public var Privacy_GroupsAndChannels_NeverAllow: String { return self._s[2269]! } - public var ConvertToSupergroup_HelpText: String { return self._s[2271]! } + public var AuthSessions_IncompleteAttempts: String { return self._s[2350]! } + public var Passport_Address_Region: String { return self._s[2353]! } + public var PhotoEditor_TiltShift: String { return self._s[2354]! } + public var Settings_FAQ_URL: String { return self._s[2355]! } + public var SharedMedia_TitleLink: String { return self._s[2357]! } + public var Settings_PrivacySettings: String { return self._s[2358]! } + public var Passport_Identity_TypePassportUploadScan: String { return self._s[2359]! } + public var Passport_Language_sl: String { return self._s[2360]! } + public var Settings_SetProfilePhoto: String { return self._s[2361]! } + public var Channel_About_Help: String { return self._s[2362]! } + public var Contacts_PermissionsEnable: String { return self._s[2363]! } + public var AttachmentMenu_SendAsFiles: String { return self._s[2364]! } + public var Passport_Address_AddTemporaryRegistration: String { return self._s[2366]! } + public var PrivacySettings_DeleteAccountTitle: String { return self._s[2367]! } + public var AccessDenied_VideoMessageCamera: String { return self._s[2369]! } + public var Map_OpenInYandexMaps: String { return self._s[2371]! } + public var PhotoEditor_SaturationTool: String { return self._s[2372]! } + public var Notification_Exceptions_NewException_NotificationHeader: String { return self._s[2373]! } + public var Appearance_TextSize: String { return self._s[2375]! } + public var Channel_Username_InvalidTooShort: String { return self._s[2377]! } + public var Passport_PassportInformation: String { return self._s[2380]! } + public var WatchRemote_AlertTitle: String { return self._s[2381]! } + public var Privacy_GroupsAndChannels_NeverAllow: String { return self._s[2382]! } + public var ConvertToSupergroup_HelpText: String { return self._s[2384]! } public func Time_MonthOfYear_m7(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2272]!, self._r[2272]!, [_0]) + return formatWithArgumentRanges(self._s[2385]!, self._r[2385]!, [_0]) } - public var Privacy_GroupsAndChannels_CustomHelp: String { return self._s[2273]! } - public var TwoStepAuth_RecoveryCodeInvalid: String { return self._s[2275]! } - public var AccessDenied_CameraDisabled: String { return self._s[2276]! } + public var Privacy_GroupsAndChannels_CustomHelp: String { return self._s[2386]! } + public var TwoStepAuth_RecoveryCodeInvalid: String { return self._s[2388]! } + public var AccessDenied_CameraDisabled: String { return self._s[2389]! } public func Channel_Username_UsernameIsAvailable(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2277]!, self._r[2277]!, [_0]) + return formatWithArgumentRanges(self._s[2390]!, self._r[2390]!, [_0]) } - public var PhotoEditor_ContrastTool: String { return self._s[2280]! } - public var DialogList_Draft: String { return self._s[2281]! } - public var Privacy_TopPeersDelete: String { return self._s[2283]! } - public var LoginPassword_PasswordPlaceholder: String { return self._s[2284]! } - public var Passport_Identity_TypeIdentityCardUploadScan: String { return self._s[2285]! } - public var WebSearch_RecentSectionClear: String { return self._s[2286]! } - public var Watch_ChatList_NoConversationsTitle: String { return self._s[2288]! } - public var Common_Done: String { return self._s[2289]! } - public var AuthSessions_EmptyText: String { return self._s[2290]! } - public var Conversation_ShareBotContactConfirmation: String { return self._s[2291]! } - public var Tour_Title5: String { return self._s[2292]! } + public var PhotoEditor_ContrastTool: String { return self._s[2393]! } + public var DialogList_Draft: String { return self._s[2394]! } + public var Privacy_TopPeersDelete: String { return self._s[2396]! } + public var LoginPassword_PasswordPlaceholder: String { return self._s[2397]! } + public var Passport_Identity_TypeIdentityCardUploadScan: String { return self._s[2398]! } + public var WebSearch_RecentSectionClear: String { return self._s[2399]! } + public var Watch_ChatList_NoConversationsTitle: String { return self._s[2401]! } + public var Common_Done: String { return self._s[2402]! } + public var AuthSessions_EmptyText: String { return self._s[2403]! } + public var Conversation_ShareBotContactConfirmation: String { return self._s[2404]! } + public var Tour_Title5: String { return self._s[2405]! } public func Map_DirectionsDriveEta(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2293]!, self._r[2293]!, [_0]) + return formatWithArgumentRanges(self._s[2406]!, self._r[2406]!, [_0]) } - public var ApplyLanguage_UnsufficientDataTitle: String { return self._s[2294]! } - public var Conversation_LinkDialogSave: String { return self._s[2295]! } - public var GroupInfo_ActionRestrict: String { return self._s[2296]! } - public var Checkout_Title: String { return self._s[2297]! } - public var Channel_AdminLog_CanChangeInfo: String { return self._s[2300]! } - public var Notification_RenamedGroup: String { return self._s[2301]! } - public var Checkout_PayWithFaceId: String { return self._s[2302]! } - public var Channel_BanList_BlockedTitle: String { return self._s[2303]! } - public var Checkout_WebConfirmation_Title: String { return self._s[2305]! } - public var Notifications_MessageNotificationsAlert: String { return self._s[2306]! } - public var Profile_AddToExisting: String { return self._s[2308]! } + public var ApplyLanguage_UnsufficientDataTitle: String { return self._s[2407]! } + public var Conversation_LinkDialogSave: String { return self._s[2408]! } + public var GroupInfo_ActionRestrict: String { return self._s[2409]! } + public var Checkout_Title: String { return self._s[2410]! } + public var Channel_AdminLog_CanChangeInfo: String { return self._s[2413]! } + public var Notification_RenamedGroup: String { return self._s[2414]! } + public var Checkout_PayWithFaceId: String { return self._s[2415]! } + public var Channel_BanList_BlockedTitle: String { return self._s[2416]! } + public func PINNED_TEXT_SEPARATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2418]!, self._r[2418]!, [_1, _2]) + } + public var Checkout_WebConfirmation_Title: String { return self._s[2419]! } + public var Notifications_MessageNotificationsAlert: String { return self._s[2420]! } + public var Profile_AddToExisting: String { return self._s[2422]! } public func Profile_CreateEncryptedChatOutdatedError(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2309]!, self._r[2309]!, [_0, _1]) + return formatWithArgumentRanges(self._s[2423]!, self._r[2423]!, [_0, _1]) } - public var Cache_Files: String { return self._s[2311]! } - public var Permissions_PrivacyPolicy: String { return self._s[2312]! } - public var SocksProxySetup_ConnectAndSave: String { return self._s[2313]! } - public var UserInfo_NotificationsDefaultDisabled: String { return self._s[2314]! } + public var Cache_Files: String { return self._s[2426]! } + public var Permissions_PrivacyPolicy: String { return self._s[2427]! } + public var SocksProxySetup_ConnectAndSave: String { return self._s[2428]! } + public var UserInfo_NotificationsDefaultDisabled: String { return self._s[2429]! } public func MESSAGE_POLL(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2316]!, self._r[2316]!, [_1]) + return formatWithArgumentRanges(self._s[2431]!, self._r[2431]!, [_1]) } - public var Calls_NoCallsPlaceholder: String { return self._s[2318]! } - public var Channel_Username_RevokeExistingUsernamesInfo: String { return self._s[2319]! } - public var Notifications_ExceptionsGroupPlaceholder: String { return self._s[2321]! } - public var Passport_FieldAddressHelp: String { return self._s[2322]! } - public var Privacy_GroupsAndChannels_InviteToChannelMultipleError: String { return self._s[2323]! } + public var Calls_NoCallsPlaceholder: String { return self._s[2433]! } + public var Channel_Username_RevokeExistingUsernamesInfo: String { return self._s[2434]! } + public var Notifications_ExceptionsGroupPlaceholder: String { return self._s[2436]! } + public var Passport_FieldAddressHelp: String { return self._s[2437]! } + public var Privacy_GroupsAndChannels_InviteToChannelMultipleError: String { return self._s[2438]! } public func Login_TermsOfService_ProceedBot(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2324]!, self._r[2324]!, [_0]) + return formatWithArgumentRanges(self._s[2439]!, self._r[2439]!, [_0]) } - public var Channel_AdminLog_EmptyTitle: String { return self._s[2325]! } - public var Privacy_Calls_NeverAllow_Title: String { return self._s[2327]! } - public var Login_UnknownError: String { return self._s[2328]! } - public var Group_UpgradeNoticeText2: String { return self._s[2330]! } - public var Watch_Compose_AddContact: String { return self._s[2331]! } - public var Web_Error: String { return self._s[2332]! } - public var Profile_MessageLifetime1h: String { return self._s[2333]! } - public var CheckoutInfo_ReceiverInfoEmailPlaceholder: String { return self._s[2334]! } - public var Channel_Username_CheckingUsername: String { return self._s[2335]! } + public var Channel_AdminLog_EmptyTitle: String { return self._s[2440]! } + public var Privacy_Calls_NeverAllow_Title: String { return self._s[2442]! } + public var Login_UnknownError: String { return self._s[2443]! } + public var Group_UpgradeNoticeText2: String { return self._s[2445]! } + public var Watch_Compose_AddContact: String { return self._s[2446]! } + public var Web_Error: String { return self._s[2447]! } + public var Profile_MessageLifetime1h: String { return self._s[2448]! } + public var CheckoutInfo_ReceiverInfoEmailPlaceholder: String { return self._s[2449]! } + public var Channel_Username_CheckingUsername: String { return self._s[2450]! } public func PINNED_GAME(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2336]!, self._r[2336]!, [_1]) + return formatWithArgumentRanges(self._s[2451]!, self._r[2451]!, [_1]) } - public var Channel_AboutItem: String { return self._s[2337]! } - public var Privacy_GroupsAndChannels_AlwaysAllow_Placeholder: String { return self._s[2339]! } - public var GroupInfo_SharedMedia: String { return self._s[2340]! } + public var Channel_AboutItem: String { return self._s[2452]! } + public var Privacy_GroupsAndChannels_AlwaysAllow_Placeholder: String { return self._s[2454]! } + public var GroupInfo_SharedMedia: String { return self._s[2455]! } public func Channel_AdminLog_MessagePromotedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2341]!, self._r[2341]!, [_1]) + return formatWithArgumentRanges(self._s[2456]!, self._r[2456]!, [_1]) } - public var Call_PhoneCallInProgressMessage: String { return self._s[2342]! } - public var GroupInfo_InviteLink_RevokeAlert_Text: String { return self._s[2343]! } - public var Conversation_SearchByName_Placeholder: String { return self._s[2344]! } - public var CreatePoll_AddOption: String { return self._s[2345]! } - public var Group_UpgradeNoticeHeader: String { return self._s[2346]! } - public var Channel_Management_AddModerator: String { return self._s[2347]! } - public var StickerPacksSettings_ShowStickersButton: String { return self._s[2348]! } - public var NotificationsSound_Hello: String { return self._s[2349]! } + public var Call_PhoneCallInProgressMessage: String { return self._s[2457]! } + public var GroupInfo_InviteLink_RevokeAlert_Text: String { return self._s[2458]! } + public var Conversation_SearchByName_Placeholder: String { return self._s[2459]! } + public var CreatePoll_AddOption: String { return self._s[2460]! } + public var GroupInfo_Permissions_SearchPlaceholder: String { return self._s[2461]! } + public var Group_UpgradeNoticeHeader: String { return self._s[2462]! } + public var Channel_Management_AddModerator: String { return self._s[2463]! } + public var StickerPacksSettings_ShowStickersButton: String { return self._s[2464]! } + public var NotificationsSound_Hello: String { return self._s[2465]! } public func CHAT_MESSAGE_GEO(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2350]!, self._r[2350]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2466]!, self._r[2466]!, [_1, _2]) } - public var SocksProxySetup_SavedProxies: String { return self._s[2351]! } - public var Channel_Stickers_Placeholder: String { return self._s[2353]! } + public var SocksProxySetup_SavedProxies: String { return self._s[2467]! } + public var Channel_Stickers_Placeholder: String { return self._s[2469]! } public func Login_EmailCodeBody(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2354]!, self._r[2354]!, [_0]) + return formatWithArgumentRanges(self._s[2470]!, self._r[2470]!, [_0]) } - public var PrivacyPolicy_DeclineDeclineAndDelete: String { return self._s[2355]! } - public var Channel_Management_AddModeratorHelp: String { return self._s[2356]! } - public var ContactInfo_BirthdayLabel: String { return self._s[2357]! } - public var ChangePhoneNumberCode_RequestingACall: String { return self._s[2358]! } - public var AutoDownloadSettings_Channels: String { return self._s[2359]! } - public var Passport_Language_mn: String { return self._s[2360]! } - public var Notifications_ResetAllNotificationsHelp: String { return self._s[2363]! } - public var Passport_Language_ja: String { return self._s[2365]! } - public var Settings_About_Title: String { return self._s[2366]! } - public var Settings_NotificationsAndSounds: String { return self._s[2367]! } - public var ChannelInfo_DeleteGroup: String { return self._s[2368]! } - public var Settings_BlockedUsers: String { return self._s[2369]! } + public var PrivacyPolicy_DeclineDeclineAndDelete: String { return self._s[2471]! } + public var Channel_Management_AddModeratorHelp: String { return self._s[2472]! } + public var ContactInfo_BirthdayLabel: String { return self._s[2473]! } + public var ChangePhoneNumberCode_RequestingACall: String { return self._s[2474]! } + public var AutoDownloadSettings_Channels: String { return self._s[2475]! } + public var Passport_Language_mn: String { return self._s[2476]! } + public var Notifications_ResetAllNotificationsHelp: String { return self._s[2479]! } + public var Passport_Language_ja: String { return self._s[2481]! } + public var Settings_About_Title: String { return self._s[2482]! } + public var Settings_NotificationsAndSounds: String { return self._s[2483]! } + public var ChannelInfo_DeleteGroup: String { return self._s[2484]! } + public var Settings_BlockedUsers: String { return self._s[2485]! } public func Time_MonthOfYear_m4(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2370]!, self._r[2370]!, [_0]) + return formatWithArgumentRanges(self._s[2486]!, self._r[2486]!, [_0]) } - public var Passport_Address_AddResidentialAddress: String { return self._s[2371]! } - public var Channel_Username_Title: String { return self._s[2372]! } + public var Passport_Address_AddResidentialAddress: String { return self._s[2487]! } + public var Channel_Username_Title: String { return self._s[2488]! } public func Notification_RemovedGroupPhoto(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2373]!, self._r[2373]!, [_0]) + return formatWithArgumentRanges(self._s[2489]!, self._r[2489]!, [_0]) } - public var AttachmentMenu_File: String { return self._s[2375]! } - public var AppleWatch_Title: String { return self._s[2376]! } - public var Activity_RecordingVideoMessage: String { return self._s[2377]! } - public var Weekday_Saturday: String { return self._s[2378]! } - public var Profile_CreateEncryptedChatError: String { return self._s[2379]! } - public var Common_Next: String { return self._s[2381]! } - public var Channel_Stickers_YourStickers: String { return self._s[2383]! } - public var Call_AudioRouteHeadphones: String { return self._s[2384]! } - public var TwoStepAuth_EnterPasswordForgot: String { return self._s[2386]! } - public var Watch_Contacts_NoResults: String { return self._s[2388]! } - public var PhotoEditor_TintTool: String { return self._s[2390]! } - public var LoginPassword_ResetAccount: String { return self._s[2392]! } - public var Settings_SavedMessages: String { return self._s[2393]! } - public var StickerPack_Add: String { return self._s[2394]! } - public var Your_cards_number_is_invalid: String { return self._s[2395]! } - public var Checkout_TotalAmount: String { return self._s[2396]! } + public var AttachmentMenu_File: String { return self._s[2491]! } + public var AppleWatch_Title: String { return self._s[2492]! } + public var Activity_RecordingVideoMessage: String { return self._s[2493]! } + public var Weekday_Saturday: String { return self._s[2494]! } + public var Profile_CreateEncryptedChatError: String { return self._s[2495]! } + public var Common_Next: String { return self._s[2497]! } + public var Channel_Stickers_YourStickers: String { return self._s[2499]! } + public var Call_AudioRouteHeadphones: String { return self._s[2500]! } + public var TwoStepAuth_EnterPasswordForgot: String { return self._s[2502]! } + public var Watch_Contacts_NoResults: String { return self._s[2504]! } + public var PhotoEditor_TintTool: String { return self._s[2506]! } + public var LoginPassword_ResetAccount: String { return self._s[2508]! } + public var Settings_SavedMessages: String { return self._s[2509]! } + public func MESSAGE_GIF_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2510]!, self._r[2510]!, [_1]) + } + public var StickerPack_Add: String { return self._s[2511]! } + public var Your_cards_number_is_invalid: String { return self._s[2512]! } + public var Checkout_TotalAmount: String { return self._s[2513]! } public func ChangePhoneNumberCode_CallTimer(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2397]!, self._r[2397]!, [_0]) + return formatWithArgumentRanges(self._s[2514]!, self._r[2514]!, [_0]) } - public var ChatSettings_ConnectionType_UseSocks5: String { return self._s[2398]! } + public func GroupPermission_AddedInfo(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2515]!, self._r[2515]!, [_1, _2]) + } + public var ChatSettings_ConnectionType_UseSocks5: String { return self._s[2516]! } public func CHANNEL_MESSAGE_STICKER(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2400]!, self._r[2400]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2518]!, self._r[2518]!, [_1, _2]) } public func Conversation_RestrictedTextTimed(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2401]!, self._r[2401]!, [_0]) - } - public var GroupInfo_InviteLink_ShareLink: String { return self._s[2402]! } - public var StickerPack_Share: String { return self._s[2403]! } - public var Passport_DeleteAddress: String { return self._s[2404]! } - public var Settings_Passport: String { return self._s[2405]! } - public var SharedMedia_EmptyFilesText: String { return self._s[2406]! } - public var Conversation_DeleteMessagesForMe: String { return self._s[2407]! } - public var PasscodeSettings_AutoLock_IfAwayFor_1hour: String { return self._s[2408]! } - public var Contacts_PermissionsText: String { return self._s[2409]! } - public var Group_Setup_HistoryVisible: String { return self._s[2410]! } - public var Passport_Address_AddRentalAgreement: String { return self._s[2412]! } - public var SocksProxySetup_Title: String { return self._s[2413]! } - public var Notification_Mute1h: String { return self._s[2414]! } - public func Passport_Email_CodeHelp(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2415]!, self._r[2415]!, [_0]) - } - public var FastTwoStepSetup_PasswordSection: String { return self._s[2416]! } - public var NetworkUsageSettings_ResetStatsConfirmation: String { return self._s[2419]! } - public var InfoPlist_NSFaceIDUsageDescription: String { return self._s[2421]! } - public var DialogList_NoMessagesText: String { return self._s[2422]! } - public var Privacy_ContactsResetConfirmation: String { return self._s[2423]! } - public var Privacy_Calls_P2PHelp: String { return self._s[2424]! } - public var Your_cards_expiration_year_is_invalid: String { return self._s[2426]! } - public var Common_TakePhotoOrVideo: String { return self._s[2427]! } - public var Call_StatusBusy: String { return self._s[2428]! } - public var Conversation_PinnedMessage: String { return self._s[2429]! } - public var AutoDownloadSettings_VoiceMessagesTitle: String { return self._s[2430]! } - public var TwoStepAuth_SetupPasswordConfirmFailed: String { return self._s[2431]! } - public var AppleWatch_ReplyPresets: String { return self._s[2432]! } - public var Passport_DiscardMessageDescription: String { return self._s[2434]! } - public var Login_NetworkError: String { return self._s[2435]! } - public func Notification_PinnedRoundMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2436]!, self._r[2436]!, [_0]) - } - public func Channel_AdminLog_MessageRemovedChannelUsername(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2437]!, self._r[2437]!, [_0]) - } - public var SocksProxySetup_PasswordPlaceholder: String { return self._s[2438]! } - public func CONTACT_JOINED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2440]!, self._r[2440]!, [_1]) - } - public var Login_ResetAccountProtected_LimitExceeded: String { return self._s[2441]! } - public func Watch_LastSeen_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2443]!, self._r[2443]!, [_0]) - } - public var Call_ConnectionErrorMessage: String { return self._s[2444]! } - public var Compose_GroupTokenListPlaceholder: String { return self._s[2446]! } - public var ConversationMedia_Title: String { return self._s[2447]! } - public var EncryptionKey_Title: String { return self._s[2449]! } - public var TwoStepAuth_EnterPasswordTitle: String { return self._s[2450]! } - public var Notification_Exceptions_AddException: String { return self._s[2451]! } - public var Profile_MessageLifetime1m: String { return self._s[2452]! } - public func Channel_AdminLog_MessageUnkickedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2453]!, self._r[2453]!, [_1]) - } - public var Month_GenMay: String { return self._s[2454]! } - public func LiveLocationUpdated_TodayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2455]!, self._r[2455]!, [_0]) - } - public var ChannelMembers_WhoCanAddMembersAllHelp: String { return self._s[2456]! } - public var Conversation_EmptyPlaceholder: String { return self._s[2458]! } - public var Passport_Address_AddPassportRegistration: String { return self._s[2459]! } - public var Notifications_ChannelNotificationsAlert: String { return self._s[2460]! } - public var Camera_TapAndHoldForVideo: String { return self._s[2461]! } - public var Channel_JoinChannel: String { return self._s[2463]! } - public var Appearance_Animations: String { return self._s[2466]! } - public func Notification_MessageLifetimeChanged(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2467]!, self._r[2467]!, [_1, _2]) - } - public var Stickers_GroupStickers: String { return self._s[2469]! } - public var ConvertToSupergroup_HelpTitle: String { return self._s[2471]! } - public var Passport_Address_Street: String { return self._s[2472]! } - public var Conversation_AddContact: String { return self._s[2473]! } - public var Login_PhonePlaceholder: String { return self._s[2474]! } - public var Channel_Members_InviteLink: String { return self._s[2476]! } - public var Bot_Stop: String { return self._s[2477]! } - public var Notification_PassportValueAddress: String { return self._s[2479]! } - public var Month_ShortJuly: String { return self._s[2480]! } - public var Passport_Address_TypeTemporaryRegistrationUploadScan: String { return self._s[2481]! } - public var Channel_AdminLog_BanSendMedia: String { return self._s[2482]! } - public var Passport_Identity_ReverseSide: String { return self._s[2483]! } - public var Watch_Stickers_Recents: String { return self._s[2486]! } - public var PrivacyLastSeenSettings_EmpryUsersPlaceholder: String { return self._s[2488]! } - public var Map_SendThisLocation: String { return self._s[2489]! } - public func Time_MonthOfYear_m1(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2490]!, self._r[2490]!, [_0]) - } - public func InviteText_SingleContact(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2491]!, self._r[2491]!, [_0]) - } - public var ConvertToSupergroup_Note: String { return self._s[2492]! } - public func FileSize_MB(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2493]!, self._r[2493]!, [_0]) - } - public var NetworkUsageSettings_GeneralDataSection: String { return self._s[2494]! } - public func Compatibility_SecretMediaVersionTooLow(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2495]!, self._r[2495]!, [_0, _1]) - } - public var Login_CallRequestState3: String { return self._s[2497]! } - public func CHANNEL_MESSAGE_GEO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2499]!, self._r[2499]!, [_1]) - } - public var PasscodeSettings_UnlockWithFaceId: String { return self._s[2500]! } - public var Channel_AdminLogFilter_Title: String { return self._s[2501]! } - public var Notifications_GroupNotificationsExceptions: String { return self._s[2505]! } - public func FileSize_B(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2506]!, self._r[2506]!, [_0]) - } - public var Passport_CorrectErrors: String { return self._s[2507]! } - public func Channel_MessageTitleUpdated(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2508]!, self._r[2508]!, [_0]) - } - public var Map_SendMyCurrentLocation: String { return self._s[2509]! } - public var SharedMedia_SearchNoResults: String { return self._s[2510]! } - public var Permissions_NotificationsText_v0: String { return self._s[2511]! } - public var LoginPassword_FloodError: String { return self._s[2512]! } - public var Group_Setup_HistoryHiddenHelp: String { return self._s[2514]! } - public func TwoStepAuth_PendingEmailHelp(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2515]!, self._r[2515]!, [_0]) - } - public var Passport_Language_bn: String { return self._s[2516]! } - public func DialogList_SingleUploadingPhotoSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2517]!, self._r[2517]!, [_0]) - } - public func Notification_PinnedAudioMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2518]!, self._r[2518]!, [_0]) - } - public func Channel_AdminLog_MessageChangedGroupStickerPack(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2519]!, self._r[2519]!, [_0]) } - public var GroupInfo_InvitationLinkGroupFull: String { return self._s[2522]! } - public var Group_EditAdmin_PermissionChangeInfo: String { return self._s[2524]! } - public var Contacts_PermissionsAllow: String { return self._s[2525]! } - public var ReportPeer_ReasonCopyright: String { return self._s[2526]! } - public var Channel_EditAdmin_PermissinAddAdminOn: String { return self._s[2527]! } - public var Paint_Duplicate: String { return self._s[2528]! } - public var Notification_ChannelMigratedFrom: String { return self._s[2529]! } - public var Passport_Address_Country: String { return self._s[2530]! } - public var Notification_RenamedChannel: String { return self._s[2532]! } - public var CheckoutInfo_ErrorPostcodeInvalid: String { return self._s[2533]! } - public var Group_MessagePhotoUpdated: String { return self._s[2534]! } - public var Channel_BanUser_PermissionSendMedia: String { return self._s[2535]! } - public var Conversation_ContextMenuBan: String { return self._s[2536]! } - public var TwoStepAuth_EmailSent: String { return self._s[2537]! } - public var MessagePoll_NoVotes: String { return self._s[2538]! } - public var Passport_Language_is: String { return self._s[2539]! } - public var Tour_Text5: String { return self._s[2541]! } - public func Call_GroupFormat(_ _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[2520]! } + public var StickerPack_Share: String { return self._s[2521]! } + public var Passport_DeleteAddress: String { return self._s[2522]! } + public var Settings_Passport: String { return self._s[2523]! } + public var SharedMedia_EmptyFilesText: String { return self._s[2524]! } + public var Conversation_DeleteMessagesForMe: String { return self._s[2525]! } + public var PasscodeSettings_AutoLock_IfAwayFor_1hour: String { return self._s[2526]! } + public var Contacts_PermissionsText: String { return self._s[2527]! } + public var Group_Setup_HistoryVisible: String { return self._s[2528]! } + public var Passport_Address_AddRentalAgreement: String { return self._s[2530]! } + public var SocksProxySetup_Title: String { return self._s[2531]! } + public var Notification_Mute1h: String { return self._s[2532]! } + public func Passport_Email_CodeHelp(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2533]!, self._r[2533]!, [_0]) } - public var Paint_Edit: String { return self._s[2545]! } - public var LoginPassword_ForgotPassword: String { return self._s[2548]! } - public var GroupInfo_GroupNamePlaceholder: String { return self._s[2549]! } - public func Notification_Kicked(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2550]!, self._r[2550]!, [_0, _1]) + public func PINNED_CONTACT_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2534]!, self._r[2534]!, [_1]) } - public var Conversation_InputTextCaptionPlaceholder: String { return self._s[2551]! } - public var AutoDownloadSettings_VideoMessagesTitle: String { return self._s[2552]! } - public var Passport_Language_uz: String { return self._s[2553]! } - public var Conversation_PinMessageAlertGroup: String { return self._s[2554]! } - public var Map_StopLiveLocation: String { return self._s[2556]! } - public var PasscodeSettings_Help: String { return self._s[2558]! } - public var NotificationsSound_Input: String { return self._s[2559]! } - public var Share_Title: String { return self._s[2561]! } - public var Login_TermsOfServiceAgree: String { return self._s[2562]! } - public var Compose_NewEncryptedChatTitle: String { return self._s[2563]! } - public var Channel_AdminLog_TitleSelectedEvents: String { return self._s[2564]! } - public var Channel_EditAdmin_PermissionEditMessages: String { return self._s[2565]! } - public var EnterPasscode_EnterTitle: String { return self._s[2566]! } - public func Call_PrivacyErrorMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2567]!, self._r[2567]!, [_0]) + public var FastTwoStepSetup_PasswordSection: String { return self._s[2535]! } + public var NetworkUsageSettings_ResetStatsConfirmation: String { return self._s[2538]! } + public var InfoPlist_NSFaceIDUsageDescription: String { return self._s[2540]! } + public var DialogList_NoMessagesText: String { return self._s[2541]! } + public var Privacy_ContactsResetConfirmation: String { return self._s[2542]! } + public var Privacy_Calls_P2PHelp: String { return self._s[2543]! } + public var Your_cards_expiration_year_is_invalid: String { return self._s[2545]! } + public var Common_TakePhotoOrVideo: String { return self._s[2546]! } + public var Call_StatusBusy: String { return self._s[2547]! } + public var Conversation_PinnedMessage: String { return self._s[2548]! } + public var AutoDownloadSettings_VoiceMessagesTitle: String { return self._s[2549]! } + public var TwoStepAuth_SetupPasswordConfirmFailed: String { return self._s[2550]! } + public var AppleWatch_ReplyPresets: String { return self._s[2551]! } + public var Passport_DiscardMessageDescription: String { return self._s[2553]! } + public var Login_NetworkError: String { return self._s[2554]! } + public func Notification_PinnedRoundMessage(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2555]!, self._r[2555]!, [_0]) } - public var Settings_CopyPhoneNumber: String { return self._s[2568]! } - public var NotificationsSound_Keys: String { return self._s[2569]! } - public func Call_ParticipantVersionOutdatedError(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2570]!, self._r[2570]!, [_0]) + public func Channel_AdminLog_MessageRemovedChannelUsername(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2556]!, self._r[2556]!, [_0]) } - public var Notification_MessageLifetime1w: String { return self._s[2571]! } - public var Message_Video: String { return self._s[2572]! } - public func Notification_JoinedChat(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2575]!, self._r[2575]!, [_0]) + public var SocksProxySetup_PasswordPlaceholder: String { return self._s[2557]! } + public func CONTACT_JOINED(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2559]!, self._r[2559]!, [_1]) } - public func PrivacySettings_LastSeenContactsPlus(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2576]!, self._r[2576]!, [_0]) + public var Login_ResetAccountProtected_LimitExceeded: String { return self._s[2560]! } + public func Watch_LastSeen_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2562]!, self._r[2562]!, [_0]) } - public var Passport_Language_mk: String { return self._s[2577]! } - public var CreatePoll_CancelConfirmation: String { return self._s[2578]! } - public var Conversation_SilentBroadcastTooltipOn: String { return self._s[2580]! } - public var PrivacyPolicy_Decline: String { return self._s[2581]! } - public var Passport_Identity_DoesNotExpire: String { return self._s[2582]! } - public var Channel_AdminLogFilter_EventsRestrictions: String { return self._s[2583]! } - public var Permissions_SiriAllow_v0: String { return self._s[2584]! } - public func CHAT_MESSAGE_STICKER(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2585]!, self._r[2585]!, [_1, _2, _3]) + public var Call_ConnectionErrorMessage: String { return self._s[2563]! } + public var Compose_GroupTokenListPlaceholder: String { return self._s[2565]! } + public var ConversationMedia_Title: String { return self._s[2566]! } + public var EncryptionKey_Title: String { return self._s[2568]! } + public var TwoStepAuth_EnterPasswordTitle: String { return self._s[2569]! } + public var Notification_Exceptions_AddException: String { return self._s[2570]! } + public var Profile_MessageLifetime1m: String { return self._s[2571]! } + public func Channel_AdminLog_MessageUnkickedName(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2572]!, self._r[2572]!, [_1]) } - public func CHANNEL_MESSAGES(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + public var Month_GenMay: String { return self._s[2573]! } + public func LiveLocationUpdated_TodayAt(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2574]!, self._r[2574]!, [_0]) + } + public var ChannelMembers_WhoCanAddMembersAllHelp: String { return self._s[2575]! } + public var Conversation_EmptyPlaceholder: String { return self._s[2577]! } + public var Passport_Address_AddPassportRegistration: String { return self._s[2578]! } + public var Notifications_ChannelNotificationsAlert: String { return self._s[2579]! } + public var Camera_TapAndHoldForVideo: String { return self._s[2580]! } + public var Channel_JoinChannel: String { return self._s[2582]! } + public var Appearance_Animations: String { return self._s[2585]! } + public func Notification_MessageLifetimeChanged(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2586]!, self._r[2586]!, [_1, _2]) } + public var Stickers_GroupStickers: String { return self._s[2588]! } + public var ConvertToSupergroup_HelpTitle: String { return self._s[2590]! } + public var Passport_Address_Street: String { return self._s[2591]! } + public var Conversation_AddContact: String { return self._s[2592]! } + public var Login_PhonePlaceholder: String { return self._s[2593]! } + public var Channel_Members_InviteLink: String { return self._s[2595]! } + public var Bot_Stop: String { return self._s[2596]! } + public var Notification_PassportValueAddress: String { return self._s[2598]! } + public var Month_ShortJuly: String { return self._s[2599]! } + public var Passport_Address_TypeTemporaryRegistrationUploadScan: String { return self._s[2600]! } + public var Channel_AdminLog_BanSendMedia: String { return self._s[2601]! } + public var Passport_Identity_ReverseSide: String { return self._s[2602]! } + public var Watch_Stickers_Recents: String { return self._s[2605]! } + public var PrivacyLastSeenSettings_EmpryUsersPlaceholder: String { return self._s[2607]! } + public var Map_SendThisLocation: String { return self._s[2608]! } + public func Time_MonthOfYear_m1(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2609]!, self._r[2609]!, [_0]) + } + public func CHANNEL_MESSAGE_STICKER_SEPARATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2610]!, self._r[2610]!, [_1, _2]) + } + public func InviteText_SingleContact(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2611]!, self._r[2611]!, [_0]) + } + public var ConvertToSupergroup_Note: String { return self._s[2612]! } + public func FileSize_MB(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2613]!, self._r[2613]!, [_0]) + } + public var NetworkUsageSettings_GeneralDataSection: String { return self._s[2614]! } + public func PINNED_POLL_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2615]!, self._r[2615]!, [_1]) + } + public func Compatibility_SecretMediaVersionTooLow(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2616]!, self._r[2616]!, [_0, _1]) + } + public var Login_CallRequestState3: String { return self._s[2617]! } + public func CHANNEL_MESSAGE_GEO(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2620]!, self._r[2620]!, [_1]) + } + public var PasscodeSettings_UnlockWithFaceId: String { return self._s[2621]! } + public var Channel_AdminLogFilter_Title: String { return self._s[2622]! } + public var Notifications_GroupNotificationsExceptions: String { return self._s[2626]! } + public func FileSize_B(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2627]!, self._r[2627]!, [_0]) + } + public var Passport_CorrectErrors: String { return self._s[2628]! } + public func Channel_MessageTitleUpdated(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2629]!, self._r[2629]!, [_0]) + } + public var Map_SendMyCurrentLocation: String { return self._s[2630]! } + public var SharedMedia_SearchNoResults: String { return self._s[2631]! } + public var Permissions_NotificationsText_v0: String { return self._s[2632]! } + public var LoginPassword_FloodError: String { return self._s[2633]! } + public var Group_Setup_HistoryHiddenHelp: String { return self._s[2635]! } + public func TwoStepAuth_PendingEmailHelp(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2636]!, self._r[2636]!, [_0]) + } + public var Passport_Language_bn: String { return self._s[2637]! } + public func DialogList_SingleUploadingPhotoSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2638]!, self._r[2638]!, [_0]) + } + public func Notification_PinnedAudioMessage(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2639]!, self._r[2639]!, [_0]) + } + public func Channel_AdminLog_MessageChangedGroupStickerPack(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2640]!, self._r[2640]!, [_0]) + } + public var GroupInfo_InvitationLinkGroupFull: String { return self._s[2643]! } + public var Group_EditAdmin_PermissionChangeInfo: String { return self._s[2645]! } + public var Contacts_PermissionsAllow: String { return self._s[2646]! } + public var ReportPeer_ReasonCopyright: String { return self._s[2647]! } + public var Channel_EditAdmin_PermissinAddAdminOn: String { return self._s[2648]! } + public var Paint_Duplicate: String { return self._s[2649]! } + public var Notification_ChannelMigratedFrom: String { return self._s[2650]! } + public var Passport_Address_Country: String { return self._s[2651]! } + public var Notification_RenamedChannel: String { return self._s[2653]! } + public var CheckoutInfo_ErrorPostcodeInvalid: String { return self._s[2654]! } + public var Group_MessagePhotoUpdated: String { return self._s[2655]! } + public var Channel_BanUser_PermissionSendMedia: String { return self._s[2656]! } + public var Conversation_ContextMenuBan: String { return self._s[2657]! } + public var TwoStepAuth_EmailSent: String { return self._s[2658]! } + public var MessagePoll_NoVotes: String { return self._s[2659]! } + public var Passport_Language_is: String { return self._s[2660]! } + public var Tour_Text5: String { return self._s[2662]! } + public func Call_GroupFormat(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2664]!, self._r[2664]!, [_1, _2]) + } + public var Paint_Edit: String { return self._s[2666]! } + public var LoginPassword_ForgotPassword: String { return self._s[2669]! } + public var GroupInfo_GroupNamePlaceholder: String { return self._s[2670]! } + public func Notification_Kicked(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2671]!, self._r[2671]!, [_0, _1]) + } + public var Conversation_InputTextCaptionPlaceholder: String { return self._s[2672]! } + public var AutoDownloadSettings_VideoMessagesTitle: String { return self._s[2673]! } + public var Conversation_PinMessageAlertGroup: String { return self._s[2674]! } + public var Passport_Language_uz: String { return self._s[2675]! } + public var Map_StopLiveLocation: String { return self._s[2677]! } + public var PasscodeSettings_Help: String { return self._s[2679]! } + public var NotificationsSound_Input: String { return self._s[2680]! } + public var Share_Title: String { return self._s[2682]! } + public var Login_TermsOfServiceAgree: String { return self._s[2683]! } + public var Compose_NewEncryptedChatTitle: String { return self._s[2684]! } + public var Channel_AdminLog_TitleSelectedEvents: String { return self._s[2685]! } + public var Channel_EditAdmin_PermissionEditMessages: String { return self._s[2686]! } + public var EnterPasscode_EnterTitle: String { return self._s[2687]! } + public func Call_PrivacyErrorMessage(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2688]!, self._r[2688]!, [_0]) + } + public var Settings_CopyPhoneNumber: String { return self._s[2689]! } + public var NotificationsSound_Keys: String { return self._s[2690]! } + public func Call_ParticipantVersionOutdatedError(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2691]!, self._r[2691]!, [_0]) + } + public var Notification_MessageLifetime1w: String { return self._s[2692]! } + public var Message_Video: String { return self._s[2693]! } + public func MESSAGE_GEO_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2696]!, self._r[2696]!, [_1]) + } + public func Notification_JoinedChat(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2697]!, self._r[2697]!, [_0]) + } + public func PrivacySettings_LastSeenContactsPlus(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2698]!, self._r[2698]!, [_0]) + } + public var Passport_Language_mk: String { return self._s[2699]! } + public var CreatePoll_CancelConfirmation: String { return self._s[2700]! } + public var Conversation_SilentBroadcastTooltipOn: String { return self._s[2702]! } + public var PrivacyPolicy_Decline: String { return self._s[2703]! } + public var Passport_Identity_DoesNotExpire: String { return self._s[2704]! } + public var Channel_AdminLogFilter_EventsRestrictions: String { return self._s[2705]! } + public var Permissions_SiriAllow_v0: String { return self._s[2706]! } + public func CHAT_MESSAGE_STICKER(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2707]!, self._r[2707]!, [_1, _2, _3]) + } + public func CHANNEL_MESSAGES(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2708]!, self._r[2708]!, [_1, _2]) + } public func Notification_RenamedChat(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2587]!, self._r[2587]!, [_0]) + return formatWithArgumentRanges(self._s[2709]!, self._r[2709]!, [_0]) } - public var Paint_Regular: String { return self._s[2588]! } - public var ChatSettings_AutoDownloadReset: String { return self._s[2589]! } - public var BlockedUsers_SelectUserTitle: String { return self._s[2590]! } - public var GroupInfo_InviteByLink: String { return self._s[2592]! } - public var MessageTimer_Custom: String { return self._s[2593]! } - public var UserInfo_NotificationsDefaultEnabled: String { return self._s[2594]! } - public var Passport_Address_TypeTemporaryRegistration: String { return self._s[2596]! } - public var Channel_Username_InvalidTaken: String { return self._s[2597]! } - public var Conversation_ClousStorageInfo_Description3: String { return self._s[2598]! } + public var Paint_Regular: String { return self._s[2710]! } + public var ChatSettings_AutoDownloadReset: String { return self._s[2711]! } + public var BlockedUsers_SelectUserTitle: String { return self._s[2712]! } + public var GroupInfo_InviteByLink: String { return self._s[2714]! } + public var MessageTimer_Custom: String { return self._s[2715]! } + public var UserInfo_NotificationsDefaultEnabled: String { return self._s[2716]! } + public var Passport_Address_TypeTemporaryRegistration: String { return self._s[2718]! } + public var Channel_Username_InvalidTaken: String { return self._s[2719]! } + public var Conversation_ClousStorageInfo_Description3: String { return self._s[2720]! } public func CHANNEL_MESSAGE_VIDEO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2599]!, self._r[2599]!, [_1]) + return formatWithArgumentRanges(self._s[2721]!, self._r[2721]!, [_1]) + } + public var Settings_ChatBackground: String { return self._s[2722]! } + public var Channel_Subscribers_Title: String { return self._s[2723]! } + public var ApplyLanguage_ChangeLanguageTitle: String { return self._s[2724]! } + public var Watch_ConnectionDescription: String { return self._s[2725]! } + public func PINNED_VIDEO_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2729]!, self._r[2729]!, [_1]) + } + public var EditProfile_Title: String { return self._s[2730]! } + public var NotificationsSound_Bamboo: String { return self._s[2732]! } + public var Channel_AdminLog_MessagePreviousMessage: String { return self._s[2734]! } + public var Login_SmsRequestState2: String { return self._s[2735]! } + public var Passport_Language_ar: String { return self._s[2736]! } + public var Conversation_MessageDialogEdit: String { return self._s[2737]! } + public var Common_Close: String { return self._s[2738]! } + public func CHAT_MESSAGE_TEXT_SEPARATED(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2742]!, self._r[2742]!, [_1, _2, _3]) } - public var Settings_ChatBackground: String { return self._s[2600]! } - public var Channel_Subscribers_Title: String { return self._s[2601]! } - public var ApplyLanguage_ChangeLanguageTitle: String { return self._s[2602]! } - public var Watch_ConnectionDescription: String { return self._s[2603]! } - public var EditProfile_Title: String { return self._s[2607]! } - public var NotificationsSound_Bamboo: String { return self._s[2609]! } - public var Channel_AdminLog_MessagePreviousMessage: String { return self._s[2611]! } - public var Login_SmsRequestState2: String { return self._s[2612]! } - public var Passport_Language_ar: String { return self._s[2613]! } - public var Conversation_MessageDialogEdit: String { return self._s[2614]! } - public var Common_Close: String { return self._s[2615]! } public func Channel_AdminLog_MessageToggleInvitesOff(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2619]!, self._r[2619]!, [_0]) - } - public var UserInfo_About_Placeholder: String { return self._s[2620]! } - public func Conversation_FileHowToText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2621]!, self._r[2621]!, [_0]) - } - public var Channel_Info_Banned: String { return self._s[2623]! } - public func Time_MonthOfYear_m11(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2624]!, self._r[2624]!, [_0]) - } - public var Passport_Language_my: String { return self._s[2625]! } - public func Time_PreciseDate_m9(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2626]!, self._r[2626]!, [_1, _2, _3]) - } - public var Preview_CopyAddress: String { return self._s[2627]! } - public func DialogList_SinglePlayingGameSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2628]!, self._r[2628]!, [_0]) - } - public var KeyCommand_JumpToPreviousChat: String { return self._s[2629]! } - public var UserInfo_BotSettings: String { return self._s[2630]! } - public var LiveLocation_MenuStopAll: String { return self._s[2632]! } - public var Passport_PasswordCreate: String { return self._s[2633]! } - public var StickerSettings_MaskContextInfo: String { return self._s[2634]! } - public var Message_PinnedLocationMessage: String { return self._s[2635]! } - public var Map_Satellite: String { return self._s[2636]! } - public var Username_TooManyPublicUsernamesError: String { return self._s[2637]! } - public var TwoStepAuth_EnterPasswordInvalid: String { return self._s[2638]! } - public func Notification_PinnedTextMessage(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2639]!, self._r[2639]!, [_0, _1]) - } - public var Notifications_ChannelNotificationsHelp: String { return self._s[2640]! } - public var Privacy_Calls_P2PContacts: String { return self._s[2641]! } - public var NotificationsSound_None: String { return self._s[2642]! } - public var AccessDenied_VoiceMicrophone: String { return self._s[2644]! } - public func ApplyLanguage_ChangeLanguageAlreadyActive(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2645]!, self._r[2645]!, [_1]) - } - public var Cache_Indexing: String { return self._s[2646]! } - public var DialogList_RecentTitlePeople: String { return self._s[2648]! } - public var DialogList_EncryptionRejected: String { return self._s[2649]! } - public var Passport_ScanPassportHelp: String { return self._s[2650]! } - public var Application_Name: String { return self._s[2651]! } - public var Channel_AdminLogFilter_ChannelEventsInfo: String { return self._s[2652]! } - public var Passport_Identity_TranslationHelp: String { return self._s[2654]! } - public func Notification_JoinedGroupByLink(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2655]!, self._r[2655]!, [_0]) - } - public func DialogList_EncryptedChatStartedOutgoing(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2656]!, self._r[2656]!, [_0]) - } - public var Channel_EditAdmin_PermissionDeleteMessages: String { return self._s[2657]! } - public var Privacy_ChatsTitle: String { return self._s[2658]! } - public var DialogList_ClearHistoryConfirmation: String { return self._s[2659]! } - public var Watch_Suggestion_HoldOn: String { return self._s[2660]! } - public var SocksProxySetup_RequiredCredentials: String { return self._s[2661]! } - public var Passport_Address_TypeRentalAgreementUploadScan: String { return self._s[2662]! } - public var TwoStepAuth_EmailSkipAlert: String { return self._s[2663]! } - public var Channel_Setup_TypePublic: String { return self._s[2666]! } - public func Channel_AdminLog_MessageToggleInvitesOn(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2667]!, self._r[2667]!, [_0]) - } - public var Channel_TypeSetup_Title: String { return self._s[2669]! } - public var Map_OpenInMaps: String { return self._s[2671]! } - public var NotificationsSound_Tremolo: String { return self._s[2673]! } - public func Date_ChatDateHeaderYear(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2674]!, self._r[2674]!, [_1, _2, _3]) - } - public var ConversationProfile_UnknownAddMemberError: String { return self._s[2675]! } - public var Passport_PasswordHelp: String { return self._s[2676]! } - public var Login_CodeExpiredError: String { return self._s[2677]! } - public var Channel_EditAdmin_PermissionChangeInfo: String { return self._s[2678]! } - public var Conversation_TitleUnmute: String { return self._s[2679]! } - public var Passport_Identity_ScansHelp: String { return self._s[2680]! } - public var Passport_Language_lo: String { return self._s[2681]! } - public var Camera_FlashAuto: String { return self._s[2682]! } - public var Common_Cancel: String { return self._s[2683]! } - public var DialogList_SavedMessagesTooltip: String { return self._s[2684]! } - public var TwoStepAuth_SetupPasswordTitle: String { return self._s[2685]! } - public var Conversation_ReportSpamConfirmation: String { return self._s[2686]! } - public var ChatSettings_Title: String { return self._s[2688]! } - public var Passport_PasswordReset: String { return self._s[2689]! } - public var SocksProxySetup_TypeNone: String { return self._s[2690]! } - public var PhoneNumberHelp_Help: String { return self._s[2692]! } - public var Checkout_EnterPassword: String { return self._s[2693]! } - public var Share_AuthTitle: String { return self._s[2695]! } - public var Activity_UploadingDocument: String { return self._s[2696]! } - public var State_Connecting: String { return self._s[2697]! } - public var Profile_MessageLifetime1w: String { return self._s[2698]! } - public var Conversation_ContextMenuReport: String { return self._s[2699]! } - public var CheckoutInfo_ReceiverInfoPhone: String { return self._s[2700]! } - public var AutoNightTheme_ScheduledTo: String { return self._s[2701]! } - public var AuthSessions_Terminate: String { return self._s[2702]! } - public var Checkout_NewCard_CardholderNamePlaceholder: String { return self._s[2703]! } - public var KeyCommand_JumpToPreviousUnreadChat: String { return self._s[2704]! } - public var PhotoEditor_Set: String { return self._s[2705]! } - public var Login_PadPhoneHelp: String { return self._s[2706]! } - public var PrivacyPolicy_DeclineLastWarning: String { return self._s[2709]! } - public var NotificationsSound_Complete: String { return self._s[2710]! } - public var Group_Info_AdminLog: String { return self._s[2711]! } - public var Channel_AdminLog_InfoPanelAlertText: String { return self._s[2712]! } - public var Conversation_Admin: String { return self._s[2714]! } - public var Conversation_GifTooltip: String { return self._s[2715]! } - public var Passport_NotLoggedInMessage: String { return self._s[2716]! } - public var Profile_MessageLifetimeForever: String { return self._s[2717]! } - public var SharedMedia_EmptyTitle: String { return self._s[2719]! } - public var Channel_Edit_PrivatePublicLinkAlert: String { return self._s[2720]! } - public var Username_Help: String { return self._s[2721]! } - public var DialogList_LanguageTooltip: String { return self._s[2723]! } - public var Map_LoadError: String { return self._s[2724]! } - public var Notification_Exceptions_NewException: String { return self._s[2725]! } - public var TwoStepAuth_EmailTitle: String { return self._s[2726]! } - public var WatchRemote_AlertText: String { return self._s[2727]! } - public var ChatSettings_ConnectionType_Title: String { return self._s[2729]! } - public func LOCKED_MESSAGE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2730]!, self._r[2730]!, [_1]) - } - public var Passport_Address_CountryPlaceholder: String { return self._s[2731]! } - public func DialogList_AwaitingEncryption(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2732]!, self._r[2732]!, [_0]) - } - public func Time_PreciseDate_m6(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2733]!, self._r[2733]!, [_1, _2, _3]) - } - public var Group_AdminLog_EmptyText: String { return self._s[2734]! } - public var AccessDenied_VideoMicrophone: String { return self._s[2736]! } - public var Conversation_ContextMenuStickerPackAdd: String { return self._s[2737]! } - public var Cache_ClearNone: String { return self._s[2738]! } - public var SocksProxySetup_FailedToConnect: String { return self._s[2739]! } - public var Permissions_NotificationsTitle_v0: String { return self._s[2740]! } - public func Channel_AdminLog_MessageEdited(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2741]!, self._r[2741]!, [_0]) - } - public var Passport_Identity_Country: String { return self._s[2742]! } - public func Notification_CreatedChat(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2743]!, self._r[2743]!, [_0]) } - public var AccessDenied_Settings: String { return self._s[2744]! } - public var Passport_Address_TypeUtilityBillUploadScan: String { return self._s[2745]! } - public var Month_ShortMay: String { return self._s[2746]! } - public var Compose_NewGroup: String { return self._s[2747]! } - public var Group_Setup_TypePrivate: String { return self._s[2749]! } - public var Login_PadPhoneHelpTitle: String { return self._s[2750]! } - public var Appearance_ThemeDayClassic: String { return self._s[2751]! } - public var Channel_AdminLog_MessagePreviousCaption: String { return self._s[2752]! } - public var Privacy_GroupsAndChannels_WhoCanAddMe: String { return self._s[2753]! } - public var Conversation_typing: String { return self._s[2755]! } - public var Paint_Masks: String { return self._s[2756]! } - public var Username_InvalidTaken: String { return self._s[2757]! } - public var TwoStepAuth_EmailAddSuccess: String { return self._s[2758]! } - public func CHAT_PHOTO_EDITED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2759]!, self._r[2759]!, [_1, _2]) + public var UserInfo_About_Placeholder: String { return self._s[2744]! } + public func Conversation_FileHowToText(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2745]!, self._r[2745]!, [_0]) } - public var Call_StatusNoAnswer: String { return self._s[2760]! } - public var Passport_Identity_Selfie: String { return self._s[2761]! } - public var Login_InfoLastNamePlaceholder: String { return self._s[2762]! } - public var Privacy_SecretChatsLinkPreviewsHelp: String { return self._s[2763]! } - public var Conversation_ClearSecretHistory: String { return self._s[2764]! } - public var NetworkUsageSettings_Title: String { return self._s[2766]! } - public var Your_cards_security_code_is_invalid: String { return self._s[2768]! } - public func Notification_LeftChannel(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2770]!, self._r[2770]!, [_0]) + public var GroupInfo_Permissions_SectionTitle: String { return self._s[2746]! } + public var Channel_Info_Banned: String { return self._s[2748]! } + public func Time_MonthOfYear_m11(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2749]!, self._r[2749]!, [_0]) } - public func Call_CallInProgressMessage(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2771]!, self._r[2771]!, [_1, _2]) + public var Passport_Language_my: String { return self._s[2750]! } + public func CHAT_MESSAGE_GEO_SEPARATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2751]!, self._r[2751]!, [_1, _2]) } - public var SaveIncomingPhotosSettings_From: String { return self._s[2773]! } - public var Map_LiveLocationTitle: String { return self._s[2774]! } - public var Login_InfoAvatarAdd: String { return self._s[2775]! } - public var Passport_Identity_FilesView: String { return self._s[2776]! } - public var UserInfo_GenericPhoneLabel: String { return self._s[2777]! } - public var Privacy_Calls_NeverAllow: String { return self._s[2778]! } - public func Contacts_AddPhoneNumber(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2779]!, self._r[2779]!, [_0]) + public func Time_PreciseDate_m9(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2752]!, self._r[2752]!, [_1, _2, _3]) } - public var TwoStepAuth_ConfirmationText: String { return self._s[2780]! } - public var ChatSettings_AutomaticVideoMessageDownload: String { return self._s[2781]! } - public var Channel_AdminLogFilter_AdminsAll: String { return self._s[2782]! } - public var Tour_Title2: String { return self._s[2783]! } - public var Conversation_FileOpenIn: String { return self._s[2784]! } - public var Checkout_ErrorPrecheckoutFailed: String { return self._s[2785]! } - public var Wallpaper_Set: String { return self._s[2786]! } - public var Passport_Identity_Translations: String { return self._s[2788]! } - public func Channel_AdminLog_MessageChangedChannelAbout(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2789]!, self._r[2789]!, [_0]) + public var Preview_CopyAddress: String { return self._s[2753]! } + public func DialogList_SinglePlayingGameSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2754]!, self._r[2754]!, [_0]) } - public var Channel_LeaveChannel: String { return self._s[2790]! } - public func PINNED_INVOICE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2791]!, self._r[2791]!, [_1]) + public var KeyCommand_JumpToPreviousChat: String { return self._s[2755]! } + public var UserInfo_BotSettings: String { return self._s[2756]! } + public var LiveLocation_MenuStopAll: String { return self._s[2758]! } + public var Passport_PasswordCreate: String { return self._s[2759]! } + public var StickerSettings_MaskContextInfo: String { return self._s[2760]! } + public var Message_PinnedLocationMessage: String { return self._s[2761]! } + public var Map_Satellite: String { return self._s[2762]! } + public var Username_TooManyPublicUsernamesError: String { return self._s[2763]! } + public var TwoStepAuth_EnterPasswordInvalid: String { return self._s[2764]! } + public func Notification_PinnedTextMessage(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2765]!, self._r[2765]!, [_0, _1]) } - public var PhotoEditor_HighlightsTint: String { return self._s[2792]! } - public var Passport_Email_Delete: String { return self._s[2793]! } - public var Conversation_Mute: String { return self._s[2795]! } - public var Channel_AdminLog_CanSendMessages: String { return self._s[2797]! } - public func Notification_PassportValuesSentMessage(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2798]!, self._r[2798]!, [_1, _2]) + public var Notifications_ChannelNotificationsHelp: String { return self._s[2766]! } + public var Privacy_Calls_P2PContacts: String { return self._s[2767]! } + public var NotificationsSound_None: String { return self._s[2768]! } + public var AccessDenied_VoiceMicrophone: String { return self._s[2770]! } + public func ApplyLanguage_ChangeLanguageAlreadyActive(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2771]!, self._r[2771]!, [_1]) } - public var Calls_CallTabDescription: String { return self._s[2799]! } - public var Passport_Identity_NativeNameHelp: String { return self._s[2800]! } - public var Common_No: String { return self._s[2801]! } - public var Weekday_Sunday: String { return self._s[2802]! } - public var Notification_Reply: String { return self._s[2803]! } - public var Conversation_ViewMessage: String { return self._s[2804]! } - public func Checkout_SavePasswordTimeoutAndFaceId(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2805]!, self._r[2805]!, [_0]) + public var Cache_Indexing: String { return self._s[2772]! } + public var DialogList_RecentTitlePeople: String { return self._s[2774]! } + public var DialogList_EncryptionRejected: String { return self._s[2775]! } + public var GroupInfo_Administrators: String { return self._s[2776]! } + public var Passport_ScanPassportHelp: String { return self._s[2777]! } + public var Application_Name: String { return self._s[2778]! } + public var Channel_AdminLogFilter_ChannelEventsInfo: String { return self._s[2779]! } + public var Passport_Identity_TranslationHelp: String { return self._s[2781]! } + public func Notification_JoinedGroupByLink(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2782]!, self._r[2782]!, [_0]) } - public func Map_LiveLocationPrivateDescription(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2806]!, self._r[2806]!, [_0]) + public func DialogList_EncryptedChatStartedOutgoing(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2783]!, self._r[2783]!, [_0]) } - public var Message_PinnedDocumentMessage: String { return self._s[2807]! } - public var DialogList_TabTitle: String { return self._s[2809]! } - public var Passport_FieldEmail: String { return self._s[2810]! } - public var Conversation_UnpinMessageAlert: String { return self._s[2811]! } - public var Passport_Address_TypeBankStatement: String { return self._s[2812]! } - public var Passport_Identity_ExpiryDate: String { return self._s[2813]! } - public var Privacy_Calls_P2P: String { return self._s[2814]! } - public func CancelResetAccount_Success(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2816]!, self._r[2816]!, [_0]) + public var Channel_EditAdmin_PermissionDeleteMessages: String { return self._s[2784]! } + public var Privacy_ChatsTitle: String { return self._s[2785]! } + public var DialogList_ClearHistoryConfirmation: String { return self._s[2786]! } + public var Watch_Suggestion_HoldOn: String { return self._s[2787]! } + public var SocksProxySetup_RequiredCredentials: String { return self._s[2788]! } + public var Passport_Address_TypeRentalAgreementUploadScan: String { return self._s[2789]! } + public var TwoStepAuth_EmailSkipAlert: String { return self._s[2790]! } + public var Channel_Setup_TypePublic: String { return self._s[2793]! } + public func Channel_AdminLog_MessageToggleInvitesOn(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2794]!, self._r[2794]!, [_0]) } - public var SocksProxySetup_UseForCallsHelp: String { return self._s[2817]! } - public var EnterPasscode_ChangeTitle: String { return self._s[2818]! } - public var Passport_InfoText: String { return self._s[2819]! } - public var Checkout_NewCard_SaveInfoEnableHelp: String { return self._s[2820]! } - public func Login_InvalidPhoneEmailSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2821]!, self._r[2821]!, [_0]) + public var Channel_TypeSetup_Title: String { return self._s[2796]! } + public var Map_OpenInMaps: String { return self._s[2798]! } + public var NotificationsSound_Tremolo: String { return self._s[2800]! } + public func Date_ChatDateHeaderYear(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2802]!, self._r[2802]!, [_1, _2, _3]) } - public func Time_PreciseDate_m3(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2822]!, self._r[2822]!, [_1, _2, _3]) + public var ConversationProfile_UnknownAddMemberError: String { return self._s[2803]! } + public var Passport_PasswordHelp: String { return self._s[2804]! } + public var Login_CodeExpiredError: String { return self._s[2805]! } + public var Channel_EditAdmin_PermissionChangeInfo: String { return self._s[2806]! } + public var Conversation_TitleUnmute: String { return self._s[2807]! } + public var Passport_Identity_ScansHelp: String { return self._s[2808]! } + public var Passport_Language_lo: String { return self._s[2809]! } + public var Camera_FlashAuto: String { return self._s[2810]! } + public var Common_Cancel: String { return self._s[2811]! } + public var DialogList_SavedMessagesTooltip: String { return self._s[2812]! } + public var TwoStepAuth_SetupPasswordTitle: String { return self._s[2813]! } + public var Conversation_ReportSpamConfirmation: String { return self._s[2814]! } + public var ChatSettings_Title: String { return self._s[2816]! } + public var Passport_PasswordReset: String { return self._s[2817]! } + public var SocksProxySetup_TypeNone: String { return self._s[2818]! } + public var PhoneNumberHelp_Help: String { return self._s[2820]! } + public var Checkout_EnterPassword: String { return self._s[2821]! } + public var Activity_UploadingDocument: String { return self._s[2823]! } + public var Share_AuthTitle: String { return self._s[2824]! } + public var State_Connecting: String { return self._s[2825]! } + public var Profile_MessageLifetime1w: String { return self._s[2826]! } + public var Conversation_ContextMenuReport: String { return self._s[2827]! } + public var CheckoutInfo_ReceiverInfoPhone: String { return self._s[2828]! } + public var AutoNightTheme_ScheduledTo: String { return self._s[2829]! } + public func CHAT_DELETE_MEMBER_SEPARATED(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2830]!, self._r[2830]!, [_1, _2, _3]) } - public var Passport_Identity_EditDriversLicense: String { return self._s[2823]! } - public var Conversation_TapAndHoldToRecord: String { return self._s[2825]! } - public func Notification_CallTimeFormat(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2826]!, self._r[2826]!, [_1, _2]) + public var AuthSessions_Terminate: String { return self._s[2831]! } + public func MESSAGE_TEXT_SEPARATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2832]!, self._r[2832]!, [_1, _2]) } - public func Generic_OpenHiddenLinkAlert(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2828]!, self._r[2828]!, [_0]) + public var Checkout_NewCard_CardholderNamePlaceholder: String { return self._s[2833]! } + public var KeyCommand_JumpToPreviousUnreadChat: String { return self._s[2834]! } + public var PhotoEditor_Set: String { return self._s[2835]! } + public var EmptyGroupInfo_Title: String { return self._s[2836]! } + public var Login_PadPhoneHelp: String { return self._s[2837]! } + public var PrivacyPolicy_DeclineLastWarning: String { return self._s[2840]! } + public var NotificationsSound_Complete: String { return self._s[2841]! } + public func CHAT_MESSAGE_CONTACT_SEPARATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2842]!, self._r[2842]!, [_1, _2]) } - public var DialogList_Unread: String { return self._s[2829]! } - public var User_DeletedAccount: String { return self._s[2830]! } - public func Watch_Time_ShortYesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2831]!, self._r[2831]!, [_0]) + public var Group_Info_AdminLog: String { return self._s[2843]! } + public var Channel_AdminLog_InfoPanelAlertText: String { return self._s[2844]! } + public var Conversation_Admin: String { return self._s[2846]! } + public var Conversation_GifTooltip: String { return self._s[2847]! } + public var Passport_NotLoggedInMessage: String { return self._s[2848]! } + public var Profile_MessageLifetimeForever: String { return self._s[2849]! } + public func MESSAGE_POLL_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2851]!, self._r[2851]!, [_1]) } - public var UserInfo_NotificationsDefault: String { return self._s[2832]! } - public var SharedMedia_CategoryMedia: String { return self._s[2833]! } - public var SocksProxySetup_ProxyStatusUnavailable: String { return self._s[2834]! } - public var Channel_AdminLog_MessageRestrictedForever: String { return self._s[2835]! } - public var Watch_ChatList_Compose: String { return self._s[2836]! } - public var Notifications_MessageNotificationsExceptionsHelp: String { return self._s[2837]! } - public var Watch_Microphone_Access: String { return self._s[2838]! } - public var Group_Setup_HistoryHeader: String { return self._s[2839]! } - public var Activity_UploadingPhoto: String { return self._s[2840]! } - public var Conversation_Edit: String { return self._s[2842]! } - public var Group_ErrorSendRestrictedMedia: String { return self._s[2843]! } - public var Login_TermsOfServiceDecline: String { return self._s[2844]! } - public var Message_PinnedContactMessage: String { return self._s[2845]! } - public func Channel_AdminLog_MessageRestrictedNameUsername(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2846]!, self._r[2846]!, [_1, _2]) + public var SharedMedia_EmptyTitle: String { return self._s[2852]! } + public var Channel_Edit_PrivatePublicLinkAlert: String { return self._s[2853]! } + public var Username_Help: String { return self._s[2854]! } + public var DialogList_LanguageTooltip: String { return self._s[2856]! } + public var Map_LoadError: String { return self._s[2857]! } + public var Notification_Exceptions_NewException: String { return self._s[2858]! } + public var TwoStepAuth_EmailTitle: String { return self._s[2859]! } + public var WatchRemote_AlertText: String { return self._s[2860]! } + public var ChatSettings_ConnectionType_Title: String { return self._s[2862]! } + public func CHANNEL_MESSAGE_GEOLIVE_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2863]!, self._r[2863]!, [_1]) } - public func Login_PhoneBannedEmailBody(_ _1: String, _ _2: String, _ _3: String, _ _4: String, _ _5: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2847]!, self._r[2847]!, [_1, _2, _3, _4, _5]) + public func LOCKED_MESSAGE(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2864]!, self._r[2864]!, [_1]) } - public var TwoStepAuth_AdditionalPassword: String { return self._s[2849]! } - public var Passport_Phone_EnterOtherNumber: String { return self._s[2850]! } - public var TwoStepAuth_RecoveryEmailAddDescription: String { return self._s[2851]! } - public var Passport_FieldPhone: String { return self._s[2852]! } - public var Message_PinnedPhotoMessage: String { return self._s[2853]! } - public var InfoPlist_NSCameraUsageDescription: String { return self._s[2855]! } - public var Conversation_Call: String { return self._s[2856]! } - public var Common_TakePhoto: String { return self._s[2858]! } - public var Channel_NotificationLoading: String { return self._s[2859]! } - public func Notification_Exceptions_Sound(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2860]!, self._r[2860]!, [_0]) + public var Passport_Address_CountryPlaceholder: String { return self._s[2865]! } + public func DialogList_AwaitingEncryption(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2866]!, self._r[2866]!, [_0]) } - public var Permissions_SiriTitle_v0: String { return self._s[2861]! } - public func Login_ResetAccountProtected_Text(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2862]!, self._r[2862]!, [_0]) + public func Time_PreciseDate_m6(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2867]!, self._r[2867]!, [_1, _2, _3]) } - public var Channel_MessagePhotoRemoved: String { return self._s[2863]! } - public var Common_edit: String { return self._s[2864]! } - public var PrivacySettings_AuthSessions: String { return self._s[2865]! } - public var Month_ShortJune: String { return self._s[2866]! } - public var PrivacyLastSeenSettings_AlwaysShareWith_Placeholder: String { return self._s[2867]! } - public var Call_ReportSend: String { return self._s[2868]! } - public var Watch_LastSeen_JustNow: String { return self._s[2869]! } - public var Notifications_MessageNotifications: String { return self._s[2870]! } - public var BroadcastListInfo_AddRecipient: String { return self._s[2872]! } - public var Group_Status: String { return self._s[2873]! } - public func AutoNightTheme_LocationHelp(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2874]!, self._r[2874]!, [_0, _1]) + public var Group_AdminLog_EmptyText: String { return self._s[2868]! } + public var AccessDenied_VideoMicrophone: String { return self._s[2870]! } + public var Conversation_ContextMenuStickerPackAdd: String { return self._s[2871]! } + public var Cache_ClearNone: String { return self._s[2872]! } + public var SocksProxySetup_FailedToConnect: String { return self._s[2873]! } + public var Permissions_NotificationsTitle_v0: String { return self._s[2874]! } + public func Channel_AdminLog_MessageEdited(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2875]!, self._r[2875]!, [_0]) } - public var ShareMenu_ShareTo: String { return self._s[2875]! } - public var Conversation_Moderate_Ban: String { return self._s[2876]! } - public func Conversation_DeleteMessagesFor(_ _0: String) -> (String, [(Int, NSRange)]) { + public var Passport_Identity_Country: String { return self._s[2876]! } + public func Notification_CreatedChat(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2877]!, self._r[2877]!, [_0]) } - public var SharedMedia_ViewInChat: String { return self._s[2878]! } - public var Map_LiveLocationFor8Hours: String { return self._s[2879]! } - public func Map_AccurateTo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2881]!, self._r[2881]!, [_0]) + public var AccessDenied_Settings: String { return self._s[2878]! } + public var Passport_Address_TypeUtilityBillUploadScan: String { return self._s[2879]! } + public var Month_ShortMay: String { return self._s[2880]! } + public var Compose_NewGroup: String { return self._s[2881]! } + public var Group_Setup_TypePrivate: String { return self._s[2883]! } + public var Login_PadPhoneHelpTitle: String { return self._s[2884]! } + public var Appearance_ThemeDayClassic: String { return self._s[2885]! } + public var Channel_AdminLog_MessagePreviousCaption: String { return self._s[2886]! } + public var Privacy_GroupsAndChannels_WhoCanAddMe: String { return self._s[2887]! } + public var Conversation_typing: String { return self._s[2889]! } + public var Paint_Masks: String { return self._s[2890]! } + public func PINNED_DOC_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2891]!, self._r[2891]!, [_1]) } - public var Appearance_ReduceMotion: String { return self._s[2882]! } - public var Map_OpenInHereMaps: String { return self._s[2883]! } - public var Channel_Setup_TypePublicHelp: String { return self._s[2884]! } - public var Passport_Identity_EditInternalPassport: String { return self._s[2885]! } - public var PhotoEditor_Skip: String { return self._s[2886]! } - public func PasscodeSettings_FailedAttempts(_ value: Int32) -> String { + public var Username_InvalidTaken: String { return self._s[2892]! } + public func CHAT_PHOTO_EDITED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2893]!, self._r[2893]!, [_1, _2]) + } + public var Call_StatusNoAnswer: String { return self._s[2894]! } + public var TwoStepAuth_EmailAddSuccess: String { return self._s[2895]! } + public var Passport_Identity_Selfie: String { return self._s[2896]! } + public var Login_InfoLastNamePlaceholder: String { return self._s[2897]! } + public var Privacy_SecretChatsLinkPreviewsHelp: String { return self._s[2898]! } + public var Conversation_ClearSecretHistory: String { return self._s[2899]! } + public var NetworkUsageSettings_Title: String { return self._s[2901]! } + public var Your_cards_security_code_is_invalid: String { return self._s[2903]! } + public func Notification_LeftChannel(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2905]!, self._r[2905]!, [_0]) + } + public func Call_CallInProgressMessage(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2906]!, self._r[2906]!, [_1, _2]) + } + public var SaveIncomingPhotosSettings_From: String { return self._s[2908]! } + public var Map_LiveLocationTitle: String { return self._s[2909]! } + public var Login_InfoAvatarAdd: String { return self._s[2910]! } + public var Passport_Identity_FilesView: String { return self._s[2911]! } + public var UserInfo_GenericPhoneLabel: String { return self._s[2912]! } + public var Privacy_Calls_NeverAllow: String { return self._s[2913]! } + public func Contacts_AddPhoneNumber(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2914]!, self._r[2914]!, [_0]) + } + public var TwoStepAuth_ConfirmationText: String { return self._s[2915]! } + public var ChatSettings_AutomaticVideoMessageDownload: String { return self._s[2916]! } + public var Channel_AdminLogFilter_AdminsAll: String { return self._s[2917]! } + public var Tour_Title2: String { return self._s[2918]! } + public var Conversation_FileOpenIn: String { return self._s[2919]! } + public var Checkout_ErrorPrecheckoutFailed: String { return self._s[2920]! } + public var Wallpaper_Set: String { return self._s[2921]! } + public var Passport_Identity_Translations: String { return self._s[2923]! } + public func Channel_AdminLog_MessageChangedChannelAbout(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2924]!, self._r[2924]!, [_0]) + } + public var Channel_LeaveChannel: String { return self._s[2925]! } + public func MESSAGE_NOTEXT_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2926]!, self._r[2926]!, [_1]) + } + public func PINNED_INVOICE(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2927]!, self._r[2927]!, [_1]) + } + public var PhotoEditor_HighlightsTint: String { return self._s[2928]! } + public var Passport_Email_Delete: String { return self._s[2929]! } + public var Conversation_Mute: String { return self._s[2931]! } + public var Channel_AdminLog_CanSendMessages: String { return self._s[2933]! } + public func Notification_PassportValuesSentMessage(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2934]!, self._r[2934]!, [_1, _2]) + } + public var Calls_CallTabDescription: String { return self._s[2935]! } + public var Passport_Identity_NativeNameHelp: String { return self._s[2936]! } + public var Common_No: String { return self._s[2937]! } + public var Weekday_Sunday: String { return self._s[2938]! } + public var Notification_Reply: String { return self._s[2939]! } + public var Conversation_ViewMessage: String { return self._s[2940]! } + public func Checkout_SavePasswordTimeoutAndFaceId(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2941]!, self._r[2941]!, [_0]) + } + public func Map_LiveLocationPrivateDescription(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2942]!, self._r[2942]!, [_0]) + } + public var Message_PinnedDocumentMessage: String { return self._s[2943]! } + public var DialogList_TabTitle: String { return self._s[2945]! } + public var Passport_FieldEmail: String { return self._s[2946]! } + public var Conversation_UnpinMessageAlert: String { return self._s[2947]! } + public var Passport_Address_TypeBankStatement: String { return self._s[2948]! } + public var Passport_Identity_ExpiryDate: String { return self._s[2949]! } + public var Privacy_Calls_P2P: String { return self._s[2950]! } + public func CancelResetAccount_Success(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2952]!, self._r[2952]!, [_0]) + } + public var SocksProxySetup_UseForCallsHelp: String { return self._s[2953]! } + public var EnterPasscode_ChangeTitle: String { return self._s[2954]! } + public var Passport_InfoText: String { return self._s[2955]! } + public var Checkout_NewCard_SaveInfoEnableHelp: String { return self._s[2956]! } + public func Login_InvalidPhoneEmailSubject(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2957]!, self._r[2957]!, [_0]) + } + public func Time_PreciseDate_m3(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2958]!, self._r[2958]!, [_1, _2, _3]) + } + public var Passport_Identity_EditDriversLicense: String { return self._s[2959]! } + public var Conversation_TapAndHoldToRecord: String { return self._s[2961]! } + public func Notification_CallTimeFormat(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2962]!, self._r[2962]!, [_1, _2]) + } + public func MESSAGE_ROUND_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2963]!, self._r[2963]!, [_1]) + } + public func PHONE_CALL_MISSED_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2965]!, self._r[2965]!, [_1]) + } + public func Generic_OpenHiddenLinkAlert(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2967]!, self._r[2967]!, [_0]) + } + public var DialogList_Unread: String { return self._s[2968]! } + public var User_DeletedAccount: String { return self._s[2969]! } + public func Watch_Time_ShortYesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2970]!, self._r[2970]!, [_0]) + } + public var UserInfo_NotificationsDefault: String { return self._s[2971]! } + public var SharedMedia_CategoryMedia: String { return self._s[2972]! } + public var SocksProxySetup_ProxyStatusUnavailable: String { return self._s[2973]! } + public var Channel_AdminLog_MessageRestrictedForever: String { return self._s[2974]! } + public var Watch_ChatList_Compose: String { return self._s[2975]! } + public var Notifications_MessageNotificationsExceptionsHelp: String { return self._s[2976]! } + public var Watch_Microphone_Access: String { return self._s[2977]! } + public var Group_Setup_HistoryHeader: String { return self._s[2978]! } + public var Activity_UploadingPhoto: String { return self._s[2979]! } + public func MESSAGE_VIDEO_SECRET_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2981]!, self._r[2981]!, [_1]) + } + public var Conversation_Edit: String { return self._s[2982]! } + public var Group_ErrorSendRestrictedMedia: String { return self._s[2983]! } + public var Login_TermsOfServiceDecline: String { return self._s[2984]! } + public var Message_PinnedContactMessage: String { return self._s[2985]! } + public func Channel_AdminLog_MessageRestrictedNameUsername(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2986]!, self._r[2986]!, [_1, _2]) + } + public func Login_PhoneBannedEmailBody(_ _1: String, _ _2: String, _ _3: String, _ _4: String, _ _5: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2987]!, self._r[2987]!, [_1, _2, _3, _4, _5]) + } + public var TwoStepAuth_AdditionalPassword: String { return self._s[2989]! } + public var Passport_Phone_EnterOtherNumber: String { return self._s[2990]! } + public var Message_PinnedPhotoMessage: String { return self._s[2991]! } + public var Passport_FieldPhone: String { return self._s[2992]! } + public var TwoStepAuth_RecoveryEmailAddDescription: String { return self._s[2993]! } + public var InfoPlist_NSCameraUsageDescription: String { return self._s[2995]! } + public var Conversation_Call: String { return self._s[2996]! } + public var Common_TakePhoto: String { return self._s[2998]! } + public var Channel_NotificationLoading: String { return self._s[2999]! } + public func Notification_Exceptions_Sound(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3000]!, self._r[3000]!, [_0]) + } + public var Permissions_SiriTitle_v0: String { return self._s[3001]! } + public func Login_ResetAccountProtected_Text(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3002]!, self._r[3002]!, [_0]) + } + public var Channel_MessagePhotoRemoved: String { return self._s[3003]! } + public var Common_edit: String { return self._s[3004]! } + public var PrivacySettings_AuthSessions: String { return self._s[3005]! } + public var Month_ShortJune: String { return self._s[3006]! } + public var PrivacyLastSeenSettings_AlwaysShareWith_Placeholder: String { return self._s[3007]! } + public var Call_ReportSend: String { return self._s[3008]! } + public var Watch_LastSeen_JustNow: String { return self._s[3009]! } + public var Notifications_MessageNotifications: String { return self._s[3010]! } + public var BroadcastListInfo_AddRecipient: String { return self._s[3012]! } + public var Group_Status: String { return self._s[3013]! } + public func AutoNightTheme_LocationHelp(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3014]!, self._r[3014]!, [_0, _1]) + } + public var ShareMenu_ShareTo: String { return self._s[3015]! } + public var Conversation_Moderate_Ban: String { return self._s[3016]! } + public func Conversation_DeleteMessagesFor(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3017]!, self._r[3017]!, [_0]) + } + public var SharedMedia_ViewInChat: String { return self._s[3018]! } + public var Map_LiveLocationFor8Hours: String { return self._s[3019]! } + public func Map_AccurateTo(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3021]!, self._r[3021]!, [_0]) + } + public var Appearance_ReduceMotion: String { return self._s[3022]! } + public var Map_OpenInHereMaps: String { return self._s[3023]! } + public var Channel_Setup_TypePublicHelp: String { return self._s[3024]! } + public var Passport_Identity_EditInternalPassport: String { return self._s[3025]! } + public var PhotoEditor_Skip: String { return self._s[3026]! } + public func StickerPack_RemoveMaskCount(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[0 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Watch_UserInfo_Mute(_ value: Int32) -> String { + public func QuickSend_Photos(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[1 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Media_SharePhoto(_ value: Int32) -> String { + public func LiveLocationUpdated_MinutesAgo(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[2 * 6 + Int(form.rawValue)]!, "\(value)") } - public func ForwardedContacts(_ value: Int32) -> String { + public func Notification_GameScoreSimple(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[3 * 6 + Int(form.rawValue)]!, "\(value)") } - public func MessagePoll_VotedCount(_ value: Int32) -> String { + public func Call_ShortSeconds(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[4 * 6 + Int(form.rawValue)]!, "\(value)") } - public func StickerPack_AddMaskCount(_ value: Int32) -> String { + public func ForwardedVideoMessages(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[5 * 6 + Int(form.rawValue)]!, "\(value)") } - public func SharedMedia_Generic(_ value: Int32) -> String { + public func ForwardedMessages(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[6 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Conversation_StatusMembers(_ value: Int32) -> String { + public func Media_SharePhoto(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[7 * 6 + Int(form.rawValue)]!, "\(value)") } - public func StickerPack_RemoveMaskCount(_ value: Int32) -> String { + public func InviteText_ContactsCountText(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[8 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Notifications_ExceptionMuteExpires_Hours(_ value: Int32) -> String { + public func MuteExpires_Days(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[9 * 6 + Int(form.rawValue)]!, "\(value)") } - public func ServiceMessage_GameScoreSelfExtended(_ value: Int32) -> String { + public func MessageTimer_Days(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[10 * 6 + Int(form.rawValue)]!, "\(value)") } - public func QuickSend_Photos(_ value: Int32) -> String { + public func Notifications_ExceptionMuteExpires_Days(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[11 * 6 + Int(form.rawValue)]!, "\(value)") } - public func GroupInfo_ParticipantCount(_ value: Int32) -> String { + public func SharedMedia_Generic(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[12 * 6 + Int(form.rawValue)]!, "\(value)") } - public func MuteExpires_Hours(_ value: Int32) -> String { + public func Conversation_StatusSubscribers(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[13 * 6 + Int(form.rawValue)]!, "\(value)") } - public func DialogList_LiveLocationChatsCount(_ value: Int32) -> String { + public func LastSeen_HoursAgo(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[14 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Notification_GameScoreSelfExtended(_ value: Int32) -> String { + public func Call_ShortMinutes(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[15 * 6 + Int(form.rawValue)]!, "\(value)") } - public func ForwardedAudios(_ value: Int32) -> String { + public func CHAT_MESSAGE_PHOTOS_SEPARATED(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[16 * 6 + Int(form.rawValue)]!, "\(value)") } - public func MessageTimer_ShortMinutes(_ value: Int32) -> String { + public func MessageTimer_ShortWeeks(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[17 * 6 + Int(form.rawValue)]!, "\(value)") } - public func ForwardedFiles(_ value: Int32) -> String { + public func Invitation_Members(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[18 * 6 + Int(form.rawValue)]!, "\(value)") } - public func LastSeen_MinutesAgo(_ value: Int32) -> String { + public func Map_ETAHours(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[19 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Conversation_StatusSubscribers(_ value: Int32) -> String { + public func ForwardedPhotos(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[20 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Map_ETAMinutes(_ value: Int32) -> String { + public func MuteExpires_Hours(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[21 * 6 + Int(form.rawValue)]!, "\(value)") } - public func ServiceMessage_GameScoreSimple(_ value: Int32) -> String { + public func SharedMedia_Photo(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[22 * 6 + Int(form.rawValue)]!, "\(value)") } - public func ForwardedLocations(_ value: Int32) -> String { + public func ForwardedGifs(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[23 * 6 + Int(form.rawValue)]!, "\(value)") } - public func CreatePoll_AddMoreOptions(_ value: Int32) -> String { + public func Media_ShareVideo(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[24 * 6 + Int(form.rawValue)]!, "\(value)") } - public func MessageTimer_Years(_ value: Int32) -> String { + public func ServiceMessage_GameScoreSelfSimple(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[25 * 6 + Int(form.rawValue)]!, "\(value)") } - public func ForwardedVideos(_ value: Int32) -> String { + public func StickerPack_RemoveStickerCount(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[26 * 6 + Int(form.rawValue)]!, "\(value)") } - public func AttachmentMenu_SendGif(_ value: Int32) -> String { + public func SharedMedia_DeleteItemsConfirmation(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[27 * 6 + Int(form.rawValue)]!, "\(value)") } - public func AttachmentMenu_SendVideo(_ value: Int32) -> String { + public func Watch_LastSeen_HoursAgo(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[28 * 6 + Int(form.rawValue)]!, "\(value)") } - public func ForwardedGifs(_ value: Int32) -> String { + public func ForwardedFiles(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[29 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Watch_LastSeen_HoursAgo(_ value: Int32) -> String { + public func AttachmentMenu_SendItem(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[30 * 6 + Int(form.rawValue)]!, "\(value)") } - public func LiveLocation_MenuChatsCount(_ value: Int32) -> String { + public func Conversation_LiveLocationMembersCount(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[31 * 6 + Int(form.rawValue)]!, "\(value)") } @@ -3382,230 +3666,266 @@ public final class PresentationStrings { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[33 * 6 + Int(form.rawValue)]!, "\(value)") } - public func MessageTimer_ShortHours(_ value: Int32) -> String { + public func ChatList_DeleteConfirmation(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[34 * 6 + Int(form.rawValue)]!, "\(value)") } - public func MuteExpires_Days(_ value: Int32) -> String { + public func AttachmentMenu_SendGif(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[35 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Conversation_StatusOnline(_ value: Int32) -> String { + public func ForwardedAudios(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[36 * 6 + Int(form.rawValue)]!, "\(value)") } - public func MessageTimer_Seconds(_ value: Int32) -> String { + public func Media_ShareItem(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[37 * 6 + Int(form.rawValue)]!, "\(value)") } - public func MessageTimer_Minutes(_ value: Int32) -> String { + public func Notifications_ExceptionMuteExpires_Minutes(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[38 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Invitation_Members(_ value: Int32) -> String { + public func MessageTimer_Hours(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[39 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Call_ShortSeconds(_ value: Int32) -> String { + public func Notifications_ExceptionMuteExpires_Hours(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[40 * 6 + Int(form.rawValue)]!, "\(value)") } - public func MessageTimer_ShortDays(_ value: Int32) -> String { + public func Conversation_StatusOnline(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[41 * 6 + Int(form.rawValue)]!, "\(value)") } - public func StickerPack_AddStickerCount(_ value: Int32) -> String { + public func LiveLocation_MenuChatsCount(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[42 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Passport_Scans(_ value: Int32) -> String { + public func MESSAGE_PHOTOS_SEPARATED(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[43 * 6 + Int(form.rawValue)]!, "\(value)") } - public func ForwardedStickers(_ value: Int32) -> String { + public func CreatePoll_AddMoreOptions(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[44 * 6 + Int(form.rawValue)]!, "\(value)") } - public func MessageTimer_Days(_ value: Int32) -> String { + public func Forward_ConfirmMultipleFiles(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[45 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Notification_GameScoreSimple(_ value: Int32) -> String { + public func CHANNEL_MESSAGES_SEPARATED(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[46 * 6 + Int(form.rawValue)]!, "\(value)") } - public func ForwardedPolls(_ value: Int32) -> String { + public func CHANNEL_MESSAGE_FWDS_SEPARATED(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[47 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Call_Minutes(_ value: Int32) -> String { + public func MESSAGES_SEPARATED(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[48 * 6 + Int(form.rawValue)]!, "\(value)") } - public func MessageTimer_ShortWeeks(_ value: Int32) -> String { + public func MessageTimer_ShortHours(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[49 * 6 + Int(form.rawValue)]!, "\(value)") } - public func MessageTimer_Months(_ value: Int32) -> String { + public func DialogList_LiveLocationChatsCount(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[50 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Notifications_ExceptionMuteExpires_Minutes(_ value: Int32) -> String { + public func Watch_LastSeen_MinutesAgo(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[51 * 6 + Int(form.rawValue)]!, "\(value)") } - public func InviteText_ContactsCountText(_ value: Int32) -> String { + public func Notifications_Exceptions(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[52 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Notifications_ExceptionMuteExpires_Days(_ value: Int32) -> String { + public func Contacts_ImportersCount(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[53 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Conversation_LiveLocationMembersCount(_ value: Int32) -> String { + public func MessageTimer_Years(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[54 * 6 + Int(form.rawValue)]!, "\(value)") } - public func MuteFor_Hours(_ value: Int32) -> String { + public func ForwardedAuthorsOthers(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[55 * 6 + Int(form.rawValue)]!, "\(value)") } - public func ChatList_DeleteConfirmation(_ value: Int32) -> String { + public func UserCount(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[56 * 6 + Int(form.rawValue)]!, "\(value)") } - public func MessageTimer_Weeks(_ value: Int32) -> String { + public func ForwardedLocations(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[57 * 6 + Int(form.rawValue)]!, "\(value)") } - public func ForwardedAuthorsOthers(_ value: Int32) -> String { + public func MessageTimer_ShortMinutes(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[58 * 6 + Int(form.rawValue)]!, "\(value)") } - public func SharedMedia_DeleteItemsConfirmation(_ value: Int32) -> String { + public func PrivacyLastSeenSettings_AddUsers(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[59 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Notifications_Exceptions(_ value: Int32) -> String { + public func AttachmentMenu_SendVideo(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[60 * 6 + Int(form.rawValue)]!, "\(value)") } - public func UserCount(_ value: Int32) -> String { + public func Conversation_StatusMembers(_ 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 Notification_GameScoreSelfSimple(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[62 * 6 + Int(form.rawValue)]!, "\(value)") } - public func SharedMedia_Photo(_ value: Int32) -> String { + public func ServiceMessage_GameScoreSelfExtended(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[63 * 6 + Int(form.rawValue)]!, "\(value)") } - public func MuteExpires_Minutes(_ value: Int32) -> String { + public func MessagePoll_VotedCount(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[64 * 6 + Int(form.rawValue)]!, "\(value)") } - public func ForwardedPhotos(_ value: Int32) -> String { + public func LastSeen_MinutesAgo(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[65 * 6 + Int(form.rawValue)]!, "\(value)") } - public func StickerPack_RemoveStickerCount(_ value: Int32) -> String { + public func MessageTimer_Weeks(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[66 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Watch_LastSeen_MinutesAgo(_ value: Int32) -> String { + public func SharedMedia_Video(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[67 * 6 + Int(form.rawValue)]!, "\(value)") } - public func MuteFor_Days(_ value: Int32) -> String { + public func Call_Minutes(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[68 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Forward_ConfirmMultipleFiles(_ value: Int32) -> String { + public func MessageTimer_Seconds(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[69 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Call_ShortMinutes(_ value: Int32) -> String { + public func StickerPack_AddMaskCount(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[70 * 6 + Int(form.rawValue)]!, "\(value)") } - public func SharedMedia_Video(_ value: Int32) -> String { + public func CHAT_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 MessageTimer_ShortSeconds(_ value: Int32) -> String { + public func AttachmentMenu_SendPhoto(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[72 * 6 + Int(form.rawValue)]!, "\(value)") } - public func ForwardedMessages(_ value: Int32) -> String { + public func ForwardedContacts(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[73 * 6 + Int(form.rawValue)]!, "\(value)") } - public func ForwardedVideoMessages(_ value: Int32) -> String { + public func MuteExpires_Minutes(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[74 * 6 + Int(form.rawValue)]!, "\(value)") } - public func SharedMedia_Link(_ value: Int32) -> String { + public func MessageTimer_ShortDays(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[75 * 6 + Int(form.rawValue)]!, "\(value)") } - public func MessageTimer_Hours(_ value: Int32) -> String { + public func ForwardedPolls(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[76 * 6 + Int(form.rawValue)]!, "\(value)") } - public func ServiceMessage_GameScoreExtended(_ value: Int32) -> String { + public func MESSAGE_FWDS_SEPARATED(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[77 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Map_ETAHours(_ value: Int32) -> String { + public func SharedMedia_File(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[78 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Notification_GameScoreSelfSimple(_ value: Int32) -> String { + public func Watch_UserInfo_Mute(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[79 * 6 + Int(form.rawValue)]!, "\(value)") } - public func PrivacyLastSeenSettings_AddUsers(_ value: Int32) -> String { + public func ForwardedVideos(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[80 * 6 + Int(form.rawValue)]!, "\(value)") } - public func AttachmentMenu_SendPhoto(_ value: Int32) -> String { + public func Call_Seconds(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[81 * 6 + Int(form.rawValue)]!, "\(value)") } - public func LiveLocationUpdated_MinutesAgo(_ value: Int32) -> String { + public func MessageTimer_ShortSeconds(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[82 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Media_ShareVideo(_ value: Int32) -> String { + public func MuteFor_Days(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[83 * 6 + Int(form.rawValue)]!, "\(value)") } - public func ServiceMessage_GameScoreSelfSimple(_ value: Int32) -> String { + public func Notification_GameScoreSelfExtended(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[84 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Media_ShareItem(_ value: Int32) -> String { + public func MessageTimer_Minutes(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[85 * 6 + Int(form.rawValue)]!, "\(value)") } - public func SharedMedia_File(_ value: Int32) -> String { + public func PasscodeSettings_FailedAttempts(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[86 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Contacts_ImportersCount(_ value: Int32) -> String { + public func ForwardedStickers(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[87 * 6 + Int(form.rawValue)]!, "\(value)") } - public func AttachmentMenu_SendItem(_ 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 LastSeen_HoursAgo(_ value: Int32) -> String { + public func ServiceMessage_GameScoreSimple(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[89 * 6 + Int(form.rawValue)]!, "\(value)") } + public func Passport_Scans(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + return String(format: self._ps[90 * 6 + Int(form.rawValue)]!, "\(value)") + } + public func StickerPack_AddStickerCount(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + return String(format: self._ps[91 * 6 + Int(form.rawValue)]!, "\(value)") + } + public func Map_ETAMinutes(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + return String(format: self._ps[92 * 6 + Int(form.rawValue)]!, "\(value)") + } + public func MuteFor_Hours(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + return String(format: self._ps[93 * 6 + Int(form.rawValue)]!, "\(value)") + } + public func GroupInfo_ParticipantCount(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + return String(format: self._ps[94 * 6 + Int(form.rawValue)]!, "\(value)") + } + public func ServiceMessage_GameScoreExtended(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + return String(format: self._ps[95 * 6 + Int(form.rawValue)]!, "\(value)") + } + public func CHAT_MESSAGES_SEPARATED(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + return String(format: self._ps[96 * 6 + Int(form.rawValue)]!, "\(value)") + } + public func MessageTimer_Months(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + return String(format: self._ps[97 * 6 + Int(form.rawValue)]!, "\(value)") + } + public func SharedMedia_Link(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + return String(format: self._ps[98 * 6 + Int(form.rawValue)]!, "\(value)") + } init(primaryComponent: PresentationStringsComponent, secondaryComponent: PresentationStringsComponent?) { self.primaryComponent = primaryComponent diff --git a/TelegramUI/Resources/PresentationStrings.mapping b/TelegramUI/Resources/PresentationStrings.mapping index 289b2dd0d1..01ecc2b242 100644 Binary files a/TelegramUI/Resources/PresentationStrings.mapping and b/TelegramUI/Resources/PresentationStrings.mapping differ diff --git a/TelegramUI/UserInfoController.swift b/TelegramUI/UserInfoController.swift index fbfeb7005a..b025d7b312 100644 --- a/TelegramUI/UserInfoController.swift +++ b/TelegramUI/UserInfoController.swift @@ -887,7 +887,7 @@ public func userInfoController(account: Account, peerId: PeerId, mode: UserInfoC viewSettings = GlobalNotificationSettingsSet.defaultSettings } - let controller = notificationMuteSettingsController(presentationData: presentationData, notificationSettings: viewSettings.privateChats, updateSettings: { value in + let controller = notificationMuteSettingsController(presentationData: presentationData, notificationSettings: viewSettings.privateChats, soundSettings: nil, openSoundSettings: {}, updateSettings: { value in changeMuteSettingsDisposable.set(updatePeerMuteSetting(account: account, peerId: peerId, muteInterval: value).start()) }) presentControllerImpl?(controller, ViewControllerPresentationArguments(presentationAnimation: .modalSheet))