From d8b99880ea57b311cae2618a6b7711c11ff022fc Mon Sep 17 00:00:00 2001 From: Ilya Laktyushin Date: Thu, 27 Feb 2020 21:26:07 +0400 Subject: [PATCH 1/6] Update API [skip ci] --- SiriIntents/IntentHandler.swift | 2 +- submodules/SyncCore/Sources/Namespaces.swift | 1 + .../SyncCore/Sources/TelegramMediaFile.swift | 11 ++++++ submodules/TelegramApi/Sources/Api0.swift | 3 +- submodules/TelegramApi/Sources/Api1.swift | 36 +++++++++++++++---- .../Sources/PresentationCallManager.swift | 4 +++ submodules/TelegramCore/Sources/Account.swift | 2 +- .../Sources/CachedStickerPack.swift | 26 ++++++++++++++ .../Sources/CallSessionManager.swift | 35 +++++++++--------- .../Sources/LoadedStickerPack.swift | 2 ++ submodules/TelegramCore/Sources/Network.swift | 4 ++- .../Sources/StickerSetInstallation.swift | 3 ++ .../SynchronizeSavedStickersOperation.swift | 2 +- .../Sources/TelegramMediaFile.swift | 2 ++ .../TelegramUI/TelegramUI/AppDelegate.swift | 2 +- .../NotificationContentContext.swift | 2 +- .../TelegramUI/ShareExtensionContext.swift | 2 +- .../Sources/OngoingCallContext.swift | 4 +++ .../libtgvoip/OngoingCallThreadLocalContext.h | 1 + .../OngoingCallThreadLocalContext.mm | 4 +++ 20 files changed, 116 insertions(+), 32 deletions(-) diff --git a/SiriIntents/IntentHandler.swift b/SiriIntents/IntentHandler.swift index 9083112cb9..46253f0897 100644 --- a/SiriIntents/IntentHandler.swift +++ b/SiriIntents/IntentHandler.swift @@ -106,7 +106,7 @@ public class IntentHandler: INExtension, INSendMessageIntentHandling, INSearchFo let deviceSpecificEncryptionParameters = BuildConfig.deviceSpecificEncryptionParameters(rootPath, baseAppBundleId: baseAppBundleId) let encryptionParameters = ValueBoxEncryptionParameters(forceEncryptionIfNoSet: false, key: ValueBoxEncryptionParameters.Key(data: deviceSpecificEncryptionParameters.key)!, salt: ValueBoxEncryptionParameters.Salt(data: deviceSpecificEncryptionParameters.salt)!) - account = currentAccount(allocateIfNotExists: false, networkArguments: NetworkInitializationArguments(apiId: apiId, apiHash: apiHash, languagesCategory: languagesCategory, appVersion: appVersion, voipMaxLayer: 0, appData: .single(buildConfig.bundleData(withAppToken: nil, signatureDict: nil)), autolockDeadine: .single(nil), encryptionProvider: OpenSSLEncryptionProvider()), supplementary: true, manager: accountManager, rootPath: rootPath, auxiliaryMethods: accountAuxiliaryMethods, encryptionParameters: encryptionParameters) + account = currentAccount(allocateIfNotExists: false, networkArguments: NetworkInitializationArguments(apiId: apiId, apiHash: apiHash, languagesCategory: languagesCategory, appVersion: appVersion, voipMaxLayer: 0, voipVersions: [], appData: .single(buildConfig.bundleData(withAppToken: nil, signatureDict: nil)), autolockDeadine: .single(nil), encryptionProvider: OpenSSLEncryptionProvider()), supplementary: true, manager: accountManager, rootPath: rootPath, auxiliaryMethods: accountAuxiliaryMethods, encryptionParameters: encryptionParameters) |> mapToSignal { account -> Signal in if let account = account { switch account { diff --git a/submodules/SyncCore/Sources/Namespaces.swift b/submodules/SyncCore/Sources/Namespaces.swift index 1af4170023..7b384619c8 100644 --- a/submodules/SyncCore/Sources/Namespaces.swift +++ b/submodules/SyncCore/Sources/Namespaces.swift @@ -43,6 +43,7 @@ public struct Namespaces { public static let CloudMaskPacks: Int32 = 1 public static let EmojiKeywords: Int32 = 2 public static let CloudAnimatedEmoji: Int32 = 3 + public static let CloudDice: Int32 = 4 } public struct OrderedItemList { diff --git a/submodules/SyncCore/Sources/TelegramMediaFile.swift b/submodules/SyncCore/Sources/TelegramMediaFile.swift index 535e7eae78..072ae24ca0 100644 --- a/submodules/SyncCore/Sources/TelegramMediaFile.swift +++ b/submodules/SyncCore/Sources/TelegramMediaFile.swift @@ -12,6 +12,7 @@ public enum StickerPackReference: PostboxCoding, Hashable, Equatable { case id(id: Int64, accessHash: Int64) case name(String) case animatedEmoji + case dice public init(decoder: PostboxDecoder) { switch decoder.decodeInt32ForKey("r", orElse: 0) { @@ -21,6 +22,8 @@ public enum StickerPackReference: PostboxCoding, Hashable, Equatable { self = .name(decoder.decodeStringForKey("n", orElse: "")) case 2: self = .animatedEmoji + case 3: + self = .dice default: self = .name("") assertionFailure() @@ -38,6 +41,8 @@ public enum StickerPackReference: PostboxCoding, Hashable, Equatable { encoder.encodeString(name, forKey: "n") case .animatedEmoji: encoder.encodeInt32(2, forKey: "r") + case .dice: + encoder.encodeInt32(3, forKey: "r") } } @@ -61,6 +66,12 @@ public enum StickerPackReference: PostboxCoding, Hashable, Equatable { } else { return false } + case .dice: + if case .dice = rhs { + return true + } else { + return false + } } } } diff --git a/submodules/TelegramApi/Sources/Api0.swift b/submodules/TelegramApi/Sources/Api0.swift index 26baa33fef..afd8f5b371 100644 --- a/submodules/TelegramApi/Sources/Api0.swift +++ b/submodules/TelegramApi/Sources/Api0.swift @@ -513,7 +513,7 @@ fileprivate let parsers: [Int32 : (BufferReader) -> Any?] = { dict[-1502174430] = { return Api.InputMessage.parse_inputMessageID($0) } dict[-1160215659] = { return Api.InputMessage.parse_inputMessageReplyTo($0) } dict[-2037963464] = { return Api.InputMessage.parse_inputMessagePinned($0) } - dict[-1564789301] = { return Api.PhoneCallProtocol.parse_phoneCallProtocol($0) } + dict[-58224696] = { return Api.PhoneCallProtocol.parse_phoneCallProtocol($0) } dict[-1237848657] = { return Api.StatsDateRangeDays.parse_statsDateRangeDays($0) } dict[-1567175714] = { return Api.MessageFwdAuthor.parse_messageFwdAuthor($0) } dict[-1539849235] = { return Api.WallPaper.parse_wallPaper($0) } @@ -579,6 +579,7 @@ fileprivate let parsers: [Int32 : (BufferReader) -> Any?] = { dict[-1645763991] = { return Api.InputStickerSet.parse_inputStickerSetID($0) } dict[-2044933984] = { return Api.InputStickerSet.parse_inputStickerSetShortName($0) } dict[42402760] = { return Api.InputStickerSet.parse_inputStickerSetAnimatedEmoji($0) } + dict[2044861011] = { return Api.InputStickerSet.parse_inputStickerSetDice($0) } dict[-1729618630] = { return Api.BotInfo.parse_botInfo($0) } dict[-1519637954] = { return Api.updates.State.parse_state($0) } dict[372165663] = { return Api.FoundGif.parse_foundGif($0) } diff --git a/submodules/TelegramApi/Sources/Api1.swift b/submodules/TelegramApi/Sources/Api1.swift index 1046f9f6f9..790975a865 100644 --- a/submodules/TelegramApi/Sources/Api1.swift +++ b/submodules/TelegramApi/Sources/Api1.swift @@ -14600,25 +14600,30 @@ public extension Api { } public enum PhoneCallProtocol: TypeConstructorDescription { - case phoneCallProtocol(flags: Int32, minLayer: Int32, maxLayer: Int32) + case phoneCallProtocol(flags: Int32, minLayer: Int32, maxLayer: Int32, libraryVersions: [String]) public func serialize(_ buffer: Buffer, _ boxed: Swift.Bool) { switch self { - case .phoneCallProtocol(let flags, let minLayer, let maxLayer): + case .phoneCallProtocol(let flags, let minLayer, let maxLayer, let libraryVersions): if boxed { - buffer.appendInt32(-1564789301) + buffer.appendInt32(-58224696) } serializeInt32(flags, buffer: buffer, boxed: false) serializeInt32(minLayer, buffer: buffer, boxed: false) serializeInt32(maxLayer, buffer: buffer, boxed: false) + buffer.appendInt32(481674261) + buffer.appendInt32(Int32(libraryVersions.count)) + for item in libraryVersions { + serializeString(item, buffer: buffer, boxed: false) + } break } } public func descriptionFields() -> (String, [(String, Any)]) { switch self { - case .phoneCallProtocol(let flags, let minLayer, let maxLayer): - return ("phoneCallProtocol", [("flags", flags), ("minLayer", minLayer), ("maxLayer", maxLayer)]) + case .phoneCallProtocol(let flags, let minLayer, let maxLayer, let libraryVersions): + return ("phoneCallProtocol", [("flags", flags), ("minLayer", minLayer), ("maxLayer", maxLayer), ("libraryVersions", libraryVersions)]) } } @@ -14629,11 +14634,16 @@ public extension Api { _2 = reader.readInt32() var _3: Int32? _3 = reader.readInt32() + var _4: [String]? + if let _ = reader.readInt32() { + _4 = Api.parseVector(reader, elementSignature: -1255641564, elementType: String.self) + } let _c1 = _1 != nil let _c2 = _2 != nil let _c3 = _3 != nil - if _c1 && _c2 && _c3 { - return Api.PhoneCallProtocol.phoneCallProtocol(flags: _1!, minLayer: _2!, maxLayer: _3!) + let _c4 = _4 != nil + if _c1 && _c2 && _c3 && _c4 { + return Api.PhoneCallProtocol.phoneCallProtocol(flags: _1!, minLayer: _2!, maxLayer: _3!, libraryVersions: _4!) } else { return nil @@ -16258,6 +16268,7 @@ public extension Api { case inputStickerSetID(id: Int64, accessHash: Int64) case inputStickerSetShortName(shortName: String) case inputStickerSetAnimatedEmoji + case inputStickerSetDice public func serialize(_ buffer: Buffer, _ boxed: Swift.Bool) { switch self { @@ -16285,6 +16296,12 @@ public extension Api { buffer.appendInt32(42402760) } + break + case .inputStickerSetDice: + if boxed { + buffer.appendInt32(2044861011) + } + break } } @@ -16299,6 +16316,8 @@ public extension Api { return ("inputStickerSetShortName", [("shortName", shortName)]) case .inputStickerSetAnimatedEmoji: return ("inputStickerSetAnimatedEmoji", []) + case .inputStickerSetDice: + return ("inputStickerSetDice", []) } } @@ -16333,6 +16352,9 @@ public extension Api { public static func parse_inputStickerSetAnimatedEmoji(_ reader: BufferReader) -> InputStickerSet? { return Api.InputStickerSet.inputStickerSetAnimatedEmoji } + public static func parse_inputStickerSetDice(_ reader: BufferReader) -> InputStickerSet? { + return Api.InputStickerSet.inputStickerSetDice + } } public enum BotInfo: TypeConstructorDescription { diff --git a/submodules/TelegramCallsUI/Sources/PresentationCallManager.swift b/submodules/TelegramCallsUI/Sources/PresentationCallManager.swift index 6bfda0df93..2e5310dec2 100644 --- a/submodules/TelegramCallsUI/Sources/PresentationCallManager.swift +++ b/submodules/TelegramCallsUI/Sources/PresentationCallManager.swift @@ -75,6 +75,10 @@ public final class PresentationCallManagerImpl: PresentationCallManager { return OngoingCallContext.maxLayer } + public static var voipVersions: [String] { + return [OngoingCallContext.version] + } + public init(accountManager: AccountManager, getDeviceAccessData: @escaping () -> (presentationData: PresentationData, present: (ViewController, Any?) -> Void, openSettings: () -> Void), isMediaPlaying: @escaping () -> Bool, resumeMediaPlayback: @escaping () -> Void, audioSession: ManagedAudioSession, activeAccounts: Signal<[Account], NoError>) { self.getDeviceAccessData = getDeviceAccessData self.accountManager = accountManager diff --git a/submodules/TelegramCore/Sources/Account.swift b/submodules/TelegramCore/Sources/Account.swift index d28d1ee0a1..990e0a5ff1 100644 --- a/submodules/TelegramCore/Sources/Account.swift +++ b/submodules/TelegramCore/Sources/Account.swift @@ -901,7 +901,7 @@ public class Account { self.supplementary = supplementary self.peerInputActivityManager = PeerInputActivityManager() - self.callSessionManager = CallSessionManager(postbox: postbox, network: network, maxLayer: networkArguments.voipMaxLayer, addUpdates: { [weak self] updates in + self.callSessionManager = CallSessionManager(postbox: postbox, network: network, maxLayer: networkArguments.voipMaxLayer, versions: networkArguments.voipVersions, addUpdates: { [weak self] updates in self?.stateManager?.addUpdates(updates) }) self.stateManager = AccountStateManager(accountPeerId: self.peerId, accountManager: accountManager, postbox: self.postbox, network: self.network, callSessionManager: self.callSessionManager, addIsContactUpdates: { [weak self] updates in diff --git a/submodules/TelegramCore/Sources/CachedStickerPack.swift b/submodules/TelegramCore/Sources/CachedStickerPack.swift index 00f7a95fc4..4582c64171 100644 --- a/submodules/TelegramCore/Sources/CachedStickerPack.swift +++ b/submodules/TelegramCore/Sources/CachedStickerPack.swift @@ -76,6 +76,20 @@ public func cachedStickerPack(postbox: Postbox, network: Network, reference: Sti } else { return (.fetching, true, nil) } + case .dice: + let namespace = Namespaces.ItemCollection.CloudDice + let id: ItemCollectionId.Id = 0 + if let cached = transaction.retrieveItemCacheEntry(id: ItemCacheEntryId(collectionId: Namespaces.CachedItemCollection.cachedStickerPacks, key: CachedStickerPack.cacheKey(ItemCollectionId(namespace: namespace, id: id)))) as? CachedStickerPack, let info = cached.info { + previousHash = cached.hash + let current: CachedStickerPackResult = .result(info, cached.items, false) + if cached.hash != info.hash { + return (current, true, previousHash) + } else { + return (current, true, previousHash) + } + } else { + return (.fetching, true, nil) + } } } |> mapToSignal { result, loadRemote, previousHash in @@ -148,6 +162,18 @@ func cachedStickerPack(transaction: Transaction, reference: StickerPackReference if let cached = transaction.retrieveItemCacheEntry(id: ItemCacheEntryId(collectionId: Namespaces.CachedItemCollection.cachedStickerPacks, key: CachedStickerPack.cacheKey(ItemCollectionId(namespace: namespace, id: id)))) as? CachedStickerPack, let info = cached.info { return (info, cached.items, false) } + case .dice: + let namespace = Namespaces.ItemCollection.CloudDice + let id: ItemCollectionId.Id = 0 + if let currentInfo = transaction.getItemCollectionInfo(collectionId: ItemCollectionId(namespace: namespace, id: id)) as? StickerPackCollectionInfo { + let items = transaction.getItemCollectionItems(collectionId: ItemCollectionId(namespace: namespace, id: id)) + if !items.isEmpty { + return (currentInfo, items, true) + } + } + if let cached = transaction.retrieveItemCacheEntry(id: ItemCacheEntryId(collectionId: Namespaces.CachedItemCollection.cachedStickerPacks, key: CachedStickerPack.cacheKey(ItemCollectionId(namespace: namespace, id: id)))) as? CachedStickerPack, let info = cached.info { + return (info, cached.items, false) + } } return nil } diff --git a/submodules/TelegramCore/Sources/CallSessionManager.swift b/submodules/TelegramCore/Sources/CallSessionManager.swift index a84206744b..301a47a4ee 100644 --- a/submodules/TelegramCore/Sources/CallSessionManager.swift +++ b/submodules/TelegramCore/Sources/CallSessionManager.swift @@ -4,7 +4,6 @@ import MtProtoKit import SwiftSignalKit import TelegramApi - import SyncCore private let minLayer: Int32 = 65 @@ -241,6 +240,7 @@ private final class CallSessionManagerContext { private let postbox: Postbox private let network: Network private let maxLayer: Int32 + private let versions: [String] private let addUpdates: (Api.Updates) -> Void private let ringingSubscribers = Bag<([CallSessionRingingState]) -> Void>() @@ -249,11 +249,12 @@ private final class CallSessionManagerContext { private let disposables = DisposableSet() - init(queue: Queue, postbox: Postbox, network: Network, maxLayer: Int32, addUpdates: @escaping (Api.Updates) -> Void) { + init(queue: Queue, postbox: Postbox, network: Network, maxLayer: Int32, versions: [String], addUpdates: @escaping (Api.Updates) -> Void) { self.queue = queue self.postbox = postbox self.network = network self.maxLayer = maxLayer + self.versions = versions self.addUpdates = addUpdates } @@ -469,7 +470,7 @@ private final class CallSessionManagerContext { if let context = self.contexts[internalId] { switch context.state { case let .ringing(id, accessHash, gAHash, b): - context.state = .accepting(id: id, accessHash: accessHash, gAHash: gAHash, b: b, disposable: (acceptCallSession(postbox: self.postbox, network: self.network, stableId: id, accessHash: accessHash, b: b, maxLayer: self.maxLayer) |> deliverOn(self.queue)).start(next: { [weak self] result in + context.state = .accepting(id: id, accessHash: accessHash, gAHash: gAHash, b: b, disposable: (acceptCallSession(postbox: self.postbox, network: self.network, stableId: id, accessHash: accessHash, b: b, maxLayer: self.maxLayer, versions: self.versions) |> deliverOn(self.queue)).start(next: { [weak self] result in if let strongSelf = self, let context = strongSelf.contexts[internalId] { if case .accepting = context.state { switch result { @@ -534,7 +535,7 @@ private final class CallSessionManagerContext { let keyVisualHash = MTSha256(key + gA)! - context.state = .confirming(id: id, accessHash: accessHash, key: key, keyId: keyId, keyVisualHash: keyVisualHash, disposable: (confirmCallSession(network: self.network, stableId: id, accessHash: accessHash, gA: gA, keyFingerprint: keyId, maxLayer: self.maxLayer) |> deliverOnMainQueue).start(next: { [weak self] updatedCall in + context.state = .confirming(id: id, accessHash: accessHash, key: key, keyId: keyId, keyVisualHash: keyVisualHash, disposable: (confirmCallSession(network: self.network, stableId: id, accessHash: accessHash, gA: gA, keyFingerprint: keyId, maxLayer: self.maxLayer, versions: self.versions) |> deliverOnMainQueue).start(next: { [weak self] updatedCall in if let strongSelf = self, let context = strongSelf.contexts[internalId], case .confirming = context.state { if let updatedCall = updatedCall { strongSelf.updateSession(updatedCall, completion: { _ in }) @@ -616,7 +617,7 @@ private final class CallSessionManagerContext { if let (key, calculatedKeyId, keyVisualHash) = self.makeSessionEncryptionKey(config: config, gAHash: gAHash, b: b, gA: gAOrB.makeData()) { if keyFingerprint == calculatedKeyId { switch callProtocol { - case let .phoneCallProtocol(_, _, maxLayer): + case let .phoneCallProtocol(_, _, maxLayer, _): context.state = .active(id: id, accessHash: accessHash, beginTimestamp: startDate, key: key, keyId: calculatedKeyId, keyVisualHash: keyVisualHash, connections: parseConnectionSet(primary: connections.first!, alternative: Array(connections[1...])), maxLayer: maxLayer, allowsP2P: allowsP2P) self.contextUpdated(internalId: internalId) } @@ -628,7 +629,7 @@ private final class CallSessionManagerContext { } case let .confirming(id, accessHash, key, keyId, keyVisualHash, _): switch callProtocol { - case let .phoneCallProtocol(_, _, maxLayer): + case let .phoneCallProtocol(_, _, maxLayer, _): context.state = .active(id: id, accessHash: accessHash, beginTimestamp: startDate, key: key, keyId: keyId, keyVisualHash: keyVisualHash, connections: parseConnectionSet(primary: connections.first!, alternative: Array(connections[1...])), maxLayer: maxLayer, allowsP2P: allowsP2P) self.contextUpdated(internalId: internalId) } @@ -709,7 +710,7 @@ private final class CallSessionManagerContext { let randomStatus = SecRandomCopyBytes(nil, 256, aBytes.assumingMemoryBound(to: UInt8.self)) let a = Data(bytesNoCopy: aBytes, count: 256, deallocator: .free) if randomStatus == 0 { - self.contexts[internalId] = CallSessionContext(peerId: peerId, isOutgoing: true, state: .requesting(a: a, disposable: (requestCallSession(postbox: self.postbox, network: self.network, peerId: peerId, a: a, maxLayer: self.maxLayer) |> deliverOn(queue)).start(next: { [weak self] result in + self.contexts[internalId] = CallSessionContext(peerId: peerId, isOutgoing: true, state: .requesting(a: a, disposable: (requestCallSession(postbox: self.postbox, network: self.network, peerId: peerId, a: a, maxLayer: self.maxLayer, versions: self.versions) |> deliverOn(queue)).start(next: { [weak self] result in if let strongSelf = self, let context = strongSelf.contexts[internalId] { if case .requesting = context.state { switch result { @@ -743,9 +744,9 @@ public final class CallSessionManager { private let queue = Queue() private var contextRef: Unmanaged? - init(postbox: Postbox, network: Network, maxLayer: Int32, addUpdates: @escaping (Api.Updates) -> Void) { + init(postbox: Postbox, network: Network, maxLayer: Int32, versions: [String], addUpdates: @escaping (Api.Updates) -> Void) { self.queue.async { - let context = CallSessionManagerContext(queue: self.queue, postbox: postbox, network: network, maxLayer: maxLayer, addUpdates: addUpdates) + let context = CallSessionManagerContext(queue: self.queue, postbox: postbox, network: network, maxLayer: maxLayer, versions: versions, addUpdates: addUpdates) self.contextRef = Unmanaged.passRetained(context) } } @@ -846,7 +847,7 @@ private enum AcceptCallResult { case success(AcceptedCall) } -private func acceptCallSession(postbox: Postbox, network: Network, stableId: CallSessionStableId, accessHash: Int64, b: Data, maxLayer: Int32) -> Signal { +private func acceptCallSession(postbox: Postbox, network: Network, stableId: CallSessionStableId, accessHash: Int64, b: Data, maxLayer: Int32, versions: [String]) -> Signal { return validatedEncryptionConfig(postbox: postbox, network: network) |> mapToSignal { config -> Signal in var gValue: Int32 = config.g.byteSwapped @@ -860,8 +861,8 @@ private func acceptCallSession(postbox: Postbox, network: Network, stableId: Cal if !MTCheckIsSafeGAOrB(network.encryptionProvider, gb, p) { return .single(.failed) } - - return network.request(Api.functions.phone.acceptCall(peer: .inputPhoneCall(id: stableId, accessHash: accessHash), gB: Buffer(data: gb), protocol: .phoneCallProtocol(flags: (1 << 0) | (1 << 1), minLayer: minLayer, maxLayer: maxLayer))) + + return network.request(Api.functions.phone.acceptCall(peer: .inputPhoneCall(id: stableId, accessHash: accessHash), gB: Buffer(data: gb), protocol: .phoneCallProtocol(flags: (1 << 0) | (1 << 1), minLayer: minLayer, maxLayer: maxLayer, libraryVersions: versions))) |> map(Optional.init) |> `catch` { _ -> Signal in return .single(nil) @@ -887,7 +888,7 @@ private func acceptCallSession(postbox: Postbox, network: Network, stableId: Cal case let .phoneCall(flags, id, _, _, _, _, gAOrB, _, callProtocol, connections, startDate): if id == stableId { switch callProtocol{ - case let .phoneCallProtocol(_, _, maxLayer): + case let .phoneCallProtocol(_, _, maxLayer, _): return .success(.call(config: config, gA: gAOrB.makeData(), timestamp: startDate, connections: parseConnectionSet(primary: connections.first!, alternative: Array(connections[1...])), maxLayer: maxLayer, allowsP2P: (flags & (1 << 5)) != 0)) } } else { @@ -908,7 +909,7 @@ private enum RequestCallSessionResult { case failed(CallSessionError) } -private func requestCallSession(postbox: Postbox, network: Network, peerId: PeerId, a: Data, maxLayer: Int32) -> Signal { +private func requestCallSession(postbox: Postbox, network: Network, peerId: PeerId, a: Data, maxLayer: Int32, versions: [String]) -> Signal { return validatedEncryptionConfig(postbox: postbox, network: network) |> mapToSignal { config -> Signal in return postbox.transaction { transaction -> Signal in @@ -924,7 +925,7 @@ private func requestCallSession(postbox: Postbox, network: Network, peerId: Peer let gAHash = MTSha256(ga)! - return network.request(Api.functions.phone.requestCall(flags: 0, userId: inputUser, randomId: Int32(bitPattern: arc4random()), gAHash: Buffer(data: gAHash), protocol: .phoneCallProtocol(flags: (1 << 0) | (1 << 1), minLayer: minLayer, maxLayer: maxLayer))) + return network.request(Api.functions.phone.requestCall(flags: 0, userId: inputUser, randomId: Int32(bitPattern: arc4random()), gAHash: Buffer(data: gAHash), protocol: .phoneCallProtocol(flags: (1 << 0) | (1 << 1), minLayer: minLayer, maxLayer: maxLayer, libraryVersions: versions))) |> map { result -> RequestCallSessionResult in switch result { case let .phoneCall(phoneCall, _): @@ -960,8 +961,8 @@ private func requestCallSession(postbox: Postbox, network: Network, peerId: Peer } } -private func confirmCallSession(network: Network, stableId: CallSessionStableId, accessHash: Int64, gA: Data, keyFingerprint: Int64, maxLayer: Int32) -> Signal { - return network.request(Api.functions.phone.confirmCall(peer: Api.InputPhoneCall.inputPhoneCall(id: stableId, accessHash: accessHash), gA: Buffer(data: gA), keyFingerprint: keyFingerprint, protocol: .phoneCallProtocol(flags: (1 << 0) | (1 << 1), minLayer: minLayer, maxLayer: maxLayer))) +private func confirmCallSession(network: Network, stableId: CallSessionStableId, accessHash: Int64, gA: Data, keyFingerprint: Int64, maxLayer: Int32, versions: [String]) -> Signal { + return network.request(Api.functions.phone.confirmCall(peer: Api.InputPhoneCall.inputPhoneCall(id: stableId, accessHash: accessHash), gA: Buffer(data: gA), keyFingerprint: keyFingerprint, protocol: .phoneCallProtocol(flags: (1 << 0) | (1 << 1), minLayer: minLayer, maxLayer: maxLayer, libraryVersions: versions))) |> map(Optional.init) |> `catch` { _ -> Signal in return .single(nil) diff --git a/submodules/TelegramCore/Sources/LoadedStickerPack.swift b/submodules/TelegramCore/Sources/LoadedStickerPack.swift index 5a657b13b1..d19b4ab1f5 100644 --- a/submodules/TelegramCore/Sources/LoadedStickerPack.swift +++ b/submodules/TelegramCore/Sources/LoadedStickerPack.swift @@ -18,6 +18,8 @@ extension StickerPackReference { return .inputStickerSetShortName(shortName: name) case .animatedEmoji: return .inputStickerSetAnimatedEmoji + case .dice: + return .inputStickerSetDice } } } diff --git a/submodules/TelegramCore/Sources/Network.swift b/submodules/TelegramCore/Sources/Network.swift index 24b84d3fff..5a7d148b23 100644 --- a/submodules/TelegramCore/Sources/Network.swift +++ b/submodules/TelegramCore/Sources/Network.swift @@ -403,16 +403,18 @@ public struct NetworkInitializationArguments { public let languagesCategory: String public let appVersion: String public let voipMaxLayer: Int32 + public let voipVersions: [String] public let appData: Signal public let autolockDeadine: Signal public let encryptionProvider: EncryptionProvider - public init(apiId: Int32, apiHash: String, languagesCategory: String, appVersion: String, voipMaxLayer: Int32, appData: Signal, autolockDeadine: Signal, encryptionProvider: EncryptionProvider) { + public init(apiId: Int32, apiHash: String, languagesCategory: String, appVersion: String, voipMaxLayer: Int32, voipVersions: [String], appData: Signal, autolockDeadine: Signal, encryptionProvider: EncryptionProvider) { self.apiId = apiId self.apiHash = apiHash self.languagesCategory = languagesCategory self.appVersion = appVersion self.voipMaxLayer = voipMaxLayer + self.voipVersions = voipVersions self.appData = appData self.autolockDeadine = autolockDeadine self.encryptionProvider = encryptionProvider diff --git a/submodules/TelegramCore/Sources/StickerSetInstallation.swift b/submodules/TelegramCore/Sources/StickerSetInstallation.swift index f8f84a4e2d..8a6a1eb5d8 100644 --- a/submodules/TelegramCore/Sources/StickerSetInstallation.swift +++ b/submodules/TelegramCore/Sources/StickerSetInstallation.swift @@ -38,6 +38,9 @@ public func requestStickerSet(postbox: Postbox, network: Network, reference: Sti case .animatedEmoji: collectionId = nil input = .inputStickerSetAnimatedEmoji + case .dice: + collectionId = nil + input = .inputStickerSetDice } let localSignal: (ItemCollectionId) -> Signal<(ItemCollectionInfo, [ItemCollectionItem])?, NoError> = { collectionId in diff --git a/submodules/TelegramCore/Sources/SynchronizeSavedStickersOperation.swift b/submodules/TelegramCore/Sources/SynchronizeSavedStickersOperation.swift index f606cfe342..bd53548f3e 100644 --- a/submodules/TelegramCore/Sources/SynchronizeSavedStickersOperation.swift +++ b/submodules/TelegramCore/Sources/SynchronizeSavedStickersOperation.swift @@ -62,7 +62,7 @@ public func addSavedSticker(postbox: Postbox, network: Network, file: TelegramMe if !found { fetchReference = packReference } - case .animatedEmoji: + case .animatedEmoji, .dice: break } if let fetchReference = fetchReference { diff --git a/submodules/TelegramCore/Sources/TelegramMediaFile.swift b/submodules/TelegramCore/Sources/TelegramMediaFile.swift index 51edbe126b..eebae28228 100644 --- a/submodules/TelegramCore/Sources/TelegramMediaFile.swift +++ b/submodules/TelegramCore/Sources/TelegramMediaFile.swift @@ -59,6 +59,8 @@ extension StickerPackReference { self = .name(shortName) case .inputStickerSetAnimatedEmoji: self = .animatedEmoji + case .inputStickerSetDice: + self = .dice } } } diff --git a/submodules/TelegramUI/TelegramUI/AppDelegate.swift b/submodules/TelegramUI/TelegramUI/AppDelegate.swift index 6b6d402bb3..1cb3934f87 100644 --- a/submodules/TelegramUI/TelegramUI/AppDelegate.swift +++ b/submodules/TelegramUI/TelegramUI/AppDelegate.swift @@ -393,7 +393,7 @@ final class SharedApplicationContext { } } - let networkArguments = NetworkInitializationArguments(apiId: apiId, apiHash: apiHash, languagesCategory: languagesCategory, appVersion: appVersion, voipMaxLayer: PresentationCallManagerImpl.voipMaxLayer, appData: self.deviceToken.get() + let networkArguments = NetworkInitializationArguments(apiId: apiId, apiHash: apiHash, languagesCategory: languagesCategory, appVersion: appVersion, voipMaxLayer: PresentationCallManagerImpl.voipMaxLayer, voipVersions: PresentationCallManagerImpl.voipVersions, appData: self.deviceToken.get() |> map { token in let data = buildConfig.bundleData(withAppToken: token, signatureDict: signatureDict) if let data = data, let jsonString = String(data: data, encoding: .utf8) { diff --git a/submodules/TelegramUI/TelegramUI/NotificationContentContext.swift b/submodules/TelegramUI/TelegramUI/NotificationContentContext.swift index 415104c251..50b8133924 100644 --- a/submodules/TelegramUI/TelegramUI/NotificationContentContext.swift +++ b/submodules/TelegramUI/TelegramUI/NotificationContentContext.swift @@ -154,7 +154,7 @@ public final class NotificationViewControllerImpl { return nil }) - sharedAccountContext = SharedAccountContextImpl(mainWindow: nil, basePath: rootPath, encryptionParameters: ValueBoxEncryptionParameters(forceEncryptionIfNoSet: false, key: ValueBoxEncryptionParameters.Key(data: self.initializationData.encryptionParameters.0)!, salt: ValueBoxEncryptionParameters.Salt(data: self.initializationData.encryptionParameters.1)!), accountManager: accountManager, appLockContext: appLockContext, applicationBindings: applicationBindings, initialPresentationDataAndSettings: initialPresentationDataAndSettings!, networkArguments: NetworkInitializationArguments(apiId: self.initializationData.apiId, apiHash: self.initializationData.apiHash, languagesCategory: self.initializationData.languagesCategory, appVersion: self.initializationData.appVersion, voipMaxLayer: 0, appData: .single(self.initializationData.bundleData), autolockDeadine: .single(nil), encryptionProvider: OpenSSLEncryptionProvider()), rootPath: rootPath, legacyBasePath: nil, legacyCache: nil, apsNotificationToken: .never(), voipNotificationToken: .never(), setNotificationCall: { _ in }, navigateToChat: { _, _, _ in }) + sharedAccountContext = SharedAccountContextImpl(mainWindow: nil, basePath: rootPath, encryptionParameters: ValueBoxEncryptionParameters(forceEncryptionIfNoSet: false, key: ValueBoxEncryptionParameters.Key(data: self.initializationData.encryptionParameters.0)!, salt: ValueBoxEncryptionParameters.Salt(data: self.initializationData.encryptionParameters.1)!), accountManager: accountManager, appLockContext: appLockContext, applicationBindings: applicationBindings, initialPresentationDataAndSettings: initialPresentationDataAndSettings!, networkArguments: NetworkInitializationArguments(apiId: self.initializationData.apiId, apiHash: self.initializationData.apiHash, languagesCategory: self.initializationData.languagesCategory, appVersion: self.initializationData.appVersion, voipMaxLayer: 0, voipVersions: [], appData: .single(self.initializationData.bundleData), autolockDeadine: .single(nil), encryptionProvider: OpenSSLEncryptionProvider()), rootPath: rootPath, legacyBasePath: nil, legacyCache: nil, apsNotificationToken: .never(), voipNotificationToken: .never(), setNotificationCall: { _ in }, navigateToChat: { _, _, _ in }) presentationDataPromise.set(sharedAccountContext!.presentationData) } diff --git a/submodules/TelegramUI/TelegramUI/ShareExtensionContext.swift b/submodules/TelegramUI/TelegramUI/ShareExtensionContext.swift index 831d15766c..91c4c09e33 100644 --- a/submodules/TelegramUI/TelegramUI/ShareExtensionContext.swift +++ b/submodules/TelegramUI/TelegramUI/ShareExtensionContext.swift @@ -192,7 +192,7 @@ public class ShareRootControllerImpl { return nil }) - let sharedContext = SharedAccountContextImpl(mainWindow: nil, basePath: rootPath, encryptionParameters: ValueBoxEncryptionParameters(forceEncryptionIfNoSet: false, key: ValueBoxEncryptionParameters.Key(data: self.initializationData.encryptionParameters.0)!, salt: ValueBoxEncryptionParameters.Salt(data: self.initializationData.encryptionParameters.1)!), accountManager: accountManager, appLockContext: appLockContext, applicationBindings: applicationBindings, initialPresentationDataAndSettings: initialPresentationDataAndSettings!, networkArguments: NetworkInitializationArguments(apiId: self.initializationData.apiId, apiHash: self.initializationData.apiHash, languagesCategory: self.initializationData.languagesCategory, appVersion: self.initializationData.appVersion, voipMaxLayer: 0, appData: .single(self.initializationData.bundleData), autolockDeadine: .single(nil), encryptionProvider: OpenSSLEncryptionProvider()), rootPath: rootPath, legacyBasePath: nil, legacyCache: nil, apsNotificationToken: .never(), voipNotificationToken: .never(), setNotificationCall: { _ in }, navigateToChat: { _, _, _ in }) + let sharedContext = SharedAccountContextImpl(mainWindow: nil, basePath: rootPath, encryptionParameters: ValueBoxEncryptionParameters(forceEncryptionIfNoSet: false, key: ValueBoxEncryptionParameters.Key(data: self.initializationData.encryptionParameters.0)!, salt: ValueBoxEncryptionParameters.Salt(data: self.initializationData.encryptionParameters.1)!), accountManager: accountManager, appLockContext: appLockContext, applicationBindings: applicationBindings, initialPresentationDataAndSettings: initialPresentationDataAndSettings!, networkArguments: NetworkInitializationArguments(apiId: self.initializationData.apiId, apiHash: self.initializationData.apiHash, languagesCategory: self.initializationData.languagesCategory, appVersion: self.initializationData.appVersion, voipMaxLayer: 0, voipVersions: [], appData: .single(self.initializationData.bundleData), autolockDeadine: .single(nil), encryptionProvider: OpenSSLEncryptionProvider()), rootPath: rootPath, legacyBasePath: nil, legacyCache: nil, apsNotificationToken: .never(), voipNotificationToken: .never(), setNotificationCall: { _ in }, navigateToChat: { _, _, _ in }) presentationDataPromise.set(sharedContext.presentationData) internalContext = InternalContext(sharedContext: sharedContext) globalInternalContext = internalContext diff --git a/submodules/TelegramVoip/Sources/OngoingCallContext.swift b/submodules/TelegramVoip/Sources/OngoingCallContext.swift index 210144168a..016897e9fe 100644 --- a/submodules/TelegramVoip/Sources/OngoingCallContext.swift +++ b/submodules/TelegramVoip/Sources/OngoingCallContext.swift @@ -173,6 +173,10 @@ public final class OngoingCallContext { return OngoingCallThreadLocalContext.maxLayer() } + public static var version: String { + return OngoingCallThreadLocalContext.version()! + } + public init(account: Account, callSessionManager: CallSessionManager, internalId: CallSessionInternalId, proxyServer: ProxyServerSettings?, initialNetworkType: NetworkType, updatedNetworkType: Signal, serializedData: String?, dataSaving: VoiceCallDataSaving, derivedState: VoipDerivedState) { let _ = setupLogs OngoingCallThreadLocalContext.applyServerConfig(serializedData) diff --git a/submodules/libtgvoip/OngoingCallThreadLocalContext.h b/submodules/libtgvoip/OngoingCallThreadLocalContext.h index 374c9dc6a2..674a80d80e 100644 --- a/submodules/libtgvoip/OngoingCallThreadLocalContext.h +++ b/submodules/libtgvoip/OngoingCallThreadLocalContext.h @@ -59,6 +59,7 @@ typedef NS_ENUM(int32_t, OngoingCallDataSaving) { + (void)setupLoggingFunction:(void (* _Nullable)(NSString * _Nullable))loggingFunction; + (void)applyServerConfig:(NSString * _Nullable)data; + (int32_t)maxLayer; ++ (NSString *)version; @property (nonatomic, copy) void (^ _Nullable stateChanged)(OngoingCallState); @property (nonatomic, copy) void (^ _Nullable signalBarsChanged)(int32_t); diff --git a/submodules/libtgvoip/OngoingCallThreadLocalContext.mm b/submodules/libtgvoip/OngoingCallThreadLocalContext.mm index c98bcf146f..125a7b849a 100644 --- a/submodules/libtgvoip/OngoingCallThreadLocalContext.mm +++ b/submodules/libtgvoip/OngoingCallThreadLocalContext.mm @@ -218,6 +218,10 @@ static int callControllerDataSavingForType(OngoingCallDataSaving type) { return tgvoip::VoIPController::GetConnectionMaxLayer(); } ++ (NSString *)version { + return [NSString stringWithUTF8String:tgvoip::VoIPController::GetVersion()]; +} + - (instancetype _Nonnull)initWithQueue:(id _Nonnull)queue proxy:(VoipProxyServer * _Nullable)proxy networkType:(OngoingCallNetworkType)networkType dataSaving:(OngoingCallDataSaving)dataSaving derivedState:(NSData * _Nonnull)derivedState { self = [super init]; if (self != nil) { From 5e724b92eac51455c265cf9ae3d47ec1a63f5905 Mon Sep 17 00:00:00 2001 From: Ali <> Date: Fri, 28 Feb 2020 20:22:39 +0400 Subject: [PATCH 2/6] Filter improvements --- Telegram-iOS/en.lproj/Localizable.strings | 2 + .../ContactMultiselectionController.swift | 1 + .../Sources/ChatListController.swift | 459 +- .../Sources/ChatListControllerNode.swift | 660 +- .../ChatListFilterPresetController.swift | 40 +- .../ChatListFilterPresetListController.swift | 59 +- .../ChatListFilterPresetListItem.swift | 47 +- .../ChatListFilterTabContainerNode.swift | 37 +- .../Sources/Node/ChatListNode.swift | 105 +- .../Sources/Node/ChatListNodeLocation.swift | 4 +- .../TabBarChatListFilterController.swift | 32 +- .../ContextUI/Sources/ContextController.swift | 2 +- ...teractiveTransitionGestureRecognizer.swift | 46 +- .../Navigation/NavigationContainer.swift | 2 +- .../Navigation/NavigationModalContainer.swift | 2 +- .../Display/Display/TabBarContollerNode.swift | 4 +- .../Display/Display/TabBarController.swift | 7 + submodules/Display/Display/TabBarNode.swift | 38 +- .../Display/Display/ViewController.swift | 3 + .../Sources/Items/ItemListEditableItem.swift | 1 + .../Items/ItemListSingleLineInputItem.swift | 5 +- .../Postbox/Sources/ChatListTable.swift | 19 + submodules/Postbox/Sources/ChatListView.swift | 51 +- submodules/Postbox/Sources/Postbox.swift | 39 +- .../Postbox/Sources/SqliteValueBox.swift | 40 +- submodules/Postbox/Sources/ValueBox.swift | 1 + .../Sources/SettingsController.swift | 102 +- submodules/TelegramCore/Sources/Account.swift | 2 +- .../Sources/ChatListFiltering.swift | 190 +- .../Sources/PresentationStrings.swift | 7623 +++++++++-------- .../Context Menu/List.imageset/Contents.json | 2 +- .../{ic_list.pdf => ic_folder.pdf} | Bin 4167 -> 4254 bytes .../ContactMultiselectionController.swift | 189 +- .../ContactMultiselectionControllerNode.swift | 77 +- .../PeerInfo/PeerInfoPaneContainerNode.swift | 2 +- .../PeerSelectionControllerNode.swift | 6 +- .../Resources/PresentationStrings.mapping | Bin 146163 -> 146203 bytes .../WalletUI/Resources/WalletStrings.mapping | Bin 8384 -> 8384 bytes .../WalletUI/Sources/WalletStrings.swift | 4 +- 39 files changed, 5519 insertions(+), 4384 deletions(-) rename submodules/TelegramUI/Images.xcassets/Chat/Context Menu/List.imageset/{ic_list.pdf => ic_folder.pdf} (76%) diff --git a/Telegram-iOS/en.lproj/Localizable.strings b/Telegram-iOS/en.lproj/Localizable.strings index a0af4e214f..17dbcd68bf 100644 --- a/Telegram-iOS/en.lproj/Localizable.strings +++ b/Telegram-iOS/en.lproj/Localizable.strings @@ -5366,3 +5366,5 @@ Any member of this group will be able to see messages in the channel."; "Stats.ViewsBySourceTitle" = "VIEWS BY SOURCE"; "Stats.FollowersBySourceTitle" = "FOLLOWERS BY SOURCE"; "Stats.LanguagesTitle" = "LANGUAGES"; + +"ChatListFilter.AddChatsTitle" = "Add Chats"; diff --git a/submodules/AccountContext/Sources/ContactMultiselectionController.swift b/submodules/AccountContext/Sources/ContactMultiselectionController.swift index 0d69cfc183..cfbe13f9f2 100644 --- a/submodules/AccountContext/Sources/ContactMultiselectionController.swift +++ b/submodules/AccountContext/Sources/ContactMultiselectionController.swift @@ -7,6 +7,7 @@ public enum ContactMultiselectionControllerMode { case groupCreation case peerSelection(searchChatList: Bool, searchGroups: Bool, searchChannels: Bool) case channelCreation + case chatSelection } public enum ContactListFilter { diff --git a/submodules/ChatListUI/Sources/ChatListController.swift b/submodules/ChatListUI/Sources/ChatListController.swift index 751772e64b..8e41b09f4c 100644 --- a/submodules/ChatListUI/Sources/ChatListController.swift +++ b/submodules/ChatListUI/Sources/ChatListController.swift @@ -23,19 +23,26 @@ import LocalizedPeerData import TelegramIntents private func fixListNodeScrolling(_ listNode: ListView, searchNode: NavigationBarSearchContentNode) -> Bool { + if listNode.scroller.isDragging { + return false + } if searchNode.expansionProgress > 0.0 && searchNode.expansionProgress < 1.0 { let scrollToItem: ListViewScrollToItem let targetProgress: CGFloat + let offset: CGFloat if searchNode.expansionProgress < 0.6 { scrollToItem = ListViewScrollToItem(index: 0, position: .top(-navigationBarSearchContentHeight), animated: true, curve: .Default(duration: nil), directionHint: .Up) targetProgress = 0.0 + offset = navigationBarSearchContentHeight } else { scrollToItem = ListViewScrollToItem(index: 0, position: .top(0.0), animated: true, curve: .Default(duration: nil), directionHint: .Up) targetProgress = 1.0 + offset = 0.0 } - searchNode.updateExpansionProgress(targetProgress, animated: true) + //searchNode.updateExpansionProgress(targetProgress, animated: true) - listNode.transaction(deleteIndices: [], insertIndicesAndItems: [], updateIndicesAndItems: [], options: ListViewDeleteAndInsertOptions(), scrollToItem: scrollToItem, updateSizeAndInsets: nil, stationaryItemRange: nil, updateOpaqueState: nil, completion: { _ in }) + //listNode.transaction(deleteIndices: [], insertIndicesAndItems: [], updateIndicesAndItems: [], options: ListViewDeleteAndInsertOptions(), scrollToItem: scrollToItem, updateSizeAndInsets: nil, stationaryItemRange: nil, updateOpaqueState: nil, completion: { _ in }) + listNode.scrollToOffsetFromTop(offset) return true } else if searchNode.expansionProgress == 1.0 { var sortItemNode: ListViewItemNode? @@ -138,13 +145,11 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, private var searchContentNode: NavigationBarSearchContentNode? private let tabContainerNode: ChatListFilterTabContainerNode - private var tabContainerData: ([ChatListFilterTabEntry], ChatListFilterTabEntryId)? - - private let chatListFilterValue = Promise() + private var tabContainerData: [ChatListFilterTabEntry]? public override func updateNavigationCustomData(_ data: Any?, progress: CGFloat, transition: ContainedViewLayoutTransition) { if self.isNodeLoaded { - self.chatListDisplayNode.chatListNode.updateSelectedChatLocation(data as? ChatLocation, progress: progress, transition: transition) + self.chatListDisplayNode.containerNode.updateSelectedChatLocation(data: data as? ChatLocation, progress: progress, transition: transition) } } @@ -232,12 +237,12 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, if strongSelf.chatListDisplayNode.searchDisplayController != nil { strongSelf.deactivateSearch(animated: true) } else { - switch strongSelf.chatListDisplayNode.chatListNode.visibleContentOffset() { + switch strongSelf.chatListDisplayNode.containerNode.currentItemNode.visibleContentOffset() { case .none, .unknown: if let searchContentNode = strongSelf.searchContentNode { searchContentNode.updateExpansionProgress(1.0, animated: true) } - strongSelf.chatListDisplayNode.chatListNode.scrollToPosition(.top) + strongSelf.chatListDisplayNode.containerNode.currentItemNode.scrollToPosition(.top) case let .known(offset): if offset <= navigationBarSearchContentHeight + 1.0 { strongSelf.tabContainerNode.tabSelected?(.all) @@ -245,24 +250,11 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, if let searchContentNode = strongSelf.searchContentNode { searchContentNode.updateExpansionProgress(1.0, animated: true) } - strongSelf.chatListDisplayNode.chatListNode.scrollToPosition(.top) + strongSelf.chatListDisplayNode.containerNode.currentItemNode.scrollToPosition(.top) } } } } - self.longTapWithTabBar = { [weak self] in - guard let strongSelf = self else { - return - } - if strongSelf.chatListDisplayNode.searchDisplayController != nil { - strongSelf.deactivateSearch(animated: true) - } else { - if let searchContentNode = strongSelf.searchContentNode { - searchContentNode.updateExpansionProgress(1.0, animated: true) - } - strongSelf.chatListDisplayNode.chatListNode.scrollToPosition(.auto) - } - } let hasProxy = context.sharedContext.accountManager.sharedData(keys: [SharedDataKeys.proxySettings]) |> map { sharedData -> (Bool, Bool) in @@ -287,22 +279,17 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, context.account.networkState, hasProxy, passcode, - self.chatListDisplayNode.chatListNode.state + self.chatListDisplayNode.containerNode.currentItemState ).start(next: { [weak self] networkState, proxy, passcode, state in if let strongSelf = self { let defaultTitle: String if strongSelf.groupId == .root { - if let chatListFilter = strongSelf.filter { - let title: String = chatListFilter.title ?? strongSelf.presentationData.strings.DialogList_Title - defaultTitle = title - } else { - defaultTitle = strongSelf.presentationData.strings.DialogList_Title - } + defaultTitle = strongSelf.presentationData.strings.DialogList_Title } else { defaultTitle = strongSelf.presentationData.strings.ChatList_ArchivedChatsTitle } if state.editing { - if strongSelf.groupId == .root && strongSelf.filter == nil { + if strongSelf.groupId == .root { strongSelf.navigationItem.rightBarButtonItem = nil } @@ -312,11 +299,9 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, var isRoot = false if case .root = strongSelf.groupId { isRoot = true - if strongSelf.filter == nil { - let rightBarButtonItem = UIBarButtonItem(image: PresentationResourcesRootController.navigationComposeIcon(strongSelf.presentationData.theme), style: .plain, target: strongSelf, action: #selector(strongSelf.composePressed)) - rightBarButtonItem.accessibilityLabel = strongSelf.presentationData.strings.VoiceOver_Navigation_Compose - strongSelf.navigationItem.rightBarButtonItem = rightBarButtonItem - } + let rightBarButtonItem = UIBarButtonItem(image: PresentationResourcesRootController.navigationComposeIcon(strongSelf.presentationData.theme), style: .plain, target: strongSelf, action: #selector(strongSelf.composePressed)) + rightBarButtonItem.accessibilityLabel = strongSelf.presentationData.strings.VoiceOver_Navigation_Compose + strongSelf.navigationItem.rightBarButtonItem = rightBarButtonItem } let (hasProxy, connectsViaProxy) = proxy @@ -420,30 +405,39 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, } if self.filter == nil { + self.chatListDisplayNode.containerNode.currentItemFilterUpdated = { [weak self] filter, fraction, transition in + guard let strongSelf = self else { + return + } + guard let layout = strongSelf.validLayout else { + return + } + guard let tabContainerData = strongSelf.tabContainerData else { + return + } + strongSelf.tabContainerNode.update(size: CGSize(width: layout.size.width, height: 46.0), sideInset: layout.safeInsets.left, filters: tabContainerData, selectedFilter: filter, transitionFraction: fraction, presentationData: strongSelf.presentationData, transition: transition) + } let preferencesKey: PostboxViewKey = .preferences(keys: Set([ ApplicationSpecificPreferencesKeys.chatListFilterSettings ])) let filterItems = chatListFilterItems(context: context) - |> map { totalCount, items -> [ChatListFilterTabEntry] in - var result: [ChatListFilterTabEntry] = [] - result.append(.all(unreadCount: totalCount)) - for (filter, unreadCount) in items { - result.append(.filter(id: filter.id, text: filter.title ?? "", unreadCount: unreadCount)) - } - return result - } - |> distinctUntilChanged self.filterDisposable = (combineLatest(queue: .mainQueue(), context.account.postbox.combinedView(keys: [ preferencesKey ]), - filterItems, - self.chatListFilterValue.get() |> map { $0?.id } |> distinctUntilChanged + filterItems ) - |> deliverOnMainQueue).start(next: { [weak self] combinedView, filterItems, selectedFilter in + |> deliverOnMainQueue).start(next: { [weak self] combinedView, countAndFilterItems in guard let strongSelf = self else { return } + let (totalCount, items) = countAndFilterItems + var filterItems: [ChatListFilterTabEntry] = [] + filterItems.append(.all(unreadCount: totalCount)) + for (filter, unreadCount) in items { + filterItems.append(.filter(id: filter.id, text: filter.title, unreadCount: unreadCount)) + } + var filterSettings: ChatListFilterSettings = .default if let preferencesView = combinedView.views[preferencesKey] as? PreferencesView { if let value = preferencesView.values[ApplicationSpecificPreferencesKeys.chatListFilterSettings] as? ChatListFilterSettings { @@ -458,12 +452,18 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, var wasEmpty = false if let tabContainerData = strongSelf.tabContainerData { - wasEmpty = tabContainerData.0.count <= 1 + wasEmpty = tabContainerData.count <= 1 } else { wasEmpty = true } - let selectedEntryId: ChatListFilterTabEntryId = selectedFilter.flatMap { .filter($0) } ?? .all - strongSelf.tabContainerData = (resolvedItems, selectedEntryId) + let selectedEntryId = strongSelf.chatListDisplayNode.containerNode.currentItemFilter + strongSelf.tabContainerData = resolvedItems + var availableFilters: [ChatListContainerNodeFilter] = [] + availableFilters.append(.all) + for item in items { + availableFilters.append(.filter(item.0)) + } + strongSelf.chatListDisplayNode.containerNode.updateAvailableFilters(availableFilters) let isEmpty = resolvedItems.count <= 1 @@ -479,7 +479,7 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, strongSelf.containerLayoutUpdated(layout, transition: .immediate) (strongSelf.parent as? TabBarController)?.updateLayout() } else { - strongSelf.tabContainerNode.update(size: CGSize(width: layout.size.width, height: NavigationBar.defaultSecondaryContentHeight), sideInset: layout.safeInsets.left, filters: resolvedItems, selectedFilter: selectedEntryId, presentationData: strongSelf.presentationData, transition: .animated(duration: 0.4, curve: .spring)) + strongSelf.tabContainerNode.update(size: CGSize(width: layout.size.width, height: 46.0), sideInset: layout.safeInsets.left, filters: resolvedItems, selectedFilter: selectedEntryId, transitionFraction: strongSelf.chatListDisplayNode.containerNode.transitionFraction, presentationData: strongSelf.presentationData, transition: .animated(duration: 0.4, curve: .spring)) } } }) @@ -497,7 +497,7 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, guard let strongSelf = self else { return } - let previousFilter = strongSelf.chatListDisplayNode.chatListNode.chatListFilter + let previousFilter = strongSelf.chatListDisplayNode.containerNode.currentItemNode.chatListFilter let updatedFilter: ChatListFilter? switch id { case .all: @@ -518,26 +518,7 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, updatedFilter = nil } } - if previousFilter?.id != updatedFilter?.id { - var paneSwitchAnimationDirection: ChatListNodePaneSwitchAnimationDirection? - if let previousId = previousFilter?.id, let updatedId = updatedFilter?.id, let previousIndex = filters.index(where: { $0.id == previousId }), let updatedIndex = filters.index(where: { $0.id == updatedId }) { - if previousIndex > updatedIndex { - paneSwitchAnimationDirection = .right - } else { - paneSwitchAnimationDirection = .left - } - } else if (previousFilter != nil) != (updatedFilter != nil) { - if previousFilter != nil { - paneSwitchAnimationDirection = .right - } else { - paneSwitchAnimationDirection = .left - } - } - if let direction = paneSwitchAnimationDirection { - strongSelf.chatListDisplayNode.chatListNode.paneSwitchAnimation = (direction, .animated(duration: 0.4, curve: .spring)) - } - } - strongSelf.chatListDisplayNode.chatListNode.updateFilter(updatedFilter) + strongSelf.chatListDisplayNode.containerNode.switchToFilter(id: updatedFilter.flatMap { .filter($0.id) } ?? .all) }) } @@ -549,38 +530,17 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, guard let strongSelf = self else { return } - var items: [ContextMenuItem] = [] - items.append(.action(ContextMenuActionItem(text: strongSelf.presentationData.strings.Common_Edit, icon: { _ in - return nil - }, action: { c, f in - c.dismiss(completion: { - guard let strongSelf = self else { - return - } - let _ = (strongSelf.context.account.postbox.transaction { transaction -> [ChatListFilter] in - let settings = transaction.getPreferencesEntry(key: PreferencesKeys.chatListFilters) as? ChatListFiltersState ?? ChatListFiltersState.default - return settings.filters - } - |> deliverOnMainQueue).start(next: { presetList in - guard let strongSelf = self else { - return - } - var found = false - for filter in presetList { - if filter.id == id { - strongSelf.push(chatListFilterPresetController(context: strongSelf.context, currentPreset: filter, updated: { _ in })) - f(.dismissWithoutContent) - found = true - break - } - } - }) - }) - }))) - if let chatListFilter = strongSelf.chatListDisplayNode.chatListNode.chatListFilter, chatListFilter.includePeers.count < 100 { - //TODO:localization - items.append(.action(ContextMenuActionItem(text: "Add Chats", icon: { _ in - return nil + let _ = (strongSelf.context.account.postbox.transaction { transaction -> [ChatListFilter] in + let settings = transaction.getPreferencesEntry(key: PreferencesKeys.chatListFilters) as? ChatListFiltersState ?? ChatListFiltersState.default + return settings.filters + } + |> deliverOnMainQueue).start(next: { [weak self] filters in + guard let strongSelf = self else { + return + } + var items: [ContextMenuItem] = [] + items.append(.action(ContextMenuActionItem(text: strongSelf.presentationData.strings.Common_Edit, icon: { theme in + return generateTintedImage(image: UIImage(bundleImageName: "Chat/Context Menu/Edit"), color: theme.contextMenu.primaryColor) }, action: { c, f in c.dismiss(completion: { guard let strongSelf = self else { @@ -597,7 +557,7 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, var found = false for filter in presetList { if filter.id == id { - strongSelf.push(chatListFilterAddChatsController(context: strongSelf.context, filter: filter)) + strongSelf.push(chatListFilterPresetController(context: strongSelf.context, currentPreset: filter, updated: { _ in })) f(.dismissWithoutContent) found = true break @@ -606,10 +566,74 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, }) }) }))) - } - - let controller = ContextController(account: strongSelf.context.account, presentationData: strongSelf.presentationData, source: .extracted(ChatListHeaderBarContextExtractedContentSource(controller: strongSelf, sourceNode: sourceNode)), items: .single(items), reactionItems: [], recognizer: nil, gesture: gesture) - strongSelf.context.sharedContext.mainWindow?.presentInGlobalOverlay(controller) + if let filter = filters.first(where: { $0.id == id }), filter.data.includePeers.count < 100 { + //TODO:localization + items.append(.action(ContextMenuActionItem(text: "Add Chats", icon: { theme in + return generateTintedImage(image: UIImage(bundleImageName: "Chat/Context Menu/Add"), color: theme.contextMenu.primaryColor) + }, action: { c, f in + c.dismiss(completion: { + guard let strongSelf = self else { + return + } + let _ = (strongSelf.context.account.postbox.transaction { transaction -> [ChatListFilter] in + let settings = transaction.getPreferencesEntry(key: PreferencesKeys.chatListFilters) as? ChatListFiltersState ?? ChatListFiltersState.default + return settings.filters + } + |> deliverOnMainQueue).start(next: { presetList in + guard let strongSelf = self else { + return + } + var found = false + for filter in presetList { + if filter.id == id { + strongSelf.push(chatListFilterAddChatsController(context: strongSelf.context, filter: filter)) + f(.dismissWithoutContent) + found = true + break + } + } + }) + }) + }))) + items.append(.action(ContextMenuActionItem(text: "Delete", textColor: .destructive, icon: { theme in + return generateTintedImage(image: UIImage(bundleImageName: "Chat/Context Menu/Delete"), color: theme.contextMenu.destructiveColor) + }, action: { c, f in + c.dismiss(completion: { + guard let strongSelf = self else { + return + } + let actionSheet = ActionSheetController(presentationData: strongSelf.presentationData) + + actionSheet.setItemGroups([ + ActionSheetItemGroup(items: [ + ActionSheetButtonItem(title: strongSelf.presentationData.strings.Common_Delete, color: .destructive, action: { [weak actionSheet] in + actionSheet?.dismissAnimated() + + guard let strongSelf = self else { + return + } + let _ = updateChatListFilterSettingsInteractively(postbox: strongSelf.context.account.postbox, { settings in + var settings = settings + settings.filters = settings.filters.filter({ $0.id != id }) + return settings + }).start() + let _ = replaceRemoteChatListFilters(account: strongSelf.context.account).start() + }) + ]), + ActionSheetItemGroup(items: [ + ActionSheetButtonItem(title: strongSelf.presentationData.strings.Common_Cancel, color: .accent, font: .bold, action: { [weak actionSheet] in + actionSheet?.dismissAnimated() + }) + ]) + ]) + strongSelf.present(actionSheet, in: .window(.root)) + }) + }))) + } + + let controller = ContextController(account: strongSelf.context.account, presentationData: strongSelf.presentationData, source: .extracted(ChatListHeaderBarContextExtractedContentSource(controller: strongSelf, sourceNode: sourceNode)), items: .single(items), reactionItems: [], recognizer: nil, gesture: gesture) + strongSelf.context.sharedContext.mainWindow?.presentInGlobalOverlay(controller) + }) } } @@ -642,11 +666,7 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, } self.searchContentNode?.updateThemeAndPlaceholder(theme: self.presentationData.theme, placeholder: self.presentationData.strings.DialogList_SearchLabel) - var editing = false - self.chatListDisplayNode.chatListNode.updateState { state in - editing = state.editing - return state - } + let editing = self.chatListDisplayNode.containerNode.currentItemNode.currentState.editing let editItem: UIBarButtonItem if editing { editItem = UIBarButtonItem(title: self.presentationData.strings.Common_Done, style: .done, target: self, action: #selector(self.donePressed)) @@ -676,7 +696,6 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, override public func loadDisplayNode() { self.displayNode = ChatListControllerNode(context: self.context, groupId: self.groupId, filter: self.filter, previewing: self.previewing, controlsHistoryPreload: self.controlsHistoryPreload, presentationData: self.presentationData, controller: self) - self.chatListFilterValue.set(self.chatListDisplayNode.chatListNode.appliedChatListFilterSignal) self.chatListDisplayNode.navigationBar = self.navigationBar @@ -684,37 +703,37 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, self?.deactivateSearch(animated: true) } - self.chatListDisplayNode.chatListNode.activateSearch = { [weak self] in + self.chatListDisplayNode.containerNode.activateSearch = { [weak self] in self?.activateSearch() } - self.chatListDisplayNode.chatListNode.presentAlert = { [weak self] text in + self.chatListDisplayNode.containerNode.presentAlert = { [weak self] text in if let strongSelf = self { self?.present(textAlertController(context: strongSelf.context, title: nil, text: text, actions: [TextAlertAction(type: .defaultAction, title: strongSelf.presentationData.strings.Common_OK, action: {})]), in: .window(.root)) } } - self.chatListDisplayNode.chatListNode.present = { [weak self] c in + self.chatListDisplayNode.containerNode.present = { [weak self] c in if let strongSelf = self { self?.present(c, in: .window(.root)) } } - self.chatListDisplayNode.chatListNode.toggleArchivedFolderHiddenByDefault = { [weak self] in + self.chatListDisplayNode.containerNode.toggleArchivedFolderHiddenByDefault = { [weak self] in guard let strongSelf = self else { return } strongSelf.toggleArchivedFolderHiddenByDefault() } - self.chatListDisplayNode.chatListNode.deletePeerChat = { [weak self] peerId in + self.chatListDisplayNode.containerNode.deletePeerChat = { [weak self] peerId in guard let strongSelf = self else { return } strongSelf.deletePeerChat(peerId: peerId) } - self.chatListDisplayNode.chatListNode.peerSelected = { [weak self] peerId, animated, isAd in + self.chatListDisplayNode.containerNode.peerSelected = { [weak self] peer, animated, isAd in if let strongSelf = self { if let navigationController = strongSelf.navigationController as? NavigationController { if isAd { @@ -738,37 +757,37 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, scrollToEndIfExists = true } - strongSelf.context.sharedContext.navigateToChatController(NavigateToChatControllerParams(navigationController: navigationController, context: strongSelf.context, chatLocation: .peer(peerId), scrollToEndIfExists: scrollToEndIfExists, options: strongSelf.groupId == PeerGroupId.root ? [.removeOnMasterDetails] : [], parentGroupId: strongSelf.groupId, completion: { [weak self] in - self?.chatListDisplayNode.chatListNode.clearHighlightAnimated(true) + strongSelf.context.sharedContext.navigateToChatController(NavigateToChatControllerParams(navigationController: navigationController, context: strongSelf.context, chatLocation: .peer(peer.id), scrollToEndIfExists: scrollToEndIfExists, options: strongSelf.groupId == PeerGroupId.root ? [.removeOnMasterDetails] : [], parentGroupId: strongSelf.groupId, completion: { [weak self] in + self?.chatListDisplayNode.containerNode.currentItemNode.clearHighlightAnimated(true) })) } } } - self.chatListDisplayNode.chatListNode.groupSelected = { [weak self] groupId in + self.chatListDisplayNode.containerNode.groupSelected = { [weak self] groupId in if let strongSelf = self { if let navigationController = strongSelf.navigationController as? NavigationController { let chatListController = ChatListControllerImpl(context: strongSelf.context, groupId: groupId, controlsHistoryPreload: false, enableDebugActions: false) chatListController.navigationPresentation = .master navigationController.pushViewController(chatListController) - strongSelf.chatListDisplayNode.chatListNode.clearHighlightAnimated(true) + strongSelf.chatListDisplayNode.containerNode.currentItemNode.clearHighlightAnimated(true) } } } - self.chatListDisplayNode.chatListNode.updatePeerGrouping = { [weak self] peerId, group in + self.chatListDisplayNode.containerNode.updatePeerGrouping = { [weak self] peerId, group in guard let strongSelf = self else { return } if group { strongSelf.archiveChats(peerIds: [peerId]) } else { - strongSelf.chatListDisplayNode.chatListNode.setCurrentRemovingPeerId(peerId) + strongSelf.chatListDisplayNode.containerNode.currentItemNode.setCurrentRemovingPeerId(peerId) let _ = updatePeerGroupIdInteractively(postbox: strongSelf.context.account.postbox, peerId: peerId, groupId: group ? Namespaces.PeerGroup.archive : .root).start(completed: { guard let strongSelf = self else { return } - strongSelf.chatListDisplayNode.chatListNode.setCurrentRemovingPeerId(nil) + strongSelf.chatListDisplayNode.containerNode.currentItemNode.setCurrentRemovingPeerId(nil) }) } } @@ -786,7 +805,7 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, strongSelf.context.sharedContext.navigateToChatController(NavigateToChatControllerParams(navigationController: navigationController, context: strongSelf.context, chatLocation: .peer(actualPeerId), subject: .message(messageId), purposefulAction: { self?.deactivateSearch(animated: false) }, scrollToEndIfExists: scrollToEndIfExists, options: strongSelf.groupId == PeerGroupId.root ? [.removeOnMasterDetails] : [])) - strongSelf.chatListDisplayNode.chatListNode.clearHighlightAnimated(true) + strongSelf.chatListDisplayNode.containerNode.currentItemNode.clearHighlightAnimated(true) } } })) @@ -815,7 +834,7 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, strongSelf.context.sharedContext.navigateToChatController(NavigateToChatControllerParams(navigationController: navigationController, context: strongSelf.context, chatLocation: .peer(peer.id), purposefulAction: { [weak self] in self?.deactivateSearch(animated: false) }, scrollToEndIfExists: scrollToEndIfExists, options: strongSelf.groupId == PeerGroupId.root ? [.removeOnMasterDetails] : [])) - strongSelf.chatListDisplayNode.chatListNode.clearHighlightAnimated(true) + strongSelf.chatListDisplayNode.containerNode.currentItemNode.clearHighlightAnimated(true) } } })) @@ -867,7 +886,7 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, navigationController.filterController(strongSelf, animated: true) } - self.chatListDisplayNode.chatListNode.contentOffsetChanged = { [weak self] offset in + self.chatListDisplayNode.containerNode.contentOffsetChanged = { [weak self] offset in if let strongSelf = self, let searchContentNode = strongSelf.searchContentNode, let validLayout = strongSelf.validLayout { var offset = offset if validLayout.inVoiceOver { @@ -877,7 +896,7 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, } } - self.chatListDisplayNode.chatListNode.contentScrollingEnded = { [weak self] listView in + self.chatListDisplayNode.containerNode.contentScrollingEnded = { [weak self] listView in if let strongSelf = self, let searchContentNode = strongSelf.searchContentNode { return fixListNodeScrolling(listView, searchNode: searchContentNode) } else { @@ -897,7 +916,7 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, guard let strongSelf = self else { return } - if let filter = strongSelf.chatListDisplayNode.chatListNode.chatListFilter { + if let filter = strongSelf.chatListDisplayNode.containerNode.currentItemNode.chatListFilter { strongSelf.push(chatListFilterPresetController(context: strongSelf.context, currentPreset: filter, updated: { _ in })) } else { strongSelf.composePressed() @@ -908,7 +927,7 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, self?.toolbarActionSelected(action: action) } - self.chatListDisplayNode.chatListNode.activateChatPreview = { [weak self] item, node, gesture in + self.chatListDisplayNode.containerNode.activateChatPreview = { [weak self] item, node, gesture in guard let strongSelf = self else { gesture?.cancel() return @@ -940,7 +959,7 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, } let context = self.context - let peerIdsAndOptions: Signal<(ChatListSelectionOptions, Set)?, NoError> = self.chatListDisplayNode.chatListNode.state + let peerIdsAndOptions: Signal<(ChatListSelectionOptions, Set)?, NoError> = self.chatListDisplayNode.containerNode.currentItemState |> map { state -> Set? in if !state.editing { return nil @@ -988,7 +1007,7 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, } } } - toolbar = Toolbar(leftAction: leftAction, rightAction: ToolbarAction(title: presentationData.strings.Common_Delete, isEnabled: options.delete), middleAction: strongSelf.chatListDisplayNode.chatListNode.chatListFilter != nil ? nil : ToolbarAction(title: presentationData.strings.ChatList_ArchiveAction, isEnabled: archiveEnabled)) + toolbar = Toolbar(leftAction: leftAction, rightAction: ToolbarAction(title: presentationData.strings.Common_Delete, isEnabled: options.delete), middleAction: strongSelf.chatListDisplayNode.containerNode.currentItemNode.chatListFilter != nil ? nil : ToolbarAction(title: presentationData.strings.ChatList_ArchiveAction, isEnabled: archiveEnabled)) } } else { if let (options, peerIds) = peerIdsAndOptions { @@ -1006,7 +1025,7 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, strongSelf.setToolbar(toolbar, transition: .animated(duration: 0.3, curve: .easeInOut)) })) - self.ready.set(self.chatListDisplayNode.chatListNode.ready) + self.ready.set(self.chatListDisplayNode.containerNode.ready) self.displayNodeDidLoad() } @@ -1105,7 +1124,7 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, })) } - self.chatListDisplayNode.chatListNode.addedVisibleChatsWithPeerIds = { [weak self] peerIds in + self.chatListDisplayNode.containerNode.addedVisibleChatsWithPeerIds = { [weak self] peerIds in guard let strongSelf = self else { return } @@ -1145,7 +1164,7 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, self.deactivateSearch(animated: false) } - self.chatListDisplayNode.chatListNode.clearHighlightAnimated(true) + self.chatListDisplayNode.containerNode.currentItemNode.clearHighlightAnimated(true) } override public func containerLayoutUpdated(_ layout: ContainerViewLayout, transition: ContainedViewLayoutTransition) { @@ -1161,12 +1180,12 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, tabContainerOffset += 44.0 + 44.0 + 44.0 } - transition.updateFrame(node: self.tabContainerNode, frame: CGRect(origin: CGPoint(x: 0.0, y: self.visualNavigationInsetHeight - self.additionalHeight - NavigationBar.defaultSecondaryContentHeight + tabContainerOffset), size: CGSize(width: layout.size.width, height: NavigationBar.defaultSecondaryContentHeight))) - self.tabContainerNode.update(size: CGSize(width: layout.size.width, height: NavigationBar.defaultSecondaryContentHeight), sideInset: layout.safeInsets.left, filters: self.tabContainerData?.0 ?? [], selectedFilter: self.tabContainerData?.1, presentationData: self.presentationData, transition: .animated(duration: 0.4, curve: .spring)) + transition.updateFrame(node: self.tabContainerNode, frame: CGRect(origin: CGPoint(x: 0.0, y: self.visualNavigationInsetHeight - self.additionalHeight - 46.0 + tabContainerOffset), size: CGSize(width: layout.size.width, height: 46.0))) + self.tabContainerNode.update(size: CGSize(width: layout.size.width, height: 46.0), sideInset: layout.safeInsets.left, filters: self.tabContainerData ?? [], selectedFilter: self.chatListDisplayNode.containerNode.currentItemFilter, transitionFraction: self.chatListDisplayNode.containerNode.transitionFraction, presentationData: self.presentationData, transition: .animated(duration: 0.4, curve: .spring)) if let searchContentNode = self.searchContentNode, layout.inVoiceOver != wasInVoiceOver { searchContentNode.updateListVisibleContentOffset(.known(0.0)) - self.chatListDisplayNode.chatListNode.scrollToPosition(.top) + self.chatListDisplayNode.scrollToTop() } self.chatListDisplayNode.containerLayoutUpdated(layout, navigationBarHeight: self.navigationInsetHeight, visualNavigationHeight: self.visualNavigationInsetHeight, cleanNavigationBarHeight: self.cleanNavigationHeight, transition: transition) @@ -1188,7 +1207,7 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, } self.searchContentNode?.setIsEnabled(false, animated: true) - self.chatListDisplayNode.chatListNode.updateState { state in + self.chatListDisplayNode.containerNode.updateState { state in var state = state state.editing = true state.peerIdWithRevealedOptions = nil @@ -1206,7 +1225,7 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, } (self.navigationController as? NavigationController)?.updateMasterDetailsBlackout(nil, transition: .animated(duration: 0.4, curve: .spring)) self.searchContentNode?.setIsEnabled(true, animated: true) - self.chatListDisplayNode.chatListNode.updateState { state in + self.chatListDisplayNode.containerNode.updateState { state in var state = state state.editing = false state.peerIdWithRevealedOptions = nil @@ -1217,7 +1236,7 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, public func activateSearch() { if self.displayNavigationBar { - let _ = (self.chatListDisplayNode.chatListNode.contentsReady + let _ = (self.chatListDisplayNode.containerNode.currentItemNode.contentsReady |> take(1) |> deliverOnMainQueue).start(completed: { [weak self] in guard let strongSelf = self else { @@ -1303,10 +1322,10 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, return nil } - let listLocation = self.view.convert(location, to: self.chatListDisplayNode.chatListNode.view) + let listLocation = self.view.convert(location, to: self.chatListDisplayNode.containerNode.currentItemNode.view) var selectedNode: ChatListItemNode? - self.chatListDisplayNode.chatListNode.forEachItemNode { itemNode in + self.chatListDisplayNode.containerNode.currentItemNode.forEachItemNode { itemNode in if let itemNode = itemNode as? ChatListItemNode, itemNode.frame.contains(listLocation), !itemNode.isDisplayingRevealedOptions { selectedNode = itemNode } @@ -1346,12 +1365,12 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, chatController.updatePresentationMode(.standard(previewing: false)) if let navigationController = self.navigationController as? NavigationController { self.context.sharedContext.navigateToChatController(NavigateToChatControllerParams(navigationController: navigationController, chatController: chatController, context: self.context, chatLocation: chatController.chatLocation, animated: false)) - self.chatListDisplayNode.chatListNode.clearHighlightAnimated(true) + self.chatListDisplayNode.containerNode.currentItemNode.clearHighlightAnimated(true) } } else if let chatListController = viewControllerToCommit as? ChatListController { if let navigationController = self.navigationController as? NavigationController { navigationController.pushViewController(chatListController, animated: false, completion: {}) - self.chatListDisplayNode.chatListNode.clearHighlightAnimated(true) + self.chatListDisplayNode.containerNode.currentItemNode.clearHighlightAnimated(true) } } } @@ -1373,22 +1392,22 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, let inputShortcuts: [KeyShortcut] = [ KeyShortcut(title: strings.KeyCommand_JumpToPreviousChat, input: UIKeyCommand.inputUpArrow, modifiers: [.alternate], action: { [weak self] in if let strongSelf = self { - strongSelf.chatListDisplayNode.chatListNode.selectChat(.previous(unread: false)) + strongSelf.chatListDisplayNode.containerNode.currentItemNode.selectChat(.previous(unread: false)) } }), KeyShortcut(title: strings.KeyCommand_JumpToNextChat, input: UIKeyCommand.inputDownArrow, modifiers: [.alternate], action: { [weak self] in if let strongSelf = self { - strongSelf.chatListDisplayNode.chatListNode.selectChat(.next(unread: false)) + strongSelf.chatListDisplayNode.containerNode.currentItemNode.selectChat(.next(unread: false)) } }), KeyShortcut(title: strings.KeyCommand_JumpToPreviousUnreadChat, input: UIKeyCommand.inputUpArrow, modifiers: [.alternate, .shift], action: { [weak self] in if let strongSelf = self { - strongSelf.chatListDisplayNode.chatListNode.selectChat(.previous(unread: true)) + strongSelf.chatListDisplayNode.containerNode.currentItemNode.selectChat(.previous(unread: true)) } }), KeyShortcut(title: strings.KeyCommand_JumpToNextUnreadChat, input: UIKeyCommand.inputDownArrow, modifiers: [.alternate, .shift], action: { [weak self] in if let strongSelf = self { - strongSelf.chatListDisplayNode.chatListNode.selectChat(.next(unread: true)) + strongSelf.chatListDisplayNode.containerNode.currentItemNode.selectChat(.next(unread: true)) } }), KeyShortcut(title: strings.KeyCommand_NewMessage, input: "N", modifiers: [.command], action: { [weak self] in @@ -1403,9 +1422,9 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, let openChat: (Int) -> Void = { [weak self] index in if let strongSelf = self { if index == 0 { - strongSelf.chatListDisplayNode.chatListNode.selectChat(.peerId(strongSelf.context.account.peerId)) + strongSelf.chatListDisplayNode.containerNode.currentItemNode.selectChat(.peerId(strongSelf.context.account.peerId)) } else { - strongSelf.chatListDisplayNode.chatListNode.selectChat(.index(index - 1)) + strongSelf.chatListDisplayNode.containerNode.currentItemNode.selectChat(.index(index - 1)) } } } @@ -1420,7 +1439,7 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, } override public func toolbarActionSelected(action: ToolbarActionOption) { - let peerIds = self.chatListDisplayNode.chatListNode.currentState.selectedPeerIds + let peerIds = self.chatListDisplayNode.containerNode.currentItemNode.currentState.selectedPeerIds if case .left = action { let signal: Signal let context = self.context @@ -1433,7 +1452,7 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, } else { let groupId = self.groupId signal = self.context.account.postbox.transaction { transaction -> Void in - markAllChatsAsReadInteractively(transaction: transaction, viewTracker: context.account.viewTracker, groupId: groupId, filterPredicate: self.chatListDisplayNode.chatListNode.chatListFilter.flatMap(chatListFilterPredicate)) + markAllChatsAsReadInteractively(transaction: transaction, viewTracker: context.account.viewTracker, groupId: groupId, filterPredicate: (self.chatListDisplayNode.containerNode.currentItemNode.chatListFilter?.data).flatMap(chatListFilterPredicate)) } } let _ = (signal @@ -1450,7 +1469,7 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, return } - strongSelf.chatListDisplayNode.chatListNode.updateState({ state in + strongSelf.chatListDisplayNode.containerNode.updateState({ state in var state = state for peerId in peerIds { state.pendingRemovalPeerIds.insert(peerId) @@ -1494,15 +1513,15 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, |> deliverOnMainQueue).start() return true } else if value == .undo { - strongSelf.chatListDisplayNode.chatListNode.setCurrentRemovingPeerId(peerIds.first!) - strongSelf.chatListDisplayNode.chatListNode.updateState({ state in + strongSelf.chatListDisplayNode.containerNode.currentItemNode.setCurrentRemovingPeerId(peerIds.first!) + strongSelf.chatListDisplayNode.containerNode.updateState({ state in var state = state for peerId in peerIds { state.pendingRemovalPeerIds.remove(peerId) } return state }) - self?.chatListDisplayNode.chatListNode.setCurrentRemovingPeerId(peerIds.first!) + self?.chatListDisplayNode.containerNode.currentItemNode.setCurrentRemovingPeerId(peerIds.first!) return true } return false @@ -1526,7 +1545,7 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, self.archiveChats(peerIds: Array(peerIds)) } else { if !peerIds.isEmpty { - self.chatListDisplayNode.chatListNode.setCurrentRemovingPeerId(peerIds.first!) + self.chatListDisplayNode.containerNode.currentItemNode.setCurrentRemovingPeerId(peerIds.first!) let _ = (self.context.account.postbox.transaction { transaction -> Void in for peerId in peerIds { updatePeerGroupIdInteractively(transaction: transaction, peerId: peerId, groupId: .root) @@ -1536,7 +1555,7 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, guard let strongSelf = self else { return } - strongSelf.chatListDisplayNode.chatListNode.setCurrentRemovingPeerId(nil) + strongSelf.chatListDisplayNode.containerNode.currentItemNode.setCurrentRemovingPeerId(nil) strongSelf.donePressed() }) } @@ -1559,7 +1578,7 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, guard let strongSelf = self else { return } - strongSelf.chatListDisplayNode.chatListNode.updateState { state in + strongSelf.chatListDisplayNode.containerNode.updateState { state in var state = state if value { state.archiveShouldBeTemporaryRevealed = false @@ -1677,7 +1696,7 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, guard let strongSelf = self else { return } - strongSelf.chatListDisplayNode.chatListNode.updateState({ state in + strongSelf.chatListDisplayNode.containerNode.updateState({ state in var state = state state.pendingClearHistoryPeerIds.insert(peer.peerId) return state @@ -1698,7 +1717,7 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, guard let strongSelf = self else { return } - strongSelf.chatListDisplayNode.chatListNode.updateState({ state in + strongSelf.chatListDisplayNode.containerNode.updateState({ state in var state = state state.pendingClearHistoryPeerIds.remove(peer.peerId) return state @@ -1706,7 +1725,7 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, }) return true } else if value == .undo { - strongSelf.chatListDisplayNode.chatListNode.updateState({ state in + strongSelf.chatListDisplayNode.containerNode.updateState({ state in var state = state state.pendingClearHistoryPeerIds.remove(peer.peerId) return state @@ -1870,7 +1889,7 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, return } let postbox = self.context.account.postbox - self.chatListDisplayNode.chatListNode.setCurrentRemovingPeerId(peerIds[0]) + self.chatListDisplayNode.containerNode.currentItemNode.setCurrentRemovingPeerId(peerIds[0]) let _ = (ApplicationSpecificNotice.incrementArchiveChatTips(accountManager: self.context.sharedContext.accountManager, count: 1) |> deliverOnMainQueue).start(next: { [weak self] previousHintCount in let _ = (postbox.transaction { transaction -> Void in @@ -1882,7 +1901,7 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, guard let strongSelf = self else { return } - strongSelf.chatListDisplayNode.chatListNode.setCurrentRemovingPeerId(nil) + strongSelf.chatListDisplayNode.containerNode.currentItemNode.setCurrentRemovingPeerId(nil) for peerId in peerIds { deleteSendMessageIntents(peerId: peerId) @@ -1893,7 +1912,7 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, return false } if value == .undo { - strongSelf.chatListDisplayNode.chatListNode.setCurrentRemovingPeerId(peerIds[0]) + strongSelf.chatListDisplayNode.containerNode.currentItemNode.setCurrentRemovingPeerId(peerIds[0]) let _ = (postbox.transaction { transaction -> Void in for peerId in peerIds { updatePeerGroupIdInteractively(transaction: transaction, peerId: peerId, groupId: .root) @@ -1903,7 +1922,7 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, guard let strongSelf = self else { return } - strongSelf.chatListDisplayNode.chatListNode.setCurrentRemovingPeerId(nil) + strongSelf.chatListDisplayNode.containerNode.currentItemNode.setCurrentRemovingPeerId(nil) }) return true } else { @@ -1949,13 +1968,13 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, } let peerId = peer.peerId - self.chatListDisplayNode.chatListNode.setCurrentRemovingPeerId(peerId) - self.chatListDisplayNode.chatListNode.updateState({ state in + self.chatListDisplayNode.containerNode.currentItemNode.setCurrentRemovingPeerId(peerId) + self.chatListDisplayNode.containerNode.updateState({ state in var state = state state.pendingRemovalPeerIds.insert(peer.peerId) return state }) - self.chatListDisplayNode.chatListNode.setCurrentRemovingPeerId(nil) + self.chatListDisplayNode.containerNode.currentItemNode.setCurrentRemovingPeerId(nil) let statusText: String if let channel = chatPeer as? TelegramChannel { if deleteGloballyIfPossible { @@ -1999,7 +2018,7 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, return false } if value == .commit { - strongSelf.chatListDisplayNode.chatListNode.setCurrentRemovingPeerId(peerId) + strongSelf.chatListDisplayNode.containerNode.currentItemNode.setCurrentRemovingPeerId(peerId) if let channel = chatPeer as? TelegramChannel { strongSelf.context.peerChannelMemberCategoriesContextsManager.externallyRemoved(peerId: channel.id, memberId: strongSelf.context.account.peerId) } @@ -2007,25 +2026,25 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, guard let strongSelf = self else { return } - strongSelf.chatListDisplayNode.chatListNode.updateState({ state in + strongSelf.chatListDisplayNode.containerNode.updateState({ state in var state = state state.pendingRemovalPeerIds.remove(peer.peerId) return state }) - strongSelf.chatListDisplayNode.chatListNode.setCurrentRemovingPeerId(nil) + strongSelf.chatListDisplayNode.containerNode.currentItemNode.setCurrentRemovingPeerId(nil) deleteSendMessageIntents(peerId: peerId) }) completion() return true } else if value == .undo { - strongSelf.chatListDisplayNode.chatListNode.setCurrentRemovingPeerId(peerId) - strongSelf.chatListDisplayNode.chatListNode.updateState({ state in + strongSelf.chatListDisplayNode.containerNode.currentItemNode.setCurrentRemovingPeerId(peerId) + strongSelf.chatListDisplayNode.containerNode.updateState({ state in var state = state state.pendingRemovalPeerIds.remove(peer.peerId) return state }) - strongSelf.chatListDisplayNode.chatListNode.setCurrentRemovingPeerId(nil) + strongSelf.chatListDisplayNode.containerNode.currentItemNode.setCurrentRemovingPeerId(nil) return true } return false @@ -2054,35 +2073,6 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, })) } - public func presentTabBarPreviewingController(sourceNodes: [ASDisplayNode]) { - if self.isNodeLoaded { - let _ = (self.context.account.postbox.transaction { transaction -> [ChatListFilter] in - let settings = transaction.getPreferencesEntry(key: PreferencesKeys.chatListFilters) as? ChatListFiltersState ?? ChatListFiltersState.default - return settings.filters - } - |> deliverOnMainQueue).start(next: { [weak self] presetList in - guard let strongSelf = self else { - return - } - let controller = TabBarChatListFilterController(context: strongSelf.context, sourceNodes: sourceNodes, presetList: presetList, currentPreset: strongSelf.chatListDisplayNode.chatListNode.chatListFilter, setup: { - guard let strongSelf = self else { - return - } - strongSelf.push(chatListFilterPresetListController(context: strongSelf.context, updated: { _ in - })) - }, updatePreset: { value in - guard let strongSelf = self else { - return - } - if let value = value { - strongSelf.tabContainerNode.tabSelected?(.filter(value.id)) - } - }) - strongSelf.context.sharedContext.mainWindow?.present(controller, on: .root) - }) - } - } - override public func tabBarItemContextAction(sourceNode: ContextExtractedContentContainingNode, gesture: ContextGesture) { let _ = (combineLatest(queue: .mainQueue(), self.context.account.postbox.transaction { transaction -> [ChatListFilter] in @@ -2120,6 +2110,18 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, }) }))) + if strongSelf.chatListDisplayNode.containerNode.currentItemNode.chatListFilter != nil { + items.append(.action(ContextMenuActionItem(text: "All Chats", icon: { theme in + return nil + }, action: { c, f in + f(.dismissWithoutContent) + guard let strongSelf = self else { + return + } + strongSelf.tabContainerNode.tabSelected?(.all) + }))) + } + if !presetList.isEmpty { items.append(.separator) @@ -2135,25 +2137,25 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, case privateChats } let filterType: ChatListFilterType - if preset.includePeers.isEmpty { - if preset.categories == .all { - if preset.excludeRead { + if preset.data.includePeers.isEmpty { + if preset.data.categories == .all { + if preset.data.excludeRead { filterType = .unread - } else if preset.excludeMuted { + } else if preset.data.excludeMuted { filterType = .unmuted } else { filterType = .generic } } else { - if preset.categories == .channels { + if preset.data.categories == .channels { filterType = .channels - } else if preset.categories.isSubset(of: [.publicGroups, .privateGroups]) { + } else if preset.data.categories.isSubset(of: [.publicGroups, .privateGroups]) { filterType = .groups - } else if preset.categories == .bots { + } else if preset.data.categories == .bots { filterType = .bots - } else if preset.categories == .secretChats { + } else if preset.data.categories == .secretChats { filterType = .secretChats - } else if preset.categories == .privateChats { + } else if preset.data.categories == .privateChats { filterType = .privateChats } else { filterType = .generic @@ -2203,6 +2205,27 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, strongSelf.context.sharedContext.mainWindow?.presentInGlobalOverlay(controller) }) } + + override public func tabBarItemSwipeAction(direction: TabBarItemSwipeDirection) { + guard let entries = self.tabContainerData, var index = entries.index(where: { $0.id == self.chatListDisplayNode.containerNode.currentItemFilter }) else { + return + } + switch direction { + case .right: + if index == 0 { + index = entries.count - 1 + } else { + index -= 1 + } + case .left: + if index == entries.count - 1 { + index = 0 + } else { + index += 1 + } + } + self.tabContainerNode.tabSelected?(entries[index].id) + } } private final class ChatListTabBarContextExtractedContentSource: ContextExtractedContentSource { diff --git a/submodules/ChatListUI/Sources/ChatListControllerNode.swift b/submodules/ChatListUI/Sources/ChatListControllerNode.swift index 4464bf8cfc..6a67317762 100644 --- a/submodules/ChatListUI/Sources/ChatListControllerNode.swift +++ b/submodules/ChatListUI/Sources/ChatListControllerNode.swift @@ -26,19 +26,579 @@ private final class ChatListControllerNodeView: UITracingLayerView, PreviewingHo weak var controller: ChatListControllerImpl? } -private struct TestItem: Comparable, Identifiable { - var value: Int - var version: Int +enum ChatListContainerNodeFilter: Equatable { + case all + case filter(ChatListFilter) - var stableId: Int { - return self.value + var id: ChatListFilterTabEntryId { + switch self { + case .all: + return .all + case let .filter(filter): + return .filter(filter.id) + } } - static func <(lhs: TestItem, rhs: TestItem) -> Bool { - if lhs.version != rhs.version { - return lhs.version < rhs.version + var filter: ChatListFilter? { + switch self { + case .all: + return nil + case let .filter(filter): + return filter + } + } +} + +private final class ChatListContainerItemNode: ASDisplayNode { + private var presentationData: PresentationData + private let becameEmpty: (ChatListFilter?) -> Void + private let emptyAction: (ChatListFilter?) -> Void + + private var emptyNode: ChatListEmptyNode? + let listNode: ChatListNode + + private var validLayout: (CGSize, UIEdgeInsets, CGFloat)? + + init(context: AccountContext, groupId: PeerGroupId, filter: ChatListFilter?, previewing: Bool, presentationData: PresentationData, becameEmpty: @escaping (ChatListFilter?) -> Void, emptyAction: @escaping (ChatListFilter?) -> Void) { + self.presentationData = presentationData + self.becameEmpty = becameEmpty + self.emptyAction = emptyAction + + self.listNode = ChatListNode(context: context, groupId: groupId, chatListFilter: filter, previewing: previewing, controlsHistoryPreload: false, mode: .chatList, theme: presentationData.theme, fontSize: presentationData.listsFontSize, strings: presentationData.strings, dateTimeFormat: presentationData.dateTimeFormat, nameSortOrder: presentationData.nameSortOrder, nameDisplayOrder: presentationData.nameDisplayOrder, disableAnimations: presentationData.disableAnimations) + + super.init() + + self.addSubnode(self.listNode) + + self.listNode.isEmptyUpdated = { [weak self] isEmptyState, _, _, transition in + guard let strongSelf = self else { + return + } + switch isEmptyState { + case let .empty(isLoading): + if let currentNode = strongSelf.emptyNode { + currentNode.updateIsLoading(isLoading) + } else { + let emptyNode = ChatListEmptyNode(isFilter: filter != nil, isLoading: isLoading, theme: strongSelf.presentationData.theme, strings: strongSelf.presentationData.strings, action: { + self?.emptyAction(filter) + }) + strongSelf.emptyNode = emptyNode + strongSelf.addSubnode(emptyNode) + if let (size, insets, _) = strongSelf.validLayout { + let emptyNodeFrame = CGRect(origin: CGPoint(x: 0.0, y: insets.top), size: CGSize(width: size.width, height: size.height - insets.top - insets.bottom)) + emptyNode.frame = emptyNodeFrame + emptyNode.updateLayout(size: emptyNodeFrame.size, transition: .immediate) + } + } + strongSelf.becameEmpty(filter) + case .notEmpty: + if let emptyNode = strongSelf.emptyNode { + strongSelf.emptyNode = nil + transition.updateAlpha(node: emptyNode, alpha: 0.0, completion: { [weak emptyNode] _ in + emptyNode?.removeFromSupernode() + }) + } + } + } + } + + func updatePresentationData(_ presentationData: PresentationData) { + self.presentationData = presentationData + + self.listNode.updateThemeAndStrings(theme: presentationData.theme, fontSize: presentationData.listsFontSize, strings: presentationData.strings, dateTimeFormat: presentationData.dateTimeFormat, nameSortOrder: presentationData.nameSortOrder, nameDisplayOrder: presentationData.nameDisplayOrder, disableAnimations: presentationData.disableAnimations) + + self.emptyNode?.updateThemeAndStrings(theme: presentationData.theme, strings: presentationData.strings) + } + + func updateLayout(size: CGSize, insets: UIEdgeInsets, visualNavigationHeight: CGFloat, transition: ContainedViewLayoutTransition) { + self.validLayout = (size, insets, visualNavigationHeight) + + let updateSizeAndInsets = ListViewUpdateSizeAndInsets(size: size, insets: insets, duration: 0.0, curve: .Default(duration: 0.0)) + + transition.updateFrame(node: self.listNode, frame: CGRect(origin: CGPoint(), size: size)) + self.listNode.visualInsets = UIEdgeInsets(top: visualNavigationHeight, left: 0.0, bottom: 0.0, right: 0.0) + self.listNode.updateLayout(transition: .immediate, updateSizeAndInsets: updateSizeAndInsets) + + if let emptyNode = self.emptyNode { + let emptyNodeFrame = CGRect(origin: CGPoint(x: 0.0, y: insets.top), size: CGSize(width: size.width, height: size.height - insets.top - insets.bottom)) + transition.updateFrame(node: emptyNode, frame: emptyNodeFrame) + emptyNode.updateLayout(size: emptyNodeFrame.size, transition: transition) + } + } +} + +final class ChatListContainerNode: ASDisplayNode, UIGestureRecognizerDelegate { + private let context: AccountContext + private let groupId: PeerGroupId + private let previewing: Bool + private let filterBecameEmpty: (ChatListFilter?) -> Void + private let filterEmptyAction: (ChatListFilter?) -> Void + + private var presentationData: PresentationData + + private var itemNodes: [ChatListFilterTabEntryId: ChatListContainerItemNode] = [:] + private var pendingItemNode: (ChatListFilterTabEntryId, ChatListContainerItemNode, Disposable)? + private var availableFilters: [ChatListContainerNodeFilter] = [.all] + private var selectedId: ChatListFilterTabEntryId + + private(set) var transitionFraction: CGFloat = 0.0 + private var disableItemNodeOperationsWhileAnimating: Bool = false + private var validLayout: (layout: ContainerViewLayout, navigationBarHeight: CGFloat, visualNavigationHeight: CGFloat, cleanNavigationBarHeight: CGFloat)? + + private let _ready = Promise() + var ready: Signal { + return _ready.get() + } + + private var currentItemNodeValue: ChatListContainerItemNode? + var currentItemNode: ChatListNode { + return self.currentItemNodeValue!.listNode + } + + private let currentItemStateValue = Promise() + var currentItemState: Signal { + return self.currentItemStateValue.get() + } + + var currentItemFilterUpdated: ((ChatListFilterTabEntryId, CGFloat, ContainedViewLayoutTransition) -> Void)? + var currentItemFilter: ChatListFilterTabEntryId { + return self.currentItemNode.chatListFilter.flatMap { .filter($0.id) } ?? .all + } + + private func applyItemNodeAsCurrent(id: ChatListFilterTabEntryId, itemNode: ChatListContainerItemNode) { + if let previousItemNode = self.currentItemNodeValue { + previousItemNode.listNode.activateSearch = nil + previousItemNode.listNode.presentAlert = nil + previousItemNode.listNode.present = nil + previousItemNode.listNode.toggleArchivedFolderHiddenByDefault = nil + previousItemNode.listNode.deletePeerChat = nil + previousItemNode.listNode.peerSelected = nil + previousItemNode.listNode.groupSelected = nil + previousItemNode.listNode.updatePeerGrouping = nil + previousItemNode.listNode.contentOffsetChanged = nil + previousItemNode.listNode.contentScrollingEnded = nil + previousItemNode.listNode.activateChatPreview = nil + previousItemNode.listNode.addedVisibleChatsWithPeerIds = nil + + previousItemNode.accessibilityElementsHidden = true + } + self.currentItemNodeValue = itemNode + itemNode.accessibilityElementsHidden = false + + itemNode.listNode.activateSearch = { [weak self] in + self?.activateSearch?() + } + itemNode.listNode.presentAlert = { [weak self] text in + self?.presentAlert?(text) + } + itemNode.listNode.present = { [weak self] c in + self?.present?(c) + } + itemNode.listNode.toggleArchivedFolderHiddenByDefault = { [weak self] in + self?.toggleArchivedFolderHiddenByDefault?() + } + itemNode.listNode.deletePeerChat = { [weak self] peerId in + self?.deletePeerChat?(peerId) + } + itemNode.listNode.peerSelected = { [weak self] peerId, a, b in + self?.peerSelected?(peerId, a, b) + } + itemNode.listNode.groupSelected = { [weak self] groupId in + self?.groupSelected?(groupId) + } + itemNode.listNode.updatePeerGrouping = { [weak self] peerId, group in + self?.updatePeerGrouping?(peerId, group) + } + itemNode.listNode.contentOffsetChanged = { [weak self] offset in + self?.contentOffsetChanged?(offset) + } + itemNode.listNode.contentScrollingEnded = { [weak self] listView in + return self?.contentScrollingEnded?(listView) ?? false + } + itemNode.listNode.activateChatPreview = { [weak self] item, sourceNode, gesture in + self?.activateChatPreview?(item, sourceNode, gesture) + } + itemNode.listNode.addedVisibleChatsWithPeerIds = { [weak self] ids in + self?.addedVisibleChatsWithPeerIds?(ids) + } + + self.currentItemStateValue.set(itemNode.listNode.state) + } + + var activateSearch: (() -> Void)? + var presentAlert: ((String) -> Void)? + var present: ((ViewController) -> Void)? + var toggleArchivedFolderHiddenByDefault: (() -> Void)? + var deletePeerChat: ((PeerId) -> Void)? + var peerSelected: ((Peer, Bool, Bool) -> Void)? + var groupSelected: ((PeerGroupId) -> Void)? + var updatePeerGrouping: ((PeerId, Bool) -> Void)? + var contentOffsetChanged: ((ListViewVisibleContentOffset) -> Void)? + var contentScrollingEnded: ((ListView) -> Bool)? + var activateChatPreview: ((ChatListItem, ASDisplayNode, ContextGesture?) -> Void)? + var addedVisibleChatsWithPeerIds: (([PeerId]) -> Void)? + + init(context: AccountContext, groupId: PeerGroupId, previewing: Bool, presentationData: PresentationData, filterBecameEmpty: @escaping (ChatListFilter?) -> Void, filterEmptyAction: @escaping (ChatListFilter?) -> Void) { + self.context = context + self.groupId = groupId + self.previewing = previewing + self.filterBecameEmpty = filterBecameEmpty + self.filterEmptyAction = filterEmptyAction + + self.presentationData = presentationData + + self.selectedId = .all + + super.init() + + let itemNode = ChatListContainerItemNode(context: self.context, groupId: self.groupId, filter: nil, previewing: self.previewing, presentationData: presentationData, becameEmpty: { [weak self] filter in + self?.filterBecameEmpty(filter) + }, emptyAction: { [weak self] filter in + self?.filterEmptyAction(filter) + }) + self.itemNodes[.all] = itemNode + self.addSubnode(itemNode) + + self._ready.set(itemNode.listNode.ready) + + self.applyItemNodeAsCurrent(id: .all, itemNode: itemNode) + + let panRecognizer = InteractiveTransitionGestureRecognizer(target: self, action: #selector(self.panGesture(_:)), allowedDirections: { [weak self] _ in + guard let strongSelf = self, let index = strongSelf.availableFilters.index(where: { $0.id == strongSelf.selectedId }) else { + return [] + } + var directions: InteractiveTransitionGestureRecognizerDirections = [.left, .right] + if strongSelf.availableFilters.count > 1 { + if index == 0 { + directions.remove(.right) + } + if index == strongSelf.availableFilters.count - 1 { + directions.remove(.left) + } + } else { + directions = [] + } + return directions + }) + panRecognizer.delegate = self + panRecognizer.delaysTouchesBegan = false + panRecognizer.cancelsTouchesInView = true + self.view.addGestureRecognizer(panRecognizer) + } + + deinit { + self.pendingItemNode?.2.dispose() + } + + func gestureRecognizer(_ gestureRecognizer: UIGestureRecognizer, shouldRecognizeSimultaneouslyWith otherGestureRecognizer: UIGestureRecognizer) -> Bool { + return false + } + + func gestureRecognizer(_ gestureRecognizer: UIGestureRecognizer, shouldBeRequiredToFailBy otherGestureRecognizer: UIGestureRecognizer) -> Bool { + if let _ = otherGestureRecognizer as? InteractiveTransitionGestureRecognizer { + return false + } + if let _ = otherGestureRecognizer as? UIPanGestureRecognizer { + return true + } + return false + } + + @objc private func panGesture(_ recognizer: UIPanGestureRecognizer) { + switch recognizer.state { + case .changed: + if let (layout, navigationBarHeight, visualNavigationHeight, cleanNavigationBarHeight) = self.validLayout, let selectedIndex = self.availableFilters.index(where: { $0.id == self.selectedId }) { + let translation = recognizer.translation(in: self.view) + var transitionFraction = translation.x / layout.size.width + if selectedIndex <= 0 { + transitionFraction = min(0.0, transitionFraction) + } + if selectedIndex >= self.availableFilters.count - 1 { + transitionFraction = max(0.0, transitionFraction) + } + self.transitionFraction = transitionFraction + if let currentItemNode = self.currentItemNodeValue { + let isNavigationHidden = currentItemNode.listNode.isNavigationHidden + for (_, itemNode) in self.itemNodes { + if itemNode !== currentItemNode { + itemNode.listNode.adjustScrollOffsetForNavigation(isNavigationHidden: isNavigationHidden) + } + } + } + self.update(layout: layout, navigationBarHeight: navigationBarHeight, visualNavigationHeight: visualNavigationHeight, cleanNavigationBarHeight: cleanNavigationBarHeight, transition: .immediate) + self.currentItemFilterUpdated?(self.currentItemFilter, self.transitionFraction, .immediate) + } + case .cancelled, .ended: + if let (layout, navigationBarHeight, visualNavigationHeight, cleanNavigationBarHeight) = self.validLayout, let selectedIndex = self.availableFilters.index(where: { $0.id == self.selectedId }) { + let translation = recognizer.translation(in: self.view) + let velocity = recognizer.velocity(in: self.view) + var directionIsToRight: Bool? + if abs(velocity.x) > 10.0 { + directionIsToRight = velocity.x < 0.0 + } else { + if abs(translation.x) > layout.size.width / 2.0 { + directionIsToRight = translation.x > layout.size.width / 2.0 + } + } + if let directionIsToRight = directionIsToRight { + var updatedIndex = selectedIndex + if directionIsToRight { + updatedIndex = min(updatedIndex + 1, self.availableFilters.count - 1) + } else { + updatedIndex = max(updatedIndex - 1, 0) + } + let switchToId = self.availableFilters[updatedIndex].id + if switchToId != self.selectedId, let itemNode = self.itemNodes[switchToId] { + self.selectedId = switchToId + self.applyItemNodeAsCurrent(id: switchToId, itemNode: itemNode) + } + } + self.transitionFraction = 0.0 + let transition: ContainedViewLayoutTransition = .animated(duration: 0.45, curve: .spring) + self.disableItemNodeOperationsWhileAnimating = true + self.update(layout: layout, navigationBarHeight: navigationBarHeight, visualNavigationHeight: visualNavigationHeight, cleanNavigationBarHeight: cleanNavigationBarHeight, transition: transition) + self.currentItemFilterUpdated?(self.currentItemFilter, self.transitionFraction, transition) + transition.updateBounds(node: self, bounds: self.bounds, force: true, completion: { [weak self] _ in + guard let strongSelf = self else { + return + } + strongSelf.disableItemNodeOperationsWhileAnimating = false + if let (layout, navigationBarHeight, visualNavigationHeight, cleanNavigationBarHeight) = strongSelf.validLayout { + strongSelf.update(layout: layout, navigationBarHeight: navigationBarHeight, visualNavigationHeight: visualNavigationHeight, cleanNavigationBarHeight: cleanNavigationBarHeight, transition: .immediate) + } + }) + } + default: + break + } + } + + func updatePresentationData(_ presentationData: PresentationData) { + self.presentationData = presentationData + + for (_, itemNode) in self.itemNodes { + itemNode.updatePresentationData(presentationData) + } + } + + func playArchiveAnimation() { + if let itemNode = self.itemNodes[self.selectedId] { + itemNode.listNode.forEachVisibleItemNode { node in + if let node = node as? ChatListItemNode { + node.playArchiveAnimation() + } + } + } + } + + func scrollToTop() { + if let itemNode = self.itemNodes[self.selectedId] { + itemNode.listNode.scrollToPosition(.top) + } + } + + func updateSelectedChatLocation(data: ChatLocation?, progress: CGFloat, transition: ContainedViewLayoutTransition) { + for (_, itemNode) in self.itemNodes { + itemNode.listNode.updateSelectedChatLocation(data, progress: progress, transition: transition) + } + } + + func updateState(_ f: (ChatListNodeState) -> ChatListNodeState) { + self.currentItemNode.updateState(f) + let updatedState = self.currentItemNode.currentState + for (id, itemNode) in self.itemNodes { + if id != self.selectedId { + itemNode.listNode.updateState { state in + var state = state + state.editing = updatedState.editing + state.selectedPeerIds = updatedState.selectedPeerIds + return state + } + } + } + } + + func updateAvailableFilters(_ availableFilters: [ChatListContainerNodeFilter]) { + if self.availableFilters != availableFilters { + self.availableFilters = availableFilters + if let (layout, navigationBarHeight, visualNavigationHeight, cleanNavigationBarHeight) = self.validLayout { + self.update(layout: layout, navigationBarHeight: navigationBarHeight, visualNavigationHeight: visualNavigationHeight, cleanNavigationBarHeight: cleanNavigationBarHeight, transition: .immediate) + } + } + } + + func switchToFilter(id: ChatListFilterTabEntryId) { + guard let (layout, navigationBarHeight, visualNavigationHeight, cleanNavigationBarHeight) = self.validLayout else { + return + } + if id != self.selectedId, let index = self.availableFilters.index(where: { $0.id == id }) { + if let itemNode = self.itemNodes[id] { + self.selectedId = id + if let currentItemNode = self.currentItemNodeValue { + itemNode.listNode.adjustScrollOffsetForNavigation(isNavigationHidden: currentItemNode.listNode.isNavigationHidden) + } + self.applyItemNodeAsCurrent(id: id, itemNode: itemNode) + let transition: ContainedViewLayoutTransition = .animated(duration: 0.35, curve: .spring) + self.update(layout: layout, navigationBarHeight: navigationBarHeight, visualNavigationHeight: visualNavigationHeight, cleanNavigationBarHeight: cleanNavigationBarHeight, transition: transition) + self.currentItemFilterUpdated?(self.currentItemFilter, self.transitionFraction, transition) + } else if self.pendingItemNode == nil { + let itemNode = ChatListContainerItemNode(context: self.context, groupId: self.groupId, filter: self.availableFilters[index].filter, previewing: self.previewing, presentationData: self.presentationData, becameEmpty: { [weak self] filter in + self?.filterBecameEmpty(filter) + }, emptyAction: { [weak self] filter in + self?.filterEmptyAction(filter) + }) + let disposable = MetaDisposable() + self.pendingItemNode = (id, itemNode, disposable) + + disposable.set((itemNode.listNode.ready + |> filter { $0 } + |> take(1) + |> deliverOnMainQueue).start(next: { [weak self, weak itemNode] _ in + guard let strongSelf = self, let itemNode = itemNode, itemNode === strongSelf.pendingItemNode?.1 else { + return + } + guard let (layout, navigationBarHeight, visualNavigationHeight, cleanNavigationBarHeight) = strongSelf.validLayout else { + return + } + strongSelf.pendingItemNode = nil + + let transition: ContainedViewLayoutTransition = .animated(duration: 0.35, curve: .spring) + + if let previousIndex = strongSelf.availableFilters.index(where: { $0.id == strongSelf.selectedId }), let index = strongSelf.availableFilters.index(where: { $0.id == id }) { + let previousId = strongSelf.selectedId + let offsetDirection: CGFloat = index < previousIndex ? 1.0 : -1.0 + let offset = offsetDirection * layout.size.width + + var validNodeIds: [ChatListFilterTabEntryId] = [] + for i in max(0, index - 1) ... min(strongSelf.availableFilters.count - 1, index + 1) { + validNodeIds.append(strongSelf.availableFilters[i].id) + } + + var removeIds: [ChatListFilterTabEntryId] = [] + for (id, _) in strongSelf.itemNodes { + if !validNodeIds.contains(id) { + removeIds.append(id) + } + } + for id in removeIds { + if let itemNode = strongSelf.itemNodes.removeValue(forKey: id) { + if id == previousId { + transition.updateFrame(node: itemNode, frame: itemNode.frame.offsetBy(dx: offset, dy: 0.0), completion: { [weak itemNode] _ in + itemNode?.removeFromSupernode() + }) + } else { + itemNode.removeFromSupernode() + } + } + } + + strongSelf.itemNodes[id] = itemNode + strongSelf.addSubnode(itemNode) + + let itemFrame = CGRect(origin: CGPoint(x: 0.0, y: 0.0), size: layout.size) + itemNode.frame = itemFrame + + transition.animatePositionAdditive(node: itemNode, offset: CGPoint(x: -offset, y: 0.0)) + + var insets = layout.insets(options: [.input]) + insets.top += navigationBarHeight + + insets.left += layout.safeInsets.left + insets.right += layout.safeInsets.right + + itemNode.updateLayout(size: layout.size, insets: insets, visualNavigationHeight: visualNavigationHeight, transition: .immediate) + + strongSelf.selectedId = id + if let currentItemNode = strongSelf.currentItemNodeValue { + itemNode.listNode.adjustScrollOffsetForNavigation(isNavigationHidden: currentItemNode.listNode.isNavigationHidden) + } + strongSelf.applyItemNodeAsCurrent(id: id, itemNode: itemNode) + + strongSelf.update(layout: layout, navigationBarHeight: navigationBarHeight, visualNavigationHeight: visualNavigationHeight, cleanNavigationBarHeight: cleanNavigationBarHeight, transition: .immediate) + + strongSelf.currentItemFilterUpdated?(strongSelf.currentItemFilter, strongSelf.transitionFraction, transition) + } + })) + } + } + } + + func update(layout: ContainerViewLayout, navigationBarHeight: CGFloat, visualNavigationHeight: CGFloat, cleanNavigationBarHeight: CGFloat, transition: ContainedViewLayoutTransition) { + self.validLayout = (layout, navigationBarHeight, visualNavigationHeight, cleanNavigationBarHeight) + + var insets = layout.insets(options: [.input]) + insets.top += navigationBarHeight + + insets.left += layout.safeInsets.left + insets.right += layout.safeInsets.right + + if let selectedIndex = self.availableFilters.index(where: { $0.id == self.selectedId }) { + var validNodeIds: [ChatListFilterTabEntryId] = [] + for i in max(0, selectedIndex - 1) ... min(self.availableFilters.count - 1, selectedIndex + 1) { + let id = self.availableFilters[i].id + validNodeIds.append(id) + + if self.itemNodes[id] == nil && !self.disableItemNodeOperationsWhileAnimating { + let itemNode = ChatListContainerItemNode(context: self.context, groupId: self.groupId, filter: self.availableFilters[i].filter, previewing: self.previewing, presentationData: self.presentationData, becameEmpty: { [weak self] filter in + self?.filterBecameEmpty(filter) + }, emptyAction: { [weak self] filter in + self?.filterEmptyAction(filter) + }) + self.itemNodes[id] = itemNode + } + } + + var removeIds: [ChatListFilterTabEntryId] = [] + var animateSlidingIds: [ChatListFilterTabEntryId] = [] + var slidingOffset: CGFloat? + for (id, itemNode) in self.itemNodes { + if !validNodeIds.contains(id) { + removeIds.append(id) + } + guard let index = self.availableFilters.index(where: { $0.id == id }) else { + continue + } + let indexDistance = CGFloat(index - selectedIndex) + self.transitionFraction + + let wasAdded = itemNode.supernode == nil + var nodeTransition = transition + if wasAdded { + self.addSubnode(itemNode) + nodeTransition = .immediate + } + + let itemFrame = CGRect(origin: CGPoint(x: indexDistance * layout.size.width, y: 0.0), size: layout.size) + if !wasAdded && slidingOffset == nil { + slidingOffset = itemNode.frame.minX - itemFrame.minX + } + nodeTransition.updateFrame(node: itemNode, frame: itemFrame, completion: { [weak self] _ in + guard let strongSelf = self else { + return + } + }) + + itemNode.updateLayout(size: layout.size, insets: insets, visualNavigationHeight: visualNavigationHeight, transition: nodeTransition) + + if wasAdded, case .animated = transition { + animateSlidingIds.append(id) + } + } + if let slidingOffset = slidingOffset { + for id in animateSlidingIds { + if let itemNode = self.itemNodes[id] { + transition.animatePositionAdditive(node: itemNode, offset: CGPoint(x: slidingOffset, y: 0.0), completion: { + }) + } + } + } + if !self.disableItemNodeOperationsWhileAnimating { + for id in removeIds { + if let itemNode = self.itemNodes.removeValue(forKey: id) { + itemNode.removeFromSupernode() + } + } + } } - return lhs.value < rhs.value } } @@ -47,9 +607,7 @@ final class ChatListControllerNode: ASDisplayNode { private let groupId: PeerGroupId private var presentationData: PresentationData - private var chatListEmptyNodeContainer: ChatListEmptyNodeContainer - private var chatListEmptyIndicator: ActivityIndicator? - let chatListNode: ChatListNode + let containerNode: ChatListContainerNode var navigationBar: NavigationBar? weak var controller: ChatListControllerImpl? @@ -78,8 +636,13 @@ final class ChatListControllerNode: ASDisplayNode { self.groupId = groupId self.presentationData = presentationData - self.chatListEmptyNodeContainer = ChatListEmptyNodeContainer(theme: presentationData.theme, strings: presentationData.strings) - self.chatListNode = ChatListNode(context: context, groupId: groupId, chatListFilter: filter, previewing: previewing, controlsHistoryPreload: controlsHistoryPreload, mode: .chatList, theme: presentationData.theme, fontSize: presentationData.listsFontSize, strings: presentationData.strings, dateTimeFormat: presentationData.dateTimeFormat, nameSortOrder: presentationData.nameSortOrder, nameDisplayOrder: presentationData.nameDisplayOrder, disableAnimations: presentationData.disableAnimations) + var filterBecameEmpty: ((ChatListFilter?) -> Void)? + var filterEmptyAction: ((ChatListFilter?) -> Void)? + self.containerNode = ChatListContainerNode(context: context, groupId: groupId, previewing: previewing, presentationData: presentationData, filterBecameEmpty: { filter in + filterBecameEmpty?(filter) + }, filterEmptyAction: { filter in + filterEmptyAction?(filter) + }) self.controller = controller @@ -91,35 +654,24 @@ final class ChatListControllerNode: ASDisplayNode { self.backgroundColor = presentationData.theme.chatList.backgroundColor - self.addSubnode(self.chatListNode) - self.addSubnode(self.chatListEmptyNodeContainer) - self.chatListNode.isEmptyUpdated = { [weak self] isEmptyState, isFilter, transitionDirection, transition in + self.addSubnode(self.containerNode) + + self.addSubnode(self.debugListView) + + filterBecameEmpty = { [weak self] _ in guard let strongSelf = self else { return } - switch isEmptyState { - case .empty(false): - if case .group = strongSelf.groupId { - strongSelf.dismissSelf?() - } else { - strongSelf.chatListEmptyNodeContainer.update(state: isEmptyState, isFilter: isFilter, direction: transitionDirection, transition: transition) - } - case .notEmpty(false): - if case .group = strongSelf.groupId { - strongSelf.dismissSelf?() - } else { - strongSelf.chatListEmptyNodeContainer.update(state: isEmptyState, isFilter: isFilter, direction: transitionDirection, transition: transition) - } - default: - strongSelf.chatListEmptyNodeContainer.update(state: isEmptyState, isFilter: isFilter, direction: transitionDirection, transition: transition) + if case .group = strongSelf.groupId { + strongSelf.dismissSelf?() } } - - self.chatListEmptyNodeContainer.action = { [weak self] in - self?.emptyListAction?() + filterEmptyAction = { [weak self] filter in + guard let strongSelf = self else { + return + } + strongSelf.emptyListAction?() } - - self.addSubnode(self.debugListView) } override func didLoad() { @@ -133,9 +685,8 @@ final class ChatListControllerNode: ASDisplayNode { self.backgroundColor = self.presentationData.theme.chatList.backgroundColor - self.chatListNode.updateThemeAndStrings(theme: self.presentationData.theme, fontSize: self.presentationData.listsFontSize, strings: self.presentationData.strings, dateTimeFormat: self.presentationData.dateTimeFormat, nameSortOrder: self.presentationData.nameSortOrder, nameDisplayOrder: self.presentationData.nameDisplayOrder, disableAnimations: self.presentationData.disableAnimations) + self.containerNode.updatePresentationData(presentationData) self.searchDisplayController?.updatePresentationData(presentationData) - self.chatListEmptyNodeContainer.updateThemeAndStrings(theme: self.presentationData.theme, strings: self.presentationData.strings) if let toolbarNode = self.toolbarNode { toolbarNode.updateTheme(TabBarControllerTheme(rootControllerTheme: self.presentationData.theme)) @@ -194,23 +745,8 @@ final class ChatListControllerNode: ASDisplayNode { }) } - self.chatListNode.bounds = CGRect(x: 0.0, y: 0.0, width: layout.size.width, height: layout.size.height) - self.chatListNode.position = CGPoint(x: layout.size.width / 2.0, y: layout.size.height / 2.0) - - let (duration, curve) = listViewAnimationDurationAndCurve(transition: transition) - let updateSizeAndInsets = ListViewUpdateSizeAndInsets(size: layout.size, insets: insets, duration: duration, curve: curve) - - self.chatListNode.visualInsets = UIEdgeInsets(top: visualNavigationHeight, left: 0.0, bottom: 0.0, right: 0.0) - self.chatListNode.updateLayout(transition: transition, updateSizeAndInsets: updateSizeAndInsets) - - let emptySize = CGSize(width: updateSizeAndInsets.size.width, height: updateSizeAndInsets.size.height - updateSizeAndInsets.insets.top - updateSizeAndInsets.insets.bottom) - transition.updateFrame(node: self.chatListEmptyNodeContainer, frame: CGRect(origin: CGPoint(x: 0.0, y: updateSizeAndInsets.insets.top), size: emptySize)) - self.chatListEmptyNodeContainer.updateLayout(size: emptySize, transition: transition) - - if let chatListEmptyIndicator = self.chatListEmptyIndicator { - let indicatorSize = chatListEmptyIndicator.measure(CGSize(width: 100.0, height: 100.0)) - transition.updateFrame(node: chatListEmptyIndicator, frame: CGRect(origin: CGPoint(x: floor((layout.size.width - indicatorSize.width) / 2.0), y: updateSizeAndInsets.insets.top + floor((layout.size.height - updateSizeAndInsets.insets.top - updateSizeAndInsets.insets.bottom - indicatorSize.height) / 2.0)), size: indicatorSize)) - } + transition.updateFrame(node: self.containerNode, frame: CGRect(origin: CGPoint(), size: layout.size)) + self.containerNode.update(layout: layout, navigationBarHeight: navigationBarHeight, visualNavigationHeight: visualNavigationHeight, cleanNavigationBarHeight: cleanNavigationBarHeight, transition: transition) if let searchDisplayController = self.searchDisplayController { searchDisplayController.containerLayoutUpdated(layout, navigationBarHeight: cleanNavigationBarHeight, transition: transition) @@ -242,7 +778,7 @@ final class ChatListControllerNode: ASDisplayNode { requestDeactivateSearch() } }) - self.chatListNode.accessibilityElementsHidden = true + self.containerNode.accessibilityElementsHidden = true self.searchDisplayController?.containerLayoutUpdated(containerLayout, navigationBarHeight: cleanNavigationBarHeight, transition: .immediate) self.searchDisplayController?.activate(insertSubnode: { [weak self, weak placeholderNode] subnode, isSearchBar in @@ -260,23 +796,19 @@ final class ChatListControllerNode: ASDisplayNode { if let searchDisplayController = self.searchDisplayController { searchDisplayController.deactivate(placeholder: placeholderNode, animated: animated) self.searchDisplayController = nil - self.chatListNode.accessibilityElementsHidden = false + self.containerNode.accessibilityElementsHidden = false } } func playArchiveAnimation() { - self.chatListNode.forEachVisibleItemNode { node in - if let node = node as? ChatListItemNode { - node.playArchiveAnimation() - } - } + self.containerNode.playArchiveAnimation() } func scrollToTop() { if let searchDisplayController = self.searchDisplayController { searchDisplayController.contentNode.scrollToTop() } else { - self.chatListNode.scrollToPosition(.top) + self.containerNode.scrollToTop() } } } diff --git a/submodules/ChatListUI/Sources/ChatListFilterPresetController.swift b/submodules/ChatListUI/Sources/ChatListFilterPresetController.swift index c9bdcc3c23..ddf591eb45 100644 --- a/submodules/ChatListUI/Sources/ChatListFilterPresetController.swift +++ b/submodules/ChatListUI/Sources/ChatListFilterPresetController.swift @@ -18,13 +18,15 @@ private final class ChatListFilterPresetControllerArguments { let openAddPeer: () -> Void let deleteAdditionalPeer: (PeerId) -> Void let setPeerIdWithRevealedOptions: (PeerId?, PeerId?) -> Void + let focusOnName: () -> Void - init(context: AccountContext, updateState: @escaping ((ChatListFilterPresetControllerState) -> ChatListFilterPresetControllerState) -> Void, openAddPeer: @escaping () -> Void, deleteAdditionalPeer: @escaping (PeerId) -> Void, setPeerIdWithRevealedOptions: @escaping (PeerId?, PeerId?) -> Void) { + init(context: AccountContext, updateState: @escaping ((ChatListFilterPresetControllerState) -> ChatListFilterPresetControllerState) -> Void, openAddPeer: @escaping () -> Void, deleteAdditionalPeer: @escaping (PeerId) -> Void, setPeerIdWithRevealedOptions: @escaping (PeerId?, PeerId?) -> Void, focusOnName: @escaping () -> Void) { self.context = context self.updateState = updateState self.openAddPeer = openAddPeer self.deleteAdditionalPeer = deleteAdditionalPeer self.setPeerIdWithRevealedOptions = setPeerIdWithRevealedOptions + self.focusOnName = focusOnName } } @@ -168,13 +170,15 @@ private enum ChatListFilterPresetEntry: ItemListNodeEntry { case let .nameHeader(title): return ItemListSectionHeaderItem(presentationData: presentationData, text: title, sectionId: self.section) case let .name(placeholder, value): - return ItemListSingleLineInputItem(presentationData: presentationData, title: NSAttributedString(), text: value, placeholder: placeholder, type: .regular(capitalization: true, autocorrection: false), sectionId: self.section, textUpdated: { value in + return ItemListSingleLineInputItem(presentationData: presentationData, title: NSAttributedString(), text: value, placeholder: placeholder, type: .regular(capitalization: true, autocorrection: false), clearType: .always, sectionId: self.section, textUpdated: { value in arguments.updateState { current in var state = current state.name = value return state } - }, action: {}) + }, action: {}, cleared: { + arguments.focusOnName() + }) case let .typesHeader(text): return ItemListSectionHeaderItem(presentationData: presentationData, text: text, sectionId: self.section) case let .filterPrivateChats(title, value): @@ -276,7 +280,7 @@ private func chatListFilterPresetControllerEntries(presentationData: Presentatio } func chatListFilterAddChatsController(context: AccountContext, filter: ChatListFilter) -> ViewController { - let controller = context.sharedContext.makeContactMultiselectionController(ContactMultiselectionControllerParams(context: context, mode: .peerSelection(searchChatList: true, searchGroups: true, searchChannels: true), options: [])) + let controller = context.sharedContext.makeContactMultiselectionController(ContactMultiselectionControllerParams(context: context, mode: .chatSelection, options: [])) controller.navigationPresentation = .modal let _ = (controller.result |> take(1) @@ -285,7 +289,7 @@ func chatListFilterAddChatsController(context: AccountContext, filter: ChatListF var settings = settings for i in 0 ..< settings.filters.count { if settings.filters[i].id == filter.id { - let previousIncludePeers = settings.filters[i].includePeers + let previousIncludePeers = settings.filters[i].data.includePeers var chatPeerIds: [PeerId] = [] for peerId in peerIds { @@ -296,7 +300,7 @@ func chatListFilterAddChatsController(context: AccountContext, filter: ChatListF break } } - settings.filters[i].includePeers = chatPeerIds + previousIncludePeers.filter { peerId in + settings.filters[i].data.includePeers = chatPeerIds + previousIncludePeers.filter { peerId in return !chatPeerIds.contains(peerId) } } @@ -305,6 +309,8 @@ func chatListFilterAddChatsController(context: AccountContext, filter: ChatListF }) |> deliverOnMainQueue).start(next: { settings in controller?.dismiss() + + let _ = replaceRemoteChatListFilters(account: context.account).start() }) }) return controller @@ -317,7 +323,7 @@ func chatListFilterPresetController(context: AccountContext, currentPreset: Chat } else { initialName = "New Filter" } - let initialState = ChatListFilterPresetControllerState(name: initialName, includeCategories: currentPreset?.categories ?? .all, excludeMuted: currentPreset?.excludeMuted ?? false, excludeRead: currentPreset?.excludeRead ?? false, additionallyIncludePeers: currentPreset?.includePeers ?? []) + let initialState = ChatListFilterPresetControllerState(name: initialName, includeCategories: currentPreset?.data.categories ?? .all, excludeMuted: currentPreset?.data.excludeMuted ?? false, excludeRead: currentPreset?.data.excludeRead ?? false, additionallyIncludePeers: currentPreset?.data.includePeers ?? []) let stateValue = Atomic(value: initialState) let statePromise = ValuePromise(initialState, ignoreRepeated: true) let updateState: ((ChatListFilterPresetControllerState) -> ChatListFilterPresetControllerState) -> Void = { f in @@ -331,6 +337,7 @@ func chatListFilterPresetController(context: AccountContext, currentPreset: Chat var presentControllerImpl: ((ViewController, Any?) -> Void)? var dismissImpl: (() -> Void)? + var focusOnNameImpl: (() -> Void)? let arguments = ChatListFilterPresetControllerArguments( context: context, @@ -338,7 +345,7 @@ func chatListFilterPresetController(context: AccountContext, currentPreset: Chat updateState(f) }, openAddPeer: { - let controller = context.sharedContext.makeContactMultiselectionController(ContactMultiselectionControllerParams(context: context, mode: .peerSelection(searchChatList: true, searchGroups: true, searchChannels: true), options: [])) + let controller = context.sharedContext.makeContactMultiselectionController(ContactMultiselectionControllerParams(context: context, mode: .chatSelection, options: [])) addPeerDisposable.set((controller.result |> take(1) |> deliverOnMainQueue).start(next: { [weak controller] peerIds in @@ -377,6 +384,9 @@ func chatListFilterPresetController(context: AccountContext, currentPreset: Chat } return state } + }, + focusOnName: { + focusOnNameImpl?() } ) @@ -409,7 +419,7 @@ func chatListFilterPresetController(context: AccountContext, currentPreset: Chat }) let rightNavigationButton = ItemListNavigationButton(content: .text(currentPreset == nil ? presentationData.strings.Common_Create : presentationData.strings.Common_Done), style: .bold, enabled: state.isComplete, action: { let state = stateValue.with { $0 } - let preset = ChatListFilter(id: currentPreset?.id ?? -1, title: state.name, categories: state.includeCategories, excludeMuted: state.excludeMuted, excludeRead: state.excludeRead, includePeers: state.additionallyIncludePeers) + let preset = ChatListFilter(id: currentPreset?.id ?? -1, title: state.name, data: ChatListFilterData(categories: state.includeCategories, excludeMuted: state.excludeMuted, excludeRead: state.excludeRead, includePeers: state.additionallyIncludePeers)) let _ = (updateChatListFilterSettingsInteractively(postbox: context.account.postbox, { settings in var preset = preset if currentPreset == nil { @@ -435,6 +445,8 @@ func chatListFilterPresetController(context: AccountContext, currentPreset: Chat |> deliverOnMainQueue).start(next: { settings in updated(settings.filters) dismissImpl?() + + let _ = replaceRemoteChatListFilters(account: context.account).start() }) }) @@ -455,6 +467,16 @@ func chatListFilterPresetController(context: AccountContext, currentPreset: Chat dismissImpl = { [weak controller] in let _ = controller?.dismiss() } + focusOnNameImpl = { [weak controller] in + guard let controller = controller else { + return + } + controller.forEachItemNode { itemNode in + if let itemNode = itemNode as? ItemListSingleLineInputItemNode { + itemNode.focus() + } + } + } return controller } diff --git a/submodules/ChatListUI/Sources/ChatListFilterPresetListController.swift b/submodules/ChatListUI/Sources/ChatListFilterPresetListController.swift index 53b5d67994..b00da48d68 100644 --- a/submodules/ChatListUI/Sources/ChatListFilterPresetListController.swift +++ b/submodules/ChatListUI/Sources/ChatListFilterPresetListController.swift @@ -53,7 +53,7 @@ private enum ChatListFilterPresetListEntryStableId: Hashable { private enum ChatListFilterPresetListEntry: ItemListNodeEntry { case listHeader(String) - case preset(index: Int, title: String?, preset: ChatListFilter, canBeReordered: Bool, canBeDeleted: Bool, isEditing: Bool) + case preset(index: Int, title: String, label: String, preset: ChatListFilter, canBeReordered: Bool, canBeDeleted: Bool, isEditing: Bool) case addItem(text: String, isEditing: Bool) case listFooter(String) @@ -99,8 +99,8 @@ private enum ChatListFilterPresetListEntry: ItemListNodeEntry { switch self { case let .listHeader(text): return ItemListSectionHeaderItem(presentationData: presentationData, text: text, multiline: true, sectionId: self.section) - case let .preset(index, title, preset, canBeReordered, canBeDeleted, isEditing): - return ChatListFilterPresetListItem(presentationData: presentationData, preset: preset, title: title ?? "", editing: ChatListFilterPresetListItemEditing(editable: true, editing: isEditing, revealed: false), canBeReordered: canBeReordered, canBeDeleted: canBeDeleted, sectionId: self.section, action: { + case let .preset(index, title, label, preset, canBeReordered, canBeDeleted, isEditing): + return ChatListFilterPresetListItem(presentationData: presentationData, preset: preset, title: title ?? "", label: label, editing: ChatListFilterPresetListItemEditing(editable: true, editing: isEditing, revealed: false), canBeReordered: canBeReordered, canBeDeleted: canBeDeleted, sectionId: self.section, action: { arguments.openPreset(preset) }, setItemWithRevealedOptions: { lhs, rhs in arguments.setItemWithRevealedOptions(lhs, rhs) @@ -122,14 +122,14 @@ private struct ChatListFilterPresetListControllerState: Equatable { var revealedPreset: Int32? = nil } -private func chatListFilterPresetListControllerEntries(presentationData: PresentationData, state: ChatListFilterPresetListControllerState, filtersState: ChatListFiltersState, settings: ChatListFilterSettings) -> [ChatListFilterPresetListEntry] { +private func chatListFilterPresetListControllerEntries(presentationData: PresentationData, state: ChatListFilterPresetListControllerState, filters: [(ChatListFilter, Int)], settings: ChatListFilterSettings) -> [ChatListFilterPresetListEntry] { var entries: [ChatListFilterPresetListEntry] = [] entries.append(.listHeader("FILTERS")) - for preset in filtersState.filters { - entries.append(.preset(index: entries.count, title: preset.title, preset: preset, canBeReordered: filtersState.filters.count > 1, canBeDeleted: true, isEditing: state.isEditing)) + for (filter, chatCount) in filters { + entries.append(.preset(index: entries.count, title: filter.title, label: chatCount == 0 ? "" : "\(chatCount)", preset: filter, canBeReordered: filters.count > 1, canBeDeleted: true, isEditing: state.isEditing)) } - if filtersState.filters.count < 10 { + if filters.count < 10 { entries.append(.addItem(text: "Create New Filter", isEditing: state.isEditing)) } entries.append(.listFooter("Tap \"Edit\" to change the order or delete filters.")) @@ -137,7 +137,7 @@ private func chatListFilterPresetListControllerEntries(presentationData: Present return entries } -func chatListFilterPresetListController(context: AccountContext, updated: @escaping ([ChatListFilter]) -> Void) -> ViewController { +public func chatListFilterPresetListController(context: AccountContext, updated: @escaping ([ChatListFilter]) -> Void) -> ViewController { let initialState = ChatListFilterPresetListControllerState() let statePromise = ValuePromise(initialState, ignoreRepeated: true) let stateValue = Atomic(value: initialState) @@ -171,21 +171,51 @@ func chatListFilterPresetListController(context: AccountContext, updated: @escap }) |> deliverOnMainQueue).start(next: { settings in updated(settings.filters) + + let _ = replaceRemoteChatListFilters(account: context.account).start() }) }) - let preferences = context.account.postbox.preferencesView(keys: [PreferencesKeys.chatListFilters, ApplicationSpecificPreferencesKeys.chatListFilterSettings]) + let chatCountCache = Atomic<[ChatListFilterData: Int]>(value: [:]) + + let filtersWithCounts = context.account.postbox.preferencesView(keys: [PreferencesKeys.chatListFilters]) + |> map { preferences -> [ChatListFilter] in + let filtersState = preferences.values[PreferencesKeys.chatListFilters] as? ChatListFiltersState ?? ChatListFiltersState.default + return filtersState.filters + } + |> distinctUntilChanged + |> mapToSignal { filters -> Signal<[(ChatListFilter, Int)], NoError> in + return context.account.postbox.transaction { transaction -> [(ChatListFilter, Int)] in + return filters.map { filter -> (ChatListFilter, Int) in + let count: Int + if let cachedValue = chatCountCache.with({ dict -> Int? in + return dict[filter.data] + }) { + count = cachedValue + } else { + count = transaction.getChatCountMatchingPredicate(chatListFilterPredicate(filter: filter.data)) + let _ = chatCountCache.modify { dict in + var dict = dict + dict[filter.data] = count + return dict + } + } + return (filter, count) + } + } + } + + let preferences = context.account.postbox.preferencesView(keys: [ApplicationSpecificPreferencesKeys.chatListFilterSettings]) let signal = combineLatest(queue: .mainQueue(), context.sharedContext.presentationData, statePromise.get(), + filtersWithCounts, preferences ) - |> map { presentationData, state, preferences -> (ItemListControllerState, (ItemListNodeState, Any)) in - let filtersState = preferences.values[PreferencesKeys.chatListFilters] as? ChatListFiltersState ?? ChatListFiltersState.default + |> map { presentationData, state, filtersWithCounts, preferences -> (ItemListControllerState, (ItemListNodeState, Any)) in let filterSettings = preferences.values[ApplicationSpecificPreferencesKeys.chatListFilterSettings] as? ChatListFilterSettings ?? ChatListFilterSettings.default let leftNavigationButton = ItemListNavigationButton(content: .text(presentationData.strings.Common_Close), style: .regular, enabled: true, action: { - let _ = replaceRemoteChatListFilters(account: context.account).start() dismissImpl?() }) let rightNavigationButton: ItemListNavigationButton @@ -208,7 +238,7 @@ func chatListFilterPresetListController(context: AccountContext, updated: @escap } let controllerState = ItemListControllerState(presentationData: ItemListPresentationData(presentationData), title: .text("Filters"), leftNavigationButton: leftNavigationButton, rightNavigationButton: rightNavigationButton, backNavigationButton: ItemListBackButton(title: presentationData.strings.Common_Back), animateChanges: false) - let listState = ItemListNodeState(presentationData: ItemListPresentationData(presentationData), entries: chatListFilterPresetListControllerEntries(presentationData: presentationData, state: state, filtersState: filtersState, settings: filterSettings), style: .blocks, animateChanges: true) + let listState = ItemListNodeState(presentationData: ItemListPresentationData(presentationData), entries: chatListFilterPresetListControllerEntries(presentationData: presentationData, state: state, filters: filtersWithCounts, settings: filterSettings), style: .blocks, animateChanges: true) return (controllerState, (listState, arguments)) } @@ -217,6 +247,9 @@ func chatListFilterPresetListController(context: AccountContext, updated: @escap let controller = ItemListController(context: context, state: signal) controller.navigationPresentation = .modal + controller.willDisappear = { _ in + let _ = replaceRemoteChatListFilters(account: context.account).start() + } pushControllerImpl = { [weak controller] c in controller?.push(c) } diff --git a/submodules/ChatListUI/Sources/ChatListFilterPresetListItem.swift b/submodules/ChatListUI/Sources/ChatListFilterPresetListItem.swift index be38d24b1d..d839e97504 100644 --- a/submodules/ChatListUI/Sources/ChatListFilterPresetListItem.swift +++ b/submodules/ChatListUI/Sources/ChatListFilterPresetListItem.swift @@ -20,6 +20,7 @@ final class ChatListFilterPresetListItem: ListViewItem, ItemListItem { let presentationData: ItemListPresentationData let preset: ChatListFilter let title: String + let label: String let editing: ChatListFilterPresetListItemEditing let canBeReordered: Bool let canBeDeleted: Bool @@ -32,6 +33,7 @@ final class ChatListFilterPresetListItem: ListViewItem, ItemListItem { presentationData: ItemListPresentationData, preset: ChatListFilter, title: String, + label: String, editing: ChatListFilterPresetListItemEditing, canBeReordered: Bool, canBeDeleted: Bool, @@ -43,6 +45,7 @@ final class ChatListFilterPresetListItem: ListViewItem, ItemListItem { self.presentationData = presentationData self.preset = preset self.title = title + self.label = label self.editing = editing self.canBeReordered = canBeReordered self.canBeDeleted = canBeDeleted @@ -108,6 +111,8 @@ private final class ChatListFilterPresetListItemNode: ItemListRevealOptionsItemN private let maskNode: ASImageNode private let titleNode: TextNode + private let labelNode: TextNode + private let arrowNode: ASImageNode private let activateArea: AccessibilityAreaNode @@ -141,6 +146,14 @@ private final class ChatListFilterPresetListItemNode: ItemListRevealOptionsItemN self.titleNode.contentMode = .left self.titleNode.contentsScale = UIScreen.main.scale + self.labelNode = TextNode() + self.labelNode.isUserInteractionEnabled = false + + self.arrowNode = ASImageNode() + self.arrowNode.displayWithoutProcessing = true + self.arrowNode.displaysAsynchronously = false + self.arrowNode.isLayerBacked = true + self.activateArea = AccessibilityAreaNode() self.highlightedBackgroundNode = ASDisplayNode() @@ -149,6 +162,8 @@ private final class ChatListFilterPresetListItemNode: ItemListRevealOptionsItemN super.init(layerBacked: false, dynamicBounce: false, rotated: false, seeThrough: false) self.addSubnode(self.titleNode) + self.addSubnode(self.labelNode) + self.addSubnode(self.arrowNode) self.addSubnode(self.activateArea) self.activateArea.activate = { [weak self] in @@ -159,6 +174,7 @@ private final class ChatListFilterPresetListItemNode: ItemListRevealOptionsItemN func asyncLayout() -> (_ item: ChatListFilterPresetListItem, _ params: ListViewItemLayoutParams, _ neighbors: ItemListNeighbors) -> (ListViewItemNodeLayout, (Bool) -> Void) { let makeTitleLayout = TextNode.asyncLayout(self.titleNode) + let makeLabelLayout = TextNode.asyncLayout(self.labelNode) let editableControlLayout = ItemListEditableControlNode.asyncLayout(self.editableControlNode) let reorderControlLayout = ItemListEditableReorderControlNode.asyncLayout(self.reorderControlNode) @@ -166,9 +182,11 @@ private final class ChatListFilterPresetListItemNode: ItemListRevealOptionsItemN return { item, params, neighbors in var updatedTheme: PresentationTheme? + var updateArrowImage: UIImage? if currentItem?.presentationData.theme !== item.presentationData.theme { updatedTheme = item.presentationData.theme + updateArrowImage = PresentationResourcesItemList.disclosureArrowImage(item.presentationData.theme) } let peerRevealOptions: [ItemListRevealOption] @@ -187,21 +205,27 @@ private final class ChatListFilterPresetListItemNode: ItemListRevealOptionsItemN var editingOffset: CGFloat = 0.0 var reorderInset: CGFloat = 0.0 - if item.editing.editing && item.canBeReordered { + if item.editing.editing { let sizeAndApply = editableControlLayout(item.presentationData.theme, false) editableControlSizeAndApply = sizeAndApply editingOffset = sizeAndApply.0 - let reorderSizeAndApply = reorderControlLayout(item.presentationData.theme) - reorderControlSizeAndApply = reorderSizeAndApply - reorderInset = reorderSizeAndApply.0 + if item.canBeReordered { + let reorderSizeAndApply = reorderControlLayout(item.presentationData.theme) + reorderControlSizeAndApply = reorderSizeAndApply + reorderInset = reorderSizeAndApply.0 + } } let leftInset: CGFloat = 16.0 + params.leftInset let rightInset: CGFloat = params.rightInset + max(reorderInset, 55.0) + let rightArrowInset: CGFloat = 34.0 + params.rightInset let (titleLayout, titleApply) = makeTitleLayout(TextNodeLayoutArguments(attributedString: titleAttributedString, backgroundColor: nil, maximumNumberOfLines: 1, truncationType: .middle, constrainedSize: CGSize(width: params.width - leftInset - 12.0 - editingOffset - rightInset, height: CGFloat.greatestFiniteMagnitude), alignment: .natural, cutout: nil, insets: UIEdgeInsets())) + let labelConstrain: CGFloat = params.width - params.rightInset - leftInset - 40.0 - titleLayout.size.width - 10.0 + let (labelLayout, labelApply) = makeLabelLayout(TextNodeLayoutArguments(attributedString: NSAttributedString(string: item.label, font: titleFont, textColor: item.presentationData.theme.list.itemSecondaryTextColor), backgroundColor: nil, maximumNumberOfLines: 1, truncationType: .end, constrainedSize: CGSize(width: labelConstrain, height: CGFloat.greatestFiniteMagnitude), alignment: .natural, cutout: nil, insets: UIEdgeInsets())) + let insets = itemListNeighborsGroupedInsets(neighbors) let contentSize = CGSize(width: params.width, height: titleLayout.size.height + 11.0 * 2.0) let separatorHeight = UIScreenPixel @@ -280,6 +304,7 @@ private final class ChatListFilterPresetListItemNode: ItemListRevealOptionsItemN } let _ = titleApply() + let _ = labelApply() if strongSelf.backgroundNode.supernode == nil { strongSelf.insertSubnode(strongSelf.backgroundNode, at: 0) @@ -326,6 +351,20 @@ private final class ChatListFilterPresetListItemNode: ItemListRevealOptionsItemN transition.updateFrame(node: strongSelf.titleNode, frame: CGRect(origin: CGPoint(x: leftInset + revealOffset + editingOffset, y: 11.0), size: titleLayout.size)) + let labelFrame = CGRect(origin: CGPoint(x: params.width - rightArrowInset - labelLayout.size.width, y: 11.0), size: labelLayout.size) + strongSelf.labelNode.frame = labelFrame + + transition.updateAlpha(node: strongSelf.labelNode, alpha: reorderControlSizeAndApply != nil ? 0.0 : 1.0) + transition.updateAlpha(node: strongSelf.arrowNode, alpha: reorderControlSizeAndApply != nil ? 0.0 : 1.0) + + if let updateArrowImage = updateArrowImage { + strongSelf.arrowNode.image = updateArrowImage + } + + if let arrowImage = strongSelf.arrowNode.image { + strongSelf.arrowNode.frame = CGRect(origin: CGPoint(x: params.width - params.rightInset - 7.0 - arrowImage.size.width, y: floorToScreenPixels((layout.contentSize.height - arrowImage.size.height) / 2.0)), size: arrowImage.size) + } + strongSelf.activateArea.frame = CGRect(origin: CGPoint(x: leftInset + revealOffset + editingOffset, y: 0.0), size: CGSize(width: params.width - params.rightInset - 56.0 - (leftInset + revealOffset + editingOffset), height: layout.contentSize.height)) strongSelf.highlightedBackgroundNode.frame = CGRect(origin: CGPoint(x: 0.0, y: -UIScreenPixel), size: CGSize(width: params.width, height: layout.contentSize.height + UIScreenPixel + UIScreenPixel)) diff --git a/submodules/ChatListUI/Sources/ChatListFilterTabContainerNode.swift b/submodules/ChatListUI/Sources/ChatListFilterTabContainerNode.swift index 4d8a690927..1f41a8604c 100644 --- a/submodules/ChatListUI/Sources/ChatListFilterTabContainerNode.swift +++ b/submodules/ChatListUI/Sources/ChatListFilterTabContainerNode.swift @@ -257,13 +257,12 @@ final class ChatListFilterTabContainerNode: ASDisplayNode { } } - func update(size: CGSize, sideInset: CGFloat, filters: [ChatListFilterTabEntry], selectedFilter: ChatListFilterTabEntryId?, presentationData: PresentationData, transition: ContainedViewLayoutTransition) { - let focusOnSelectedFilter = self.currentParams?.selectedFilter != selectedFilter - var previousSelectedAbsFrame: CGRect? + private var previousSelectedAbsFrame: CGRect? + private var previousSelectedFrame: CGRect? + + func update(size: CGSize, sideInset: CGFloat, filters: [ChatListFilterTabEntry], selectedFilter: ChatListFilterTabEntryId?, transitionFraction: CGFloat, presentationData: PresentationData, transition: ContainedViewLayoutTransition) { + var focusOnSelectedFilter = self.currentParams?.selectedFilter != selectedFilter let previousScrollBounds = self.scrollNode.bounds - if let currentSelectedFilter = self.currentParams?.selectedFilter, let itemNode = self.itemNodes[currentSelectedFilter] { - previousSelectedAbsFrame = itemNode.frame.offsetBy(dx: -self.scrollNode.bounds.minX, dy: 0.0) - } if self.currentParams?.presentationData.theme !== presentationData.theme { self.selectedLineNode.image = generateImage(CGSize(width: 7.0, height: 4.0), rotatedContext: { size, context in @@ -362,7 +361,7 @@ final class ChatListFilterTabContainerNode: ASDisplayNode { } } - let minSpacing: CGFloat = 30.0 + let minSpacing: CGFloat = 26.0 let sideInset: CGFloat = 16.0 var leftOffset: CGFloat = sideInset @@ -391,7 +390,8 @@ final class ChatListFilterTabContainerNode: ASDisplayNode { self.scrollNode.view.contentSize = CGSize(width: leftOffset - minSpacing + sideInset - 5.0, height: size.height) - let transitionFraction: CGFloat = 0.0 + var previousFrame: CGRect? + var nextFrame: CGRect? var selectedFrame: CGRect? if let selectedFilter = selectedFilter, let currentIndex = filters.index(where: { $0.id == selectedFilter }) { func interpolateFrame(from fromValue: CGRect, to toValue: CGRect, t: CGFloat) -> CGRect { @@ -422,28 +422,41 @@ final class ChatListFilterTabContainerNode: ASDisplayNode { } else { transition.updateFrame(node: self.selectedLineNode, frame: lineFrame) } + if !transitionFraction.isZero { + if previousScrollBounds.minX.isZero { + focusOnSelectedFilter = true + } else if previousScrollBounds.maxX == previousScrollBounds.width { + focusOnSelectedFilter = true + } else if let previousSelectedFrame = self.previousSelectedFrame, abs(previousSelectedFrame.offsetBy(dx: -previousScrollBounds.minX, dy: 0.0).midX - previousScrollBounds.width / 2.0) < 1.0 { + focusOnSelectedFilter = true + } + } if focusOnSelectedFilter { - if selectedFilter == filters.first?.id { + if transitionFraction.isZero && selectedFilter == filters.first?.id { transition.updateBounds(node: self.scrollNode, bounds: CGRect(origin: CGPoint(), size: self.scrollNode.bounds.size)) - } else if selectedFilter == filters.last?.id { + } else if transitionFraction.isZero && selectedFilter == filters.last?.id { transition.updateBounds(node: self.scrollNode, bounds: CGRect(origin: CGPoint(x: max(0.0, self.scrollNode.view.contentSize.width - self.scrollNode.bounds.width), y: 0.0), size: self.scrollNode.bounds.size)) } else { let contentOffsetX = max(0.0, min(self.scrollNode.view.contentSize.width - self.scrollNode.bounds.width, floor(selectedFrame.midX - self.scrollNode.bounds.width / 2.0))) transition.updateBounds(node: self.scrollNode, bounds: CGRect(origin: CGPoint(x: contentOffsetX, y: 0.0), size: self.scrollNode.bounds.size)) } - } else if !wasAdded, let previousSelectedAbsFrame = previousSelectedAbsFrame { + } else if !wasAdded, transitionFraction.isZero, let previousSelectedAbsFrame = self.previousSelectedAbsFrame { let contentOffsetX: CGFloat if previousScrollBounds.minX.isZero { contentOffsetX = 0.0 } else if previousScrollBounds.maxX == previousScrollBounds.width { contentOffsetX = self.scrollNode.view.contentSize.width - self.scrollNode.bounds.width } else { - contentOffsetX = selectedFrame.midX - previousSelectedAbsFrame.midX + contentOffsetX = max(0.0, min(self.scrollNode.view.contentSize.width - self.scrollNode.bounds.width, selectedFrame.midX - previousSelectedAbsFrame.midX)) } transition.updateBounds(node: self.scrollNode, bounds: CGRect(origin: CGPoint(x: contentOffsetX, y: 0.0), size: self.scrollNode.bounds.size)) } + self.previousSelectedAbsFrame = selectedFrame.offsetBy(dx: -self.scrollNode.bounds.minX, dy: 0.0) + self.previousSelectedFrame = selectedFrame } else { self.selectedLineNode.isHidden = true + self.previousSelectedAbsFrame = nil + self.previousSelectedFrame = nil } } } diff --git a/submodules/ChatListUI/Sources/Node/ChatListNode.swift b/submodules/ChatListUI/Sources/Node/ChatListNode.swift index 6d2f4b5903..407bfe1421 100644 --- a/submodules/ChatListUI/Sources/Node/ChatListNode.swift +++ b/submodules/ChatListUI/Sources/Node/ChatListNode.swift @@ -17,7 +17,7 @@ import SearchUI public enum ChatListNodeMode { case chatList - case peers(filter: ChatListNodePeersFilter) + case peers(filter: ChatListNodePeersFilter, isSelecting: Bool) } struct ChatListNodeListViewTransition { @@ -153,7 +153,7 @@ private func mappedInsertEntries(context: AccountContext, nodeInteraction: ChatL switch mode { case .chatList: return ListViewInsertItem(index: entry.index, previousIndex: entry.previousIndex, item: ChatListItem(presentationData: presentationData, context: context, peerGroupId: peerGroupId, isInFilter: isInFilter, index: index, content: .peer(message: message, peer: peer, combinedReadState: combinedReadState, notificationSettings: notificationSettings, presence: presence, summaryInfo: summaryInfo, embeddedState: embeddedState, inputActivities: inputActivities, isAd: isAd, ignoreUnreadBadge: false, displayAsMessage: false, hasFailedMessages: hasFailedMessages), editing: editing, hasActiveRevealControls: hasActiveRevealControls, selected: selected, header: nil, enableContextActions: true, hiddenOffset: false, interaction: nodeInteraction), directionHint: entry.directionHint) - case let .peers(filter): + case let .peers(filter, _): let itemPeer = peer.chatMainPeer var chatPeer: Peer? if let peer = peer.peers[peer.peerId] { @@ -218,7 +218,7 @@ private func mappedInsertEntries(context: AccountContext, nodeInteraction: ChatL } } - return ListViewInsertItem(index: entry.index, previousIndex: entry.previousIndex, item: ContactsPeerItem(presentationData: ItemListPresentationData(theme: presentationData.theme, fontSize: presentationData.fontSize, strings: presentationData.strings), sortOrder: presentationData.nameSortOrder, displayOrder: presentationData.nameDisplayOrder, context: context, peerMode: .generalSearch, peer: .peer(peer: itemPeer, chatPeer: chatPeer), status: .none, enabled: enabled, selection: .none, editing: ContactsPeerItemEditing(editable: false, editing: false, revealed: false), index: nil, header: nil, action: { _ in + return ListViewInsertItem(index: entry.index, previousIndex: entry.previousIndex, item: ContactsPeerItem(presentationData: ItemListPresentationData(theme: presentationData.theme, fontSize: presentationData.fontSize, strings: presentationData.strings), sortOrder: presentationData.nameSortOrder, displayOrder: presentationData.nameDisplayOrder, context: context, peerMode: .generalSearch, peer: .peer(peer: itemPeer, chatPeer: chatPeer), status: .none, enabled: enabled, selection: editing ? .selectable(selected: selected) : .none, editing: ContactsPeerItemEditing(editable: false, editing: false, revealed: false), index: nil, header: nil, action: { _ in if let chatPeer = chatPeer { nodeInteraction.peerSelected(chatPeer) } @@ -245,7 +245,7 @@ private func mappedUpdateEntries(context: AccountContext, nodeInteraction: ChatL switch mode { case .chatList: return ListViewUpdateItem(index: entry.index, previousIndex: entry.previousIndex, item: ChatListItem(presentationData: presentationData, context: context, peerGroupId: peerGroupId, isInFilter: isInFilter, index: index, content: .peer(message: message, peer: peer, combinedReadState: combinedReadState, notificationSettings: notificationSettings, presence: presence, summaryInfo: summaryInfo, embeddedState: embeddedState, inputActivities: inputActivities, isAd: isAd, ignoreUnreadBadge: false, displayAsMessage: false, hasFailedMessages: hasFailedMessages), editing: editing, hasActiveRevealControls: hasActiveRevealControls, selected: selected, header: nil, enableContextActions: true, hiddenOffset: false, interaction: nodeInteraction), directionHint: entry.directionHint) - case let .peers(filter): + case let .peers(filter, _): let itemPeer = peer.chatMainPeer var chatPeer: Peer? if let peer = peer.peers[peer.peerId] { @@ -266,7 +266,7 @@ private func mappedUpdateEntries(context: AccountContext, nodeInteraction: ChatL enabled = false } } - return ListViewUpdateItem(index: entry.index, previousIndex: entry.previousIndex, item: ContactsPeerItem(presentationData: ItemListPresentationData(theme: presentationData.theme, fontSize: presentationData.fontSize, strings: presentationData.strings), sortOrder: presentationData.nameSortOrder, displayOrder: presentationData.nameDisplayOrder, context: context, peerMode: .generalSearch, peer: .peer(peer: itemPeer, chatPeer: chatPeer), status: .none, enabled: enabled, selection: .none, editing: ContactsPeerItemEditing(editable: false, editing: false, revealed: false), index: nil, header: nil, action: { _ in + return ListViewUpdateItem(index: entry.index, previousIndex: entry.previousIndex, item: ContactsPeerItem(presentationData: ItemListPresentationData(theme: presentationData.theme, fontSize: presentationData.fontSize, strings: presentationData.strings), sortOrder: presentationData.nameSortOrder, displayOrder: presentationData.nameDisplayOrder, context: context, peerMode: .generalSearch, peer: .peer(peer: itemPeer, chatPeer: chatPeer), status: .none, enabled: enabled, selection: editing ? .selectable(selected: selected) : .none, editing: ContactsPeerItemEditing(editable: false, editing: false, revealed: false), index: nil, header: nil, action: { _ in if let chatPeer = chatPeer { nodeInteraction.peerSelected(chatPeer) } @@ -352,7 +352,7 @@ public final class ChatListNode: ListView { return _contentsReady.get() } - public var peerSelected: ((PeerId, Bool, Bool) -> Void)? + public var peerSelected: ((Peer, Bool, Bool) -> Void)? public var disabledPeerSelected: ((Peer) -> Void)? public var groupSelected: ((PeerGroupId) -> Void)? public var addContact: ((String) -> Void)? @@ -373,7 +373,7 @@ public final class ChatListNode: ListView { private var dequeuedInitialTransitionOnLayout = false private var enqueuedTransition: (ChatListNodeListViewTransition, () -> Void)? - private(set) var currentState: ChatListNodeState + public private(set) var currentState: ChatListNodeState private let statePromise: ValuePromise public var state: Signal { return self.statePromise.get() @@ -453,7 +453,12 @@ public final class ChatListNode: ListView { self.controlsHistoryPreload = controlsHistoryPreload self.mode = mode - self.currentState = ChatListNodeState(presentationData: ChatListPresentationData(theme: theme, fontSize: fontSize, strings: strings, dateTimeFormat: dateTimeFormat, nameSortOrder: nameSortOrder, nameDisplayOrder: nameDisplayOrder, disableAnimations: disableAnimations), editing: false, peerIdWithRevealedOptions: nil, selectedPeerIds: Set(), peerInputActivities: nil, pendingRemovalPeerIds: Set(), pendingClearHistoryPeerIds: Set(), archiveShouldBeTemporaryRevealed: false) + var isSelecting = false + if case .peers(_, true) = mode { + isSelecting = true + } + + self.currentState = ChatListNodeState(presentationData: ChatListPresentationData(theme: theme, fontSize: fontSize, strings: strings, dateTimeFormat: dateTimeFormat, nameSortOrder: nameSortOrder, nameDisplayOrder: nameDisplayOrder, disableAnimations: disableAnimations), editing: isSelecting, peerIdWithRevealedOptions: nil, selectedPeerIds: Set(), peerInputActivities: nil, pendingRemovalPeerIds: Set(), pendingClearHistoryPeerIds: Set(), archiveShouldBeTemporaryRevealed: false) self.statePromise = ValuePromise(self.currentState, ignoreRepeated: true) self.theme = theme @@ -471,7 +476,7 @@ public final class ChatListNode: ListView { } }, peerSelected: { [weak self] peer in if let strongSelf = self, let peerSelected = strongSelf.peerSelected { - peerSelected(peer.id, true, false) + peerSelected(peer, true, false) } }, disabledPeerSelected: { [weak self] peer in if let strongSelf = self, let disabledPeerSelected = strongSelf.disabledPeerSelected { @@ -491,7 +496,7 @@ public final class ChatListNode: ListView { } }, messageSelected: { [weak self] peer, message, isAd in if let strongSelf = self, let peerSelected = strongSelf.peerSelected { - peerSelected(peer.id, true, isAd) + peerSelected(peer, true, isAd) } }, groupSelected: { [weak self] groupId in if let strongSelf = self, let groupSelected = strongSelf.groupSelected { @@ -586,7 +591,7 @@ public final class ChatListNode: ListView { let currentRemovingPeerId = self.currentRemovingPeerId let savedMessagesPeer: Signal - if case let .peers(filter) = mode, filter.contains(.onlyWriteable) { + if case let .peers(filter, _) = mode, filter.contains(.onlyWriteable) { savedMessagesPeer = context.account.postbox.loadedPeerWithId(context.account.peerId) |> map(Optional.init) } else { @@ -639,7 +644,7 @@ public final class ChatListNode: ListView { switch mode { case .chatList: return true - case let .peers(filter): + case let .peers(filter, _): guard !filter.contains(.excludeSavedMessages) || peer.peerId != currentPeerId else { return false } guard !filter.contains(.excludeSecretChats) || peer.peerId.namespace != Namespaces.Peer.SecretChat else { return false } guard !filter.contains(.onlyPrivateChats) || peer.peerId.namespace == Namespaces.Peer.CloudUser else { return false } @@ -1422,6 +1427,35 @@ public final class ChatListNode: ListView { } } + var isNavigationHidden: Bool { + switch self.visibleContentOffset() { + case let .known(value) where abs(value) < navigationBarSearchContentHeight: + return false + default: + return true + } + } + + func adjustScrollOffsetForNavigation(isNavigationHidden: Bool) { + if self.isNavigationHidden == isNavigationHidden { + return + } + var scrollToItem: ListViewScrollToItem? + switch self.visibleContentOffset() { + case let .known(value) where abs(value) < navigationBarSearchContentHeight: + if isNavigationHidden { + scrollToItem = ListViewScrollToItem(index: 0, position: .top(-navigationBarSearchContentHeight), animated: false, curve: .Default(duration: 0.0), directionHint: .Up) + } + default: + if !isNavigationHidden { + scrollToItem = ListViewScrollToItem(index: 0, position: .top(0.0), animated: false, curve: .Default(duration: 0.0), directionHint: .Up) + } + } + if let scrollToItem = scrollToItem { + self.transaction(deleteIndices: [], insertIndicesAndItems: [], updateIndicesAndItems: [], options: [.Synchronous], scrollToItem: scrollToItem, updateSizeAndInsets: nil, stationaryItemRange: nil, updateOpaqueState: nil, completion: { _ in }) + } + } + public func updateLayout(transition: ContainedViewLayoutTransition, updateSizeAndInsets: ListViewUpdateSizeAndInsets) { self.transaction(deleteIndices: [], insertIndicesAndItems: [], updateIndicesAndItems: [], options: [.Synchronous, .LowLatency], scrollToItem: nil, updateSizeAndInsets: updateSizeAndInsets, stationaryItemRange: nil, updateOpaqueState: nil, completion: { _ in }) @@ -1524,9 +1558,9 @@ public final class ChatListNode: ListView { } let entryCount = chatListView.filteredEntries.count - var current: (ChatListIndex, PeerId, Int)? = nil - var previous: (ChatListIndex, PeerId)? = nil - var next: (ChatListIndex, PeerId)? = nil + var current: (ChatListIndex, Peer, Int)? = nil + var previous: (ChatListIndex, Peer)? = nil + var next: (ChatListIndex, Peer)? = nil outer: for i in range.firstIndex ..< range.lastIndex { if i < 0 || i >= entryCount { @@ -1536,7 +1570,7 @@ public final class ChatListNode: ListView { switch chatListView.filteredEntries[entryCount - i - 1] { case let .PeerEntry(index, _, _, _, _, _, peer, _, _, _, _, _, _, _, _): if interaction.highlightedChatLocation?.location == ChatLocation.peer(peer.peerId) { - current = (index, peer.peerId, entryCount - i - 1) + current = (index, peer.peer!, entryCount - i - 1) break outer } default: @@ -1556,22 +1590,35 @@ public final class ChatListNode: ListView { } else { position = .later(than: nil) } - let _ = (relativeUnreadChatListIndex(position: position) |> deliverOnMainQueue).start(next: { [weak self] index in - guard let strongSelf = self, let index = index else { + let postbox = self.context.account.postbox + let _ = (relativeUnreadChatListIndex(position: position) + |> mapToSignal { index -> Signal<(ChatListIndex, Peer)?, NoError> in + if let index = index { + return postbox.transaction { transaction -> (ChatListIndex, Peer)? in + return transaction.getPeer(index.messageIndex.id.peerId).flatMap { peer -> (ChatListIndex, Peer)? in + (index, peer) + } + } + } else { + return .single(nil) + } + } + |> deliverOnMainQueue).start(next: { [weak self] indexAndPeer in + guard let strongSelf = self, let (index, peer) = indexAndPeer else { return } let location: ChatListNodeLocation = .scroll(index: index, sourceIndex: strongSelf.currentlyVisibleLatestChatListIndex() ?? .absoluteUpperBound, scrollPosition: .center(.top), animated: true, filter: strongSelf.chatListFilter) strongSelf.setChatListLocation(location) - strongSelf.peerSelected?(index.messageIndex.id.peerId, false, false) + strongSelf.peerSelected?(peer, false, false) }) case .previous(unread: false), .next(unread: false): - var target: (ChatListIndex, PeerId)? = nil + var target: (ChatListIndex, Peer)? = nil if let current = current, entryCount > 1 { if current.2 > 0, case let .PeerEntry(index, _, _, _, _, _, peer, _, _, _, _, _, _, _, _) = chatListView.filteredEntries[current.2 - 1] { - next = (index, peer.peerId) + next = (index, peer.peer!) } if current.2 <= entryCount - 2, case let .PeerEntry(index, _, _, _, _, _, peer, _, _, _, _, _, _, _, _) = chatListView.filteredEntries[current.2 + 1] { - previous = (index, peer.peerId) + previous = (index, peer.peer!) } if case .previous = option { target = previous @@ -1580,7 +1627,7 @@ public final class ChatListNode: ListView { } } else if entryCount > 0 { if case let .PeerEntry(index, _, _, _, _, _, peer, _, _, _, _, _, _, _, _) = chatListView.filteredEntries[entryCount - 1] { - target = (index, peer.peerId) + target = (index, peer.peer!) } } if let target = target { @@ -1589,7 +1636,15 @@ public final class ChatListNode: ListView { self.peerSelected?(target.1, false, false) } case let .peerId(peerId): - self.peerSelected?(peerId, false, false) + let _ = (self.context.account.postbox.transaction { transaction -> Peer? in + return transaction.getPeer(peerId) + } + |> deliverOnMainQueue).start(next: { [weak self] peer in + guard let strongSelf = self, let peer = peer else { + return + } + strongSelf.peerSelected?(peer, false, false) + }) case let .index(index): guard index < 10 else { return @@ -1607,7 +1662,7 @@ public final class ChatListNode: ListView { if entries.count > index, case let .MessageEntry(index, _, _, _, _, renderedPeer, _, _, _) = entries[10 - index - 1] { let location: ChatListNodeLocation = .scroll(index: index, sourceIndex: .absoluteLowerBound, scrollPosition: .center(.top), animated: true, filter: filter) self.setChatListLocation(location) - self.peerSelected?(renderedPeer.peerId, false, false) + self.peerSelected?(renderedPeer.peer!, false, false) } }) }) diff --git a/submodules/ChatListUI/Sources/Node/ChatListNodeLocation.swift b/submodules/ChatListUI/Sources/Node/ChatListNodeLocation.swift index 802010adb0..351f9ad159 100644 --- a/submodules/ChatListUI/Sources/Node/ChatListNodeLocation.swift +++ b/submodules/ChatListUI/Sources/Node/ChatListNodeLocation.swift @@ -29,7 +29,7 @@ struct ChatListNodeViewUpdate { let scrollPosition: ChatListNodeViewScrollPosition? } -func chatListFilterPredicate(filter: ChatListFilter) -> ChatListFilterPredicate { +func chatListFilterPredicate(filter: ChatListFilterData) -> ChatListFilterPredicate { let includePeers = Set(filter.includePeers) return ChatListFilterPredicate(includePeerIds: includePeers, include: { peer, notificationSettings, isUnread in if filter.excludeRead { @@ -97,7 +97,7 @@ func chatListFilterPredicate(filter: ChatListFilter) -> ChatListFilterPredicate } func chatListViewForLocation(groupId: PeerGroupId, location: ChatListNodeLocation, account: Account) -> Signal { - let filterPredicate: ChatListFilterPredicate? = location.filter.flatMap(chatListFilterPredicate) + let filterPredicate: ChatListFilterPredicate? = (location.filter?.data).flatMap(chatListFilterPredicate) switch location { case let .initial(count, _): diff --git a/submodules/ChatListUI/Sources/TabBarChatListFilterController.swift b/submodules/ChatListUI/Sources/TabBarChatListFilterController.swift index c02d9656b6..cce754115f 100644 --- a/submodules/ChatListUI/Sources/TabBarChatListFilterController.swift +++ b/submodules/ChatListUI/Sources/TabBarChatListFilterController.swift @@ -320,7 +320,7 @@ func chatListFilterItems(context: AccountContext) -> Signal<(Int, [(ChatListFilt unreadCountItems.append(.total(nil)) var additionalPeerIds = Set() for filter in filters { - additionalPeerIds.formUnion(filter.includePeers) + additionalPeerIds.formUnion(filter.data.includePeers) } if !additionalPeerIds.isEmpty { for peerId in additionalPeerIds { @@ -390,22 +390,22 @@ func chatListFilterItems(context: AccountContext) -> Signal<(Int, [(ChatListFilt var shouldUpdateLayout = false for filter in filters { var tags: [PeerSummaryCounterTags] = [] - if filter.categories.contains(.privateChats) { + if filter.data.categories.contains(.privateChats) { tags.append(.privateChat) } - if filter.categories.contains(.secretChats) { + if filter.data.categories.contains(.secretChats) { tags.append(.secretChat) } - if filter.categories.contains(.privateGroups) { + if filter.data.categories.contains(.privateGroups) { tags.append(.privateGroup) } - if filter.categories.contains(.bots) { + if filter.data.categories.contains(.bots) { tags.append(.bot) } - if filter.categories.contains(.publicGroups) { + if filter.data.categories.contains(.publicGroups) { tags.append(.publicGroup) } - if filter.categories.contains(.channels) { + if filter.data.categories.contains(.channels) { tags.append(.channel) } @@ -417,7 +417,7 @@ func chatListFilterItems(context: AccountContext) -> Signal<(Int, [(ChatListFilt } } } - for peerId in filter.includePeers { + for peerId in filter.data.includePeers { if let (tag, peerCount) = peerTagAndCount[peerId] { if !tags.contains(tag) { if peerCount != 0 { @@ -513,7 +513,7 @@ private final class TabBarChatListFilterControllerNode: ViewControllerTracingNod unreadCountItems.append(.total(nil)) var additionalPeerIds = Set() for preset in presetList { - additionalPeerIds.formUnion(preset.includePeers) + additionalPeerIds.formUnion(preset.data.includePeers) } if !additionalPeerIds.isEmpty { for peerId in additionalPeerIds { @@ -567,22 +567,22 @@ private final class TabBarChatListFilterControllerNode: ViewControllerTracingNod let badgeString: String if let preset = contentNode.preset { var tags: [PeerSummaryCounterTags] = [] - if preset.categories.contains(.privateChats) { + if preset.data.categories.contains(.privateChats) { tags.append(.privateChat) } - if preset.categories.contains(.secretChats) { + if preset.data.categories.contains(.secretChats) { tags.append(.secretChat) } - if preset.categories.contains(.privateGroups) { + if preset.data.categories.contains(.privateGroups) { tags.append(.privateGroup) } - if preset.categories.contains(.bots) { + if preset.data.categories.contains(.bots) { tags.append(.bot) } - if preset.categories.contains(.publicGroups) { + if preset.data.categories.contains(.publicGroups) { tags.append(.publicGroup) } - if preset.categories.contains(.channels) { + if preset.data.categories.contains(.channels) { tags.append(.channel) } @@ -594,7 +594,7 @@ private final class TabBarChatListFilterControllerNode: ViewControllerTracingNod } } } - for peerId in preset.includePeers { + for peerId in preset.data.includePeers { if let (tag, peerCount) = peerTagAndCount[peerId] { if !tags.contains(tag) { count += peerCount diff --git a/submodules/ContextUI/Sources/ContextController.swift b/submodules/ContextUI/Sources/ContextController.swift index f63658522d..e8f603e52c 100644 --- a/submodules/ContextUI/Sources/ContextController.swift +++ b/submodules/ContextUI/Sources/ContextController.swift @@ -747,7 +747,7 @@ private final class ContextControllerNode: ViewControllerTracingNode, UIScrollVi self.withoutBlurDimNode.layer.animateAlpha(from: 1.0, to: 0.0, duration: transitionDuration * animationDurationFactor, removeOnCompletion: false) } - self.actionsContainerNode.layer.animateAlpha(from: 1.0, to: 0.0, duration: 0.2 * animationDurationFactor, removeOnCompletion: false, completion: { _ in + self.actionsContainerNode.layer.animateAlpha(from: 1.0, to: 0.0, duration: 0.15 * animationDurationFactor, removeOnCompletion: false, completion: { _ in completedActionsNode = true intermediateCompletion() }) diff --git a/submodules/Display/Display/InteractiveTransitionGestureRecognizer.swift b/submodules/Display/Display/InteractiveTransitionGestureRecognizer.swift index 6462a0d325..c129c90f15 100644 --- a/submodules/Display/Display/InteractiveTransitionGestureRecognizer.swift +++ b/submodules/Display/Display/InteractiveTransitionGestureRecognizer.swift @@ -38,18 +38,23 @@ public struct InteractiveTransitionGestureRecognizerDirections: OptionSet { self.rawValue = rawValue } - public static let left = InteractiveTransitionGestureRecognizerDirections(rawValue: 1 << 0) - public static let right = InteractiveTransitionGestureRecognizerDirections(rawValue: 1 << 1) + public static let leftEdge = InteractiveTransitionGestureRecognizerDirections(rawValue: 1 << 2) + public static let rightEdge = InteractiveTransitionGestureRecognizerDirections(rawValue: 1 << 3) + public static let leftCenter = InteractiveTransitionGestureRecognizerDirections(rawValue: 1 << 0) + public static let rightCenter = InteractiveTransitionGestureRecognizerDirections(rawValue: 1 << 1) + + public static let left: InteractiveTransitionGestureRecognizerDirections = [.leftEdge, .leftCenter] + public static let right: InteractiveTransitionGestureRecognizerDirections = [.rightEdge, .rightCenter] } public class InteractiveTransitionGestureRecognizer: UIPanGestureRecognizer { - private let allowedDirections: () -> InteractiveTransitionGestureRecognizerDirections + private let allowedDirections: (CGPoint) -> InteractiveTransitionGestureRecognizerDirections private var validatedGesture = false private var firstLocation: CGPoint = CGPoint() private var currentAllowedDirections: InteractiveTransitionGestureRecognizerDirections = [] - public init(target: Any?, action: Selector?, allowedDirections: @escaping () -> InteractiveTransitionGestureRecognizerDirections) { + public init(target: Any?, action: Selector?, allowedDirections: @escaping (CGPoint) -> InteractiveTransitionGestureRecognizerDirections) { self.allowedDirections = allowedDirections super.init(target: target, action: action) @@ -65,37 +70,50 @@ public class InteractiveTransitionGestureRecognizer: UIPanGestureRecognizer { } override public func touchesBegan(_ touches: Set, with event: UIEvent) { - self.currentAllowedDirections = self.allowedDirections() - if self.currentAllowedDirections.isEmpty { + let touch = touches.first! + let point = touch.location(in: self.view) + + var allowedDirections = self.allowedDirections(point) + if allowedDirections.isEmpty { self.state = .failed return } super.touchesBegan(touches, with: event) - let touch = touches.first! - self.firstLocation = touch.location(in: self.view) + self.firstLocation = point if let target = self.view?.hitTest(self.firstLocation, with: event) { if hasHorizontalGestures(target, point: self.view?.convert(self.firstLocation, to: target)) { - self.state = .cancelled + allowedDirections.remove(.leftCenter) + allowedDirections.remove(.rightCenter) } } + + if allowedDirections.isEmpty { + self.state = .failed + } else { + self.currentAllowedDirections = allowedDirections + } } override public func touchesMoved(_ touches: Set, with event: UIEvent) { let location = touches.first!.location(in: self.view) - let translation = CGPoint(x: location.x - firstLocation.x, y: location.y - firstLocation.y) + let translation = CGPoint(x: location.x - self.firstLocation.x, y: location.y - self.firstLocation.y) let absTranslationX: CGFloat = abs(translation.x) let absTranslationY: CGFloat = abs(translation.y) + let size = self.view?.bounds.size ?? CGSize() + if !self.validatedGesture { - if self.currentAllowedDirections.contains(.right) && self.firstLocation.x < 16.0 { + if self.currentAllowedDirections.contains(.rightEdge) && self.firstLocation.x < 16.0 { self.validatedGesture = true - } else if !self.currentAllowedDirections.contains(.left) && translation.x < 0.0 { + } else if self.currentAllowedDirections.contains(.leftEdge) && self.firstLocation.x > size.width - 16.0 { + self.validatedGesture = true + } else if !self.currentAllowedDirections.contains(.leftCenter) && translation.x < 0.0 { self.state = .failed - } else if !self.currentAllowedDirections.contains(.right) && translation.x > 0.0 { + } else if !self.currentAllowedDirections.contains(.rightCenter) && translation.x > 0.0 { self.state = .failed } else if absTranslationY > 2.0 && absTranslationY > absTranslationX * 2.0 { self.state = .failed @@ -104,7 +122,7 @@ public class InteractiveTransitionGestureRecognizer: UIPanGestureRecognizer { } } - if validatedGesture { + if self.validatedGesture { super.touchesMoved(touches, with: event) } } diff --git a/submodules/Display/Display/Navigation/NavigationContainer.swift b/submodules/Display/Display/Navigation/NavigationContainer.swift index c45e446656..b5be8762d8 100644 --- a/submodules/Display/Display/Navigation/NavigationContainer.swift +++ b/submodules/Display/Display/Navigation/NavigationContainer.swift @@ -111,7 +111,7 @@ final class NavigationContainer: ASDisplayNode, UIGestureRecognizerDelegate { override func didLoad() { super.didLoad() - let panRecognizer = InteractiveTransitionGestureRecognizer(target: self, action: #selector(self.panGesture(_:)), allowedDirections: { [weak self] in + let panRecognizer = InteractiveTransitionGestureRecognizer(target: self, action: #selector(self.panGesture(_:)), allowedDirections: { [weak self] _ in guard let strongSelf = self, strongSelf.controllers.count > 1 else { return [] } diff --git a/submodules/Display/Display/Navigation/NavigationModalContainer.swift b/submodules/Display/Display/Navigation/NavigationModalContainer.swift index 1798a9c436..215e48b233 100644 --- a/submodules/Display/Display/Navigation/NavigationModalContainer.swift +++ b/submodules/Display/Display/Navigation/NavigationModalContainer.swift @@ -90,7 +90,7 @@ final class NavigationModalContainer: ASDisplayNode, UIScrollViewDelegate, UIGes self.scrollNode.view.clipsToBounds = false self.scrollNode.view.delegate = self - let panRecognizer = InteractiveTransitionGestureRecognizer(target: self, action: #selector(self.panGesture(_:)), allowedDirections: { [weak self] in + let panRecognizer = InteractiveTransitionGestureRecognizer(target: self, action: #selector(self.panGesture(_:)), allowedDirections: { [weak self] _ in guard let strongSelf = self, !strongSelf.isDismissed else { return [] } diff --git a/submodules/Display/Display/TabBarContollerNode.swift b/submodules/Display/Display/TabBarContollerNode.swift index dee3c1f46a..c84927e88a 100644 --- a/submodules/Display/Display/TabBarContollerNode.swift +++ b/submodules/Display/Display/TabBarContollerNode.swift @@ -25,10 +25,10 @@ final class TabBarControllerNode: ASDisplayNode { } } - init(theme: TabBarControllerTheme, navigationBar: NavigationBar?, itemSelected: @escaping (Int, Bool, [ASDisplayNode]) -> Void, contextAction: @escaping (Int, ContextExtractedContentContainingNode, ContextGesture) -> Void, toolbarActionSelected: @escaping (ToolbarActionOption) -> Void) { + init(theme: TabBarControllerTheme, navigationBar: NavigationBar?, itemSelected: @escaping (Int, Bool, [ASDisplayNode]) -> Void, contextAction: @escaping (Int, ContextExtractedContentContainingNode, ContextGesture) -> Void, swipeAction: @escaping (Int, TabBarItemSwipeDirection) -> Void, toolbarActionSelected: @escaping (ToolbarActionOption) -> Void) { self.theme = theme self.navigationBar = navigationBar - self.tabBarNode = TabBarNode(theme: theme, itemSelected: itemSelected, contextAction: contextAction) + self.tabBarNode = TabBarNode(theme: theme, itemSelected: itemSelected, contextAction: contextAction, swipeAction: swipeAction) self.toolbarActionSelected = toolbarActionSelected super.init() diff --git a/submodules/Display/Display/TabBarController.swift b/submodules/Display/Display/TabBarController.swift index bf48fe944b..73c6c68d34 100644 --- a/submodules/Display/Display/TabBarController.swift +++ b/submodules/Display/Display/TabBarController.swift @@ -240,6 +240,13 @@ open class TabBarController: ViewController { if index >= 0 && index < strongSelf.controllers.count { strongSelf.controllers[index].tabBarItemContextAction(sourceNode: node, gesture: gesture) } + }, swipeAction: { [weak self] index, direction in + guard let strongSelf = self else { + return + } + if index >= 0 && index < strongSelf.controllers.count { + strongSelf.controllers[index].tabBarItemSwipeAction(direction: direction) + } }, toolbarActionSelected: { [weak self] action in self?.currentController?.toolbarActionSelected(action: action) }) diff --git a/submodules/Display/Display/TabBarNode.swift b/submodules/Display/Display/TabBarNode.swift index c4e5b28033..bc846fb434 100644 --- a/submodules/Display/Display/TabBarNode.swift +++ b/submodules/Display/Display/TabBarNode.swift @@ -88,6 +88,11 @@ private func tabBarItemImage(_ image: UIImage?, title: String, backgroundColor: private let badgeFont = Font.regular(13.0) +public enum TabBarItemSwipeDirection { + case left + case right +} + private final class TabBarItemNode: ASDisplayNode { let extractedContainerNode: ContextExtractedContentContainingNode let containerNode: ContextControllerSourceNode @@ -97,6 +102,8 @@ private final class TabBarItemNode: ASDisplayNode { let contextTextImageNode: ASImageNode var contentWidth: CGFloat? + var swiped: ((TabBarItemSwipeDirection) -> Void)? + override init() { self.extractedContainerNode = ContextExtractedContentContainingNode() self.containerNode = ContextControllerSourceNode() @@ -146,6 +153,26 @@ private final class TabBarItemNode: ASDisplayNode { transition.updateAlpha(node: strongSelf.contextImageNode, alpha: isExtracted ? 1.0 : 0.0) transition.updateAlpha(node: strongSelf.contextTextImageNode, alpha: isExtracted ? 1.0 : 0.0) } + + let leftSwipe = UISwipeGestureRecognizer(target: self, action: #selector(self.swipeGesture(_:))) + leftSwipe.direction = .left + self.containerNode.view.addGestureRecognizer(leftSwipe) + let rightSwipe = UISwipeGestureRecognizer(target: self, action: #selector(self.swipeGesture(_:))) + rightSwipe.direction = .right + self.containerNode.view.addGestureRecognizer(rightSwipe) + } + + @objc private func swipeGesture(_ gesture: UISwipeGestureRecognizer) { + if case .ended = gesture.state { + self.containerNode.cancelGesture() + + switch gesture.direction { + case .left: + self.swiped?(.left) + default: + self.swiped?(.right) + } + } } } @@ -173,7 +200,7 @@ private final class TabBarNodeContainer { var selectedImageValue: UIImage? var appliedSelectedImageValue: UIImage? - init(item: TabBarNodeItem, imageNode: TabBarItemNode, updateBadge: @escaping (String) -> Void, updateTitle: @escaping (String, Bool) -> Void, updateImage: @escaping (UIImage?) -> Void, updateSelectedImage: @escaping (UIImage?) -> Void, contextAction: @escaping (ContextExtractedContentContainingNode, ContextGesture) -> Void) { + init(item: TabBarNodeItem, imageNode: TabBarItemNode, updateBadge: @escaping (String) -> Void, updateTitle: @escaping (String, Bool) -> Void, updateImage: @escaping (UIImage?) -> Void, updateSelectedImage: @escaping (UIImage?) -> Void, contextAction: @escaping (ContextExtractedContentContainingNode, ContextGesture) -> Void, swipeAction: @escaping (TabBarItemSwipeDirection) -> Void) { self.item = item.item self.imageNode = imageNode @@ -225,6 +252,9 @@ private final class TabBarNodeContainer { } contextAction(strongSelf.imageNode.extractedContainerNode, gesture) } + imageNode.swiped = { [weak self] direction in + swipeAction(direction) + } imageNode.containerNode.isGestureEnabled = item.hasContext } @@ -269,6 +299,7 @@ class TabBarNode: ASDisplayNode { private let itemSelected: (Int, Bool, [ASDisplayNode]) -> Void private let contextAction: (Int, ContextExtractedContentContainingNode, ContextGesture) -> Void + private let swipeAction: (Int, TabBarItemSwipeDirection) -> Void private var theme: TabBarControllerTheme private var validLayout: (CGSize, CGFloat, CGFloat, CGFloat)? @@ -282,9 +313,10 @@ class TabBarNode: ASDisplayNode { private var tapRecognizer: TapLongTapOrDoubleTapGestureRecognizer? - init(theme: TabBarControllerTheme, itemSelected: @escaping (Int, Bool, [ASDisplayNode]) -> Void, contextAction: @escaping (Int, ContextExtractedContentContainingNode, ContextGesture) -> Void) { + init(theme: TabBarControllerTheme, itemSelected: @escaping (Int, Bool, [ASDisplayNode]) -> Void, contextAction: @escaping (Int, ContextExtractedContentContainingNode, ContextGesture) -> Void, swipeAction: @escaping (Int, TabBarItemSwipeDirection) -> Void) { self.itemSelected = itemSelected self.contextAction = contextAction + self.swipeAction = swipeAction self.theme = theme self.separatorNode = ASDisplayNode() @@ -381,6 +413,8 @@ class TabBarNode: ASDisplayNode { }, contextAction: { [weak self] node, gesture in self?.tapRecognizer?.cancel() self?.contextAction(i, node, gesture) + }, swipeAction: { [weak self] direction in + self?.swipeAction(i, direction) }) if let selectedIndex = self.selectedIndex, selectedIndex == i { let (textImage, contentWidth) = tabBarItemImage(item.item.selectedImage, title: item.item.title ?? "", backgroundColor: .clear, tintColor: self.theme.tabBarSelectedTextColor, horizontal: self.horizontal, imageMode: false, centered: self.centered) diff --git a/submodules/Display/Display/ViewController.swift b/submodules/Display/Display/ViewController.swift index 2b5a41b898..c93752cbd0 100644 --- a/submodules/Display/Display/ViewController.swift +++ b/submodules/Display/Display/ViewController.swift @@ -632,6 +632,9 @@ public enum ViewControllerNavigationPresentation { open func tabBarItemContextAction(sourceNode: ContextExtractedContentContainingNode, gesture: ContextGesture) { } + + open func tabBarItemSwipeAction(direction: TabBarItemSwipeDirection) { + } } func traceIsOpaque(layer: CALayer, rect: CGRect) -> Bool { diff --git a/submodules/ItemListUI/Sources/Items/ItemListEditableItem.swift b/submodules/ItemListUI/Sources/Items/ItemListEditableItem.swift index dc6f9a1a6f..5a2c91dd52 100644 --- a/submodules/ItemListUI/Sources/Items/ItemListEditableItem.swift +++ b/submodules/ItemListUI/Sources/Items/ItemListEditableItem.swift @@ -91,6 +91,7 @@ open class ItemListRevealOptionsItemNode: ListViewItemNode, UIGestureRecognizerD let recognizer = ItemListRevealOptionsGestureRecognizer(target: self, action: #selector(self.revealGesture(_:))) self.recognizer = recognizer + recognizer.delegate = self recognizer.allowAnyDirection = self.allowAnyDirection self.view.addGestureRecognizer(recognizer) diff --git a/submodules/ItemListUI/Sources/Items/ItemListSingleLineInputItem.swift b/submodules/ItemListUI/Sources/Items/ItemListSingleLineInputItem.swift index 5b8028f7a9..6173e2adb4 100644 --- a/submodules/ItemListUI/Sources/Items/ItemListSingleLineInputItem.swift +++ b/submodules/ItemListUI/Sources/Items/ItemListSingleLineInputItem.swift @@ -45,9 +45,10 @@ public class ItemListSingleLineInputItem: ListViewItem, ItemListItem { let shouldUpdateText: (String) -> Bool let processPaste: ((String) -> String)? let updatedFocus: ((Bool) -> Void)? + let cleared: (() -> Void)? public let tag: ItemListItemTag? - public init(presentationData: ItemListPresentationData, title: NSAttributedString, text: String, placeholder: String, type: ItemListSingleLineInputItemType = .regular(capitalization: true, autocorrection: true), returnKeyType: UIReturnKeyType = .`default`, spacing: CGFloat = 0.0, clearType: ItemListSingleLineInputClearType = .none, enabled: Bool = true, tag: ItemListItemTag? = nil, sectionId: ItemListSectionId, textUpdated: @escaping (String) -> Void, shouldUpdateText: @escaping (String) -> Bool = { _ in return true }, processPaste: ((String) -> String)? = nil, updatedFocus: ((Bool) -> Void)? = nil, action: @escaping () -> Void) { + public init(presentationData: ItemListPresentationData, title: NSAttributedString, text: String, placeholder: String, type: ItemListSingleLineInputItemType = .regular(capitalization: true, autocorrection: true), returnKeyType: UIReturnKeyType = .`default`, spacing: CGFloat = 0.0, clearType: ItemListSingleLineInputClearType = .none, enabled: Bool = true, tag: ItemListItemTag? = nil, sectionId: ItemListSectionId, textUpdated: @escaping (String) -> Void, shouldUpdateText: @escaping (String) -> Bool = { _ in return true }, processPaste: ((String) -> String)? = nil, updatedFocus: ((Bool) -> Void)? = nil, action: @escaping () -> Void, cleared: (() -> Void)? = nil) { self.presentationData = presentationData self.title = title self.text = text @@ -64,6 +65,7 @@ public class ItemListSingleLineInputItem: ListViewItem, ItemListItem { self.processPaste = processPaste self.updatedFocus = updatedFocus self.action = action + self.cleared = cleared } public func nodeConfiguredForParams(async: @escaping (@escaping () -> Void) -> Void, params: ListViewItemLayoutParams, synchronousLoads: Bool, previousItem: ListViewItem?, nextItem: ListViewItem?, completion: @escaping (ListViewItemNode, @escaping () -> (Signal?, (ListViewItemApply) -> Void)) -> Void) { @@ -420,6 +422,7 @@ public class ItemListSingleLineInputItemNode: ListViewItemNode, UITextFieldDeleg @objc private func clearButtonPressed() { self.textNode.textField.text = "" self.textUpdated("") + self.item?.cleared?() } private func textUpdated(_ text: String) { diff --git a/submodules/Postbox/Sources/ChatListTable.swift b/submodules/Postbox/Sources/ChatListTable.swift index 9252022dce..d205921714 100644 --- a/submodules/Postbox/Sources/ChatListTable.swift +++ b/submodules/Postbox/Sources/ChatListTable.swift @@ -641,6 +641,25 @@ final class ChatListTable: Table { return entries } + func countWithPredicate(groupId: PeerGroupId, predicate: (PeerId) -> Bool) -> Int { + var result = 0 + self.valueBox.filteredRange(self.table, start: self.lowerBound(groupId: groupId), end: self.upperBound(groupId: groupId), keys: { key in + let (_, _, messageIndex, type) = extractKey(key) + + if type == ChatListEntryType.message.rawValue { + if predicate(messageIndex.id.peerId) { + result += 1 + return .accept + } else { + return .skip + } + } else { + return .skip + } + }, limit: 10000) + return result + } + func getStandalone(peerId: PeerId, messageHistoryTable: MessageHistoryTable) -> ChatListIntermediateEntry? { let index = self.indexTable.get(peerId: peerId) switch index.inclusion { diff --git a/submodules/Postbox/Sources/ChatListView.swift b/submodules/Postbox/Sources/ChatListView.swift index aa70142924..d0a4ea0845 100644 --- a/submodules/Postbox/Sources/ChatListView.swift +++ b/submodules/Postbox/Sources/ChatListView.swift @@ -320,6 +320,7 @@ final class MutableChatListView { fileprivate var additionalItemIds: Set fileprivate var additionalItemEntries: [MutableChatListEntry] fileprivate var additionalMixedItemIds: Set + fileprivate var additionalMixedPinnedItemIds: Set fileprivate var additionalMixedItemEntries: [MutableChatListEntry] fileprivate var earlier: MutableChatListEntry? fileprivate var later: MutableChatListEntry? @@ -340,10 +341,17 @@ final class MutableChatListView { self.additionalItemEntries = [] self.additionalMixedItemEntries = [] self.additionalMixedItemIds = Set() + self.additionalMixedPinnedItemIds = Set() if let filterPredicate = self.filterPredicate { self.additionalMixedItemIds.formUnion(filterPredicate.includePeerIds) + for (itemId, _) in postbox.chatListTable.getPinnedItemIds(groupId: self.groupId, messageHistoryTable: postbox.messageHistoryTable, peerChatInterfaceStateTable: postbox.peerChatInterfaceStateTable) { + switch itemId { + case let .peer(peerId): + self.additionalMixedPinnedItemIds.insert(peerId) + } + } } - for peerId in self.additionalMixedItemIds { + for peerId in self.additionalMixedItemIds.union(self.additionalMixedPinnedItemIds) { if let entry = postbox.chatListTable.getEntry(peerId: peerId, messageHistoryTable: postbox.messageHistoryTable, peerChatInterfaceStateTable: postbox.peerChatInterfaceStateTable) { self.additionalMixedItemEntries.append(MutableChatListEntry(entry, cachedDataTable: postbox.cachedPeerDataTable, readStateTable: postbox.readStateTable, messageHistoryTable: postbox.messageHistoryTable)) } @@ -554,7 +562,7 @@ final class MutableChatListView { if !updatedPeerNotificationSettings.isEmpty { if let filterPredicate = self.filterPredicate { for (peerId, settingsChange) in updatedPeerNotificationSettings { - if let peer = postbox.peerTable.get(peerId) { + if let peer = postbox.peerTable.get(peerId), !self.additionalMixedItemIds.contains(peerId), !self.additionalMixedPinnedItemIds.contains(peerId) { let isUnread = postbox.readStateTable.getCombinedState(peerId)?.isUnread ?? false let wasIncluded = filterPredicate.includes(peer: peer, notificationSettings: settingsChange.0, isUnread: isUnread) let isIncluded = filterPredicate.includes(peer: peer, notificationSettings: settingsChange.1, isUnread: isUnread) @@ -611,6 +619,22 @@ final class MutableChatListView { continue } } + + for i in 0 ..< self.additionalMixedItemEntries.count { + switch self.additionalMixedItemEntries[i] { + case let .MessageEntry(index, message, readState, _, embeddedState, peer, peerPresence, summaryInfo, hasFailed): + var notificationSettingsPeerId = peer.peerId + if let peer = peer.peers[peer.peerId], let associatedPeerId = peer.associatedPeerId { + notificationSettingsPeerId = associatedPeerId + } + if let (_, settings) = updatedPeerNotificationSettings[notificationSettingsPeerId] { + self.additionalMixedItemEntries[i] = .MessageEntry(index, message, readState, settings, embeddedState, peer, peerPresence, summaryInfo, hasFailed) + hasChanges = true + } + default: + continue + } + } } if !transaction.updatedFailedMessagePeerIds.isEmpty { @@ -723,7 +747,7 @@ final class MutableChatListView { hasChanges = true } var updateAdditionalMixedItems = false - for peerId in self.additionalMixedItemIds { + for peerId in self.additionalMixedItemIds.union(self.additionalMixedPinnedItemIds) { if transaction.currentOperationsByPeerId[peerId] != nil { updateAdditionalMixedItems = true } @@ -736,7 +760,7 @@ final class MutableChatListView { } if updateAdditionalMixedItems { self.additionalMixedItemEntries.removeAll() - for peerId in self.additionalMixedItemIds { + for peerId in self.additionalMixedItemIds.union(self.additionalMixedPinnedItemIds) { if let entry = postbox.chatListTable.getEntry(peerId: peerId, messageHistoryTable: postbox.messageHistoryTable, peerChatInterfaceStateTable: postbox.peerChatInterfaceStateTable) { self.additionalMixedItemEntries.append(MutableChatListEntry(entry, cachedDataTable: postbox.cachedPeerDataTable, readStateTable: postbox.readStateTable, messageHistoryTable: postbox.messageHistoryTable)) } @@ -755,6 +779,12 @@ final class MutableChatListView { if !filterPredicate.includes(peer: peer, notificationSettings: postbox.peerNotificationSettingsTable.getEffective(index.messageIndex.id.peerId), isUnread: isUnread) { return false } + if self.additionalMixedItemIds.contains(peer.id) { + return false + } + if self.additionalMixedPinnedItemIds.contains(peer.id) { + return false + } } else { return false } @@ -1076,12 +1106,17 @@ public final class ChatListView { existingIds.insert(messageEntry.0.messageIndex.id.peerId) } } - for entry in mutableView.additionalMixedItemEntries { + loop: for entry in mutableView.additionalMixedItemEntries { if case let .MessageEntry(messageEntry) = entry { if !existingIds.contains(messageEntry.0.messageIndex.id.peerId) { switch entry { case let .MessageEntry(index, message, combinedReadState, notificationSettings, embeddedState, peer, peerPresence, summaryInfo, hasFailed): - entries.append(.MessageEntry(index, message, combinedReadState, notificationSettings, embeddedState, peer, peerPresence, summaryInfo, hasFailed)) + if let filterPredicate = mutableView.filterPredicate, let peerValue = peer.peer { + if filterPredicate.includes(peer: peerValue, notificationSettings: notificationSettings, isUnread: combinedReadState?.isUnread ?? false) { + existingIds.insert(messageEntry.0.messageIndex.id.peerId) + entries.append(.MessageEntry(ChatListIndex(pinningIndex: nil, messageIndex: index.messageIndex), message, combinedReadState, notificationSettings, embeddedState, peer, peerPresence, summaryInfo, hasFailed)) + } + } case let .HoleEntry(hole): entries.append(.HoleEntry(hole)) case .IntermediateMessageEntry: @@ -1104,12 +1139,8 @@ public final class ChatListView { additionalItemEntries.append(.MessageEntry(index, message, combinedReadState, notificationSettings, embeddedState, peer, peerPresence, summaryInfo, hasFailed)) case .HoleEntry: assertionFailure() - /*case .GroupReferenceEntry: - assertionFailure()*/ case .IntermediateMessageEntry: assertionFailure() - /*case .IntermediateGroupReferenceEntry: - assertionFailure()*/ } } diff --git a/submodules/Postbox/Sources/Postbox.swift b/submodules/Postbox/Sources/Postbox.swift index 7c837fcf1f..775b063ee8 100644 --- a/submodules/Postbox/Sources/Postbox.swift +++ b/submodules/Postbox/Sources/Postbox.swift @@ -763,6 +763,39 @@ public final class Transaction { } } + public func getChatCountMatchingPredicate(_ predicate: ChatListFilterPredicate) -> Int { + assert(!self.disposed) + guard let postbox = self.postbox else { + return 0 + } + var includedPeerIds: [PeerId: Bool] = [:] + for peerId in predicate.includePeerIds { + includedPeerIds[peerId] = false + } + var count = postbox.chatListTable.countWithPredicate(groupId: .root, predicate: { peerId in + if let peer = postbox.peerTable.get(peerId) { + let isUnread = postbox.readStateTable.getCombinedState(peerId)?.isUnread ?? false + let notificationsPeerId = peer.notificationSettingsPeerId ?? peerId + if predicate.includes(peer: peer, notificationSettings: postbox.peerNotificationSettingsTable.getEffective(notificationsPeerId), isUnread: isUnread) { + includedPeerIds[peer.id] = true + return true + } else { + return false + } + } else { + return false + } + }) + for (peerId, included) in includedPeerIds { + if !included { + if postbox.chatListTable.getPeerChatListIndex(peerId: peerId) != nil { + count += 1 + } + } + } + return count + } + public func legacyGetAccessChallengeData() -> PostboxAccessChallengeData { assert(!self.disposed) if let postbox = self.postbox { @@ -1657,9 +1690,13 @@ public final class Postbox { return { entry in switch entry { case let .message(index, _, _): + if index.pinningIndex != nil { + return false + } if let peer = self.peerTable.get(index.messageIndex.id.peerId) { let isUnread = self.readStateTable.getCombinedState(index.messageIndex.id.peerId)?.isUnread ?? false - if predicate.includes(peer: peer, notificationSettings: self.peerNotificationSettingsTable.getEffective(index.messageIndex.id.peerId), isUnread: isUnread) { + let notificationsPeerId = peer.notificationSettingsPeerId ?? peer.id + if predicate.includes(peer: peer, notificationSettings: self.peerNotificationSettingsTable.getEffective(notificationsPeerId), isUnread: isUnread) { return true } else { return false diff --git a/submodules/Postbox/Sources/SqliteValueBox.swift b/submodules/Postbox/Sources/SqliteValueBox.swift index 70b3e5661d..664ee920bc 100644 --- a/submodules/Postbox/Sources/SqliteValueBox.swift +++ b/submodules/Postbox/Sources/SqliteValueBox.swift @@ -1501,7 +1501,10 @@ public final class SqliteValueBox: ValueBox { public func filteredRange(_ table: ValueBoxTable, start: ValueBoxKey, end: ValueBoxKey, values: (ValueBoxKey, ReadBuffer) -> ValueBoxFilterResult, limit: Int) { var currentStart = start var acceptedCount = 0 - while acceptedCount < limit { + while true { + if limit > 0 && acceptedCount >= limit { + break + } var hadStop = false var lastKey: ValueBoxKey? self.range(table, start: currentStart, end: end, values: { key, value in @@ -1530,6 +1533,41 @@ public final class SqliteValueBox: ValueBox { } } + public func filteredRange(_ table: ValueBoxTable, start: ValueBoxKey, end: ValueBoxKey, keys: (ValueBoxKey) -> ValueBoxFilterResult, limit: Int) { + var currentStart = start + var acceptedCount = 0 + while true { + if limit > 0 && acceptedCount >= limit { + break + } + var hadStop = false + var lastKey: ValueBoxKey? + self.range(table, start: currentStart, end: end, keys: { key in + lastKey = key + let result = keys(key) + switch result { + case .accept: + acceptedCount += 1 + return true + case .skip: + return true + case .stop: + hadStop = true + return false + } + return true + }, limit: limit) + if let lastKey = lastKey { + currentStart = lastKey + } else { + break + } + if hadStop { + break + } + } + } + public func range(_ table: ValueBoxTable, start: ValueBoxKey, end: ValueBoxKey, keys: (ValueBoxKey) -> Bool, limit: Int) { precondition(self.queue.isCurrent()) if let _ = self.tables[table.id] { diff --git a/submodules/Postbox/Sources/ValueBox.swift b/submodules/Postbox/Sources/ValueBox.swift index 08396740e6..bdc4010f1f 100644 --- a/submodules/Postbox/Sources/ValueBox.swift +++ b/submodules/Postbox/Sources/ValueBox.swift @@ -73,6 +73,7 @@ public protocol ValueBox { func range(_ table: ValueBoxTable, start: ValueBoxKey, end: ValueBoxKey, values: (ValueBoxKey, ReadBuffer) -> Bool, limit: Int) func filteredRange(_ table: ValueBoxTable, start: ValueBoxKey, end: ValueBoxKey, values: (ValueBoxKey, ReadBuffer) -> ValueBoxFilterResult, limit: Int) + func filteredRange(_ table: ValueBoxTable, start: ValueBoxKey, end: ValueBoxKey, keys: (ValueBoxKey) -> ValueBoxFilterResult, limit: Int) func range(_ table: ValueBoxTable, start: ValueBoxKey, end: ValueBoxKey, keys: (ValueBoxKey) -> Bool, limit: Int) func scan(_ table: ValueBoxTable, values: (ValueBoxKey, ReadBuffer) -> Bool) func scan(_ table: ValueBoxTable, keys: (ValueBoxKey) -> Bool) diff --git a/submodules/SettingsUI/Sources/SettingsController.swift b/submodules/SettingsUI/Sources/SettingsController.swift index 40d1114116..5db7242a96 100644 --- a/submodules/SettingsUI/Sources/SettingsController.swift +++ b/submodules/SettingsUI/Sources/SettingsController.swift @@ -114,6 +114,7 @@ private final class SettingsItemArguments { let openPhoneNumberChange: () -> Void let accountContextAction: (AccountRecordId, ASDisplayNode, ContextGesture?) -> Void let openDevices: () -> Void + let openFilters: () -> Void init( sharedContext: SharedAccountContext, @@ -147,7 +148,8 @@ private final class SettingsItemArguments { keepPhone: @escaping () -> Void, openPhoneNumberChange: @escaping () -> Void, accountContextAction: @escaping (AccountRecordId, ASDisplayNode, ContextGesture?) -> Void, - openDevices: @escaping () -> Void + openDevices: @escaping () -> Void, + openFilters: @escaping () -> Void ) { self.sharedContext = sharedContext self.avatarAndNameInfoContext = avatarAndNameInfoContext @@ -181,6 +183,7 @@ private final class SettingsItemArguments { self.openPhoneNumberChange = openPhoneNumberChange self.accountContextAction = accountContextAction self.openDevices = openDevices + self.openFilters = openFilters } } @@ -211,6 +214,8 @@ private indirect enum SettingsEntry: ItemListNodeEntry { case devices(PresentationTheme, UIImage?, String, String) + case filters(PresentationTheme, UIImage?, String, String) + case savedMessages(PresentationTheme, UIImage?, String) case recentCalls(PresentationTheme, UIImage?, String) case stickers(PresentationTheme, UIImage?, String, String, [ArchivedStickerPackItem]?) @@ -240,7 +245,7 @@ private indirect enum SettingsEntry: ItemListNodeEntry { return SettingsSection.accounts.rawValue case .proxy: return SettingsSection.proxy.rawValue - case .devices: + case .devices, .filters: return SettingsSection.media.rawValue case .savedMessages, .recentCalls, .stickers: return SettingsSection.media.rawValue @@ -285,30 +290,32 @@ private indirect enum SettingsEntry: ItemListNodeEntry { return 1006 case .devices: return 1007 - case .notificationsAndSounds: + case .filters: return 1008 - case .privacyAndSecurity: + case .notificationsAndSounds: return 1009 - case .dataAndStorage: + case .privacyAndSecurity: return 1010 - case .themes: + case .dataAndStorage: return 1011 - case .language: + case .themes: return 1012 - case .contentStickers: + case .language: return 1013 + case .contentStickers: + return 1014 #if ENABLE_WALLET case .wallet: - return 1014 + return 1015 #endif case .passport: - return 1015 - case .watch: return 1016 - case .askAQuestion: + case .watch: return 1017 - case .faq: + case .askAQuestion: return 1018 + case .faq: + return 1019 } } @@ -406,6 +413,12 @@ private indirect enum SettingsEntry: ItemListNodeEntry { } else { return false } + case let .filters(lhsTheme, lhsImage, lhsText, lhsValue): + if case let .filters(rhsTheme, rhsImage, rhsText, rhsValue) = rhs, lhsTheme === rhsTheme, lhsImage === rhsImage, lhsText == rhsText, lhsValue == rhsValue { + return true + } else { + return false + } case let .savedMessages(lhsTheme, lhsImage, lhsText): if case let .savedMessages(rhsTheme, rhsImage, rhsText) = rhs, lhsTheme === rhsTheme, lhsImage === rhsImage, lhsText == rhsText { return true @@ -567,6 +580,10 @@ private indirect enum SettingsEntry: ItemListNodeEntry { return ItemListDisclosureItem(presentationData: presentationData, icon: image, title: text, label: value, sectionId: ItemListSectionId(self.section), style: .blocks, action: { arguments.openDevices() }) + case let .filters(theme, image, text, value): + return ItemListDisclosureItem(presentationData: presentationData, icon: image, title: text, label: value, sectionId: ItemListSectionId(self.section), style: .blocks, action: { + arguments.openFilters() + }) case let .savedMessages(theme, image, text): return ItemListDisclosureItem(presentationData: presentationData, icon: image, title: text, label: "", sectionId: ItemListSectionId(self.section), style: .blocks, action: { arguments.openSavedMessages() @@ -635,7 +652,7 @@ private struct SettingsState: Equatable { var isSearching: Bool } -private func settingsEntries(account: Account, presentationData: PresentationData, state: SettingsState, view: PeerView, proxySettings: ProxySettings, notifyExceptions: NotificationExceptionsList?, notificationsAuthorizationStatus: AccessType, notificationsWarningSuppressed: Bool, unreadTrendingStickerPacks: Int, archivedPacks: [ArchivedStickerPackItem]?, privacySettings: AccountPrivacySettings?, hasWallet: Bool, hasPassport: Bool, hasWatchApp: Bool, accountsAndPeers: [(Account, Peer, Int32)], inAppNotificationSettings: InAppNotificationSettings, experimentalUISettings: ExperimentalUISettings, displayPhoneNumberConfirmation: Bool, otherSessionCount: Int, enableQRLogin: Bool) -> [SettingsEntry] { +private func settingsEntries(account: Account, presentationData: PresentationData, state: SettingsState, view: PeerView, proxySettings: ProxySettings, notifyExceptions: NotificationExceptionsList?, notificationsAuthorizationStatus: AccessType, notificationsWarningSuppressed: Bool, unreadTrendingStickerPacks: Int, archivedPacks: [ArchivedStickerPackItem]?, privacySettings: AccountPrivacySettings?, hasWallet: Bool, hasPassport: Bool, hasWatchApp: Bool, accountsAndPeers: [(Account, Peer, Int32)], inAppNotificationSettings: InAppNotificationSettings, experimentalUISettings: ExperimentalUISettings, displayPhoneNumberConfirmation: Bool, otherSessionCount: Int, enableQRLogin: Bool, enableFilters: Bool) -> [SettingsEntry] { var entries: [SettingsEntry] = [] if let peer = peerViewMainPeer(view) as? TelegramUser { @@ -688,6 +705,10 @@ private func settingsEntries(account: Account, presentationData: PresentationDat } else { entries.append(.devices(presentationData.theme, UIImage(bundleImageName: "Settings/MenuIcons/Sessions")?.precomposed(), presentationData.strings.Settings_Devices, otherSessionCount == 0 ? "" : "\(otherSessionCount + 1)")) } + if enableFilters { + //TODO:localize + entries.append(.filters(presentationData.theme, UIImage(bundleImageName: "Settings/MenuIcons/SavedMessages")?.precomposed(), "Chat Filters", "")) + } let notificationsWarning = shouldDisplayNotificationsPermissionWarning(status: notificationsAuthorizationStatus, suppressed: notificationsWarningSuppressed) entries.append(.notificationsAndSounds(presentationData.theme, PresentationResourcesSettings.notifications, presentationData.strings.Settings_NotificationsAndSounds, notifyExceptions, notificationsWarning)) @@ -925,6 +946,7 @@ public func settingsController(context: AccountContext, accountManager: AccountM let privacySettings = Promise(nil) let enableQRLogin = Promise() + let enableFilters = Promise() let openFaq: (Promise, String?) -> Void = { resolvedUrl, customAnchor in let _ = (contextValue.get() @@ -1221,17 +1243,27 @@ public func settingsController(context: AccountContext, accountManager: AccountM gesture?.cancel() } }, openDevices: { - let _ = (combineLatest(queue: .mainQueue(), - activeSessionsContextAndCount.get(), - enableQRLogin.get() - ) - |> take(1)).start(next: { activeSessionsContextAndCount, enableQRLogin in - let (activeSessionsContext, count, webSessionsContext) = activeSessionsContextAndCount - if count == 0 && enableQRLogin { - pushControllerImpl?(AuthDataTransferSplashScreen(context: context, activeSessionsContext: activeSessionsContext)) - } else { - pushControllerImpl?(recentSessionsController(context: context, activeSessionsContext: activeSessionsContext, webSessionsContext: webSessionsContext, websitesOnly: false)) - } + let _ = (contextValue.get() + |> deliverOnMainQueue + |> take(1)).start(next: { context in + let _ = (combineLatest(queue: .mainQueue(), + activeSessionsContextAndCount.get(), + enableQRLogin.get() + ) + |> take(1)).start(next: { activeSessionsContextAndCount, enableQRLogin in + let (activeSessionsContext, count, webSessionsContext) = activeSessionsContextAndCount + if count == 0 && enableQRLogin { + pushControllerImpl?(AuthDataTransferSplashScreen(context: context, activeSessionsContext: activeSessionsContext)) + } else { + pushControllerImpl?(recentSessionsController(context: context, activeSessionsContext: activeSessionsContext, webSessionsContext: webSessionsContext, websitesOnly: false)) + } + }) + }) + }, openFilters: { + let _ = (contextValue.get() + |> deliverOnMainQueue + |> take(1)).start(next: { context in + pushControllerImpl?(chatListFilterPresetListController(context: context, updated: { _ in })) }) }) @@ -1496,7 +1528,21 @@ public func settingsController(context: AccountContext, accountManager: AccountM } enableQRLogin.set(enableQRLoginSignal) - let signal = combineLatest(queue: Queue.mainQueue(), contextValue.get(), updatedPresentationData, statePromise.get(), peerView, combineLatest(queue: Queue.mainQueue(), preferences, notifyExceptions.get(), notificationsAuthorizationStatus.get(), notificationsWarningSuppressed.get(), privacySettings.get(), displayPhoneNumberConfirmation.get()), combineLatest(featuredStickerPacks, archivedPacks.get()), combineLatest(hasWallet, hasPassport.get(), hasWatchApp, enableQRLogin.get()), accountsAndPeers.get(), activeSessionsContextAndCount.get()) + let enableFiltersSignal = contextValue.get() + |> mapToSignal { context -> Signal in + return context.account.postbox.preferencesView(keys: [PreferencesKeys.appConfiguration]) + |> map { view -> Bool in + guard let appConfiguration = view.values[PreferencesKeys.appConfiguration] as? AppConfiguration else { + return false + } + let configuration = ChatListFilteringConfiguration(appConfiguration: appConfiguration) + return configuration.isEnabled + } + |> distinctUntilChanged + } + enableFilters.set(enableFiltersSignal) + + let signal = combineLatest(queue: Queue.mainQueue(), contextValue.get(), updatedPresentationData, statePromise.get(), peerView, combineLatest(queue: Queue.mainQueue(), preferences, notifyExceptions.get(), notificationsAuthorizationStatus.get(), notificationsWarningSuppressed.get(), privacySettings.get(), displayPhoneNumberConfirmation.get()), combineLatest(featuredStickerPacks, archivedPacks.get()), combineLatest(hasWallet, hasPassport.get(), hasWatchApp, enableQRLogin.get(), enableFilters.get()), accountsAndPeers.get(), activeSessionsContextAndCount.get()) |> map { context, presentationData, state, view, preferencesAndExceptions, featuredAndArchived, hasWalletPassportAndWatch, accountsAndPeers, activeSessionsContextAndCount -> (ItemListControllerState, (ItemListNodeState, Any)) in let otherSessionCount = activeSessionsContextAndCount.1 @@ -1536,8 +1582,8 @@ public func settingsController(context: AccountContext, accountManager: AccountM pushControllerImpl?(c) }, getNavigationController: getNavigationControllerImpl, exceptionsList: notifyExceptions.get(), archivedStickerPacks: archivedPacks.get(), privacySettings: privacySettings.get(), hasWallet: hasWallet, activeSessionsContext: activeSessionsContextAndCountSignal |> map { $0.0 } |> distinctUntilChanged(isEqual: { $0 === $1 }), webSessionsContext: activeSessionsContextAndCountSignal |> map { $0.2 } |> distinctUntilChanged(isEqual: { $0 === $1 })) - let (hasWallet, hasPassport, hasWatchApp, enableQRLogin) = hasWalletPassportAndWatch - let listState = ItemListNodeState(presentationData: ItemListPresentationData(presentationData), entries: settingsEntries(account: context.account, presentationData: presentationData, state: state, view: view, proxySettings: proxySettings, notifyExceptions: preferencesAndExceptions.1, notificationsAuthorizationStatus: preferencesAndExceptions.2, notificationsWarningSuppressed: preferencesAndExceptions.3, unreadTrendingStickerPacks: unreadTrendingStickerPacks, archivedPacks: featuredAndArchived.1, privacySettings: preferencesAndExceptions.4, hasWallet: hasWallet, hasPassport: hasPassport, hasWatchApp: hasWatchApp, accountsAndPeers: accountsAndPeers.1, inAppNotificationSettings: inAppNotificationSettings, experimentalUISettings: experimentalUISettings, displayPhoneNumberConfirmation: preferencesAndExceptions.5, otherSessionCount: otherSessionCount, enableQRLogin: enableQRLogin), style: .blocks, searchItem: searchItem, initialScrollToItem: ListViewScrollToItem(index: 0, position: .top(-navigationBarSearchContentHeight), animated: false, curve: .Default(duration: 0.0), directionHint: .Up)) + let (hasWallet, hasPassport, hasWatchApp, enableQRLogin, enableFilters) = hasWalletPassportAndWatch + let listState = ItemListNodeState(presentationData: ItemListPresentationData(presentationData), entries: settingsEntries(account: context.account, presentationData: presentationData, state: state, view: view, proxySettings: proxySettings, notifyExceptions: preferencesAndExceptions.1, notificationsAuthorizationStatus: preferencesAndExceptions.2, notificationsWarningSuppressed: preferencesAndExceptions.3, unreadTrendingStickerPacks: unreadTrendingStickerPacks, archivedPacks: featuredAndArchived.1, privacySettings: preferencesAndExceptions.4, hasWallet: hasWallet, hasPassport: hasPassport, hasWatchApp: hasWatchApp, accountsAndPeers: accountsAndPeers.1, inAppNotificationSettings: inAppNotificationSettings, experimentalUISettings: experimentalUISettings, displayPhoneNumberConfirmation: preferencesAndExceptions.5, otherSessionCount: otherSessionCount, enableQRLogin: enableQRLogin, enableFilters: enableFilters), style: .blocks, searchItem: searchItem, initialScrollToItem: ListViewScrollToItem(index: 0, position: .top(-navigationBarSearchContentHeight), animated: false, curve: .Default(duration: 0.0), directionHint: .Up)) return (controllerState, (listState, arguments)) } diff --git a/submodules/TelegramCore/Sources/Account.swift b/submodules/TelegramCore/Sources/Account.swift index d28d1ee0a1..cec053cf33 100644 --- a/submodules/TelegramCore/Sources/Account.swift +++ b/submodules/TelegramCore/Sources/Account.swift @@ -1044,7 +1044,7 @@ public class Account { self.managedOperationsDisposable.add(managedApplyPendingMessageReactionsActions(postbox: self.postbox, network: self.network, stateManager: self.stateManager).start()) self.managedOperationsDisposable.add(managedSynchronizeEmojiKeywordsOperations(postbox: self.postbox, network: self.network).start()) self.managedOperationsDisposable.add(managedApplyPendingScheduledMessagesActions(postbox: self.postbox, network: self.network, stateManager: self.stateManager).start()) - //self.managedOperationsDisposable.add(managedChatListFilters(postbox: self.postbox, network: self.network).start()) + self.managedOperationsDisposable.add(managedChatListFilters(postbox: self.postbox, network: self.network).start()) let importantBackgroundOperations: [Signal] = [ managedSynchronizeChatInputStateOperations(postbox: self.postbox, network: self.network) |> map { $0 ? AccountRunningImportantTasks.other : [] }, diff --git a/submodules/TelegramCore/Sources/ChatListFiltering.swift b/submodules/TelegramCore/Sources/ChatListFiltering.swift index 08c374d900..8193e3c927 100644 --- a/submodules/TelegramCore/Sources/ChatListFiltering.swift +++ b/submodules/TelegramCore/Sources/ChatListFiltering.swift @@ -5,7 +5,19 @@ import TelegramApi import SyncCore -public struct ChatListFilterPeerCategories: OptionSet { +public struct ChatListFilteringConfiguration: Equatable { + public let isEnabled: Bool + + public init(appConfiguration: AppConfiguration) { + var isEnabled = false + if let data = appConfiguration.data, let value = data["dialog_filters_enabled"] as? Bool, value { + isEnabled = true + } + self.isEnabled = isEnabled + } +} + +public struct ChatListFilterPeerCategories: OptionSet, Hashable { public var rawValue: Int32 public init(rawValue: Int32) { @@ -93,50 +105,58 @@ extension ChatListFilterPeerCategories { } } -public struct ChatListFilter: PostboxCoding, Equatable { - public var id: Int32 - public var title: String? +public struct ChatListFilterData: Equatable, Hashable { public var categories: ChatListFilterPeerCategories public var excludeMuted: Bool public var excludeRead: Bool public var includePeers: [PeerId] public init( - id: Int32, - title: String?, categories: ChatListFilterPeerCategories, excludeMuted: Bool, excludeRead: Bool, includePeers: [PeerId] ) { - self.id = id - self.title = title self.categories = categories self.excludeMuted = excludeMuted self.excludeRead = excludeRead self.includePeers = includePeers } +} + +public struct ChatListFilter: PostboxCoding, Equatable { + public var id: Int32 + public var title: String + public var data: ChatListFilterData + + public init( + id: Int32, + title: String, + data: ChatListFilterData + ) { + self.id = id + self.title = title + self.data = data + } public init(decoder: PostboxDecoder) { self.id = decoder.decodeInt32ForKey("id", orElse: 0) - self.title = decoder.decodeOptionalStringForKey("title") - self.categories = ChatListFilterPeerCategories(rawValue: decoder.decodeInt32ForKey("categories", orElse: 0)) - self.excludeMuted = decoder.decodeInt32ForKey("excludeMuted", orElse: 0) != 0 - self.excludeRead = decoder.decodeInt32ForKey("excludeRead", orElse: 0) != 0 - self.includePeers = decoder.decodeInt64ArrayForKey("includePeers").map(PeerId.init) + self.title = decoder.decodeStringForKey("title", orElse: "") + self.data = ChatListFilterData( + categories: ChatListFilterPeerCategories(rawValue: decoder.decodeInt32ForKey("categories", orElse: 0)), + excludeMuted: decoder.decodeInt32ForKey("excludeMuted", orElse: 0) != 0, + excludeRead: decoder.decodeInt32ForKey("excludeRead", orElse: 0) != 0, + includePeers: decoder.decodeInt64ArrayForKey("includePeers").map(PeerId.init) + ) } public func encode(_ encoder: PostboxEncoder) { encoder.encodeInt32(self.id, forKey: "id") - if let title = self.title { - encoder.encodeString(title, forKey: "title") - } else { - encoder.encodeNil(forKey: "title") - } - encoder.encodeInt32(self.categories.rawValue, forKey: "categories") - encoder.encodeInt32(self.excludeMuted ? 1 : 0, forKey: "excludeMuted") - encoder.encodeInt32(self.excludeRead ? 1 : 0, forKey: "excludeRead") - encoder.encodeInt64Array(self.includePeers.map { $0.toInt64() }, forKey: "includePeers") + encoder.encodeString(self.title, forKey: "title") + encoder.encodeInt32(self.data.categories.rawValue, forKey: "categories") + encoder.encodeInt32(self.data.excludeMuted ? 1 : 0, forKey: "excludeMuted") + encoder.encodeInt32(self.data.excludeRead ? 1 : 0, forKey: "excludeRead") + encoder.encodeInt64Array(self.data.includePeers.map { $0.toInt64() }, forKey: "includePeers") } } @@ -146,36 +166,38 @@ extension ChatListFilter { case let .dialogFilter(flags, id, title, includePeers): self.init( id: id, - title: title.isEmpty ? nil : title, - categories: ChatListFilterPeerCategories(apiFlags: flags), - excludeMuted: (flags & (1 << 11)) != 0, - excludeRead: (flags & (1 << 12)) != 0, - includePeers: includePeers.compactMap { peer -> PeerId? in - switch peer { - case let .inputPeerUser(userId, _): - return PeerId(namespace: Namespaces.Peer.CloudUser, id: userId) - case let .inputPeerChat(chatId): - return PeerId(namespace: Namespaces.Peer.CloudGroup, id: chatId) - case let .inputPeerChannel(channelId, _): - return PeerId(namespace: Namespaces.Peer.CloudChannel, id: channelId) - default: - return nil + title: title, + data: ChatListFilterData( + categories: ChatListFilterPeerCategories(apiFlags: flags), + excludeMuted: (flags & (1 << 11)) != 0, + excludeRead: (flags & (1 << 12)) != 0, + includePeers: includePeers.compactMap { peer -> PeerId? in + switch peer { + case let .inputPeerUser(userId, _): + return PeerId(namespace: Namespaces.Peer.CloudUser, id: userId) + case let .inputPeerChat(chatId): + return PeerId(namespace: Namespaces.Peer.CloudGroup, id: chatId) + case let .inputPeerChannel(channelId, _): + return PeerId(namespace: Namespaces.Peer.CloudChannel, id: channelId) + default: + return nil + } } - } + ) ) } } func apiFilter(transaction: Transaction) -> Api.DialogFilter { var flags: Int32 = 0 - if self.excludeMuted { + if self.data.excludeMuted { flags |= 1 << 11 } - if self.excludeRead { + if self.data.excludeRead { flags |= 1 << 12 } - flags |= self.categories.apiFlags - return .dialogFilter(flags: flags, id: self.id, title: self.title ?? "", includePeers: self.includePeers.compactMap { peerId -> Api.InputPeer? in + flags |= self.data.categories.apiFlags + return .dialogFilter(flags: flags, id: self.id, title: self.title, includePeers: self.data.includePeers.compactMap { peerId -> Api.InputPeer? in return transaction.getPeer(peerId).flatMap(apiInputPeer) }) } @@ -287,46 +309,70 @@ func managedChatListFilters(postbox: Postbox, network: Network) -> Signal Signal { - return requestChatListFilters(postbox: account.postbox, network: account.network) - |> `catch` { _ -> Signal<[ChatListFilter], NoError> in - return .complete() + return account.postbox.transaction { transaction -> [ChatListFilter] in + let settings = transaction.getPreferencesEntry(key: PreferencesKeys.chatListFilters) as? ChatListFiltersState ?? ChatListFiltersState.default + return settings.filters } - |> mapToSignal { remoteFilters -> Signal in - var deleteSignals: [Signal] = [] - for filter in remoteFilters { - deleteSignals.append(requestUpdateChatListFilter(account: account, id: filter.id, filter: nil) - |> `catch` { _ -> Signal in - return .complete() - } - |> ignoreValues) + |> mapToSignal { filters -> Signal in + return requestChatListFilters(postbox: account.postbox, network: account.network) + |> `catch` { _ -> Signal<[ChatListFilter], NoError> in + return .complete() } - - let addFilters = account.postbox.transaction { transaction -> [(Int32, ChatListFilter)] in - let settings = transaction.getPreferencesEntry(key: PreferencesKeys.chatListFilters) as? ChatListFiltersState ?? ChatListFiltersState.default - return settings.filters.map { filter -> (Int32, ChatListFilter) in - return (filter.id, filter) + |> mapToSignal { remoteFilters -> Signal in + var deleteSignals: [Signal] = [] + for filter in remoteFilters { + if !filters.contains(where: { $0.id == filter.id }) { + deleteSignals.append(requestUpdateChatListFilter(account: account, id: filter.id, filter: nil) + |> `catch` { _ -> Signal in + return .complete() + } + |> ignoreValues) + } } - } - |> mapToSignal { filters -> Signal in - var signals: [Signal] = [] - for (id, filter) in filters { - signals.append(requestUpdateChatListFilter(account: account, id: id, filter: filter) + + let addFilters = account.postbox.transaction { transaction -> [(Int32, ChatListFilter)] in + let settings = transaction.getPreferencesEntry(key: PreferencesKeys.chatListFilters) as? ChatListFiltersState ?? ChatListFiltersState.default + return settings.filters.map { filter -> (Int32, ChatListFilter) in + return (filter.id, filter) + } + } + |> mapToSignal { filters -> Signal in + var signals: [Signal] = [] + for (id, filter) in filters { + if !remoteFilters.contains(filter) { + signals.append(requestUpdateChatListFilter(account: account, id: id, filter: filter) + |> `catch` { _ -> Signal in + return .complete() + } + |> ignoreValues) + } + } + return combineLatest(signals) + |> ignoreValues + } + + let reorderFilters: Signal + if remoteFilters.map({ $0.id }) != filters.map({ $0.id }) { + reorderFilters = account.network.request(Api.functions.messages.updateDialogFiltersOrder(order: filters.map { $0.id })) + |> ignoreValues |> `catch` { _ -> Signal in return .complete() } - |> ignoreValues) + } else { + reorderFilters = .complete() } - return combineLatest(signals) + + return combineLatest( + deleteSignals + ) |> ignoreValues + |> then( + addFilters + ) + |> then( + reorderFilters + ) } - - return combineLatest( - deleteSignals - ) - |> ignoreValues - |> then( - addFilters - ) } } diff --git a/submodules/TelegramPresentationData/Sources/PresentationStrings.swift b/submodules/TelegramPresentationData/Sources/PresentationStrings.swift index 7cfafefe1a..d2bb674503 100644 --- a/submodules/TelegramPresentationData/Sources/PresentationStrings.swift +++ b/submodules/TelegramPresentationData/Sources/PresentationStrings.swift @@ -509,4809 +509,4807 @@ public final class PresentationStrings: Equatable { public var AuthSessions_LogOutApplicationsHelp: String { return self._s[309]! } public var Forward_ErrorPublicQuizDisabledInChannels: String { return self._s[310]! } public var Month_GenFebruary: String { return self._s[311]! } - public var Wallet_Send_NetworkErrorTitle: String { return self._s[312]! } + public var ChatListFilter_AddChatsTitle: String { return self._s[312]! } + public var Wallet_Send_NetworkErrorTitle: String { return self._s[313]! } public func Login_InvalidPhoneEmailBody(_ _1: String, _ _2: String, _ _3: String, _ _4: String, _ _5: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[314]!, self._r[314]!, [_1, _2, _3, _4, _5]) + return formatWithArgumentRanges(self._s[315]!, self._r[315]!, [_1, _2, _3, _4, _5]) } - public var Passport_Identity_TypeIdentityCard: String { return self._s[315]! } - public var Wallet_Month_ShortJune: String { return self._s[317]! } - public var AutoDownloadSettings_DataUsageMedium: String { return self._s[318]! } - public var GroupInfo_AddParticipant: String { return self._s[319]! } - public var KeyCommand_SendMessage: String { return self._s[320]! } - public var VoiceOver_Chat_YourContact: String { return self._s[322]! } - public var Map_LiveLocationShowAll: String { return self._s[323]! } - public var WallpaperSearch_ColorOrange: String { return self._s[325]! } - public var Appearance_AppIconDefaultX: String { return self._s[326]! } - public var Checkout_Receipt_Title: String { return self._s[327]! } - public var Group_OwnershipTransfer_ErrorPrivacyRestricted: String { return self._s[328]! } - public var WallpaperPreview_PreviewTopText: String { return self._s[329]! } - public var Message_Contact: String { return self._s[330]! } - public var Call_StatusIncoming: String { return self._s[331]! } - public var Wallet_TransactionInfo_StorageFeeInfo: String { return self._s[332]! } + public var Passport_Identity_TypeIdentityCard: String { return self._s[316]! } + public var Wallet_Month_ShortJune: String { return self._s[318]! } + public var AutoDownloadSettings_DataUsageMedium: String { return self._s[319]! } + public var GroupInfo_AddParticipant: String { return self._s[320]! } + public var KeyCommand_SendMessage: String { return self._s[321]! } + public var VoiceOver_Chat_YourContact: String { return self._s[323]! } + public var Map_LiveLocationShowAll: String { return self._s[324]! } + public var WallpaperSearch_ColorOrange: String { return self._s[326]! } + public var Appearance_AppIconDefaultX: String { return self._s[327]! } + public var Checkout_Receipt_Title: String { return self._s[328]! } + public var Group_OwnershipTransfer_ErrorPrivacyRestricted: String { return self._s[329]! } + public var WallpaperPreview_PreviewTopText: String { return self._s[330]! } + public var Message_Contact: String { return self._s[331]! } + public var Call_StatusIncoming: String { return self._s[332]! } + public var Wallet_TransactionInfo_StorageFeeInfo: String { return self._s[333]! } public func Channel_AdminLog_MessageKickedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[333]!, self._r[333]!, [_1]) + return formatWithArgumentRanges(self._s[334]!, self._r[334]!, [_1]) } public func PUSH_ENCRYPTED_MESSAGE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[335]!, self._r[335]!, [_1]) + return formatWithArgumentRanges(self._s[336]!, self._r[336]!, [_1]) } - public var VoiceOver_Media_PlaybackRate: String { return self._s[336]! } - public var Passport_FieldIdentityDetailsHelp: String { return self._s[337]! } - public var Conversation_ViewChannel: String { return self._s[338]! } + public var VoiceOver_Media_PlaybackRate: String { return self._s[337]! } + public var Passport_FieldIdentityDetailsHelp: String { return self._s[338]! } + public var Conversation_ViewChannel: String { return self._s[339]! } public func Time_TodayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[339]!, self._r[339]!, [_0]) + return formatWithArgumentRanges(self._s[340]!, self._r[340]!, [_0]) } - public var Theme_Colors_Accent: String { return self._s[340]! } - public var Passport_Language_nl: String { return self._s[342]! } - public var Camera_Retake: String { return self._s[343]! } + public var Theme_Colors_Accent: String { return self._s[341]! } + public var Passport_Language_nl: String { return self._s[343]! } + public var Camera_Retake: String { return self._s[344]! } public func UserInfo_BlockActionTitle(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[344]!, self._r[344]!, [_0]) + return formatWithArgumentRanges(self._s[345]!, self._r[345]!, [_0]) } - public var AuthSessions_LogOutApplications: String { return self._s[345]! } - public var ApplyLanguage_ApplySuccess: String { return self._s[346]! } - public var Tour_Title6: String { return self._s[347]! } - public var Map_ChooseAPlace: String { return self._s[348]! } - public var CallSettings_Never: String { return self._s[350]! } + public var AuthSessions_LogOutApplications: String { return self._s[346]! } + public var ApplyLanguage_ApplySuccess: String { return self._s[347]! } + public var Tour_Title6: String { return self._s[348]! } + public var Map_ChooseAPlace: String { return self._s[349]! } + public var CallSettings_Never: String { return self._s[351]! } public func Notification_ChangedGroupPhoto(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[351]!, self._r[351]!, [_0]) + return formatWithArgumentRanges(self._s[352]!, self._r[352]!, [_0]) } - public var ChannelRemoved_RemoveInfo: String { return self._s[352]! } + public var ChannelRemoved_RemoveInfo: String { return self._s[353]! } public func AutoDownloadSettings_PreloadVideoInfo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[353]!, self._r[353]!, [_0]) + return formatWithArgumentRanges(self._s[354]!, self._r[354]!, [_0]) } - public var SettingsSearch_Synonyms_Notifications_MessageNotificationsExceptions: String { return self._s[354]! } + public var SettingsSearch_Synonyms_Notifications_MessageNotificationsExceptions: String { return self._s[355]! } public func Conversation_ClearChatConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[355]!, self._r[355]!, [_0]) + return formatWithArgumentRanges(self._s[356]!, self._r[356]!, [_0]) } - public var GroupInfo_InviteLink_Title: String { return self._s[356]! } + public var GroupInfo_InviteLink_Title: String { return self._s[357]! } public func Channel_AdminLog_MessageUnkickedNameUsername(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[357]!, self._r[357]!, [_1, _2]) + return formatWithArgumentRanges(self._s[358]!, self._r[358]!, [_1, _2]) } - public var KeyCommand_ScrollUp: String { return self._s[358]! } - public var ContactInfo_URLLabelHomepage: String { return self._s[359]! } - public var Channel_OwnershipTransfer_ChangeOwner: String { return self._s[360]! } + public var KeyCommand_ScrollUp: String { return self._s[359]! } + public var ContactInfo_URLLabelHomepage: String { return self._s[360]! } + public var Channel_OwnershipTransfer_ChangeOwner: String { return self._s[361]! } public func Channel_AdminLog_DisabledSlowmode(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[361]!, self._r[361]!, [_0]) + return formatWithArgumentRanges(self._s[362]!, self._r[362]!, [_0]) } - public var TwoFactorSetup_Done_Title: String { return self._s[362]! } + public var TwoFactorSetup_Done_Title: String { return self._s[363]! } public func Conversation_EncryptedPlaceholderTitleOutgoing(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[363]!, self._r[363]!, [_0]) + return formatWithArgumentRanges(self._s[364]!, self._r[364]!, [_0]) } - public var CallFeedback_ReasonDistortedSpeech: String { return self._s[364]! } - public var Watch_LastSeen_WithinAWeek: String { return self._s[365]! } - public var ContactList_Context_SendMessage: String { return self._s[367]! } - public var Weekday_Tuesday: String { return self._s[368]! } - public var Wallet_Created_Title: String { return self._s[370]! } - public var ScheduledMessages_Delete: String { return self._s[371]! } - public var UserInfo_StartSecretChat: String { return self._s[372]! } - public var Passport_Identity_FilesTitle: String { return self._s[373]! } - public var Permissions_NotificationsAllow_v0: String { return self._s[374]! } - public var DialogList_DeleteConversationConfirmation: String { return self._s[376]! } - public var ChatList_UndoArchiveRevealedTitle: String { return self._s[377]! } + public var CallFeedback_ReasonDistortedSpeech: String { return self._s[365]! } + public var Watch_LastSeen_WithinAWeek: String { return self._s[366]! } + public var ContactList_Context_SendMessage: String { return self._s[368]! } + public var Weekday_Tuesday: String { return self._s[369]! } + public var Wallet_Created_Title: String { return self._s[371]! } + public var ScheduledMessages_Delete: String { return self._s[372]! } + public var UserInfo_StartSecretChat: String { return self._s[373]! } + public var Passport_Identity_FilesTitle: String { return self._s[374]! } + public var Permissions_NotificationsAllow_v0: String { return self._s[375]! } + public var DialogList_DeleteConversationConfirmation: String { return self._s[377]! } + public var ChatList_UndoArchiveRevealedTitle: String { return self._s[378]! } public func Wallet_Configuration_ApplyErrorTextURLUnreachable(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[378]!, self._r[378]!, [_0]) + return formatWithArgumentRanges(self._s[379]!, self._r[379]!, [_0]) } - public var AuthSessions_Sessions: String { return self._s[379]! } + public var AuthSessions_Sessions: String { return self._s[380]! } public func Settings_KeepPhoneNumber(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[381]!, self._r[381]!, [_0]) + return formatWithArgumentRanges(self._s[382]!, self._r[382]!, [_0]) } - public var TwoStepAuth_RecoveryEmailChangeDescription: String { return self._s[382]! } - public var Call_StatusWaiting: String { return self._s[383]! } - public var CreateGroup_SoftUserLimitAlert: String { return self._s[384]! } - public var FastTwoStepSetup_HintHelp: String { return self._s[385]! } - public var WallpaperPreview_CustomColorBottomText: String { return self._s[386]! } - public var EditTheme_Expand_Preview_OutgoingText: String { return self._s[387]! } - public var LogoutOptions_AddAccountText: String { return self._s[388]! } - public var PasscodeSettings_6DigitCode: String { return self._s[389]! } - public var Settings_LogoutConfirmationText: String { return self._s[390]! } - public var Passport_Identity_TypePassport: String { return self._s[392]! } - public var Map_Work: String { return self._s[395]! } + public var TwoStepAuth_RecoveryEmailChangeDescription: String { return self._s[383]! } + public var Call_StatusWaiting: String { return self._s[384]! } + public var CreateGroup_SoftUserLimitAlert: String { return self._s[385]! } + public var FastTwoStepSetup_HintHelp: String { return self._s[386]! } + public var WallpaperPreview_CustomColorBottomText: String { return self._s[387]! } + public var EditTheme_Expand_Preview_OutgoingText: String { return self._s[388]! } + public var LogoutOptions_AddAccountText: String { return self._s[389]! } + public var PasscodeSettings_6DigitCode: String { return self._s[390]! } + public var Settings_LogoutConfirmationText: String { return self._s[391]! } + public var Passport_Identity_TypePassport: String { return self._s[393]! } + public var Map_Work: String { return self._s[396]! } public func PUSH_MESSAGE_VIDEOS(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[396]!, self._r[396]!, [_1, _2]) + return formatWithArgumentRanges(self._s[397]!, self._r[397]!, [_1, _2]) } - public var SocksProxySetup_SaveProxy: String { return self._s[397]! } - public var AccessDenied_SaveMedia: String { return self._s[398]! } - public var Checkout_ErrorInvoiceAlreadyPaid: String { return self._s[400]! } - public var CreatePoll_MultipleChoice: String { return self._s[401]! } - public var Settings_Title: String { return self._s[403]! } - public var VoiceOver_Chat_RecordModeVideoMessageInfo: String { return self._s[404]! } - public var Contacts_InviteSearchLabel: String { return self._s[406]! } - public var PrivacySettings_WebSessions: String { return self._s[407]! } - public var ConvertToSupergroup_Title: String { return self._s[408]! } + public var SocksProxySetup_SaveProxy: String { return self._s[398]! } + public var AccessDenied_SaveMedia: String { return self._s[399]! } + public var Checkout_ErrorInvoiceAlreadyPaid: String { return self._s[401]! } + public var CreatePoll_MultipleChoice: String { return self._s[402]! } + public var Settings_Title: String { return self._s[404]! } + public var VoiceOver_Chat_RecordModeVideoMessageInfo: String { return self._s[405]! } + public var Contacts_InviteSearchLabel: String { return self._s[407]! } + public var PrivacySettings_WebSessions: String { return self._s[408]! } + public var ConvertToSupergroup_Title: String { return self._s[409]! } public func Channel_AdminLog_CaptionEdited(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[409]!, self._r[409]!, [_0]) + return formatWithArgumentRanges(self._s[410]!, self._r[410]!, [_0]) } - public var TwoFactorSetup_Hint_Text: String { return self._s[410]! } - public var InfoPlist_NSSiriUsageDescription: String { return self._s[411]! } + public var TwoFactorSetup_Hint_Text: String { return self._s[411]! } + public var InfoPlist_NSSiriUsageDescription: String { return self._s[412]! } public func PUSH_MESSAGE_CHANNEL_MESSAGE_GAME_SCORE(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[412]!, self._r[412]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[413]!, self._r[413]!, [_1, _2, _3]) } - public var ChatSettings_AutomaticPhotoDownload: String { return self._s[413]! } - public var UserInfo_BotHelp: String { return self._s[414]! } - public var PrivacySettings_LastSeenEverybody: String { return self._s[415]! } - public var Checkout_Name: String { return self._s[416]! } - public var AutoDownloadSettings_DataUsage: String { return self._s[417]! } - public var Channel_BanUser_BlockFor: String { return self._s[418]! } - public var Checkout_ShippingAddress: String { return self._s[419]! } - public var AutoDownloadSettings_MaxVideoSize: String { return self._s[420]! } - public var Privacy_PaymentsClearInfoDoneHelp: String { return self._s[421]! } - public var Privacy_Forwards: String { return self._s[422]! } - public var Channel_BanUser_PermissionSendPolls: String { return self._s[423]! } - public var Appearance_ThemeCarouselNewNight: String { return self._s[424]! } + public var ChatSettings_AutomaticPhotoDownload: String { return self._s[414]! } + public var UserInfo_BotHelp: String { return self._s[415]! } + public var PrivacySettings_LastSeenEverybody: String { return self._s[416]! } + public var Checkout_Name: String { return self._s[417]! } + public var AutoDownloadSettings_DataUsage: String { return self._s[418]! } + public var Channel_BanUser_BlockFor: String { return self._s[419]! } + public var Checkout_ShippingAddress: String { return self._s[420]! } + public var AutoDownloadSettings_MaxVideoSize: String { return self._s[421]! } + public var Privacy_PaymentsClearInfoDoneHelp: String { return self._s[422]! } + public var Privacy_Forwards: String { return self._s[423]! } + public var Channel_BanUser_PermissionSendPolls: String { return self._s[424]! } + public var Appearance_ThemeCarouselNewNight: String { return self._s[425]! } public func SecretVideo_NotViewedYet(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[427]!, self._r[427]!, [_0]) + return formatWithArgumentRanges(self._s[428]!, self._r[428]!, [_0]) } - public var Contacts_SortedByName: String { return self._s[428]! } - public var Group_OwnershipTransfer_Title: String { return self._s[429]! } - public var PeerInfo_BioExpand: String { return self._s[431]! } - public var VoiceOver_Chat_OpenHint: String { return self._s[432]! } - public var Group_LeaveGroup: String { return self._s[433]! } - public var Settings_UsernameEmpty: String { return self._s[434]! } + public var Contacts_SortedByName: String { return self._s[429]! } + public var Group_OwnershipTransfer_Title: String { return self._s[430]! } + public var PeerInfo_BioExpand: String { return self._s[432]! } + public var VoiceOver_Chat_OpenHint: String { return self._s[433]! } + public var Group_LeaveGroup: String { return self._s[434]! } + public var Settings_UsernameEmpty: String { return self._s[435]! } public func Notification_PinnedPollMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[435]!, self._r[435]!, [_0]) + return formatWithArgumentRanges(self._s[436]!, self._r[436]!, [_0]) } public func TwoStepAuth_ConfirmEmailDescription(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[436]!, self._r[436]!, [_1]) + return formatWithArgumentRanges(self._s[437]!, self._r[437]!, [_1]) } public func Channel_OwnershipTransfer_DescriptionInfo(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[437]!, self._r[437]!, [_1, _2]) + return formatWithArgumentRanges(self._s[438]!, self._r[438]!, [_1, _2]) } - public var Message_ImageExpired: String { return self._s[438]! } - public var TwoStepAuth_RecoveryFailed: String { return self._s[440]! } - public var EditTheme_Edit_Preview_OutgoingText: String { return self._s[441]! } - public var UserInfo_AddToExisting: String { return self._s[442]! } - public var TwoStepAuth_EnabledSuccess: String { return self._s[443]! } - public var Wallet_Send_SyncInProgress: String { return self._s[444]! } - public var SettingsSearch_Synonyms_Appearance_ChatBackground_SetColor: String { return self._s[445]! } + public var Message_ImageExpired: String { return self._s[439]! } + public var TwoStepAuth_RecoveryFailed: String { return self._s[441]! } + public var EditTheme_Edit_Preview_OutgoingText: String { return self._s[442]! } + public var UserInfo_AddToExisting: String { return self._s[443]! } + public var TwoStepAuth_EnabledSuccess: String { return self._s[444]! } + public var Wallet_Send_SyncInProgress: String { return self._s[445]! } + public var SettingsSearch_Synonyms_Appearance_ChatBackground_SetColor: String { return self._s[446]! } public func PUSH_CHANNEL_MESSAGE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[446]!, self._r[446]!, [_1]) + return formatWithArgumentRanges(self._s[447]!, self._r[447]!, [_1]) } - public var Notifications_GroupNotificationsAlert: String { return self._s[447]! } - public var Passport_Language_km: String { return self._s[448]! } - public var SocksProxySetup_AdNoticeHelp: String { return self._s[450]! } - public var VoiceOver_Media_PlaybackPlay: String { return self._s[451]! } - public var Notification_CallMissedShort: String { return self._s[452]! } - public var Wallet_Info_YourBalance: String { return self._s[453]! } - public var ReportPeer_ReasonOther_Send: String { return self._s[455]! } - public var Watch_Compose_Send: String { return self._s[456]! } - public var Passport_Identity_TypeInternalPassportUploadScan: String { return self._s[459]! } - public var TwoFactorSetup_Email_Action: String { return self._s[460]! } - public var Conversation_HoldForVideo: String { return self._s[461]! } - public var Wallet_Configuration_ApplyErrorTextURLInvalidData: String { return self._s[462]! } - public var AuthSessions_OtherDevices: String { return self._s[463]! } - public var Wallet_TransactionInfo_CommentHeader: String { return self._s[464]! } - public var CheckoutInfo_ErrorCityInvalid: String { return self._s[466]! } - public var Appearance_AutoNightThemeDisabled: String { return self._s[468]! } - public var Channel_LinkItem: String { return self._s[469]! } + public var Notifications_GroupNotificationsAlert: String { return self._s[448]! } + public var Passport_Language_km: String { return self._s[449]! } + public var SocksProxySetup_AdNoticeHelp: String { return self._s[451]! } + public var VoiceOver_Media_PlaybackPlay: String { return self._s[452]! } + public var Notification_CallMissedShort: String { return self._s[453]! } + public var Wallet_Info_YourBalance: String { return self._s[454]! } + public var ReportPeer_ReasonOther_Send: String { return self._s[456]! } + public var Watch_Compose_Send: String { return self._s[457]! } + public var Passport_Identity_TypeInternalPassportUploadScan: String { return self._s[460]! } + public var TwoFactorSetup_Email_Action: String { return self._s[461]! } + public var Conversation_HoldForVideo: String { return self._s[462]! } + public var Wallet_Configuration_ApplyErrorTextURLInvalidData: String { return self._s[463]! } + public var AuthSessions_OtherDevices: String { return self._s[464]! } + public var Wallet_TransactionInfo_CommentHeader: String { return self._s[465]! } + public var CheckoutInfo_ErrorCityInvalid: String { return self._s[467]! } + public var Appearance_AutoNightThemeDisabled: String { return self._s[469]! } + public var Channel_LinkItem: String { return self._s[470]! } public func PrivacySettings_LastSeenContactsMinusPlus(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[470]!, self._r[470]!, [_0, _1]) + return formatWithArgumentRanges(self._s[471]!, self._r[471]!, [_0, _1]) } public func Passport_Identity_NativeNameTitle(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[473]!, self._r[473]!, [_0]) + return formatWithArgumentRanges(self._s[474]!, self._r[474]!, [_0]) } - public var VoiceOver_Recording_StopAndPreview: String { return self._s[474]! } - public var Passport_Language_dv: String { return self._s[475]! } - public var Undo_LeftChannel: String { return self._s[476]! } - public var Notifications_ExceptionsMuted: String { return self._s[477]! } - public var ChatList_UnhideAction: String { return self._s[478]! } - public var Conversation_ContextMenuShare: String { return self._s[479]! } - public var Conversation_ContextMenuStickerPackInfo: String { return self._s[480]! } - public var ShareFileTip_Title: String { return self._s[481]! } - public var NotificationsSound_Chord: String { return self._s[482]! } - public var Wallet_TransactionInfo_OtherFeeHeader: String { return self._s[483]! } + public var VoiceOver_Recording_StopAndPreview: String { return self._s[475]! } + public var Passport_Language_dv: String { return self._s[476]! } + public var Undo_LeftChannel: String { return self._s[477]! } + public var Notifications_ExceptionsMuted: String { return self._s[478]! } + public var ChatList_UnhideAction: String { return self._s[479]! } + public var Conversation_ContextMenuShare: String { return self._s[480]! } + public var Conversation_ContextMenuStickerPackInfo: String { return self._s[481]! } + public var ShareFileTip_Title: String { return self._s[482]! } + public var NotificationsSound_Chord: String { return self._s[483]! } + public var Wallet_TransactionInfo_OtherFeeHeader: String { return self._s[484]! } public func PUSH_CHAT_RETURNED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[484]!, self._r[484]!, [_1, _2]) + return formatWithArgumentRanges(self._s[485]!, self._r[485]!, [_1, _2]) } - public var Passport_Address_EditTemporaryRegistration: String { return self._s[485]! } + public var Passport_Address_EditTemporaryRegistration: String { return self._s[486]! } public func Notification_Joined(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[486]!, self._r[486]!, [_0]) + return formatWithArgumentRanges(self._s[487]!, self._r[487]!, [_0]) } public func Wallet_Time_PreciseDate_m3(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[487]!, self._r[487]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[488]!, self._r[488]!, [_1, _2, _3]) } - public var Wallet_Settings_ConfigurationInfo: String { return self._s[488]! } - public var Wallpaper_ErrorNotFound: String { return self._s[489]! } - public var Notification_CallOutgoingShort: String { return self._s[491]! } - public var Wallet_WordImport_IncorrectText: String { return self._s[492]! } + public var Wallet_Settings_ConfigurationInfo: String { return self._s[489]! } + public var Wallpaper_ErrorNotFound: String { return self._s[490]! } + public var Notification_CallOutgoingShort: String { return self._s[492]! } + public var Wallet_WordImport_IncorrectText: String { return self._s[493]! } public func Watch_Time_ShortFullAt(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[493]!, self._r[493]!, [_1, _2]) + return formatWithArgumentRanges(self._s[494]!, self._r[494]!, [_1, _2]) } - public var Passport_Address_TypeUtilityBill: String { return self._s[494]! } - public var Privacy_Forwards_LinkIfAllowed: String { return self._s[495]! } - public var ReportPeer_Report: String { return self._s[496]! } - public var SettingsSearch_Synonyms_Proxy_Title: String { return self._s[497]! } - public var GroupInfo_DeactivatedStatus: String { return self._s[498]! } + public var Passport_Address_TypeUtilityBill: String { return self._s[495]! } + public var Privacy_Forwards_LinkIfAllowed: String { return self._s[496]! } + public var ReportPeer_Report: String { return self._s[497]! } + public var SettingsSearch_Synonyms_Proxy_Title: String { return self._s[498]! } + public var GroupInfo_DeactivatedStatus: String { return self._s[499]! } public func VoiceOver_Chat_MusicTitle(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[499]!, self._r[499]!, [_1, _2]) + return formatWithArgumentRanges(self._s[500]!, self._r[500]!, [_1, _2]) } - public var StickerPack_Send: String { return self._s[500]! } - public var Login_CodeSentInternal: String { return self._s[501]! } - public var Wallet_Month_GenJanuary: String { return self._s[502]! } - public var GroupInfo_InviteLink_LinkSection: String { return self._s[503]! } + public var StickerPack_Send: String { return self._s[501]! } + public var Login_CodeSentInternal: String { return self._s[502]! } + public var Wallet_Month_GenJanuary: String { return self._s[503]! } + public var GroupInfo_InviteLink_LinkSection: String { return self._s[504]! } public func Channel_AdminLog_MessageDeleted(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[504]!, self._r[504]!, [_0]) + return formatWithArgumentRanges(self._s[505]!, self._r[505]!, [_0]) } public func Conversation_EncryptionWaiting(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[506]!, self._r[506]!, [_0]) + return formatWithArgumentRanges(self._s[507]!, self._r[507]!, [_0]) } - public var Channel_BanUser_PermissionSendStickersAndGifs: String { return self._s[507]! } + public var Channel_BanUser_PermissionSendStickersAndGifs: String { return self._s[508]! } public func PUSH_PINNED_GAME(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[508]!, self._r[508]!, [_1]) + return formatWithArgumentRanges(self._s[509]!, self._r[509]!, [_1]) } - public var ReportPeer_ReasonViolence: String { return self._s[510]! } - public var Appearance_ShareThemeColor: String { return self._s[511]! } - public var Map_Locating: String { return self._s[512]! } + public var ReportPeer_ReasonViolence: String { return self._s[511]! } + public var Appearance_ShareThemeColor: String { return self._s[512]! } + public var Map_Locating: String { return self._s[513]! } public func VoiceOver_Chat_VideoFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[513]!, self._r[513]!, [_0]) + return formatWithArgumentRanges(self._s[514]!, self._r[514]!, [_0]) } public func PUSH_ALBUM(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[514]!, self._r[514]!, [_1]) + return formatWithArgumentRanges(self._s[515]!, self._r[515]!, [_1]) } - public var AutoDownloadSettings_GroupChats: String { return self._s[516]! } - public var CheckoutInfo_SaveInfo: String { return self._s[517]! } - public var SharedMedia_EmptyLinksText: String { return self._s[519]! } - public var Passport_Address_CityPlaceholder: String { return self._s[520]! } - public var CheckoutInfo_ErrorStateInvalid: String { return self._s[521]! } - public var Privacy_ProfilePhoto_CustomHelp: String { return self._s[522]! } - public var Wallet_Send_OwnAddressAlertTitle: String { return self._s[524]! } - public var Channel_AdminLog_CanAddAdmins: String { return self._s[525]! } + public var AutoDownloadSettings_GroupChats: String { return self._s[517]! } + public var CheckoutInfo_SaveInfo: String { return self._s[518]! } + public var SharedMedia_EmptyLinksText: String { return self._s[520]! } + public var Passport_Address_CityPlaceholder: String { return self._s[521]! } + public var CheckoutInfo_ErrorStateInvalid: String { return self._s[522]! } + public var Privacy_ProfilePhoto_CustomHelp: String { return self._s[523]! } + public var Wallet_Send_OwnAddressAlertTitle: String { return self._s[525]! } + public var Channel_AdminLog_CanAddAdmins: String { return self._s[526]! } public func PUSH_CHANNEL_MESSAGE_FWD(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[526]!, self._r[526]!, [_1]) + return formatWithArgumentRanges(self._s[527]!, self._r[527]!, [_1]) } public func Time_MonthOfYear_m8(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[527]!, self._r[527]!, [_0]) + return formatWithArgumentRanges(self._s[528]!, self._r[528]!, [_0]) } - public var InfoPlist_NSLocationWhenInUseUsageDescription: String { return self._s[528]! } - public var GroupInfo_InviteLink_RevokeAlert_Success: String { return self._s[529]! } - public var ChangePhoneNumberCode_Code: String { return self._s[530]! } - public var Appearance_CreateTheme: String { return self._s[531]! } + public var InfoPlist_NSLocationWhenInUseUsageDescription: String { return self._s[529]! } + public var GroupInfo_InviteLink_RevokeAlert_Success: String { return self._s[530]! } + public var ChangePhoneNumberCode_Code: String { return self._s[531]! } + public var Appearance_CreateTheme: String { return self._s[532]! } public func UserInfo_NotificationsDefaultSound(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[532]!, self._r[532]!, [_0]) + return formatWithArgumentRanges(self._s[533]!, self._r[533]!, [_0]) } - public var TwoStepAuth_SetupEmail: String { return self._s[533]! } - public var HashtagSearch_AllChats: String { return self._s[534]! } - public var MediaPlayer_UnknownTrack: String { return self._s[535]! } - public var SettingsSearch_Synonyms_Data_AutoDownloadUsingCellular: String { return self._s[537]! } + public var TwoStepAuth_SetupEmail: String { return self._s[534]! } + public var HashtagSearch_AllChats: String { return self._s[535]! } + public var MediaPlayer_UnknownTrack: String { return self._s[536]! } + public var SettingsSearch_Synonyms_Data_AutoDownloadUsingCellular: String { return self._s[538]! } public func ChatList_DeleteForEveryone(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[538]!, self._r[538]!, [_0]) + return formatWithArgumentRanges(self._s[539]!, self._r[539]!, [_0]) } - public var PhotoEditor_QualityHigh: String { return self._s[540]! } + public var PhotoEditor_QualityHigh: String { return self._s[541]! } public func Passport_Phone_UseTelegramNumber(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[541]!, self._r[541]!, [_0]) + return formatWithArgumentRanges(self._s[542]!, self._r[542]!, [_0]) } - public var ApplyLanguage_ApplyLanguageAction: String { return self._s[542]! } - public var SettingsSearch_Synonyms_Notifications_ChannelNotificationsPreview: String { return self._s[543]! } - public var Message_LiveLocation: String { return self._s[544]! } - public var Cache_LowDiskSpaceText: String { return self._s[545]! } - public var Wallet_Receive_ShareAddress: String { return self._s[546]! } - public var EditTheme_ErrorLinkTaken: String { return self._s[547]! } - public var Conversation_SendMessage: String { return self._s[548]! } - public var AuthSessions_EmptyTitle: String { return self._s[549]! } - public var Privacy_PhoneNumber: String { return self._s[550]! } - public var PeopleNearby_CreateGroup: String { return self._s[551]! } - public var Stats_SharesPerPost: String { return self._s[553]! } - public var CallSettings_UseLessData: String { return self._s[554]! } - public var NetworkUsageSettings_MediaDocumentDataSection: String { return self._s[555]! } - public var Stickers_AddToFavorites: String { return self._s[556]! } - public var Wallet_WordImport_Title: String { return self._s[557]! } - public var PhotoEditor_QualityLow: String { return self._s[558]! } - public var Watch_UserInfo_Unblock: String { return self._s[559]! } - public var Settings_Logout: String { return self._s[560]! } + public var ApplyLanguage_ApplyLanguageAction: String { return self._s[543]! } + public var SettingsSearch_Synonyms_Notifications_ChannelNotificationsPreview: String { return self._s[544]! } + public var Message_LiveLocation: String { return self._s[545]! } + public var Cache_LowDiskSpaceText: String { return self._s[546]! } + public var Wallet_Receive_ShareAddress: String { return self._s[547]! } + public var EditTheme_ErrorLinkTaken: String { return self._s[548]! } + public var Conversation_SendMessage: String { return self._s[549]! } + public var AuthSessions_EmptyTitle: String { return self._s[550]! } + public var Privacy_PhoneNumber: String { return self._s[551]! } + public var PeopleNearby_CreateGroup: String { return self._s[552]! } + public var Stats_SharesPerPost: String { return self._s[554]! } + public var CallSettings_UseLessData: String { return self._s[555]! } + public var NetworkUsageSettings_MediaDocumentDataSection: String { return self._s[556]! } + public var Stickers_AddToFavorites: String { return self._s[557]! } + public var Wallet_WordImport_Title: String { return self._s[558]! } + public var PhotoEditor_QualityLow: String { return self._s[559]! } + public var Watch_UserInfo_Unblock: String { return self._s[560]! } + public var Settings_Logout: String { return self._s[561]! } public func PUSH_MESSAGE_ROUND(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[561]!, self._r[561]!, [_1]) + return formatWithArgumentRanges(self._s[562]!, self._r[562]!, [_1]) } - public var ContactInfo_PhoneLabelWork: String { return self._s[562]! } - public var ChannelInfo_Stats: String { return self._s[563]! } - public var TextFormat_Link: String { return self._s[564]! } + public var ContactInfo_PhoneLabelWork: String { return self._s[563]! } + public var ChannelInfo_Stats: String { return self._s[564]! } + public var TextFormat_Link: String { return self._s[565]! } public func Date_ChatDateHeader(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[565]!, self._r[565]!, [_1, _2]) + return formatWithArgumentRanges(self._s[566]!, self._r[566]!, [_1, _2]) } - public var Wallet_TransactionInfo_Title: String { return self._s[566]! } + public var Wallet_TransactionInfo_Title: String { return self._s[567]! } public func Message_ForwardedMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[567]!, self._r[567]!, [_0]) + return formatWithArgumentRanges(self._s[568]!, self._r[568]!, [_0]) } - public var Watch_Notification_Joined: String { return self._s[568]! } - public var Group_Setup_TypePublicHelp: String { return self._s[569]! } - public var Passport_Scans_UploadNew: String { return self._s[570]! } - public var Checkout_LiabilityAlertTitle: String { return self._s[571]! } - public var DialogList_Title: String { return self._s[574]! } - public var NotificationSettings_ContactJoined: String { return self._s[575]! } - public var GroupInfo_LabelAdmin: String { return self._s[576]! } - public var KeyCommand_ChatInfo: String { return self._s[577]! } - public var Conversation_EditingCaptionPanelTitle: String { return self._s[578]! } - public var Call_ReportIncludeLog: String { return self._s[579]! } + public var Watch_Notification_Joined: String { return self._s[569]! } + public var Group_Setup_TypePublicHelp: String { return self._s[570]! } + public var Passport_Scans_UploadNew: String { return self._s[571]! } + public var Checkout_LiabilityAlertTitle: String { return self._s[572]! } + public var DialogList_Title: String { return self._s[575]! } + public var NotificationSettings_ContactJoined: String { return self._s[576]! } + public var GroupInfo_LabelAdmin: String { return self._s[577]! } + public var KeyCommand_ChatInfo: String { return self._s[578]! } + public var Conversation_EditingCaptionPanelTitle: String { return self._s[579]! } + public var Call_ReportIncludeLog: String { return self._s[580]! } public func Notifications_ExceptionsChangeSound(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[582]!, self._r[582]!, [_0]) + return formatWithArgumentRanges(self._s[583]!, self._r[583]!, [_0]) } - public var Stats_Followers: String { return self._s[583]! } - public var Channel_AdminLog_InfoPanelChannelAlertText: String { return self._s[584]! } - public var ChatAdmins_AllMembersAreAdmins: String { return self._s[585]! } - public var LocalGroup_IrrelevantWarning: String { return self._s[586]! } - public var Conversation_DefaultRestrictedInline: String { return self._s[587]! } - public var Message_Sticker: String { return self._s[588]! } - public var LastSeen_JustNow: String { return self._s[590]! } - public var Passport_Email_EmailPlaceholder: String { return self._s[592]! } - public var SettingsSearch_Synonyms_AppLanguage: String { return self._s[593]! } - public var Channel_AdminLogFilter_EventsEditedMessages: String { return self._s[594]! } - public var Channel_EditAdmin_PermissionsHeader: String { return self._s[595]! } - public var TwoStepAuth_Email: String { return self._s[596]! } - public var SettingsSearch_Synonyms_Notifications_ChannelNotificationsSound: String { return self._s[597]! } - public var PhotoEditor_BlurToolOff: String { return self._s[598]! } - public var Message_PinnedStickerMessage: String { return self._s[599]! } - public var ContactInfo_PhoneLabelPager: String { return self._s[600]! } - public var SettingsSearch_Synonyms_Appearance_TextSize: String { return self._s[601]! } - public var Passport_DiscardMessageTitle: String { return self._s[602]! } - public var Privacy_PaymentsTitle: String { return self._s[603]! } - public var EditTheme_Edit_Preview_IncomingReplyName: String { return self._s[604]! } - public var ClearCache_StorageCache: String { return self._s[605]! } - public var Appearance_TextSizeSetting: String { return self._s[606]! } - public var Channel_DiscussionGroup_Header: String { return self._s[608]! } - public var VoiceOver_Chat_OptionSelected: String { return self._s[609]! } - public var Appearance_ColorTheme: String { return self._s[610]! } - public var UserInfo_ShareContact: String { return self._s[611]! } - public var Passport_Address_TypePassportRegistration: String { return self._s[612]! } - public var Common_More: String { return self._s[613]! } - public var Watch_Message_Call: String { return self._s[614]! } - public var Profile_EncryptionKey: String { return self._s[617]! } - public var Privacy_TopPeers: String { return self._s[618]! } - public var Conversation_StopPollConfirmation: String { return self._s[619]! } - public var Wallet_Words_NotDoneText: String { return self._s[621]! } - public var Privacy_TopPeersWarning: String { return self._s[623]! } - public var SettingsSearch_Synonyms_Data_DownloadInBackground: String { return self._s[624]! } - public var SettingsSearch_Synonyms_Data_Storage_KeepMedia: String { return self._s[625]! } - public var Wallet_RestoreFailed_EnterWords: String { return self._s[628]! } - public var DialogList_SearchSectionMessages: String { return self._s[629]! } - public var Notifications_ChannelNotifications: String { return self._s[630]! } - public var CheckoutInfo_ShippingInfoAddress1Placeholder: String { return self._s[631]! } - public var Passport_Language_sk: String { return self._s[632]! } - public var Notification_MessageLifetime1h: String { return self._s[633]! } - public var Wallpaper_ResetWallpapersInfo: String { return self._s[634]! } - public var Appearance_ThemePreview_Chat_5_Text: String { return self._s[635]! } - public var Call_ReportSkip: String { return self._s[637]! } - public var Cache_ServiceFiles: String { return self._s[638]! } - public var Group_ErrorAddTooMuchAdmins: String { return self._s[639]! } - public var VoiceOver_Chat_YourFile: String { return self._s[640]! } - public var Map_Hybrid: String { return self._s[641]! } - public var Contacts_SearchUsersAndGroupsLabel: String { return self._s[643]! } + public var Stats_Followers: String { return self._s[584]! } + public var Channel_AdminLog_InfoPanelChannelAlertText: String { return self._s[585]! } + public var ChatAdmins_AllMembersAreAdmins: String { return self._s[586]! } + public var LocalGroup_IrrelevantWarning: String { return self._s[587]! } + public var Conversation_DefaultRestrictedInline: String { return self._s[588]! } + public var Message_Sticker: String { return self._s[589]! } + public var LastSeen_JustNow: String { return self._s[591]! } + public var Passport_Email_EmailPlaceholder: String { return self._s[593]! } + public var SettingsSearch_Synonyms_AppLanguage: String { return self._s[594]! } + public var Channel_AdminLogFilter_EventsEditedMessages: String { return self._s[595]! } + public var Channel_EditAdmin_PermissionsHeader: String { return self._s[596]! } + public var TwoStepAuth_Email: String { return self._s[597]! } + public var SettingsSearch_Synonyms_Notifications_ChannelNotificationsSound: String { return self._s[598]! } + public var PhotoEditor_BlurToolOff: String { return self._s[599]! } + public var Message_PinnedStickerMessage: String { return self._s[600]! } + public var ContactInfo_PhoneLabelPager: String { return self._s[601]! } + public var SettingsSearch_Synonyms_Appearance_TextSize: String { return self._s[602]! } + public var Passport_DiscardMessageTitle: String { return self._s[603]! } + public var Privacy_PaymentsTitle: String { return self._s[604]! } + public var EditTheme_Edit_Preview_IncomingReplyName: String { return self._s[605]! } + public var ClearCache_StorageCache: String { return self._s[606]! } + public var Appearance_TextSizeSetting: String { return self._s[607]! } + public var Channel_DiscussionGroup_Header: String { return self._s[609]! } + public var VoiceOver_Chat_OptionSelected: String { return self._s[610]! } + public var Appearance_ColorTheme: String { return self._s[611]! } + public var UserInfo_ShareContact: String { return self._s[612]! } + public var Passport_Address_TypePassportRegistration: String { return self._s[613]! } + public var Common_More: String { return self._s[614]! } + public var Watch_Message_Call: String { return self._s[615]! } + public var Profile_EncryptionKey: String { return self._s[618]! } + public var Privacy_TopPeers: String { return self._s[619]! } + public var Conversation_StopPollConfirmation: String { return self._s[620]! } + public var Wallet_Words_NotDoneText: String { return self._s[622]! } + public var Privacy_TopPeersWarning: String { return self._s[624]! } + public var SettingsSearch_Synonyms_Data_DownloadInBackground: String { return self._s[625]! } + public var SettingsSearch_Synonyms_Data_Storage_KeepMedia: String { return self._s[626]! } + public var Wallet_RestoreFailed_EnterWords: String { return self._s[629]! } + public var DialogList_SearchSectionMessages: String { return self._s[630]! } + public var Notifications_ChannelNotifications: String { return self._s[631]! } + public var CheckoutInfo_ShippingInfoAddress1Placeholder: String { return self._s[632]! } + public var Passport_Language_sk: String { return self._s[633]! } + public var Notification_MessageLifetime1h: String { return self._s[634]! } + public var Wallpaper_ResetWallpapersInfo: String { return self._s[635]! } + public var Appearance_ThemePreview_Chat_5_Text: String { return self._s[636]! } + public var Call_ReportSkip: String { return self._s[638]! } + public var Cache_ServiceFiles: String { return self._s[639]! } + public var Group_ErrorAddTooMuchAdmins: String { return self._s[640]! } + public var VoiceOver_Chat_YourFile: String { return self._s[641]! } + public var Map_Hybrid: String { return self._s[642]! } + public var Contacts_SearchUsersAndGroupsLabel: String { return self._s[644]! } public func PUSH_MESSAGE_QUIZ(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[644]!, self._r[644]!, [_1]) + return formatWithArgumentRanges(self._s[645]!, self._r[645]!, [_1]) } - public var ChatSettings_AutoDownloadVideos: String { return self._s[646]! } - public var Channel_BanUser_PermissionEmbedLinks: String { return self._s[647]! } - public var InfoPlist_NSLocationAlwaysAndWhenInUseUsageDescription: String { return self._s[648]! } - public var SocksProxySetup_ProxyTelegram: String { return self._s[651]! } + public var ChatSettings_AutoDownloadVideos: String { return self._s[647]! } + public var Channel_BanUser_PermissionEmbedLinks: String { return self._s[648]! } + public var InfoPlist_NSLocationAlwaysAndWhenInUseUsageDescription: String { return self._s[649]! } + public var SocksProxySetup_ProxyTelegram: String { return self._s[652]! } public func PUSH_MESSAGE_AUDIO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[652]!, self._r[652]!, [_1]) + return formatWithArgumentRanges(self._s[653]!, self._r[653]!, [_1]) } - public var Channel_Username_CreatePrivateLinkHelp: String { return self._s[654]! } - public var ScheduledMessages_ScheduledToday: String { return self._s[655]! } + public var Channel_Username_CreatePrivateLinkHelp: String { return self._s[655]! } + public var ScheduledMessages_ScheduledToday: String { return self._s[656]! } public func PUSH_CHAT_TITLE_EDITED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[656]!, self._r[656]!, [_1, _2]) + return formatWithArgumentRanges(self._s[657]!, self._r[657]!, [_1, _2]) } - public var Conversation_LiveLocationYou: String { return self._s[657]! } - public var SettingsSearch_Synonyms_Privacy_Calls: String { return self._s[658]! } - public var SettingsSearch_Synonyms_Notifications_MessageNotificationsPreview: String { return self._s[659]! } - public var UserInfo_ShareBot: String { return self._s[662]! } + public var Conversation_LiveLocationYou: String { return self._s[658]! } + public var SettingsSearch_Synonyms_Privacy_Calls: String { return self._s[659]! } + public var SettingsSearch_Synonyms_Notifications_MessageNotificationsPreview: String { return self._s[660]! } + public var UserInfo_ShareBot: String { return self._s[663]! } public func PUSH_AUTH_REGION(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[663]!, self._r[663]!, [_1, _2]) + return formatWithArgumentRanges(self._s[664]!, self._r[664]!, [_1, _2]) } - public var Conversation_ClearCache: String { return self._s[664]! } - public var PhotoEditor_ShadowsTint: String { return self._s[665]! } - public var Message_Audio: String { return self._s[666]! } - public var Passport_Language_lt: String { return self._s[667]! } + public var Conversation_ClearCache: String { return self._s[665]! } + public var PhotoEditor_ShadowsTint: String { return self._s[666]! } + public var Message_Audio: String { return self._s[667]! } + public var Passport_Language_lt: String { return self._s[668]! } public func Message_PinnedTextMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[668]!, self._r[668]!, [_0]) + return formatWithArgumentRanges(self._s[669]!, self._r[669]!, [_0]) } - public var Permissions_SiriText_v0: String { return self._s[669]! } - public var Conversation_FileICloudDrive: String { return self._s[670]! } - public var ChatList_DeleteForEveryoneConfirmationTitle: String { return self._s[671]! } - public var Notifications_Badge_IncludeMutedChats: String { return self._s[672]! } + public var Permissions_SiriText_v0: String { return self._s[670]! } + public var Conversation_FileICloudDrive: String { return self._s[671]! } + public var ChatList_DeleteForEveryoneConfirmationTitle: String { return self._s[672]! } + public var Notifications_Badge_IncludeMutedChats: String { return self._s[673]! } public func Notification_NewAuthDetected(_ _1: String, _ _2: String, _ _3: String, _ _4: String, _ _5: String, _ _6: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[673]!, self._r[673]!, [_1, _2, _3, _4, _5, _6]) + return formatWithArgumentRanges(self._s[674]!, self._r[674]!, [_1, _2, _3, _4, _5, _6]) } - public var DialogList_ProxyConnectionIssuesTooltip: String { return self._s[674]! } + public var DialogList_ProxyConnectionIssuesTooltip: String { return self._s[675]! } public func Time_MonthOfYear_m5(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[675]!, self._r[675]!, [_0]) + return formatWithArgumentRanges(self._s[676]!, self._r[676]!, [_0]) } - public var Channel_SignMessages: String { return self._s[676]! } + public var Channel_SignMessages: String { return self._s[677]! } public func PUSH_MESSAGE_NOTEXT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[677]!, self._r[677]!, [_1]) + return formatWithArgumentRanges(self._s[678]!, self._r[678]!, [_1]) } - public var Compose_ChannelTokenListPlaceholder: String { return self._s[678]! } - public var Passport_ScanPassport: String { return self._s[679]! } - public var Watch_Suggestion_Thanks: String { return self._s[680]! } - public var BlockedUsers_AddNew: String { return self._s[681]! } + public var Compose_ChannelTokenListPlaceholder: String { return self._s[679]! } + public var Passport_ScanPassport: String { return self._s[680]! } + public var Watch_Suggestion_Thanks: String { return self._s[681]! } + public var BlockedUsers_AddNew: String { return self._s[682]! } public func PUSH_CHAT_MESSAGE(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[682]!, self._r[682]!, [_1, _2]) + return formatWithArgumentRanges(self._s[683]!, self._r[683]!, [_1, _2]) } - public var Watch_Message_Invoice: String { return self._s[683]! } - public var SettingsSearch_Synonyms_Privacy_LastSeen: String { return self._s[684]! } - public var Month_GenJuly: String { return self._s[685]! } - public var CreatePoll_QuizInfo: String { return self._s[686]! } - public var UserInfo_StartSecretChatStart: String { return self._s[687]! } - public var SocksProxySetup_ProxySocks5: String { return self._s[688]! } - public var IntentsSettings_SuggestByShare: String { return self._s[690]! } - public var Notification_Exceptions_DeleteAllConfirmation: String { return self._s[691]! } - public var Notification_ChannelInviterSelf: String { return self._s[692]! } - public var CheckoutInfo_ReceiverInfoEmail: String { return self._s[693]! } + public var Watch_Message_Invoice: String { return self._s[684]! } + public var SettingsSearch_Synonyms_Privacy_LastSeen: String { return self._s[685]! } + public var Month_GenJuly: String { return self._s[686]! } + public var CreatePoll_QuizInfo: String { return self._s[687]! } + public var UserInfo_StartSecretChatStart: String { return self._s[688]! } + public var SocksProxySetup_ProxySocks5: String { return self._s[689]! } + public var IntentsSettings_SuggestByShare: String { return self._s[691]! } + public var Notification_Exceptions_DeleteAllConfirmation: String { return self._s[692]! } + public var Notification_ChannelInviterSelf: String { return self._s[693]! } + public var CheckoutInfo_ReceiverInfoEmail: String { return self._s[694]! } public func ApplyLanguage_ChangeLanguageUnofficialText(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[694]!, self._r[694]!, [_1, _2]) + return formatWithArgumentRanges(self._s[695]!, self._r[695]!, [_1, _2]) } - public var Stats_FollowersTitle: String { return self._s[695]! } - public var CheckoutInfo_Title: String { return self._s[696]! } - public var Watch_Stickers_RecentPlaceholder: String { return self._s[697]! } + public var Stats_FollowersTitle: String { return self._s[696]! } + public var CheckoutInfo_Title: String { return self._s[697]! } + public var Watch_Stickers_RecentPlaceholder: String { return self._s[698]! } public func Map_DistanceAway(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[698]!, self._r[698]!, [_0]) + return formatWithArgumentRanges(self._s[699]!, self._r[699]!, [_0]) } - public var Passport_Identity_MainPage: String { return self._s[699]! } - public var TwoStepAuth_ConfirmEmailResendCode: String { return self._s[700]! } - public var Passport_Language_de: String { return self._s[701]! } - public var PeerInfo_PaneVoice: String { return self._s[702]! } - public var Update_Title: String { return self._s[703]! } - public var ContactInfo_PhoneLabelWorkFax: String { return self._s[704]! } - public var Channel_AdminLog_BanEmbedLinks: String { return self._s[705]! } - public var Passport_Email_UseTelegramEmailHelp: String { return self._s[706]! } - public var Notifications_ChannelNotificationsPreview: String { return self._s[707]! } - public var NotificationsSound_Telegraph: String { return self._s[708]! } - public var Watch_LastSeen_ALongTimeAgo: String { return self._s[709]! } - public var ChannelMembers_WhoCanAddMembers: String { return self._s[710]! } + public var Passport_Identity_MainPage: String { return self._s[700]! } + public var TwoStepAuth_ConfirmEmailResendCode: String { return self._s[701]! } + public var Passport_Language_de: String { return self._s[702]! } + public var PeerInfo_PaneVoice: String { return self._s[703]! } + public var Update_Title: String { return self._s[704]! } + public var ContactInfo_PhoneLabelWorkFax: String { return self._s[705]! } + public var Channel_AdminLog_BanEmbedLinks: String { return self._s[706]! } + public var Passport_Email_UseTelegramEmailHelp: String { return self._s[707]! } + public var Notifications_ChannelNotificationsPreview: String { return self._s[708]! } + public var NotificationsSound_Telegraph: String { return self._s[709]! } + public var Watch_LastSeen_ALongTimeAgo: String { return self._s[710]! } + public var ChannelMembers_WhoCanAddMembers: String { return self._s[711]! } public func AutoDownloadSettings_UpTo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[711]!, self._r[711]!, [_0]) + return formatWithArgumentRanges(self._s[712]!, self._r[712]!, [_0]) } - public var ClearCache_Description: String { return self._s[712]! } - public var Stickers_SuggestAll: String { return self._s[713]! } - public var Conversation_ForwardTitle: String { return self._s[714]! } - public var Appearance_ThemePreview_ChatList_7_Name: String { return self._s[715]! } + public var ClearCache_Description: String { return self._s[713]! } + public var Stickers_SuggestAll: String { return self._s[714]! } + public var Conversation_ForwardTitle: String { return self._s[715]! } + public var Appearance_ThemePreview_ChatList_7_Name: String { return self._s[716]! } public func Notification_JoinedChannel(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[716]!, self._r[716]!, [_0]) + return formatWithArgumentRanges(self._s[717]!, self._r[717]!, [_0]) } - public var Calls_NewCall: String { return self._s[717]! } - public var Call_StatusEnded: String { return self._s[718]! } - public var AutoDownloadSettings_DataUsageLow: String { return self._s[719]! } - public var Settings_ProxyConnected: String { return self._s[720]! } - public var Channel_AdminLogFilter_EventsPinned: String { return self._s[721]! } - public var PhotoEditor_QualityVeryLow: String { return self._s[722]! } - public var Channel_AdminLogFilter_EventsDeletedMessages: String { return self._s[723]! } - public var Passport_PasswordPlaceholder: String { return self._s[724]! } - public var Message_PinnedInvoice: String { return self._s[725]! } - public var Passport_Identity_IssueDate: String { return self._s[726]! } - public var Passport_Language_pl: String { return self._s[727]! } + public var Calls_NewCall: String { return self._s[718]! } + public var Call_StatusEnded: String { return self._s[719]! } + public var AutoDownloadSettings_DataUsageLow: String { return self._s[720]! } + public var Settings_ProxyConnected: String { return self._s[721]! } + public var Channel_AdminLogFilter_EventsPinned: String { return self._s[722]! } + public var PhotoEditor_QualityVeryLow: String { return self._s[723]! } + public var Channel_AdminLogFilter_EventsDeletedMessages: String { return self._s[724]! } + public var Passport_PasswordPlaceholder: String { return self._s[725]! } + public var Message_PinnedInvoice: String { return self._s[726]! } + public var Passport_Identity_IssueDate: String { return self._s[727]! } + public var Passport_Language_pl: String { return self._s[728]! } public func ChannelInfo_ChannelForbidden(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[728]!, self._r[728]!, [_0]) + return formatWithArgumentRanges(self._s[729]!, self._r[729]!, [_0]) } - public var Call_StatusConnecting: String { return self._s[729]! } - public var SocksProxySetup_PasteFromClipboard: String { return self._s[730]! } + public var Call_StatusConnecting: String { return self._s[730]! } + public var SocksProxySetup_PasteFromClipboard: String { return self._s[731]! } public func Username_UsernameIsAvailable(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[731]!, self._r[731]!, [_0]) + return formatWithArgumentRanges(self._s[732]!, self._r[732]!, [_0]) } - public var ChatSettings_ConnectionType_UseProxy: String { return self._s[733]! } - public var Common_Edit: String { return self._s[734]! } - public var PrivacySettings_LastSeenNobody: String { return self._s[735]! } + public var ChatSettings_ConnectionType_UseProxy: String { return self._s[734]! } + public var Common_Edit: String { return self._s[735]! } + public var PrivacySettings_LastSeenNobody: String { return self._s[736]! } public func Notification_LeftChat(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[736]!, self._r[736]!, [_0]) + return formatWithArgumentRanges(self._s[737]!, self._r[737]!, [_0]) } - public var GroupInfo_ChatAdmins: String { return self._s[737]! } - public var PrivateDataSettings_Title: String { return self._s[738]! } - public var Login_CancelPhoneVerificationStop: String { return self._s[739]! } - public var ChatList_Read: String { return self._s[740]! } - public var Wallet_WordImport_Text: String { return self._s[741]! } - public var Undo_ChatClearedForBothSides: String { return self._s[742]! } - public var GroupPermission_SectionTitle: String { return self._s[743]! } - public var TwoFactorSetup_Intro_Title: String { return self._s[745]! } + public var GroupInfo_ChatAdmins: String { return self._s[738]! } + public var PrivateDataSettings_Title: String { return self._s[739]! } + public var Login_CancelPhoneVerificationStop: String { return self._s[740]! } + public var ChatList_Read: String { return self._s[741]! } + public var Wallet_WordImport_Text: String { return self._s[742]! } + public var Undo_ChatClearedForBothSides: String { return self._s[743]! } + public var GroupPermission_SectionTitle: String { return self._s[744]! } + public var TwoFactorSetup_Intro_Title: String { return self._s[746]! } public func PUSH_CHAT_LEFT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[746]!, self._r[746]!, [_1, _2]) + return formatWithArgumentRanges(self._s[747]!, self._r[747]!, [_1, _2]) } - public var Checkout_ErrorPaymentFailed: String { return self._s[747]! } - public var Update_UpdateApp: String { return self._s[748]! } - public var Group_Username_RevokeExistingUsernamesInfo: String { return self._s[749]! } - public var Settings_Appearance: String { return self._s[750]! } - public var SettingsSearch_Synonyms_Stickers_SuggestStickers: String { return self._s[754]! } - public var Watch_Location_Access: String { return self._s[755]! } - public var ShareMenu_CopyShareLink: String { return self._s[757]! } - public var TwoStepAuth_SetupHintTitle: String { return self._s[758]! } - public var Conversation_Theme: String { return self._s[760]! } + public var Checkout_ErrorPaymentFailed: String { return self._s[748]! } + public var Update_UpdateApp: String { return self._s[749]! } + public var Group_Username_RevokeExistingUsernamesInfo: String { return self._s[750]! } + public var Settings_Appearance: String { return self._s[751]! } + public var SettingsSearch_Synonyms_Stickers_SuggestStickers: String { return self._s[755]! } + public var Watch_Location_Access: String { return self._s[756]! } + public var ShareMenu_CopyShareLink: String { return self._s[758]! } + public var TwoStepAuth_SetupHintTitle: String { return self._s[759]! } + public var Conversation_Theme: String { return self._s[761]! } public func DialogList_SingleRecordingVideoMessageSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[761]!, self._r[761]!, [_0]) + return formatWithArgumentRanges(self._s[762]!, self._r[762]!, [_0]) } - public var Notifications_ClassicTones: String { return self._s[762]! } - public var Weekday_ShortWednesday: String { return self._s[763]! } - public var WallpaperPreview_SwipeColorsBottomText: String { return self._s[764]! } - public var Undo_LeftGroup: String { return self._s[767]! } - public var Wallet_RestoreFailed_Text: String { return self._s[768]! } - public var Conversation_LinkDialogCopy: String { return self._s[769]! } - public var Wallet_TransactionInfo_NoAddress: String { return self._s[771]! } - public var Wallet_Navigation_Back: String { return self._s[772]! } - public var KeyCommand_FocusOnInputField: String { return self._s[773]! } - public var Contacts_SelectAll: String { return self._s[774]! } - public var Preview_SaveToCameraRoll: String { return self._s[775]! } - public var PrivacySettings_PasscodeOff: String { return self._s[776]! } - public var Appearance_ThemePreview_ChatList_6_Name: String { return self._s[777]! } + public var Notifications_ClassicTones: String { return self._s[763]! } + public var Weekday_ShortWednesday: String { return self._s[764]! } + public var WallpaperPreview_SwipeColorsBottomText: String { return self._s[765]! } + public var Undo_LeftGroup: String { return self._s[768]! } + public var Wallet_RestoreFailed_Text: String { return self._s[769]! } + public var Conversation_LinkDialogCopy: String { return self._s[770]! } + public var Wallet_TransactionInfo_NoAddress: String { return self._s[772]! } + public var Wallet_Navigation_Back: String { return self._s[773]! } + public var KeyCommand_FocusOnInputField: String { return self._s[774]! } + public var Contacts_SelectAll: String { return self._s[775]! } + public var Preview_SaveToCameraRoll: String { return self._s[776]! } + public var PrivacySettings_PasscodeOff: String { return self._s[777]! } + public var Appearance_ThemePreview_ChatList_6_Name: String { return self._s[778]! } public func PUSH_CHANNEL_MESSAGE_QUIZ(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[778]!, self._r[778]!, [_1]) + return formatWithArgumentRanges(self._s[779]!, self._r[779]!, [_1]) } - public var Wallpaper_Title: String { return self._s[779]! } - public var Conversation_FilePhotoOrVideo: String { return self._s[780]! } - public var AccessDenied_Camera: String { return self._s[781]! } - public var Watch_Compose_CurrentLocation: String { return self._s[782]! } - public var PeerInfo_ButtonMessage: String { return self._s[784]! } - public var Channel_DiscussionGroup_MakeHistoryPublicProceed: String { return self._s[785]! } + public var Wallpaper_Title: String { return self._s[780]! } + public var Conversation_FilePhotoOrVideo: String { return self._s[781]! } + public var AccessDenied_Camera: String { return self._s[782]! } + public var Watch_Compose_CurrentLocation: String { return self._s[783]! } + public var PeerInfo_ButtonMessage: String { return self._s[785]! } + public var Channel_DiscussionGroup_MakeHistoryPublicProceed: String { return self._s[786]! } public func SecretImage_NotViewedYet(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[786]!, self._r[786]!, [_0]) + return formatWithArgumentRanges(self._s[787]!, self._r[787]!, [_0]) } - public var GroupInfo_InvitationLinkDoesNotExist: String { return self._s[787]! } - public var Passport_Language_ro: String { return self._s[788]! } - public var EditTheme_UploadNewTheme: String { return self._s[789]! } - public var CheckoutInfo_SaveInfoHelp: String { return self._s[790]! } - public var Wallet_Intro_Terms: String { return self._s[791]! } + public var GroupInfo_InvitationLinkDoesNotExist: String { return self._s[788]! } + public var Passport_Language_ro: String { return self._s[789]! } + public var EditTheme_UploadNewTheme: String { return self._s[790]! } + public var CheckoutInfo_SaveInfoHelp: String { return self._s[791]! } + public var Wallet_Intro_Terms: String { return self._s[792]! } public func Notification_SecretChatMessageScreenshot(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[792]!, self._r[792]!, [_0]) + return formatWithArgumentRanges(self._s[793]!, self._r[793]!, [_0]) } - public var Login_CancelPhoneVerification: String { return self._s[793]! } - public var State_ConnectingToProxy: String { return self._s[794]! } - public var Calls_RatingTitle: String { return self._s[795]! } - public var Generic_ErrorMoreInfo: String { return self._s[796]! } - public var ChatList_Search_ShowMore: String { return self._s[797]! } - public var Appearance_PreviewReplyText: String { return self._s[798]! } - public var CheckoutInfo_ShippingInfoPostcodePlaceholder: String { return self._s[799]! } + public var Login_CancelPhoneVerification: String { return self._s[794]! } + public var State_ConnectingToProxy: String { return self._s[795]! } + public var Calls_RatingTitle: String { return self._s[796]! } + public var Generic_ErrorMoreInfo: String { return self._s[797]! } + public var ChatList_Search_ShowMore: String { return self._s[798]! } + public var Appearance_PreviewReplyText: String { return self._s[799]! } + public var CheckoutInfo_ShippingInfoPostcodePlaceholder: String { return self._s[800]! } public func Wallet_Send_Balance(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[800]!, self._r[800]!, [_0]) + return formatWithArgumentRanges(self._s[801]!, self._r[801]!, [_0]) } - public var IntentsSettings_SuggestedChatsContacts: String { return self._s[801]! } - public var SharedMedia_CategoryLinks: String { return self._s[802]! } - public var Calls_Missed: String { return self._s[803]! } - public var Cache_Photos: String { return self._s[807]! } - public var GroupPermission_NoAddMembers: String { return self._s[808]! } - public var ScheduledMessages_Title: String { return self._s[809]! } + public var IntentsSettings_SuggestedChatsContacts: String { return self._s[802]! } + public var SharedMedia_CategoryLinks: String { return self._s[803]! } + public var Calls_Missed: String { return self._s[804]! } + public var Cache_Photos: String { return self._s[808]! } + public var GroupPermission_NoAddMembers: String { return self._s[809]! } + public var ScheduledMessages_Title: String { return self._s[810]! } public func Channel_AdminLog_MessageUnpinned(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[810]!, self._r[810]!, [_0]) + return formatWithArgumentRanges(self._s[811]!, self._r[811]!, [_0]) } - public var Conversation_ShareBotLocationConfirmationTitle: String { return self._s[811]! } - public var Settings_ProxyDisabled: String { return self._s[812]! } + public var Conversation_ShareBotLocationConfirmationTitle: String { return self._s[812]! } + public var Settings_ProxyDisabled: String { return self._s[813]! } public func Settings_ApplyProxyAlertCredentials(_ _1: String, _ _2: String, _ _3: String, _ _4: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[813]!, self._r[813]!, [_1, _2, _3, _4]) + return formatWithArgumentRanges(self._s[814]!, self._r[814]!, [_1, _2, _3, _4]) } public func Conversation_RestrictedMediaTimed(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[814]!, self._r[814]!, [_0]) + return formatWithArgumentRanges(self._s[815]!, self._r[815]!, [_0]) } - public var Stats_ViewsPerPost: String { return self._s[816]! } - public var ChatList_Context_RemoveFromRecents: String { return self._s[817]! } - public var Appearance_Title: String { return self._s[818]! } + public var Stats_ViewsPerPost: String { return self._s[817]! } + public var ChatList_Context_RemoveFromRecents: String { return self._s[818]! } + public var Appearance_Title: String { return self._s[819]! } public func Time_MonthOfYear_m2(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[820]!, self._r[820]!, [_0]) + return formatWithArgumentRanges(self._s[821]!, self._r[821]!, [_0]) } - public var Conversation_WalletRequiredText: String { return self._s[821]! } - public var StickerPacksSettings_ShowStickersButtonHelp: String { return self._s[822]! } - public var OldChannels_NoticeCreateText: String { return self._s[823]! } - public var Channel_EditMessageErrorGeneric: String { return self._s[824]! } - public var Privacy_Calls_IntegrationHelp: String { return self._s[825]! } - public var Preview_DeletePhoto: String { return self._s[826]! } - public var Appearance_AppIconFilledX: String { return self._s[827]! } - public var PrivacySettings_PrivacyTitle: String { return self._s[828]! } + public var Conversation_WalletRequiredText: String { return self._s[822]! } + public var StickerPacksSettings_ShowStickersButtonHelp: String { return self._s[823]! } + public var OldChannels_NoticeCreateText: String { return self._s[824]! } + public var Channel_EditMessageErrorGeneric: String { return self._s[825]! } + public var Privacy_Calls_IntegrationHelp: String { return self._s[826]! } + public var Preview_DeletePhoto: String { return self._s[827]! } + public var Appearance_AppIconFilledX: String { return self._s[828]! } + public var PrivacySettings_PrivacyTitle: String { return self._s[829]! } public func Conversation_BotInteractiveUrlAlert(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[829]!, self._r[829]!, [_0]) + return formatWithArgumentRanges(self._s[830]!, self._r[830]!, [_0]) } - public var Coub_TapForSound: String { return self._s[832]! } - public var Map_LocatingError: String { return self._s[833]! } - public var TwoStepAuth_EmailChangeSuccess: String { return self._s[835]! } - public var Conversation_SendMessage_SendSilently: String { return self._s[836]! } - public var VoiceOver_MessageContextOpenMessageMenu: String { return self._s[837]! } + public var Coub_TapForSound: String { return self._s[833]! } + public var Map_LocatingError: String { return self._s[834]! } + public var TwoStepAuth_EmailChangeSuccess: String { return self._s[836]! } + public var Conversation_SendMessage_SendSilently: String { return self._s[837]! } + public var VoiceOver_MessageContextOpenMessageMenu: String { return self._s[838]! } public func Wallet_Time_PreciseDate_m8(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[838]!, self._r[838]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[839]!, self._r[839]!, [_1, _2, _3]) } - public var Passport_ForgottenPassword: String { return self._s[839]! } - public var GroupInfo_InviteLink_RevokeLink: String { return self._s[840]! } - public var StickerPacksSettings_ArchivedPacks: String { return self._s[841]! } - public var Login_TermsOfServiceSignupDecline: String { return self._s[843]! } - public var Channel_Moderator_AccessLevelRevoke: String { return self._s[844]! } - public var Message_Location: String { return self._s[845]! } - public var Passport_Identity_NamePlaceholder: String { return self._s[846]! } - public var Channel_Management_Title: String { return self._s[847]! } - public var DialogList_SearchSectionDialogs: String { return self._s[849]! } - public var Compose_NewChannel_Members: String { return self._s[850]! } + public var Passport_ForgottenPassword: String { return self._s[840]! } + public var GroupInfo_InviteLink_RevokeLink: String { return self._s[841]! } + public var StickerPacksSettings_ArchivedPacks: String { return self._s[842]! } + public var Login_TermsOfServiceSignupDecline: String { return self._s[844]! } + public var Channel_Moderator_AccessLevelRevoke: String { return self._s[845]! } + public var Message_Location: String { return self._s[846]! } + public var Passport_Identity_NamePlaceholder: String { return self._s[847]! } + public var Channel_Management_Title: String { return self._s[848]! } + public var DialogList_SearchSectionDialogs: String { return self._s[850]! } + public var Compose_NewChannel_Members: String { return self._s[851]! } public func DialogList_SingleUploadingFileSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[851]!, self._r[851]!, [_0]) + return formatWithArgumentRanges(self._s[852]!, self._r[852]!, [_0]) } - public var GroupInfo_Location: String { return self._s[852]! } - public var Appearance_ThemePreview_ChatList_5_Name: String { return self._s[853]! } - public var ClearCache_Clear: String { return self._s[854]! } - public var AutoNightTheme_ScheduledFrom: String { return self._s[855]! } - public var PhotoEditor_WarmthTool: String { return self._s[856]! } - public var Passport_Language_tr: String { return self._s[857]! } + public var GroupInfo_Location: String { return self._s[853]! } + public var Appearance_ThemePreview_ChatList_5_Name: String { return self._s[854]! } + public var ClearCache_Clear: String { return self._s[855]! } + public var AutoNightTheme_ScheduledFrom: String { return self._s[856]! } + public var PhotoEditor_WarmthTool: String { return self._s[857]! } + public var Passport_Language_tr: String { return self._s[858]! } public func PUSH_MESSAGE_GAME_SCORE(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[858]!, self._r[858]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[859]!, self._r[859]!, [_1, _2, _3]) } - public var OldChannels_NoticeUpgradeText: String { return self._s[859]! } - public var Login_ResetAccountProtected_Reset: String { return self._s[861]! } - public var Watch_PhotoView_Title: String { return self._s[862]! } - public var Passport_Phone_Delete: String { return self._s[863]! } - public var Undo_ChatDeletedForBothSides: String { return self._s[864]! } - public var Conversation_EditingMessageMediaEditCurrentPhoto: String { return self._s[865]! } - public var GroupInfo_Permissions: String { return self._s[866]! } - public var PasscodeSettings_TurnPasscodeOff: String { return self._s[867]! } - public var Profile_ShareContactButton: String { return self._s[868]! } - public var ChatSettings_Other: String { return self._s[869]! } - public var UserInfo_NotificationsDisabled: String { return self._s[870]! } - public var CheckoutInfo_ShippingInfoCity: String { return self._s[871]! } - public var LastSeen_WithinAMonth: String { return self._s[872]! } - public var VoiceOver_Chat_PlayHint: String { return self._s[873]! } - public var Conversation_ReportGroupLocation: String { return self._s[874]! } - public var Conversation_EncryptionCanceled: String { return self._s[875]! } - public var MediaPicker_GroupDescription: String { return self._s[876]! } - public var WebSearch_Images: String { return self._s[877]! } + public var OldChannels_NoticeUpgradeText: String { return self._s[860]! } + public var Login_ResetAccountProtected_Reset: String { return self._s[862]! } + public var Watch_PhotoView_Title: String { return self._s[863]! } + public var Passport_Phone_Delete: String { return self._s[864]! } + public var Undo_ChatDeletedForBothSides: String { return self._s[865]! } + public var Conversation_EditingMessageMediaEditCurrentPhoto: String { return self._s[866]! } + public var GroupInfo_Permissions: String { return self._s[867]! } + public var PasscodeSettings_TurnPasscodeOff: String { return self._s[868]! } + public var Profile_ShareContactButton: String { return self._s[869]! } + public var ChatSettings_Other: String { return self._s[870]! } + public var UserInfo_NotificationsDisabled: String { return self._s[871]! } + public var CheckoutInfo_ShippingInfoCity: String { return self._s[872]! } + public var LastSeen_WithinAMonth: String { return self._s[873]! } + public var VoiceOver_Chat_PlayHint: String { return self._s[874]! } + public var Conversation_ReportGroupLocation: String { return self._s[875]! } + public var Conversation_EncryptionCanceled: String { return self._s[876]! } + public var MediaPicker_GroupDescription: String { return self._s[877]! } + public var WebSearch_Images: String { return self._s[878]! } public func Channel_Management_PromotedBy(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[878]!, self._r[878]!, [_0]) + return formatWithArgumentRanges(self._s[879]!, self._r[879]!, [_0]) } - public var Message_Photo: String { return self._s[879]! } - public var PasscodeSettings_HelpBottom: String { return self._s[880]! } - public var AutoDownloadSettings_VideosTitle: String { return self._s[881]! } - public var VoiceOver_Media_PlaybackRateChange: String { return self._s[882]! } - public var Passport_Identity_AddDriversLicense: String { return self._s[883]! } - public var TwoStepAuth_EnterPasswordPassword: String { return self._s[884]! } - public var NotificationsSound_Calypso: String { return self._s[885]! } - public var Map_Map: String { return self._s[886]! } + public var Message_Photo: String { return self._s[880]! } + public var PasscodeSettings_HelpBottom: String { return self._s[881]! } + public var AutoDownloadSettings_VideosTitle: String { return self._s[882]! } + public var VoiceOver_Media_PlaybackRateChange: String { return self._s[883]! } + public var Passport_Identity_AddDriversLicense: String { return self._s[884]! } + public var TwoStepAuth_EnterPasswordPassword: String { return self._s[885]! } + public var NotificationsSound_Calypso: String { return self._s[886]! } + public var Map_Map: String { return self._s[887]! } public func Conversation_LiveLocationYouAndOther(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[887]!, self._r[887]!, [_0]) + return formatWithArgumentRanges(self._s[888]!, self._r[888]!, [_0]) } - public var CheckoutInfo_ReceiverInfoTitle: String { return self._s[889]! } - public var ChatSettings_TextSizeUnits: String { return self._s[890]! } + public var CheckoutInfo_ReceiverInfoTitle: String { return self._s[890]! } + public var ChatSettings_TextSizeUnits: String { return self._s[891]! } public func VoiceOver_Chat_FileFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[891]!, self._r[891]!, [_0]) + return formatWithArgumentRanges(self._s[892]!, self._r[892]!, [_0]) } - public var Common_of: String { return self._s[892]! } - public var Conversation_ForwardContacts: String { return self._s[895]! } - public var IntentsSettings_SuggestByAll: String { return self._s[897]! } + public var Common_of: String { return self._s[893]! } + public var Conversation_ForwardContacts: String { return self._s[896]! } + public var IntentsSettings_SuggestByAll: String { return self._s[898]! } public func Call_AnsweringWithAccount(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[898]!, self._r[898]!, [_0]) + return formatWithArgumentRanges(self._s[899]!, self._r[899]!, [_0]) } - public var Passport_Language_hy: String { return self._s[899]! } - public var Notifications_MessageNotificationsHelp: String { return self._s[900]! } - public var AutoDownloadSettings_Reset: String { return self._s[901]! } - public var Wallet_TransactionInfo_AddressCopied: String { return self._s[902]! } - public var Paint_ClearConfirm: String { return self._s[903]! } - public var Camera_VideoMode: String { return self._s[904]! } + public var Passport_Language_hy: String { return self._s[900]! } + public var Notifications_MessageNotificationsHelp: String { return self._s[901]! } + public var AutoDownloadSettings_Reset: String { return self._s[902]! } + public var Wallet_TransactionInfo_AddressCopied: String { return self._s[903]! } + public var Paint_ClearConfirm: String { return self._s[904]! } + public var Camera_VideoMode: String { return self._s[905]! } public func Conversation_RestrictedStickersTimed(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[905]!, self._r[905]!, [_0]) + return formatWithArgumentRanges(self._s[906]!, self._r[906]!, [_0]) } - public var Privacy_Calls_AlwaysAllow_Placeholder: String { return self._s[906]! } - public var Conversation_ViewBackground: String { return self._s[907]! } + public var Privacy_Calls_AlwaysAllow_Placeholder: String { return self._s[907]! } + public var Conversation_ViewBackground: String { return self._s[908]! } public func Wallet_Info_TransactionDateHeaderYear(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[908]!, self._r[908]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[909]!, self._r[909]!, [_1, _2, _3]) } - public var Passport_Language_el: String { return self._s[909]! } - public var PhotoEditor_Original: String { return self._s[910]! } - public var Settings_FAQ_Button: String { return self._s[912]! } - public var Channel_Setup_PublicNoLink: String { return self._s[914]! } - public var Conversation_UnsupportedMedia: String { return self._s[915]! } - public var Conversation_SlideToCancel: String { return self._s[916]! } - public var Appearance_ThemePreview_ChatList_4_Name: String { return self._s[917]! } - public var Passport_Identity_OneOfTypeInternalPassport: String { return self._s[918]! } - public var CheckoutInfo_ShippingInfoPostcode: String { return self._s[919]! } - public var Conversation_ReportSpamChannelConfirmation: String { return self._s[920]! } - public var AutoNightTheme_NotAvailable: String { return self._s[921]! } - public var Conversation_Owner: String { return self._s[922]! } - public var Common_Create: String { return self._s[923]! } - public var Settings_ApplyProxyAlertEnable: String { return self._s[924]! } - public var ContactList_Context_Call: String { return self._s[925]! } - public var Localization_ChooseLanguage: String { return self._s[927]! } - public var ChatList_Context_AddToContacts: String { return self._s[929]! } - public var OldChannels_NoticeTitle: String { return self._s[930]! } - public var Settings_Proxy: String { return self._s[932]! } - public var Privacy_TopPeersHelp: String { return self._s[933]! } - public var CheckoutInfo_ShippingInfoCountryPlaceholder: String { return self._s[934]! } - public var Chat_UnsendMyMessages: String { return self._s[935]! } + public var Passport_Language_el: String { return self._s[910]! } + public var PhotoEditor_Original: String { return self._s[911]! } + public var Settings_FAQ_Button: String { return self._s[913]! } + public var Channel_Setup_PublicNoLink: String { return self._s[915]! } + public var Conversation_UnsupportedMedia: String { return self._s[916]! } + public var Conversation_SlideToCancel: String { return self._s[917]! } + public var Appearance_ThemePreview_ChatList_4_Name: String { return self._s[918]! } + public var Passport_Identity_OneOfTypeInternalPassport: String { return self._s[919]! } + public var CheckoutInfo_ShippingInfoPostcode: String { return self._s[920]! } + public var Conversation_ReportSpamChannelConfirmation: String { return self._s[921]! } + public var AutoNightTheme_NotAvailable: String { return self._s[922]! } + public var Conversation_Owner: String { return self._s[923]! } + public var Common_Create: String { return self._s[924]! } + public var Settings_ApplyProxyAlertEnable: String { return self._s[925]! } + public var ContactList_Context_Call: String { return self._s[926]! } + public var Localization_ChooseLanguage: String { return self._s[928]! } + public var ChatList_Context_AddToContacts: String { return self._s[930]! } + public var OldChannels_NoticeTitle: String { return self._s[931]! } + public var Settings_Proxy: String { return self._s[933]! } + public var Privacy_TopPeersHelp: String { return self._s[934]! } + public var CheckoutInfo_ShippingInfoCountryPlaceholder: String { return self._s[935]! } + public var Chat_UnsendMyMessages: String { return self._s[936]! } public func VoiceOver_Chat_Duration(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[936]!, self._r[936]!, [_0]) + return formatWithArgumentRanges(self._s[937]!, self._r[937]!, [_0]) } - public var TwoStepAuth_ConfirmationAbort: String { return self._s[937]! } + public var TwoStepAuth_ConfirmationAbort: String { return self._s[938]! } public func Contacts_AccessDeniedHelpPortrait(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[939]!, self._r[939]!, [_0]) + return formatWithArgumentRanges(self._s[940]!, self._r[940]!, [_0]) } - public var Contacts_SortedByPresence: String { return self._s[940]! } - public var Passport_Identity_SurnamePlaceholder: String { return self._s[941]! } - public var Cache_Title: String { return self._s[942]! } + public var Contacts_SortedByPresence: String { return self._s[941]! } + public var Passport_Identity_SurnamePlaceholder: String { return self._s[942]! } + public var Cache_Title: String { return self._s[943]! } public func Login_PhoneBannedEmailSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[943]!, self._r[943]!, [_0]) + return formatWithArgumentRanges(self._s[944]!, self._r[944]!, [_0]) } - public var TwoStepAuth_EmailCodeExpired: String { return self._s[944]! } - public var Channel_Moderator_Title: String { return self._s[945]! } - public var InstantPage_AutoNightTheme: String { return self._s[947]! } + public var TwoStepAuth_EmailCodeExpired: String { return self._s[945]! } + public var Channel_Moderator_Title: String { return self._s[946]! } + public var InstantPage_AutoNightTheme: String { return self._s[948]! } public func PUSH_MESSAGE_POLL(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[950]!, self._r[950]!, [_1]) + return formatWithArgumentRanges(self._s[951]!, self._r[951]!, [_1]) } - public var Passport_Scans_Upload: String { return self._s[951]! } - public var Undo_Undo: String { return self._s[953]! } - public var Contacts_AccessDeniedHelpON: String { return self._s[954]! } - public var TwoStepAuth_RemovePassword: String { return self._s[955]! } - public var Common_Delete: String { return self._s[956]! } - public var Contacts_AddPeopleNearby: String { return self._s[958]! } - public var Conversation_ContextMenuDelete: String { return self._s[959]! } - public var SocksProxySetup_Credentials: String { return self._s[960]! } - public var Appearance_EditTheme: String { return self._s[962]! } - public var ClearCache_StorageOtherApps: String { return self._s[963]! } - public var PasscodeSettings_AutoLock_Disabled: String { return self._s[964]! } - public var Wallet_Send_NetworkErrorText: String { return self._s[965]! } - public var AuthSessions_DevicesTitle: String { return self._s[967]! } - public var Passport_Address_OneOfTypeRentalAgreement: String { return self._s[969]! } - public var Conversation_ShareBotContactConfirmationTitle: String { return self._s[970]! } - public var Passport_Language_id: String { return self._s[972]! } - public var WallpaperSearch_ColorTeal: String { return self._s[973]! } - public var ChannelIntro_Title: String { return self._s[974]! } + public var Passport_Scans_Upload: String { return self._s[952]! } + public var Undo_Undo: String { return self._s[954]! } + public var Contacts_AccessDeniedHelpON: String { return self._s[955]! } + public var TwoStepAuth_RemovePassword: String { return self._s[956]! } + public var Common_Delete: String { return self._s[957]! } + public var Contacts_AddPeopleNearby: String { return self._s[959]! } + public var Conversation_ContextMenuDelete: String { return self._s[960]! } + public var SocksProxySetup_Credentials: String { return self._s[961]! } + public var Appearance_EditTheme: String { return self._s[963]! } + public var ClearCache_StorageOtherApps: String { return self._s[964]! } + public var PasscodeSettings_AutoLock_Disabled: String { return self._s[965]! } + public var Wallet_Send_NetworkErrorText: String { return self._s[966]! } + public var AuthSessions_DevicesTitle: String { return self._s[968]! } + public var Passport_Address_OneOfTypeRentalAgreement: String { return self._s[970]! } + public var Conversation_ShareBotContactConfirmationTitle: String { return self._s[971]! } + public var Passport_Language_id: String { return self._s[973]! } + public var WallpaperSearch_ColorTeal: String { return self._s[974]! } + public var ChannelIntro_Title: String { return self._s[975]! } public func Channel_AdminLog_MessageToggleSignaturesOff(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[975]!, self._r[975]!, [_0]) + return formatWithArgumentRanges(self._s[976]!, self._r[976]!, [_0]) } - public var VoiceOver_Chat_OpenLinkHint: String { return self._s[977]! } - public var VoiceOver_Chat_Reply: String { return self._s[978]! } - public var ScheduledMessages_BotActionUnavailable: String { return self._s[979]! } - public var Channel_Info_Description: String { return self._s[980]! } - public var Stickers_FavoriteStickers: String { return self._s[981]! } - public var Channel_BanUser_PermissionAddMembers: String { return self._s[982]! } - public var Notifications_DisplayNamesOnLockScreen: String { return self._s[983]! } - public var ChatSearch_ResultsTooltip: String { return self._s[984]! } - public var Wallet_VoiceOver_Editing_ClearText: String { return self._s[985]! } - public var Calls_NoMissedCallsPlacehoder: String { return self._s[986]! } - public var Group_PublicLink_Placeholder: String { return self._s[987]! } - public var Notifications_ExceptionsDefaultSound: String { return self._s[988]! } + public var VoiceOver_Chat_OpenLinkHint: String { return self._s[978]! } + public var VoiceOver_Chat_Reply: String { return self._s[979]! } + public var ScheduledMessages_BotActionUnavailable: String { return self._s[980]! } + public var Channel_Info_Description: String { return self._s[981]! } + public var Stickers_FavoriteStickers: String { return self._s[982]! } + public var Channel_BanUser_PermissionAddMembers: String { return self._s[983]! } + public var Notifications_DisplayNamesOnLockScreen: String { return self._s[984]! } + public var ChatSearch_ResultsTooltip: String { return self._s[985]! } + public var Wallet_VoiceOver_Editing_ClearText: String { return self._s[986]! } + public var Calls_NoMissedCallsPlacehoder: String { return self._s[987]! } + public var Group_PublicLink_Placeholder: String { return self._s[988]! } + public var Notifications_ExceptionsDefaultSound: String { return self._s[989]! } public func PUSH_CHANNEL_MESSAGE_POLL(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[989]!, self._r[989]!, [_1]) + return formatWithArgumentRanges(self._s[990]!, self._r[990]!, [_1]) } - public var TextFormat_Underline: String { return self._s[990]! } + public var TextFormat_Underline: String { return self._s[991]! } public func DialogList_SearchSubtitleFormat(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[992]!, self._r[992]!, [_1, _2]) + return formatWithArgumentRanges(self._s[993]!, self._r[993]!, [_1, _2]) } public func Channel_AdminLog_MessageRemovedGroupStickerPack(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[993]!, self._r[993]!, [_0]) + return formatWithArgumentRanges(self._s[994]!, self._r[994]!, [_0]) } - public var Appearance_ThemePreview_ChatList_3_Name: String { return self._s[994]! } + public var Appearance_ThemePreview_ChatList_3_Name: String { return self._s[995]! } public func Channel_OwnershipTransfer_TransferCompleted(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[995]!, self._r[995]!, [_1, _2]) + return formatWithArgumentRanges(self._s[996]!, self._r[996]!, [_1, _2]) } - public var Wallet_Intro_ImportExisting: String { return self._s[996]! } - public var GroupPermission_Delete: String { return self._s[997]! } - public var Passport_Language_uk: String { return self._s[998]! } - public var StickerPack_HideStickers: String { return self._s[1000]! } - public var ChangePhoneNumberNumber_NumberPlaceholder: String { return self._s[1001]! } + public var Wallet_Intro_ImportExisting: String { return self._s[997]! } + public var GroupPermission_Delete: String { return self._s[998]! } + public var Passport_Language_uk: String { return self._s[999]! } + public var StickerPack_HideStickers: String { return self._s[1001]! } + public var ChangePhoneNumberNumber_NumberPlaceholder: String { return self._s[1002]! } public func PUSH_CHAT_MESSAGE_PHOTO(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1002]!, self._r[1002]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1003]!, self._r[1003]!, [_1, _2]) } - public var Activity_UploadingVideoMessage: String { return self._s[1003]! } + public var Activity_UploadingVideoMessage: String { return self._s[1004]! } public func GroupPermission_ApplyAlertText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1004]!, self._r[1004]!, [_0]) + return formatWithArgumentRanges(self._s[1005]!, self._r[1005]!, [_0]) } - public var Channel_TitleInfo: String { return self._s[1005]! } - public var StickerPacksSettings_ArchivedPacks_Info: String { return self._s[1006]! } - public var Settings_CallSettings: String { return self._s[1007]! } - public var Camera_SquareMode: String { return self._s[1008]! } - public var Conversation_SendMessage_ScheduleMessage: String { return self._s[1009]! } - public var GroupInfo_SharedMediaNone: String { return self._s[1010]! } + public var Channel_TitleInfo: String { return self._s[1006]! } + public var StickerPacksSettings_ArchivedPacks_Info: String { return self._s[1007]! } + public var Settings_CallSettings: String { return self._s[1008]! } + public var Camera_SquareMode: String { return self._s[1009]! } + public var Conversation_SendMessage_ScheduleMessage: String { return self._s[1010]! } + public var GroupInfo_SharedMediaNone: String { return self._s[1011]! } public func PUSH_MESSAGE_VIDEO_SECRET(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1011]!, self._r[1011]!, [_1]) + return formatWithArgumentRanges(self._s[1012]!, self._r[1012]!, [_1]) } - public var Bot_GenericBotStatus: String { return self._s[1012]! } - public var Application_Update: String { return self._s[1014]! } - public var Month_ShortJanuary: String { return self._s[1015]! } - public var Contacts_PermissionsKeepDisabled: String { return self._s[1016]! } - public var Channel_AdminLog_BanReadMessages: String { return self._s[1017]! } - public var Settings_AppLanguage_Unofficial: String { return self._s[1018]! } - public var Passport_Address_Street2Placeholder: String { return self._s[1019]! } + public var Bot_GenericBotStatus: String { return self._s[1013]! } + public var Application_Update: String { return self._s[1015]! } + public var Month_ShortJanuary: String { return self._s[1016]! } + public var Contacts_PermissionsKeepDisabled: String { return self._s[1017]! } + public var Channel_AdminLog_BanReadMessages: String { return self._s[1018]! } + public var Settings_AppLanguage_Unofficial: String { return self._s[1019]! } + public var Passport_Address_Street2Placeholder: String { return self._s[1020]! } public func Map_LiveLocationShortHour(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1020]!, self._r[1020]!, [_0]) + return formatWithArgumentRanges(self._s[1021]!, self._r[1021]!, [_0]) } - public var NetworkUsageSettings_Cellular: String { return self._s[1021]! } - public var Appearance_PreviewOutgoingText: String { return self._s[1022]! } + public var NetworkUsageSettings_Cellular: String { return self._s[1022]! } + public var Appearance_PreviewOutgoingText: String { return self._s[1023]! } public func StickerPackActionInfo_RemovedText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1023]!, self._r[1023]!, [_0]) + return formatWithArgumentRanges(self._s[1024]!, self._r[1024]!, [_0]) } - public var Notifications_PermissionsAllowInSettings: String { return self._s[1024]! } - public var AutoDownloadSettings_OnForAll: String { return self._s[1026]! } - public var Map_Directions: String { return self._s[1027]! } - public var Passport_FieldIdentityTranslationHelp: String { return self._s[1029]! } - public var Appearance_ThemeDay: String { return self._s[1030]! } - public var LogoutOptions_LogOut: String { return self._s[1031]! } - public var Group_PublicLink_Title: String { return self._s[1033]! } - public var Channel_AddBotErrorNoRights: String { return self._s[1034]! } - public var ChatList_Search_ShowLess: String { return self._s[1035]! } - public var Passport_Identity_AddPassport: String { return self._s[1036]! } - public var LocalGroup_ButtonTitle: String { return self._s[1037]! } - public var Stats_InteractionsTitle: String { return self._s[1038]! } - public var Call_Message: String { return self._s[1039]! } - public var PhotoEditor_ExposureTool: String { return self._s[1040]! } - public var Wallet_Receive_CommentInfo: String { return self._s[1042]! } - public var Passport_FieldOneOf_Delimeter: String { return self._s[1043]! } - public var Channel_AdminLog_CanBanUsers: String { return self._s[1045]! } - public var Appearance_ThemePreview_ChatList_2_Name: String { return self._s[1046]! } - public var Appearance_Preview: String { return self._s[1047]! } - public var Compose_ChannelMembers: String { return self._s[1048]! } - public var Conversation_DeleteManyMessages: String { return self._s[1049]! } - public var ReportPeer_ReasonOther_Title: String { return self._s[1050]! } - public var Checkout_ErrorProviderAccountTimeout: String { return self._s[1051]! } - public var TwoStepAuth_ResetAccountConfirmation: String { return self._s[1052]! } - public var Channel_Stickers_CreateYourOwn: String { return self._s[1055]! } - public var Conversation_UpdateTelegram: String { return self._s[1056]! } - public var EditTheme_Create_TopInfo: String { return self._s[1057]! } + public var Notifications_PermissionsAllowInSettings: String { return self._s[1025]! } + public var AutoDownloadSettings_OnForAll: String { return self._s[1027]! } + public var Map_Directions: String { return self._s[1028]! } + public var Passport_FieldIdentityTranslationHelp: String { return self._s[1030]! } + public var Appearance_ThemeDay: String { return self._s[1031]! } + public var LogoutOptions_LogOut: String { return self._s[1032]! } + public var Group_PublicLink_Title: String { return self._s[1034]! } + public var Channel_AddBotErrorNoRights: String { return self._s[1035]! } + public var ChatList_Search_ShowLess: String { return self._s[1036]! } + public var Passport_Identity_AddPassport: String { return self._s[1037]! } + public var LocalGroup_ButtonTitle: String { return self._s[1038]! } + public var Stats_InteractionsTitle: String { return self._s[1039]! } + public var Call_Message: String { return self._s[1040]! } + public var PhotoEditor_ExposureTool: String { return self._s[1041]! } + public var Wallet_Receive_CommentInfo: String { return self._s[1043]! } + public var Passport_FieldOneOf_Delimeter: String { return self._s[1044]! } + public var Channel_AdminLog_CanBanUsers: String { return self._s[1046]! } + public var Appearance_ThemePreview_ChatList_2_Name: String { return self._s[1047]! } + public var Appearance_Preview: String { return self._s[1048]! } + public var Compose_ChannelMembers: String { return self._s[1049]! } + public var Conversation_DeleteManyMessages: String { return self._s[1050]! } + public var ReportPeer_ReasonOther_Title: String { return self._s[1051]! } + public var Checkout_ErrorProviderAccountTimeout: String { return self._s[1052]! } + public var TwoStepAuth_ResetAccountConfirmation: String { return self._s[1053]! } + public var Channel_Stickers_CreateYourOwn: String { return self._s[1056]! } + public var Conversation_UpdateTelegram: String { return self._s[1057]! } + public var EditTheme_Create_TopInfo: String { return self._s[1058]! } public func Notification_PinnedPhotoMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1058]!, self._r[1058]!, [_0]) + return formatWithArgumentRanges(self._s[1059]!, self._r[1059]!, [_0]) } - public var Wallet_WordCheck_Continue: String { return self._s[1059]! } - public var TwoFactorSetup_Hint_Action: String { return self._s[1060]! } - public var IntentsSettings_ResetAll: String { return self._s[1061]! } + public var Wallet_WordCheck_Continue: String { return self._s[1060]! } + public var TwoFactorSetup_Hint_Action: String { return self._s[1061]! } + public var IntentsSettings_ResetAll: String { return self._s[1062]! } public func PUSH_PINNED_GIF(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1062]!, self._r[1062]!, [_1]) + return formatWithArgumentRanges(self._s[1063]!, self._r[1063]!, [_1]) } - public var GroupInfo_Administrators_Title: String { return self._s[1063]! } - public var Privacy_Forwards_PreviewMessageText: String { return self._s[1064]! } + public var GroupInfo_Administrators_Title: String { return self._s[1064]! } + public var Privacy_Forwards_PreviewMessageText: String { return self._s[1065]! } public func PrivacySettings_LastSeenNobodyPlus(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1065]!, self._r[1065]!, [_0]) + return formatWithArgumentRanges(self._s[1066]!, self._r[1066]!, [_0]) } - public var Tour_Title3: String { return self._s[1066]! } - public var Channel_EditAdmin_PermissionInviteSubscribers: String { return self._s[1067]! } - public var Clipboard_SendPhoto: String { return self._s[1071]! } - public var MediaPicker_Videos: String { return self._s[1072]! } - public var Passport_Email_Title: String { return self._s[1073]! } + public var Tour_Title3: String { return self._s[1067]! } + public var Channel_EditAdmin_PermissionInviteSubscribers: String { return self._s[1068]! } + public var Clipboard_SendPhoto: String { return self._s[1072]! } + public var MediaPicker_Videos: String { return self._s[1073]! } + public var Passport_Email_Title: String { return self._s[1074]! } public func PrivacySettings_LastSeenEverybodyMinus(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1074]!, self._r[1074]!, [_0]) + return formatWithArgumentRanges(self._s[1075]!, self._r[1075]!, [_0]) } - public var StickerPacksSettings_Title: String { return self._s[1075]! } - public var Conversation_MessageDialogDelete: String { return self._s[1076]! } - public var Privacy_Calls_CustomHelp: String { return self._s[1078]! } - public var Message_Wallpaper: String { return self._s[1079]! } - public var MemberSearch_BotSection: String { return self._s[1080]! } - public var GroupInfo_SetSound: String { return self._s[1081]! } + public var StickerPacksSettings_Title: String { return self._s[1076]! } + public var Conversation_MessageDialogDelete: String { return self._s[1077]! } + public var Privacy_Calls_CustomHelp: String { return self._s[1079]! } + public var Message_Wallpaper: String { return self._s[1080]! } + public var MemberSearch_BotSection: String { return self._s[1081]! } + public var GroupInfo_SetSound: String { return self._s[1082]! } public func Time_TomorrowAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1082]!, self._r[1082]!, [_0]) + return formatWithArgumentRanges(self._s[1083]!, self._r[1083]!, [_0]) } - public var Core_ServiceUserStatus: String { return self._s[1083]! } - public var LiveLocationUpdated_JustNow: String { return self._s[1084]! } - public var Call_StatusFailed: String { return self._s[1085]! } - public var TwoFactorSetup_Email_Placeholder: String { return self._s[1086]! } - public var TwoStepAuth_SetupPasswordDescription: String { return self._s[1087]! } - public var TwoStepAuth_SetPassword: String { return self._s[1088]! } - public var Permissions_PeopleNearbyText_v0: String { return self._s[1089]! } + public var Core_ServiceUserStatus: String { return self._s[1084]! } + public var LiveLocationUpdated_JustNow: String { return self._s[1085]! } + public var Call_StatusFailed: String { return self._s[1086]! } + public var TwoFactorSetup_Email_Placeholder: String { return self._s[1087]! } + public var TwoStepAuth_SetupPasswordDescription: String { return self._s[1088]! } + public var TwoStepAuth_SetPassword: String { return self._s[1089]! } + public var Permissions_PeopleNearbyText_v0: String { return self._s[1090]! } public func SocksProxySetup_ProxyStatusPing(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1091]!, self._r[1091]!, [_0]) + return formatWithArgumentRanges(self._s[1092]!, self._r[1092]!, [_0]) } - public var Calls_SubmitRating: String { return self._s[1092]! } - public var Map_NoPlacesNearby: String { return self._s[1093]! } - public var Profile_Username: String { return self._s[1094]! } - public var Bot_DescriptionTitle: String { return self._s[1095]! } - public var MaskStickerSettings_Title: String { return self._s[1096]! } - public var SharedMedia_CategoryOther: String { return self._s[1097]! } - public var GroupInfo_SetGroupPhoto: String { return self._s[1098]! } - public var Common_NotNow: String { return self._s[1099]! } - public var CallFeedback_IncludeLogsInfo: String { return self._s[1100]! } - public var Conversation_ShareMyPhoneNumber: String { return self._s[1101]! } - public var Map_Location: String { return self._s[1102]! } - public var Invitation_JoinGroup: String { return self._s[1103]! } - public var AutoDownloadSettings_Title: String { return self._s[1105]! } - public var Conversation_DiscardVoiceMessageDescription: String { return self._s[1106]! } - public var Channel_ErrorAddBlocked: String { return self._s[1107]! } - public var Conversation_UnblockUser: String { return self._s[1108]! } - public var EditTheme_Edit_TopInfo: String { return self._s[1109]! } - public var Watch_Bot_Restart: String { return self._s[1110]! } - public var TwoStepAuth_Title: String { return self._s[1111]! } - public var Channel_AdminLog_BanSendMessages: String { return self._s[1112]! } - public var Checkout_ShippingMethod: String { return self._s[1113]! } - public var Passport_Identity_OneOfTypeIdentityCard: String { return self._s[1114]! } + public var Calls_SubmitRating: String { return self._s[1093]! } + public var Map_NoPlacesNearby: String { return self._s[1094]! } + public var Profile_Username: String { return self._s[1095]! } + public var Bot_DescriptionTitle: String { return self._s[1096]! } + public var MaskStickerSettings_Title: String { return self._s[1097]! } + public var SharedMedia_CategoryOther: String { return self._s[1098]! } + public var GroupInfo_SetGroupPhoto: String { return self._s[1099]! } + public var Common_NotNow: String { return self._s[1100]! } + public var CallFeedback_IncludeLogsInfo: String { return self._s[1101]! } + public var Conversation_ShareMyPhoneNumber: String { return self._s[1102]! } + public var Map_Location: String { return self._s[1103]! } + public var Invitation_JoinGroup: String { return self._s[1104]! } + public var AutoDownloadSettings_Title: String { return self._s[1106]! } + public var Conversation_DiscardVoiceMessageDescription: String { return self._s[1107]! } + public var Channel_ErrorAddBlocked: String { return self._s[1108]! } + public var Conversation_UnblockUser: String { return self._s[1109]! } + public var EditTheme_Edit_TopInfo: String { return self._s[1110]! } + public var Watch_Bot_Restart: String { return self._s[1111]! } + public var TwoStepAuth_Title: String { return self._s[1112]! } + public var Channel_AdminLog_BanSendMessages: String { return self._s[1113]! } + public var Checkout_ShippingMethod: String { return self._s[1114]! } + public var Passport_Identity_OneOfTypeIdentityCard: String { return self._s[1115]! } public func PUSH_CHAT_MESSAGE_STICKER(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1115]!, self._r[1115]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1116]!, self._r[1116]!, [_1, _2, _3]) } - public var PeerInfo_ButtonDiscuss: String { return self._s[1116]! } - public var EditTheme_ChangeColors: String { return self._s[1118]! } + public var PeerInfo_ButtonDiscuss: String { return self._s[1117]! } + public var EditTheme_ChangeColors: String { return self._s[1119]! } public func Chat_UnsendMyMessagesAlertTitle(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1119]!, self._r[1119]!, [_0]) - } - public func Channel_Username_LinkHint(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[1120]!, self._r[1120]!, [_0]) } - public var Appearance_ThemePreview_ChatList_1_Name: String { return self._s[1121]! } - public var SettingsSearch_Synonyms_Data_AutoplayGifs: String { return self._s[1122]! } - public var AuthSessions_TerminateOtherSessions: String { return self._s[1123]! } - public var Contacts_FailedToSendInvitesMessage: String { return self._s[1124]! } - public var PrivacySettings_TwoStepAuth: String { return self._s[1125]! } - public var Notification_Exceptions_PreviewAlwaysOn: String { return self._s[1126]! } - public var SettingsSearch_Synonyms_Privacy_Passcode: String { return self._s[1127]! } - public var Conversation_EditingMessagePanelMedia: String { return self._s[1128]! } - public var Checkout_PaymentMethod_Title: String { return self._s[1129]! } - public var SocksProxySetup_Connection: String { return self._s[1130]! } - public var Group_MessagePhotoRemoved: String { return self._s[1131]! } - public var PeopleNearby_MakeInvisible: String { return self._s[1133]! } - public var Channel_Stickers_NotFound: String { return self._s[1135]! } - public var Group_About_Help: String { return self._s[1136]! } - public var Notification_PassportValueProofOfIdentity: String { return self._s[1137]! } - public var PeopleNearby_Title: String { return self._s[1139]! } - public func ApplyLanguage_ChangeLanguageOfficialText(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1140]!, self._r[1140]!, [_1]) + public func Channel_Username_LinkHint(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1121]!, self._r[1121]!, [_0]) } - public var Map_Home: String { return self._s[1141]! } - public var CheckoutInfo_ShippingInfoStatePlaceholder: String { return self._s[1143]! } - public var Notifications_GroupNotificationsExceptionsHelp: String { return self._s[1144]! } - public var SocksProxySetup_Password: String { return self._s[1145]! } - public var Notifications_PermissionsEnable: String { return self._s[1146]! } - public var TwoStepAuth_ChangeEmail: String { return self._s[1148]! } + public var Appearance_ThemePreview_ChatList_1_Name: String { return self._s[1122]! } + public var SettingsSearch_Synonyms_Data_AutoplayGifs: String { return self._s[1123]! } + public var AuthSessions_TerminateOtherSessions: String { return self._s[1124]! } + public var Contacts_FailedToSendInvitesMessage: String { return self._s[1125]! } + public var PrivacySettings_TwoStepAuth: String { return self._s[1126]! } + public var Notification_Exceptions_PreviewAlwaysOn: String { return self._s[1127]! } + public var SettingsSearch_Synonyms_Privacy_Passcode: String { return self._s[1128]! } + public var Conversation_EditingMessagePanelMedia: String { return self._s[1129]! } + public var Checkout_PaymentMethod_Title: String { return self._s[1130]! } + public var SocksProxySetup_Connection: String { return self._s[1131]! } + public var Group_MessagePhotoRemoved: String { return self._s[1132]! } + public var PeopleNearby_MakeInvisible: String { return self._s[1134]! } + public var Channel_Stickers_NotFound: String { return self._s[1136]! } + public var Group_About_Help: String { return self._s[1137]! } + public var Notification_PassportValueProofOfIdentity: String { return self._s[1138]! } + public var PeopleNearby_Title: String { return self._s[1140]! } + public func ApplyLanguage_ChangeLanguageOfficialText(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1141]!, self._r[1141]!, [_1]) + } + public var Map_Home: String { return self._s[1142]! } + public var CheckoutInfo_ShippingInfoStatePlaceholder: String { return self._s[1144]! } + public var Notifications_GroupNotificationsExceptionsHelp: String { return self._s[1145]! } + public var SocksProxySetup_Password: String { return self._s[1146]! } + public var Notifications_PermissionsEnable: String { return self._s[1147]! } + public var TwoStepAuth_ChangeEmail: String { return self._s[1149]! } public func Channel_AdminLog_MessageInvitedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1149]!, self._r[1149]!, [_1]) + return formatWithArgumentRanges(self._s[1150]!, self._r[1150]!, [_1]) } public func Time_MonthOfYear_m10(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1151]!, self._r[1151]!, [_0]) + return formatWithArgumentRanges(self._s[1152]!, self._r[1152]!, [_0]) } - public var Passport_Identity_TypeDriversLicense: String { return self._s[1152]! } - public var ArchivedPacksAlert_Title: String { return self._s[1153]! } - public var Wallet_Receive_InvoiceUrlCopied: String { return self._s[1154]! } - public var Map_PlacesNearby: String { return self._s[1155]! } + public var Passport_Identity_TypeDriversLicense: String { return self._s[1153]! } + public var ArchivedPacksAlert_Title: String { return self._s[1154]! } + public var Wallet_Receive_InvoiceUrlCopied: String { return self._s[1155]! } + public var Map_PlacesNearby: String { return self._s[1156]! } public func Time_PreciseDate_m7(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1156]!, self._r[1156]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1157]!, self._r[1157]!, [_1, _2, _3]) } - public var PrivacyLastSeenSettings_GroupsAndChannelsHelp: String { return self._s[1157]! } - public var Privacy_Calls_NeverAllow_Placeholder: String { return self._s[1159]! } - public var Conversation_StatusTyping: String { return self._s[1160]! } - public var Broadcast_AdminLog_EmptyText: String { return self._s[1161]! } - public var Notification_PassportValueProofOfAddress: String { return self._s[1162]! } - public var UserInfo_CreateNewContact: String { return self._s[1163]! } - public var Passport_Identity_FrontSide: String { return self._s[1164]! } - public var Login_PhoneNumberAlreadyAuthorizedSwitch: String { return self._s[1165]! } - public var Calls_CallTabTitle: String { return self._s[1166]! } - public var Channel_AdminLog_ChannelEmptyText: String { return self._s[1167]! } + public var PrivacyLastSeenSettings_GroupsAndChannelsHelp: String { return self._s[1158]! } + public var Privacy_Calls_NeverAllow_Placeholder: String { return self._s[1160]! } + public var Conversation_StatusTyping: String { return self._s[1161]! } + public var Broadcast_AdminLog_EmptyText: String { return self._s[1162]! } + public var Notification_PassportValueProofOfAddress: String { return self._s[1163]! } + public var UserInfo_CreateNewContact: String { return self._s[1164]! } + public var Passport_Identity_FrontSide: String { return self._s[1165]! } + public var Login_PhoneNumberAlreadyAuthorizedSwitch: String { return self._s[1166]! } + public var Calls_CallTabTitle: String { return self._s[1167]! } + public var Channel_AdminLog_ChannelEmptyText: String { return self._s[1168]! } public func Login_BannedPhoneBody(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1169]!, self._r[1169]!, [_0]) + return formatWithArgumentRanges(self._s[1170]!, self._r[1170]!, [_0]) } - public var Watch_UserInfo_MuteTitle: String { return self._s[1170]! } - public var Group_EditAdmin_RankAdminPlaceholder: String { return self._s[1171]! } - public var SharedMedia_EmptyMusicText: String { return self._s[1172]! } - public var Wallet_Completed_Text: String { return self._s[1173]! } - public var PasscodeSettings_AutoLock_IfAwayFor_1minute: String { return self._s[1174]! } - public var Paint_Stickers: String { return self._s[1175]! } - public var Privacy_GroupsAndChannels: String { return self._s[1176]! } - public var ChatList_Context_Delete: String { return self._s[1178]! } - public var UserInfo_AddContact: String { return self._s[1179]! } + public var Watch_UserInfo_MuteTitle: String { return self._s[1171]! } + public var Group_EditAdmin_RankAdminPlaceholder: String { return self._s[1172]! } + public var SharedMedia_EmptyMusicText: String { return self._s[1173]! } + public var Wallet_Completed_Text: String { return self._s[1174]! } + public var PasscodeSettings_AutoLock_IfAwayFor_1minute: String { return self._s[1175]! } + public var Paint_Stickers: String { return self._s[1176]! } + public var Privacy_GroupsAndChannels: String { return self._s[1177]! } + public var ChatList_Context_Delete: String { return self._s[1179]! } + public var UserInfo_AddContact: String { return self._s[1180]! } public func Conversation_MessageViaUser(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1180]!, self._r[1180]!, [_0]) + return formatWithArgumentRanges(self._s[1181]!, self._r[1181]!, [_0]) } - public var PhoneNumberHelp_ChangeNumber: String { return self._s[1182]! } + public var PhoneNumberHelp_ChangeNumber: String { return self._s[1183]! } public func ChatList_ClearChatConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1184]!, self._r[1184]!, [_0]) + return formatWithArgumentRanges(self._s[1185]!, self._r[1185]!, [_0]) } - public var DialogList_NoMessagesTitle: String { return self._s[1185]! } - public var EditProfile_NameAndPhotoHelp: String { return self._s[1186]! } - public var BlockedUsers_BlockUser: String { return self._s[1187]! } - public var Notifications_PermissionsOpenSettings: String { return self._s[1188]! } - public var MediaPicker_UngroupDescription: String { return self._s[1190]! } - public var Watch_NoConnection: String { return self._s[1191]! } - public var Month_GenSeptember: String { return self._s[1192]! } - public var Conversation_ViewGroup: String { return self._s[1194]! } - public var Channel_AdminLogFilter_EventsLeavingSubscribers: String { return self._s[1197]! } - public var Privacy_Forwards_AlwaysLink: String { return self._s[1198]! } - public var Channel_OwnershipTransfer_ErrorAdminsTooMuch: String { return self._s[1199]! } - public var Passport_FieldOneOf_FinalDelimeter: String { return self._s[1200]! } - public var Wallet_WordCheck_IncorrectHeader: String { return self._s[1201]! } - public var MediaPicker_CameraRoll: String { return self._s[1203]! } - public var Month_GenAugust: String { return self._s[1204]! } - public var Wallet_Configuration_SourceHeader: String { return self._s[1205]! } - public var AccessDenied_VideoMessageMicrophone: String { return self._s[1206]! } - public var SharedMedia_EmptyText: String { return self._s[1207]! } - public var Map_ShareLiveLocation: String { return self._s[1208]! } - public var Calls_All: String { return self._s[1209]! } - public var Map_SendThisPlace: String { return self._s[1211]! } - public var Appearance_ThemeNight: String { return self._s[1213]! } - public var Conversation_HoldForAudio: String { return self._s[1214]! } - public var SettingsSearch_Synonyms_Support: String { return self._s[1217]! } - public var GroupInfo_GroupHistoryHidden: String { return self._s[1218]! } - public var SocksProxySetup_Secret: String { return self._s[1219]! } + public var DialogList_NoMessagesTitle: String { return self._s[1186]! } + public var EditProfile_NameAndPhotoHelp: String { return self._s[1187]! } + public var BlockedUsers_BlockUser: String { return self._s[1188]! } + public var Notifications_PermissionsOpenSettings: String { return self._s[1189]! } + public var MediaPicker_UngroupDescription: String { return self._s[1191]! } + public var Watch_NoConnection: String { return self._s[1192]! } + public var Month_GenSeptember: String { return self._s[1193]! } + public var Conversation_ViewGroup: String { return self._s[1195]! } + public var Channel_AdminLogFilter_EventsLeavingSubscribers: String { return self._s[1198]! } + public var Privacy_Forwards_AlwaysLink: String { return self._s[1199]! } + public var Channel_OwnershipTransfer_ErrorAdminsTooMuch: String { return self._s[1200]! } + public var Passport_FieldOneOf_FinalDelimeter: String { return self._s[1201]! } + public var Wallet_WordCheck_IncorrectHeader: String { return self._s[1202]! } + public var MediaPicker_CameraRoll: String { return self._s[1204]! } + public var Month_GenAugust: String { return self._s[1205]! } + public var Wallet_Configuration_SourceHeader: String { return self._s[1206]! } + public var AccessDenied_VideoMessageMicrophone: String { return self._s[1207]! } + public var SharedMedia_EmptyText: String { return self._s[1208]! } + public var Map_ShareLiveLocation: String { return self._s[1209]! } + public var Calls_All: String { return self._s[1210]! } + public var Map_SendThisPlace: String { return self._s[1212]! } + public var Appearance_ThemeNight: String { return self._s[1214]! } + public var Conversation_HoldForAudio: String { return self._s[1215]! } + public var SettingsSearch_Synonyms_Support: String { return self._s[1218]! } + public var GroupInfo_GroupHistoryHidden: String { return self._s[1219]! } + public var SocksProxySetup_Secret: String { return self._s[1220]! } public func Activity_RemindAboutChannel(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1220]!, self._r[1220]!, [_0]) + return formatWithArgumentRanges(self._s[1221]!, self._r[1221]!, [_0]) } - public var Channel_BanList_RestrictedTitle: String { return self._s[1222]! } - public var Conversation_Location: String { return self._s[1223]! } + public var Channel_BanList_RestrictedTitle: String { return self._s[1223]! } + public var Conversation_Location: String { return self._s[1224]! } public func AutoDownloadSettings_UpToFor(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1224]!, self._r[1224]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1225]!, self._r[1225]!, [_1, _2]) } - public var ChatSettings_AutoDownloadPhotos: String { return self._s[1226]! } - public var SettingsSearch_Synonyms_Privacy_Title: String { return self._s[1227]! } - public var Notifications_PermissionsText: String { return self._s[1228]! } - public var SettingsSearch_Synonyms_Data_SaveIncomingPhotos: String { return self._s[1229]! } - public var Call_Flip: String { return self._s[1230]! } - public var Channel_AdminLog_CanDeleteMessagesOfOthers: String { return self._s[1232]! } - public var SocksProxySetup_ProxyStatusConnecting: String { return self._s[1233]! } - public var Wallet_TransactionInfo_StorageFeeInfoUrl: String { return self._s[1234]! } - public var PrivacyPhoneNumberSettings_DiscoveryHeader: String { return self._s[1235]! } - public var Channel_EditAdmin_PermissionPinMessages: String { return self._s[1237]! } - public var TwoStepAuth_ReEnterPasswordDescription: String { return self._s[1239]! } - public var Channel_TooMuchBots: String { return self._s[1241]! } - public var Passport_DeletePassportConfirmation: String { return self._s[1242]! } - public var Login_InvalidCodeError: String { return self._s[1243]! } - public var StickerPacksSettings_FeaturedPacks: String { return self._s[1244]! } + public var ChatSettings_AutoDownloadPhotos: String { return self._s[1227]! } + public var SettingsSearch_Synonyms_Privacy_Title: String { return self._s[1228]! } + public var Notifications_PermissionsText: String { return self._s[1229]! } + public var SettingsSearch_Synonyms_Data_SaveIncomingPhotos: String { return self._s[1230]! } + public var Call_Flip: String { return self._s[1231]! } + public var Channel_AdminLog_CanDeleteMessagesOfOthers: String { return self._s[1233]! } + public var SocksProxySetup_ProxyStatusConnecting: String { return self._s[1234]! } + public var Wallet_TransactionInfo_StorageFeeInfoUrl: String { return self._s[1235]! } + public var PrivacyPhoneNumberSettings_DiscoveryHeader: String { return self._s[1236]! } + public var Channel_EditAdmin_PermissionPinMessages: String { return self._s[1238]! } + public var TwoStepAuth_ReEnterPasswordDescription: String { return self._s[1240]! } + public var Channel_TooMuchBots: String { return self._s[1242]! } + public var Passport_DeletePassportConfirmation: String { return self._s[1243]! } + public var Login_InvalidCodeError: String { return self._s[1244]! } + public var StickerPacksSettings_FeaturedPacks: String { return self._s[1245]! } public func ChatList_DeleteSecretChatConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1245]!, self._r[1245]!, [_0]) - } - public func GroupInfo_InvitationLinkAcceptChannel(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[1246]!, self._r[1246]!, [_0]) } - public var VoiceOver_Navigation_ProxySettings: String { return self._s[1247]! } - public var Call_CallInProgressTitle: String { return self._s[1248]! } - public var Month_ShortSeptember: String { return self._s[1249]! } - public var Watch_ChannelInfo_Title: String { return self._s[1250]! } - public var ChatList_DeleteSavedMessagesConfirmation: String { return self._s[1253]! } - public var DialogList_PasscodeLockHelp: String { return self._s[1254]! } - public var Chat_MultipleTextMessagesDisabled: String { return self._s[1255]! } - public var Wallet_Receive_Title: String { return self._s[1256]! } - public var Notifications_Badge_IncludePublicGroups: String { return self._s[1257]! } - public var Channel_AdminLogFilter_EventsTitle: String { return self._s[1258]! } - public var PhotoEditor_CropReset: String { return self._s[1259]! } - public var Group_Username_CreatePrivateLinkHelp: String { return self._s[1261]! } - public var Channel_Management_LabelEditor: String { return self._s[1262]! } - public var Passport_Identity_LatinNameHelp: String { return self._s[1264]! } - public var PhotoEditor_HighlightsTool: String { return self._s[1265]! } - public var Wallet_Info_WalletCreated: String { return self._s[1266]! } - public var UserInfo_Title: String { return self._s[1267]! } - public var ChatList_HideAction: String { return self._s[1268]! } - public var AccessDenied_Title: String { return self._s[1269]! } - public var DialogList_SearchLabel: String { return self._s[1270]! } - public var Group_Setup_HistoryHidden: String { return self._s[1271]! } - public var TwoStepAuth_PasswordChangeSuccess: String { return self._s[1272]! } - public var State_Updating: String { return self._s[1274]! } - public var Contacts_TabTitle: String { return self._s[1275]! } - public var Notifications_Badge_CountUnreadMessages: String { return self._s[1277]! } - public var GroupInfo_GroupHistory: String { return self._s[1278]! } - public var Conversation_UnsupportedMediaPlaceholder: String { return self._s[1279]! } - public var Wallpaper_SetColor: String { return self._s[1280]! } - public var CheckoutInfo_ShippingInfoCountry: String { return self._s[1281]! } - public var SettingsSearch_Synonyms_SavedMessages: String { return self._s[1282]! } - public var Chat_AttachmentLimitReached: String { return self._s[1283]! } - public var Passport_Identity_OneOfTypeDriversLicense: String { return self._s[1284]! } - public var Contacts_NotRegisteredSection: String { return self._s[1285]! } + public func GroupInfo_InvitationLinkAcceptChannel(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1247]!, self._r[1247]!, [_0]) + } + public var VoiceOver_Navigation_ProxySettings: String { return self._s[1248]! } + public var Call_CallInProgressTitle: String { return self._s[1249]! } + public var Month_ShortSeptember: String { return self._s[1250]! } + public var Watch_ChannelInfo_Title: String { return self._s[1251]! } + public var ChatList_DeleteSavedMessagesConfirmation: String { return self._s[1254]! } + public var DialogList_PasscodeLockHelp: String { return self._s[1255]! } + public var Chat_MultipleTextMessagesDisabled: String { return self._s[1256]! } + public var Wallet_Receive_Title: String { return self._s[1257]! } + public var Notifications_Badge_IncludePublicGroups: String { return self._s[1258]! } + public var Channel_AdminLogFilter_EventsTitle: String { return self._s[1259]! } + public var PhotoEditor_CropReset: String { return self._s[1260]! } + public var Group_Username_CreatePrivateLinkHelp: String { return self._s[1262]! } + public var Channel_Management_LabelEditor: String { return self._s[1263]! } + public var Passport_Identity_LatinNameHelp: String { return self._s[1265]! } + public var PhotoEditor_HighlightsTool: String { return self._s[1266]! } + public var Wallet_Info_WalletCreated: String { return self._s[1267]! } + public var UserInfo_Title: String { return self._s[1268]! } + public var ChatList_HideAction: String { return self._s[1269]! } + public var AccessDenied_Title: String { return self._s[1270]! } + public var DialogList_SearchLabel: String { return self._s[1271]! } + public var Group_Setup_HistoryHidden: String { return self._s[1272]! } + public var TwoStepAuth_PasswordChangeSuccess: String { return self._s[1273]! } + public var State_Updating: String { return self._s[1275]! } + public var Contacts_TabTitle: String { return self._s[1276]! } + public var Notifications_Badge_CountUnreadMessages: String { return self._s[1278]! } + public var GroupInfo_GroupHistory: String { return self._s[1279]! } + public var Conversation_UnsupportedMediaPlaceholder: String { return self._s[1280]! } + public var Wallpaper_SetColor: String { return self._s[1281]! } + public var CheckoutInfo_ShippingInfoCountry: String { return self._s[1282]! } + public var SettingsSearch_Synonyms_SavedMessages: String { return self._s[1283]! } + public var Chat_AttachmentLimitReached: String { return self._s[1284]! } + public var Passport_Identity_OneOfTypeDriversLicense: String { return self._s[1285]! } + public var Contacts_NotRegisteredSection: String { return self._s[1286]! } public func Time_PreciseDate_m4(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1286]!, self._r[1286]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1287]!, self._r[1287]!, [_1, _2, _3]) } - public var Paint_Clear: String { return self._s[1287]! } - public var StickerPacksSettings_ArchivedMasks: String { return self._s[1288]! } - public var SocksProxySetup_Connecting: String { return self._s[1289]! } - public var ExplicitContent_AlertChannel: String { return self._s[1290]! } - public var CreatePoll_AllOptionsAdded: String { return self._s[1291]! } - public var Conversation_Contact: String { return self._s[1292]! } - public var Login_CodeExpired: String { return self._s[1293]! } - public var Passport_DiscardMessageAction: String { return self._s[1294]! } - public var ChatList_Context_Unpin: String { return self._s[1295]! } - public var Channel_AdminLog_MessagePreviousDescription: String { return self._s[1296]! } + public var Paint_Clear: String { return self._s[1288]! } + public var StickerPacksSettings_ArchivedMasks: String { return self._s[1289]! } + public var SocksProxySetup_Connecting: String { return self._s[1290]! } + public var ExplicitContent_AlertChannel: String { return self._s[1291]! } + public var CreatePoll_AllOptionsAdded: String { return self._s[1292]! } + public var Conversation_Contact: String { return self._s[1293]! } + public var Login_CodeExpired: String { return self._s[1294]! } + public var Passport_DiscardMessageAction: String { return self._s[1295]! } + public var ChatList_Context_Unpin: String { return self._s[1296]! } + public var Channel_AdminLog_MessagePreviousDescription: String { return self._s[1297]! } public func VoiceOver_Chat_MusicFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1297]!, self._r[1297]!, [_0]) + return formatWithArgumentRanges(self._s[1298]!, self._r[1298]!, [_0]) } - public var Channel_AdminLog_EmptyMessageText: String { return self._s[1298]! } - public var SettingsSearch_Synonyms_Data_NetworkUsage: String { return self._s[1299]! } + public var Channel_AdminLog_EmptyMessageText: String { return self._s[1299]! } + public var SettingsSearch_Synonyms_Data_NetworkUsage: String { return self._s[1300]! } public func Group_EditAdmin_RankInfo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1300]!, self._r[1300]!, [_0]) + return formatWithArgumentRanges(self._s[1301]!, self._r[1301]!, [_0]) } - public var Month_ShortApril: String { return self._s[1301]! } - public var AuthSessions_CurrentSession: String { return self._s[1302]! } - public var Chat_AttachmentMultipleFilesDisabled: String { return self._s[1305]! } - public var Wallet_Navigation_Cancel: String { return self._s[1307]! } - public var WallpaperPreview_CropTopText: String { return self._s[1308]! } - public var PrivacySettings_DeleteAccountIfAwayFor: String { return self._s[1309]! } - public var CheckoutInfo_ShippingInfoTitle: String { return self._s[1310]! } + public var Month_ShortApril: String { return self._s[1302]! } + public var AuthSessions_CurrentSession: String { return self._s[1303]! } + public var Chat_AttachmentMultipleFilesDisabled: String { return self._s[1306]! } + public var Wallet_Navigation_Cancel: String { return self._s[1308]! } + public var WallpaperPreview_CropTopText: String { return self._s[1309]! } + public var PrivacySettings_DeleteAccountIfAwayFor: String { return self._s[1310]! } + public var CheckoutInfo_ShippingInfoTitle: String { return self._s[1311]! } public func Conversation_ScheduleMessage_SendOn(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1311]!, self._r[1311]!, [_0, _1]) + return formatWithArgumentRanges(self._s[1312]!, self._r[1312]!, [_0, _1]) } - public var Appearance_ThemePreview_Chat_2_Text: String { return self._s[1312]! } - public var Channel_Setup_TypePrivate: String { return self._s[1314]! } - public var Forward_ChannelReadOnly: String { return self._s[1317]! } - public var PhotoEditor_CurvesBlue: String { return self._s[1318]! } - public var AddContact_SharedContactException: String { return self._s[1319]! } - public var UserInfo_BotPrivacy: String { return self._s[1321]! } - public var Wallet_CreateInvoice_Title: String { return self._s[1322]! } - public var Notification_PassportValueEmail: String { return self._s[1323]! } - public var EmptyGroupInfo_Subtitle: String { return self._s[1324]! } - public var GroupPermission_NewTitle: String { return self._s[1325]! } - public var CallFeedback_ReasonDropped: String { return self._s[1326]! } - public var GroupInfo_Permissions_AddException: String { return self._s[1327]! } - public var Channel_SignMessages_Help: String { return self._s[1329]! } - public var Undo_ChatDeleted: String { return self._s[1331]! } - public var Conversation_ChatBackground: String { return self._s[1332]! } + public var Appearance_ThemePreview_Chat_2_Text: String { return self._s[1313]! } + public var Channel_Setup_TypePrivate: String { return self._s[1315]! } + public var Forward_ChannelReadOnly: String { return self._s[1318]! } + public var PhotoEditor_CurvesBlue: String { return self._s[1319]! } + public var AddContact_SharedContactException: String { return self._s[1320]! } + public var UserInfo_BotPrivacy: String { return self._s[1322]! } + public var Wallet_CreateInvoice_Title: String { return self._s[1323]! } + public var Notification_PassportValueEmail: String { return self._s[1324]! } + public var EmptyGroupInfo_Subtitle: String { return self._s[1325]! } + public var GroupPermission_NewTitle: String { return self._s[1326]! } + public var CallFeedback_ReasonDropped: String { return self._s[1327]! } + public var GroupInfo_Permissions_AddException: String { return self._s[1328]! } + public var Channel_SignMessages_Help: String { return self._s[1330]! } + public var Undo_ChatDeleted: String { return self._s[1332]! } + public var Conversation_ChatBackground: String { return self._s[1333]! } public func Wallet_WordCheck_Text(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1333]!, self._r[1333]!, [_1, _2, _3]) - } - public func PUSH_CHAT_MESSAGE_QUIZ(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[1334]!, self._r[1334]!, [_1, _2, _3]) } - public var ChannelMembers_WhoCanAddMembers_Admins: String { return self._s[1335]! } - public var FastTwoStepSetup_EmailPlaceholder: String { return self._s[1336]! } - public var Passport_Language_pt: String { return self._s[1337]! } - public var VoiceOver_Chat_YourVoiceMessage: String { return self._s[1338]! } - public var NotificationsSound_Popcorn: String { return self._s[1341]! } - public var AutoNightTheme_Disabled: String { return self._s[1342]! } - public var BlockedUsers_LeavePrefix: String { return self._s[1343]! } - public var WallpaperPreview_CustomColorTopText: String { return self._s[1344]! } - public var Contacts_PermissionsSuppressWarningText: String { return self._s[1345]! } - public var WallpaperSearch_ColorBlue: String { return self._s[1346]! } + public func PUSH_CHAT_MESSAGE_QUIZ(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1335]!, self._r[1335]!, [_1, _2, _3]) + } + public var ChannelMembers_WhoCanAddMembers_Admins: String { return self._s[1336]! } + public var FastTwoStepSetup_EmailPlaceholder: String { return self._s[1337]! } + public var Passport_Language_pt: String { return self._s[1338]! } + public var VoiceOver_Chat_YourVoiceMessage: String { return self._s[1339]! } + public var NotificationsSound_Popcorn: String { return self._s[1342]! } + public var AutoNightTheme_Disabled: String { return self._s[1343]! } + public var BlockedUsers_LeavePrefix: String { return self._s[1344]! } + public var WallpaperPreview_CustomColorTopText: String { return self._s[1345]! } + public var Contacts_PermissionsSuppressWarningText: String { return self._s[1346]! } + public var WallpaperSearch_ColorBlue: String { return self._s[1347]! } public func CancelResetAccount_TextSMS(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1347]!, self._r[1347]!, [_0]) + return formatWithArgumentRanges(self._s[1348]!, self._r[1348]!, [_0]) } - public var CheckoutInfo_ErrorNameInvalid: String { return self._s[1348]! } - public var SocksProxySetup_UseForCalls: String { return self._s[1349]! } - public var Passport_DeleteDocumentConfirmation: String { return self._s[1351]! } - public var PeerInfo_PaneGroups: String { return self._s[1352]! } + public var CheckoutInfo_ErrorNameInvalid: String { return self._s[1349]! } + public var SocksProxySetup_UseForCalls: String { return self._s[1350]! } + public var Passport_DeleteDocumentConfirmation: String { return self._s[1352]! } + public var PeerInfo_PaneGroups: String { return self._s[1353]! } public func Conversation_Megabytes(_ _0: Float) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1353]!, self._r[1353]!, ["\(_0)"]) + return formatWithArgumentRanges(self._s[1354]!, self._r[1354]!, ["\(_0)"]) } - public var SocksProxySetup_Hostname: String { return self._s[1356]! } - public var ChatSettings_AutoDownloadSettings_OffForAll: String { return self._s[1357]! } - public var Compose_NewEncryptedChat: String { return self._s[1358]! } - public var Login_CodeFloodError: String { return self._s[1359]! } - public var Calls_TabTitle: String { return self._s[1360]! } - public var Privacy_ProfilePhoto: String { return self._s[1361]! } - public var Passport_Language_he: String { return self._s[1362]! } + public var SocksProxySetup_Hostname: String { return self._s[1357]! } + public var ChatSettings_AutoDownloadSettings_OffForAll: String { return self._s[1358]! } + public var Compose_NewEncryptedChat: String { return self._s[1359]! } + public var Login_CodeFloodError: String { return self._s[1360]! } + public var Calls_TabTitle: String { return self._s[1361]! } + public var Privacy_ProfilePhoto: String { return self._s[1362]! } + public var Passport_Language_he: String { return self._s[1363]! } public func Conversation_SetReminder_RemindToday(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1363]!, self._r[1363]!, [_0]) + return formatWithArgumentRanges(self._s[1364]!, self._r[1364]!, [_0]) } - public var GroupPermission_Title: String { return self._s[1364]! } + public var GroupPermission_Title: String { return self._s[1365]! } public func Channel_AdminLog_MessageGroupPreHistoryHidden(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1365]!, self._r[1365]!, [_0]) + return formatWithArgumentRanges(self._s[1366]!, self._r[1366]!, [_0]) } - public var Wallet_TransactionInfo_SenderHeader: String { return self._s[1366]! } - public var GroupPermission_NoChangeInfo: String { return self._s[1367]! } - public var ChatList_DeleteForCurrentUser: String { return self._s[1368]! } - public var Tour_Text1: String { return self._s[1369]! } - public var Channel_EditAdmin_TransferOwnership: String { return self._s[1370]! } - public var Month_ShortFebruary: String { return self._s[1371]! } - public var TwoStepAuth_EmailSkip: String { return self._s[1372]! } + public var Wallet_TransactionInfo_SenderHeader: String { return self._s[1367]! } + public var GroupPermission_NoChangeInfo: String { return self._s[1368]! } + public var ChatList_DeleteForCurrentUser: String { return self._s[1369]! } + public var Tour_Text1: String { return self._s[1370]! } + public var Channel_EditAdmin_TransferOwnership: String { return self._s[1371]! } + public var Month_ShortFebruary: String { return self._s[1372]! } + public var TwoStepAuth_EmailSkip: String { return self._s[1373]! } public func Wallet_Time_PreciseDate_m4(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1373]!, self._r[1373]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1374]!, self._r[1374]!, [_1, _2, _3]) } - public var Stats_LanguagesTitle: String { return self._s[1374]! } - public var NotificationsSound_Glass: String { return self._s[1375]! } - public var Appearance_ThemeNightBlue: String { return self._s[1376]! } - public var CheckoutInfo_Pay: String { return self._s[1377]! } - public var PeerInfo_ButtonLeave: String { return self._s[1379]! } - public var Invite_LargeRecipientsCountWarning: String { return self._s[1380]! } - public var Call_CallAgain: String { return self._s[1382]! } - public var AttachmentMenu_SendAsFile: String { return self._s[1383]! } - public var AccessDenied_MicrophoneRestricted: String { return self._s[1384]! } - public var Passport_InvalidPasswordError: String { return self._s[1385]! } - public var Watch_Message_Game: String { return self._s[1386]! } - public var Stickers_Install: String { return self._s[1387]! } - public var VoiceOver_Chat_Message: String { return self._s[1388]! } - public var PrivacyLastSeenSettings_NeverShareWith: String { return self._s[1389]! } - public var Passport_Identity_ResidenceCountry: String { return self._s[1391]! } - public var Notifications_GroupNotificationsHelp: String { return self._s[1392]! } - public var AuthSessions_OtherSessions: String { return self._s[1393]! } - public var Channel_Username_Help: String { return self._s[1394]! } - public var Camera_Title: String { return self._s[1395]! } - public var IntentsSettings_Title: String { return self._s[1396]! } - public var GroupInfo_SetGroupPhotoDelete: String { return self._s[1398]! } - public var Privacy_ProfilePhoto_NeverShareWith_Title: String { return self._s[1399]! } - public var Channel_AdminLog_SendPolls: String { return self._s[1400]! } - public var Channel_AdminLog_TitleAllEvents: String { return self._s[1401]! } - public var Channel_EditAdmin_PermissionInviteMembers: String { return self._s[1402]! } - public var Contacts_MemberSearchSectionTitleGroup: String { return self._s[1403]! } - public var ScheduledMessages_DeleteMany: String { return self._s[1404]! } - public var Conversation_RestrictedStickers: String { return self._s[1405]! } - public var Notifications_ExceptionsResetToDefaults: String { return self._s[1407]! } - public var UserInfo_TelegramCall: String { return self._s[1409]! } - public var TwoStepAuth_SetupResendEmailCode: String { return self._s[1410]! } - public var CreatePoll_OptionsHeader: String { return self._s[1411]! } - public var SettingsSearch_Synonyms_Data_CallsUseLessData: String { return self._s[1412]! } - public var ArchivedChats_IntroTitle1: String { return self._s[1413]! } - public var Privacy_GroupsAndChannels_AlwaysAllow_Title: String { return self._s[1414]! } - public var Theme_Colors_Proceed: String { return self._s[1415]! } - public var Passport_Identity_EditPersonalDetails: String { return self._s[1416]! } + public var Stats_LanguagesTitle: String { return self._s[1375]! } + public var NotificationsSound_Glass: String { return self._s[1376]! } + public var Appearance_ThemeNightBlue: String { return self._s[1377]! } + public var CheckoutInfo_Pay: String { return self._s[1378]! } + public var PeerInfo_ButtonLeave: String { return self._s[1380]! } + public var Invite_LargeRecipientsCountWarning: String { return self._s[1381]! } + public var Call_CallAgain: String { return self._s[1383]! } + public var AttachmentMenu_SendAsFile: String { return self._s[1384]! } + public var AccessDenied_MicrophoneRestricted: String { return self._s[1385]! } + public var Passport_InvalidPasswordError: String { return self._s[1386]! } + public var Watch_Message_Game: String { return self._s[1387]! } + public var Stickers_Install: String { return self._s[1388]! } + public var VoiceOver_Chat_Message: String { return self._s[1389]! } + public var PrivacyLastSeenSettings_NeverShareWith: String { return self._s[1390]! } + public var Passport_Identity_ResidenceCountry: String { return self._s[1392]! } + public var Notifications_GroupNotificationsHelp: String { return self._s[1393]! } + public var AuthSessions_OtherSessions: String { return self._s[1394]! } + public var Channel_Username_Help: String { return self._s[1395]! } + public var Camera_Title: String { return self._s[1396]! } + public var IntentsSettings_Title: String { return self._s[1397]! } + public var GroupInfo_SetGroupPhotoDelete: String { return self._s[1399]! } + public var Privacy_ProfilePhoto_NeverShareWith_Title: String { return self._s[1400]! } + public var Channel_AdminLog_SendPolls: String { return self._s[1401]! } + public var Channel_AdminLog_TitleAllEvents: String { return self._s[1402]! } + public var Channel_EditAdmin_PermissionInviteMembers: String { return self._s[1403]! } + public var Contacts_MemberSearchSectionTitleGroup: String { return self._s[1404]! } + public var ScheduledMessages_DeleteMany: String { return self._s[1405]! } + public var Conversation_RestrictedStickers: String { return self._s[1406]! } + public var Notifications_ExceptionsResetToDefaults: String { return self._s[1408]! } + public var UserInfo_TelegramCall: String { return self._s[1410]! } + public var TwoStepAuth_SetupResendEmailCode: String { return self._s[1411]! } + public var CreatePoll_OptionsHeader: String { return self._s[1412]! } + public var SettingsSearch_Synonyms_Data_CallsUseLessData: String { return self._s[1413]! } + public var ArchivedChats_IntroTitle1: String { return self._s[1414]! } + public var Privacy_GroupsAndChannels_AlwaysAllow_Title: String { return self._s[1415]! } + public var Theme_Colors_Proceed: String { return self._s[1416]! } + public var Passport_Identity_EditPersonalDetails: String { return self._s[1417]! } public func Time_PreciseDate_m1(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1417]!, self._r[1417]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1418]!, self._r[1418]!, [_1, _2, _3]) } - public var Wallet_Month_GenAugust: String { return self._s[1418]! } - public var Settings_SaveEditedPhotos: String { return self._s[1419]! } - public var Stats_FollowersBySourceTitle: String { return self._s[1420]! } - public var TwoStepAuth_ConfirmationTitle: String { return self._s[1421]! } - public var Privacy_GroupsAndChannels_NeverAllow_Title: String { return self._s[1422]! } - public var Conversation_MessageDialogRetry: String { return self._s[1423]! } - public var ChatList_Context_MarkAsUnread: String { return self._s[1424]! } - public var MessagePoll_SubmitVote: String { return self._s[1425]! } - public var Conversation_DiscardVoiceMessageAction: String { return self._s[1426]! } - public var Permissions_PeopleNearbyTitle_v0: String { return self._s[1427]! } - public var Group_Setup_TypeHeader: String { return self._s[1428]! } - public var Paint_RecentStickers: String { return self._s[1429]! } - public var PhotoEditor_GrainTool: String { return self._s[1430]! } - public var CheckoutInfo_ShippingInfoState: String { return self._s[1431]! } - public var EmptyGroupInfo_Line4: String { return self._s[1432]! } - public var Watch_AuthRequired: String { return self._s[1434]! } + public var Wallet_Month_GenAugust: String { return self._s[1419]! } + public var Settings_SaveEditedPhotos: String { return self._s[1420]! } + public var Stats_FollowersBySourceTitle: String { return self._s[1421]! } + public var TwoStepAuth_ConfirmationTitle: String { return self._s[1422]! } + public var Privacy_GroupsAndChannels_NeverAllow_Title: String { return self._s[1423]! } + public var Conversation_MessageDialogRetry: String { return self._s[1424]! } + public var ChatList_Context_MarkAsUnread: String { return self._s[1425]! } + public var MessagePoll_SubmitVote: String { return self._s[1426]! } + public var Conversation_DiscardVoiceMessageAction: String { return self._s[1427]! } + public var Permissions_PeopleNearbyTitle_v0: String { return self._s[1428]! } + public var Group_Setup_TypeHeader: String { return self._s[1429]! } + public var Paint_RecentStickers: String { return self._s[1430]! } + public var PhotoEditor_GrainTool: String { return self._s[1431]! } + public var CheckoutInfo_ShippingInfoState: String { return self._s[1432]! } + public var EmptyGroupInfo_Line4: String { return self._s[1433]! } + public var Watch_AuthRequired: String { return self._s[1435]! } public func Passport_Email_UseTelegramEmail(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1435]!, self._r[1435]!, [_0]) + return formatWithArgumentRanges(self._s[1436]!, self._r[1436]!, [_0]) } - public var Conversation_EncryptedDescriptionTitle: String { return self._s[1436]! } - public var ChannelIntro_Text: String { return self._s[1437]! } - public var DialogList_DeleteBotConfirmation: String { return self._s[1438]! } - public var GroupPermission_NoSendMedia: String { return self._s[1439]! } - public var Calls_AddTab: String { return self._s[1440]! } - public var Message_ReplyActionButtonShowReceipt: String { return self._s[1441]! } - public var Channel_AdminLog_EmptyFilterText: String { return self._s[1442]! } - public var Conversation_WalletRequiredSetup: String { return self._s[1443]! } - public var Notification_MessageLifetime1d: String { return self._s[1444]! } - public var Notifications_ChannelNotificationsExceptionsHelp: String { return self._s[1445]! } - public var Channel_BanUser_PermissionsHeader: String { return self._s[1446]! } - public var Passport_Identity_GenderFemale: String { return self._s[1447]! } - public var BlockedUsers_BlockTitle: String { return self._s[1448]! } + public var Conversation_EncryptedDescriptionTitle: String { return self._s[1437]! } + public var ChannelIntro_Text: String { return self._s[1438]! } + public var DialogList_DeleteBotConfirmation: String { return self._s[1439]! } + public var GroupPermission_NoSendMedia: String { return self._s[1440]! } + public var Calls_AddTab: String { return self._s[1441]! } + public var Message_ReplyActionButtonShowReceipt: String { return self._s[1442]! } + public var Channel_AdminLog_EmptyFilterText: String { return self._s[1443]! } + public var Conversation_WalletRequiredSetup: String { return self._s[1444]! } + public var Notification_MessageLifetime1d: String { return self._s[1445]! } + public var Notifications_ChannelNotificationsExceptionsHelp: String { return self._s[1446]! } + public var Channel_BanUser_PermissionsHeader: String { return self._s[1447]! } + public var Passport_Identity_GenderFemale: String { return self._s[1448]! } + public var BlockedUsers_BlockTitle: String { return self._s[1449]! } public func PUSH_CHANNEL_MESSAGE_GIF(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1449]!, self._r[1449]!, [_1]) + return formatWithArgumentRanges(self._s[1450]!, self._r[1450]!, [_1]) } - public var Weekday_Yesterday: String { return self._s[1450]! } - public var WallpaperSearch_ColorBlack: String { return self._s[1451]! } - public var Settings_Context_Logout: String { return self._s[1452]! } - public var Wallet_Info_UnknownTransaction: String { return self._s[1453]! } - public var ChatList_ArchiveAction: String { return self._s[1454]! } - public var AutoNightTheme_Scheduled: String { return self._s[1455]! } - public var TwoFactorSetup_Email_SkipAction: String { return self._s[1456]! } - public var Settings_Devices: String { return self._s[1457]! } - public var ContactInfo_Note: String { return self._s[1458]! } + public var Weekday_Yesterday: String { return self._s[1451]! } + public var WallpaperSearch_ColorBlack: String { return self._s[1452]! } + public var Settings_Context_Logout: String { return self._s[1453]! } + public var Wallet_Info_UnknownTransaction: String { return self._s[1454]! } + public var ChatList_ArchiveAction: String { return self._s[1455]! } + public var AutoNightTheme_Scheduled: String { return self._s[1456]! } + public var TwoFactorSetup_Email_SkipAction: String { return self._s[1457]! } + public var Settings_Devices: String { return self._s[1458]! } + public var ContactInfo_Note: String { return self._s[1459]! } public func Login_PhoneGenericEmailBody(_ _1: String, _ _2: String, _ _3: String, _ _4: String, _ _5: String, _ _6: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1459]!, self._r[1459]!, [_1, _2, _3, _4, _5, _6]) + return formatWithArgumentRanges(self._s[1460]!, self._r[1460]!, [_1, _2, _3, _4, _5, _6]) } - public var EditTheme_ThemeTemplateAlertTitle: String { return self._s[1460]! } - public var Wallet_Receive_CreateInvoice: String { return self._s[1461]! } - public var PrivacyPolicy_DeclineDeleteNow: String { return self._s[1462]! } - public var Theme_Colors_ColorWallpaperWarningProceed: String { return self._s[1463]! } + public var EditTheme_ThemeTemplateAlertTitle: String { return self._s[1461]! } + public var Wallet_Receive_CreateInvoice: String { return self._s[1462]! } + public var PrivacyPolicy_DeclineDeleteNow: String { return self._s[1463]! } + public var Theme_Colors_ColorWallpaperWarningProceed: String { return self._s[1464]! } public func PUSH_CHAT_JOINED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1464]!, self._r[1464]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1465]!, self._r[1465]!, [_1, _2]) } - public var CreatePoll_Create: String { return self._s[1465]! } - public var Channel_Members_AddBannedErrorAdmin: String { return self._s[1466]! } + public var CreatePoll_Create: String { return self._s[1466]! } + public var Channel_Members_AddBannedErrorAdmin: String { return self._s[1467]! } public func Notification_CallFormat(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1467]!, self._r[1467]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1468]!, self._r[1468]!, [_1, _2]) } - public var ScheduledMessages_ClearAllConfirmation: String { return self._s[1468]! } - public var Checkout_ErrorProviderAccountInvalid: String { return self._s[1469]! } - public var Notifications_InAppNotificationsSounds: String { return self._s[1471]! } + public var ScheduledMessages_ClearAllConfirmation: String { return self._s[1469]! } + public var Checkout_ErrorProviderAccountInvalid: String { return self._s[1470]! } + public var Notifications_InAppNotificationsSounds: String { return self._s[1472]! } public func PUSH_PINNED_GAME_SCORE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1472]!, self._r[1472]!, [_1]) + return formatWithArgumentRanges(self._s[1473]!, self._r[1473]!, [_1]) } - public var Preview_OpenInInstagram: String { return self._s[1473]! } - public var Notification_MessageLifetimeRemovedOutgoing: String { return self._s[1474]! } + public var Preview_OpenInInstagram: String { return self._s[1474]! } + public var Notification_MessageLifetimeRemovedOutgoing: String { return self._s[1475]! } public func PUSH_CHAT_ADD_MEMBER(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1475]!, self._r[1475]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1476]!, self._r[1476]!, [_1, _2, _3]) } public func Passport_PrivacyPolicy(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1476]!, self._r[1476]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1477]!, self._r[1477]!, [_1, _2]) } - public var Channel_AdminLog_InfoPanelAlertTitle: String { return self._s[1477]! } - public var ArchivedChats_IntroText3: String { return self._s[1478]! } - public var ChatList_UndoArchiveHiddenText: String { return self._s[1479]! } - public var NetworkUsageSettings_TotalSection: String { return self._s[1480]! } - public var Wallet_Month_GenSeptember: String { return self._s[1481]! } - public var Channel_Setup_TypePrivateHelp: String { return self._s[1482]! } + public var Channel_AdminLog_InfoPanelAlertTitle: String { return self._s[1478]! } + public var ArchivedChats_IntroText3: String { return self._s[1479]! } + public var ChatList_UndoArchiveHiddenText: String { return self._s[1480]! } + public var NetworkUsageSettings_TotalSection: String { return self._s[1481]! } + public var Wallet_Month_GenSeptember: String { return self._s[1482]! } + public var Channel_Setup_TypePrivateHelp: String { return self._s[1483]! } public func PUSH_CHAT_MESSAGE_POLL(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1483]!, self._r[1483]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1484]!, self._r[1484]!, [_1, _2, _3]) } - public var Privacy_GroupsAndChannels_NeverAllow_Placeholder: String { return self._s[1485]! } - public var FastTwoStepSetup_HintSection: String { return self._s[1486]! } - public var Wallpaper_PhotoLibrary: String { return self._s[1487]! } - public var TwoStepAuth_SetupResendEmailCodeAlert: String { return self._s[1488]! } - public var Gif_NoGifsFound: String { return self._s[1489]! } - public var Watch_LastSeen_WithinAMonth: String { return self._s[1490]! } - public var VoiceOver_MessageContextDelete: String { return self._s[1491]! } - public var EditTheme_Preview: String { return self._s[1492]! } + public var Privacy_GroupsAndChannels_NeverAllow_Placeholder: String { return self._s[1486]! } + public var FastTwoStepSetup_HintSection: String { return self._s[1487]! } + public var Wallpaper_PhotoLibrary: String { return self._s[1488]! } + public var TwoStepAuth_SetupResendEmailCodeAlert: String { return self._s[1489]! } + public var Gif_NoGifsFound: String { return self._s[1490]! } + public var Watch_LastSeen_WithinAMonth: String { return self._s[1491]! } + public var VoiceOver_MessageContextDelete: String { return self._s[1492]! } + public var EditTheme_Preview: String { return self._s[1493]! } public func ClearCache_StorageTitle(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1493]!, self._r[1493]!, [_0]) + return formatWithArgumentRanges(self._s[1494]!, self._r[1494]!, [_0]) } - public var GroupInfo_ActionPromote: String { return self._s[1494]! } - public var PasscodeSettings_SimplePasscode: String { return self._s[1495]! } - public var GroupInfo_Permissions_Title: String { return self._s[1496]! } - public var Permissions_ContactsText_v0: String { return self._s[1497]! } - public var PrivacyPhoneNumberSettings_CustomDisabledHelp: String { return self._s[1498]! } - public var SettingsSearch_Synonyms_Notifications_BadgeIncludeMutedPublicGroups: String { return self._s[1499]! } - public var PrivacySettings_DataSettingsHelp: String { return self._s[1502]! } - public var Passport_FieldEmailHelp: String { return self._s[1503]! } + public var GroupInfo_ActionPromote: String { return self._s[1495]! } + public var PasscodeSettings_SimplePasscode: String { return self._s[1496]! } + public var GroupInfo_Permissions_Title: String { return self._s[1497]! } + public var Permissions_ContactsText_v0: String { return self._s[1498]! } + public var PrivacyPhoneNumberSettings_CustomDisabledHelp: String { return self._s[1499]! } + public var SettingsSearch_Synonyms_Notifications_BadgeIncludeMutedPublicGroups: String { return self._s[1500]! } + public var PrivacySettings_DataSettingsHelp: String { return self._s[1503]! } + public var Passport_FieldEmailHelp: String { return self._s[1504]! } public func Activity_RemindAboutUser(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1504]!, self._r[1504]!, [_0]) + return formatWithArgumentRanges(self._s[1505]!, self._r[1505]!, [_0]) } - public var Passport_Identity_GenderPlaceholder: String { return self._s[1505]! } - public var Weekday_ShortSaturday: String { return self._s[1506]! } - public var ContactInfo_PhoneLabelMain: String { return self._s[1507]! } - public var Watch_Conversation_UserInfo: String { return self._s[1508]! } - public var CheckoutInfo_ShippingInfoCityPlaceholder: String { return self._s[1509]! } - public var GroupPermission_PermissionDisabledByDefault: String { return self._s[1510]! } - public var PrivacyLastSeenSettings_Title: String { return self._s[1511]! } - public var Conversation_ShareBotLocationConfirmation: String { return self._s[1512]! } - public var PhotoEditor_VignetteTool: String { return self._s[1513]! } - public var Passport_Address_Street1Placeholder: String { return self._s[1514]! } - public var Passport_Language_et: String { return self._s[1515]! } - public var AppUpgrade_Running: String { return self._s[1516]! } - public var Channel_DiscussionGroup_Info: String { return self._s[1518]! } - public var EditTheme_Create_Preview_IncomingReplyName: String { return self._s[1519]! } - public var Passport_Language_bg: String { return self._s[1520]! } - public var Stickers_NoStickersFound: String { return self._s[1522]! } + public var Passport_Identity_GenderPlaceholder: String { return self._s[1506]! } + public var Weekday_ShortSaturday: String { return self._s[1507]! } + public var ContactInfo_PhoneLabelMain: String { return self._s[1508]! } + public var Watch_Conversation_UserInfo: String { return self._s[1509]! } + public var CheckoutInfo_ShippingInfoCityPlaceholder: String { return self._s[1510]! } + public var GroupPermission_PermissionDisabledByDefault: String { return self._s[1511]! } + public var PrivacyLastSeenSettings_Title: String { return self._s[1512]! } + public var Conversation_ShareBotLocationConfirmation: String { return self._s[1513]! } + public var PhotoEditor_VignetteTool: String { return self._s[1514]! } + public var Passport_Address_Street1Placeholder: String { return self._s[1515]! } + public var Passport_Language_et: String { return self._s[1516]! } + public var AppUpgrade_Running: String { return self._s[1517]! } + public var Channel_DiscussionGroup_Info: String { return self._s[1519]! } + public var EditTheme_Create_Preview_IncomingReplyName: String { return self._s[1520]! } + public var Passport_Language_bg: String { return self._s[1521]! } + public var Stickers_NoStickersFound: String { return self._s[1523]! } public func PUSH_CHANNEL_MESSAGE_TEXT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1524]!, self._r[1524]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1525]!, self._r[1525]!, [_1, _2]) } public func VoiceOver_Chat_ContactFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1525]!, self._r[1525]!, [_0]) + return formatWithArgumentRanges(self._s[1526]!, self._r[1526]!, [_0]) } - public var Wallet_Month_GenJuly: String { return self._s[1526]! } - public var Wallet_Receive_AddressHeader: String { return self._s[1527]! } - public var Wallet_Send_AmountText: String { return self._s[1528]! } - public var Settings_About: String { return self._s[1529]! } + public var Wallet_Month_GenJuly: String { return self._s[1527]! } + public var Wallet_Receive_AddressHeader: String { return self._s[1528]! } + public var Wallet_Send_AmountText: String { return self._s[1529]! } + public var Settings_About: String { return self._s[1530]! } public func Channel_AdminLog_MessageRestricted(_ _0: String, _ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1530]!, self._r[1530]!, [_0, _1, _2]) + return formatWithArgumentRanges(self._s[1531]!, self._r[1531]!, [_0, _1, _2]) } - public var ChatList_Context_MarkAsRead: String { return self._s[1532]! } - public var KeyCommand_NewMessage: String { return self._s[1533]! } - public var Group_ErrorAddBlocked: String { return self._s[1534]! } + public var ChatList_Context_MarkAsRead: String { return self._s[1533]! } + public var KeyCommand_NewMessage: String { return self._s[1534]! } + public var Group_ErrorAddBlocked: String { return self._s[1535]! } public func Message_PaymentSent(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1535]!, self._r[1535]!, [_0]) + return formatWithArgumentRanges(self._s[1536]!, self._r[1536]!, [_0]) } - public var Map_LocationTitle: String { return self._s[1536]! } - public var ReportGroupLocation_Title: String { return self._s[1537]! } - public var CallSettings_UseLessDataLongDescription: String { return self._s[1538]! } - public var Cache_ClearProgress: String { return self._s[1539]! } + public var Map_LocationTitle: String { return self._s[1537]! } + public var ReportGroupLocation_Title: String { return self._s[1538]! } + public var CallSettings_UseLessDataLongDescription: String { return self._s[1539]! } + public var Cache_ClearProgress: String { return self._s[1540]! } public func Channel_Management_ErrorNotMember(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1540]!, self._r[1540]!, [_0]) + return formatWithArgumentRanges(self._s[1541]!, self._r[1541]!, [_0]) } - public var GroupRemoved_AddToGroup: String { return self._s[1541]! } + public var GroupRemoved_AddToGroup: String { return self._s[1542]! } public func External_OpenIn(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1542]!, self._r[1542]!, [_0]) + return formatWithArgumentRanges(self._s[1543]!, self._r[1543]!, [_0]) } - public var Passport_UpdateRequiredError: String { return self._s[1543]! } - public var Wallet_SecureStorageNotAvailable_Text: String { return self._s[1544]! } + public var Passport_UpdateRequiredError: String { return self._s[1544]! } + public var Wallet_SecureStorageNotAvailable_Text: String { return self._s[1545]! } public func PUSH_MESSAGE_DOC(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1545]!, self._r[1545]!, [_1]) + return formatWithArgumentRanges(self._s[1546]!, self._r[1546]!, [_1]) } - public var Notifications_PermissionsSuppressWarningText: String { return self._s[1547]! } - public var Passport_Identity_MainPageHelp: String { return self._s[1548]! } - public var PeerInfo_ButtonSearch: String { return self._s[1549]! } - public var Conversation_StatusKickedFromGroup: String { return self._s[1550]! } - public var Passport_Language_ka: String { return self._s[1551]! } + public var Notifications_PermissionsSuppressWarningText: String { return self._s[1548]! } + public var Passport_Identity_MainPageHelp: String { return self._s[1549]! } + public var PeerInfo_ButtonSearch: String { return self._s[1550]! } + public var Conversation_StatusKickedFromGroup: String { return self._s[1551]! } + public var Passport_Language_ka: String { return self._s[1552]! } public func Wallet_Time_PreciseDate_m12(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1552]!, self._r[1552]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1553]!, self._r[1553]!, [_1, _2, _3]) } - public var Call_Decline: String { return self._s[1553]! } - public var SocksProxySetup_ProxyEnabled: String { return self._s[1554]! } - public var TwoFactorSetup_Email_SkipConfirmationText: String { return self._s[1557]! } + public var Call_Decline: String { return self._s[1554]! } + public var SocksProxySetup_ProxyEnabled: String { return self._s[1555]! } + public var TwoFactorSetup_Email_SkipConfirmationText: String { return self._s[1558]! } public func AuthCode_Alert(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1558]!, self._r[1558]!, [_0]) + return formatWithArgumentRanges(self._s[1559]!, self._r[1559]!, [_0]) } - public var CallFeedback_Send: String { return self._s[1559]! } - public var EditTheme_EditTitle: String { return self._s[1560]! } + public var CallFeedback_Send: String { return self._s[1560]! } + public var EditTheme_EditTitle: String { return self._s[1561]! } public func Channel_AdminLog_MessagePromotedNameUsername(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1561]!, self._r[1561]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1562]!, self._r[1562]!, [_1, _2]) } - public var Passport_Phone_UseTelegramNumberHelp: String { return self._s[1562]! } + public var Passport_Phone_UseTelegramNumberHelp: String { return self._s[1563]! } public func Wallet_Updated_TodayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1564]!, self._r[1564]!, [_0]) + return formatWithArgumentRanges(self._s[1565]!, self._r[1565]!, [_0]) } - public var SettingsSearch_Synonyms_Data_Title: String { return self._s[1565]! } - public var Passport_DeletePassport: String { return self._s[1566]! } - public var Appearance_AppIconFilled: String { return self._s[1567]! } - public var Privacy_Calls_P2PAlways: String { return self._s[1568]! } - public var Month_ShortDecember: String { return self._s[1569]! } - public var Channel_AdminLog_CanEditMessages: String { return self._s[1571]! } + public var SettingsSearch_Synonyms_Data_Title: String { return self._s[1566]! } + public var Passport_DeletePassport: String { return self._s[1567]! } + public var Appearance_AppIconFilled: String { return self._s[1568]! } + public var Privacy_Calls_P2PAlways: String { return self._s[1569]! } + public var Month_ShortDecember: String { return self._s[1570]! } + public var Channel_AdminLog_CanEditMessages: String { return self._s[1572]! } public func Contacts_AccessDeniedHelpLandscape(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1572]!, self._r[1572]!, [_0]) + return formatWithArgumentRanges(self._s[1573]!, self._r[1573]!, [_0]) } - public var Channel_Stickers_Searching: String { return self._s[1573]! } - public var Conversation_EncryptedDescription1: String { return self._s[1574]! } - public var Conversation_EncryptedDescription2: String { return self._s[1575]! } - public var PasscodeSettings_PasscodeOptions: String { return self._s[1576]! } - public var Conversation_EncryptedDescription3: String { return self._s[1578]! } - public var PhotoEditor_SharpenTool: String { return self._s[1579]! } - public var Wallet_Configuration_Title: String { return self._s[1580]! } + public var Channel_Stickers_Searching: String { return self._s[1574]! } + public var Conversation_EncryptedDescription1: String { return self._s[1575]! } + public var Conversation_EncryptedDescription2: String { return self._s[1576]! } + public var PasscodeSettings_PasscodeOptions: String { return self._s[1577]! } + public var Conversation_EncryptedDescription3: String { return self._s[1579]! } + public var PhotoEditor_SharpenTool: String { return self._s[1580]! } + public var Wallet_Configuration_Title: String { return self._s[1581]! } public func Conversation_AddNameToContacts(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1581]!, self._r[1581]!, [_0]) + return formatWithArgumentRanges(self._s[1582]!, self._r[1582]!, [_0]) } - public var Conversation_EncryptedDescription4: String { return self._s[1583]! } - public var Channel_Members_AddMembers: String { return self._s[1584]! } - public var Wallpaper_Search: String { return self._s[1585]! } - public var Weekday_Friday: String { return self._s[1587]! } - public var Privacy_ContactsSync: String { return self._s[1588]! } - public var SettingsSearch_Synonyms_Privacy_Data_ContactsReset: String { return self._s[1589]! } - public var ApplyLanguage_ChangeLanguageAction: String { return self._s[1590]! } + public var Conversation_EncryptedDescription4: String { return self._s[1584]! } + public var Channel_Members_AddMembers: String { return self._s[1585]! } + public var Wallpaper_Search: String { return self._s[1586]! } + public var Weekday_Friday: String { return self._s[1588]! } + public var Privacy_ContactsSync: String { return self._s[1589]! } + public var SettingsSearch_Synonyms_Privacy_Data_ContactsReset: String { return self._s[1590]! } + public var ApplyLanguage_ChangeLanguageAction: String { return self._s[1591]! } public func Channel_Management_RestrictedBy(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1591]!, self._r[1591]!, [_0]) + return formatWithArgumentRanges(self._s[1592]!, self._r[1592]!, [_0]) } - public var Wallet_Configuration_BlockchainIdHeader: String { return self._s[1592]! } - public var GroupInfo_Permissions_Removed: String { return self._s[1593]! } - public var ScheduledMessages_ScheduledOnline: String { return self._s[1594]! } - public var Passport_Identity_GenderMale: String { return self._s[1595]! } + public var Wallet_Configuration_BlockchainIdHeader: String { return self._s[1593]! } + public var GroupInfo_Permissions_Removed: String { return self._s[1594]! } + public var ScheduledMessages_ScheduledOnline: String { return self._s[1595]! } + public var Passport_Identity_GenderMale: String { return self._s[1596]! } public func Call_StatusBar(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1596]!, self._r[1596]!, [_0]) + return formatWithArgumentRanges(self._s[1597]!, self._r[1597]!, [_0]) } - public var Notifications_PermissionsKeepDisabled: String { return self._s[1597]! } - public var Conversation_JumpToDate: String { return self._s[1598]! } - public var Contacts_GlobalSearch: String { return self._s[1599]! } - public var AutoDownloadSettings_ResetHelp: String { return self._s[1600]! } - public var SettingsSearch_Synonyms_FAQ: String { return self._s[1601]! } - public var Profile_MessageLifetime1d: String { return self._s[1602]! } + public var Notifications_PermissionsKeepDisabled: String { return self._s[1598]! } + public var Conversation_JumpToDate: String { return self._s[1599]! } + public var Contacts_GlobalSearch: String { return self._s[1600]! } + public var AutoDownloadSettings_ResetHelp: String { return self._s[1601]! } + public var SettingsSearch_Synonyms_FAQ: String { return self._s[1602]! } + public var Profile_MessageLifetime1d: String { return self._s[1603]! } public func MESSAGE_INVOICE(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1603]!, self._r[1603]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1604]!, self._r[1604]!, [_1, _2]) } - public var StickerPack_BuiltinPackName: String { return self._s[1606]! } + public var StickerPack_BuiltinPackName: String { return self._s[1607]! } public func PUSH_CHAT_MESSAGE_AUDIO(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1607]!, self._r[1607]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1608]!, self._r[1608]!, [_1, _2]) } - public var VoiceOver_Chat_RecordModeVoiceMessageInfo: String { return self._s[1608]! } - public var Passport_InfoTitle: String { return self._s[1610]! } - public var Notifications_PermissionsUnreachableText: String { return self._s[1611]! } + public var VoiceOver_Chat_RecordModeVoiceMessageInfo: String { return self._s[1609]! } + public var Passport_InfoTitle: String { return self._s[1611]! } + public var Notifications_PermissionsUnreachableText: String { return self._s[1612]! } public func NetworkUsageSettings_CellularUsageSince(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1615]!, self._r[1615]!, [_0]) + return formatWithArgumentRanges(self._s[1616]!, self._r[1616]!, [_0]) } public func PUSH_CHAT_MESSAGE_GEO(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1616]!, self._r[1616]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1617]!, self._r[1617]!, [_1, _2]) } - public var Passport_Address_TypePassportRegistrationUploadScan: String { return self._s[1617]! } - public var Profile_BotInfo: String { return self._s[1618]! } - public var Watch_Compose_CreateMessage: String { return self._s[1619]! } - public var AutoDownloadSettings_VoiceMessagesInfo: String { return self._s[1620]! } - public var Month_ShortNovember: String { return self._s[1621]! } - public var Conversation_ScamWarning: String { return self._s[1622]! } - public var Wallpaper_SetCustomBackground: String { return self._s[1623]! } - public var Appearance_TextSize_Title: String { return self._s[1624]! } - public var Passport_Identity_TranslationsHelp: String { return self._s[1625]! } - public var NotificationsSound_Chime: String { return self._s[1626]! } - public var Passport_Language_ko: String { return self._s[1628]! } - public var InviteText_URL: String { return self._s[1629]! } - public var TextFormat_Monospace: String { return self._s[1630]! } + public var Passport_Address_TypePassportRegistrationUploadScan: String { return self._s[1618]! } + public var Profile_BotInfo: String { return self._s[1619]! } + public var Watch_Compose_CreateMessage: String { return self._s[1620]! } + public var AutoDownloadSettings_VoiceMessagesInfo: String { return self._s[1621]! } + public var Month_ShortNovember: String { return self._s[1622]! } + public var Conversation_ScamWarning: String { return self._s[1623]! } + public var Wallpaper_SetCustomBackground: String { return self._s[1624]! } + public var Appearance_TextSize_Title: String { return self._s[1625]! } + public var Passport_Identity_TranslationsHelp: String { return self._s[1626]! } + public var NotificationsSound_Chime: String { return self._s[1627]! } + public var Passport_Language_ko: String { return self._s[1629]! } + public var InviteText_URL: String { return self._s[1630]! } + public var TextFormat_Monospace: String { return self._s[1631]! } public func Time_PreciseDate_m11(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1631]!, self._r[1631]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1632]!, self._r[1632]!, [_1, _2, _3]) } - public var EditTheme_Edit_BottomInfo: String { return self._s[1632]! } + public var EditTheme_Edit_BottomInfo: String { return self._s[1633]! } public func Login_WillSendSms(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1633]!, self._r[1633]!, [_0]) + return formatWithArgumentRanges(self._s[1634]!, self._r[1634]!, [_0]) } public func Watch_Time_ShortWeekdayAt(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1634]!, self._r[1634]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1635]!, self._r[1635]!, [_1, _2]) } - public var Wallet_Words_Title: String { return self._s[1635]! } - public var Wallet_Month_ShortMay: String { return self._s[1636]! } - public var EditTheme_CreateTitle: String { return self._s[1638]! } - public var Passport_InfoLearnMore: String { return self._s[1639]! } - public var TwoStepAuth_EmailPlaceholder: String { return self._s[1640]! } - public var Passport_Identity_AddIdentityCard: String { return self._s[1641]! } - public var Your_card_has_expired: String { return self._s[1642]! } - public var StickerPacksSettings_StickerPacksSection: String { return self._s[1643]! } - public var GroupInfo_InviteLink_Help: String { return self._s[1644]! } - public var TwoFactorSetup_EmailVerification_ResendAction: String { return self._s[1648]! } - public var Conversation_Report: String { return self._s[1650]! } - public var Notifications_MessageNotificationsSound: String { return self._s[1651]! } - public var Notification_MessageLifetime1m: String { return self._s[1652]! } - public var Privacy_ContactsTitle: String { return self._s[1653]! } - public var Conversation_ShareMyContactInfo: String { return self._s[1654]! } - public var Wallet_WordCheck_Title: String { return self._s[1655]! } - public var ChannelMembers_WhoCanAddMembersAdminsHelp: String { return self._s[1656]! } - public var Channel_Members_Title: String { return self._s[1657]! } - public var Map_OpenInWaze: String { return self._s[1658]! } - public var Appearance_RemoveThemeColorConfirmation: String { return self._s[1659]! } - public var Login_PhoneBannedError: String { return self._s[1660]! } + public var Wallet_Words_Title: String { return self._s[1636]! } + public var Wallet_Month_ShortMay: String { return self._s[1637]! } + public var EditTheme_CreateTitle: String { return self._s[1639]! } + public var Passport_InfoLearnMore: String { return self._s[1640]! } + public var TwoStepAuth_EmailPlaceholder: String { return self._s[1641]! } + public var Passport_Identity_AddIdentityCard: String { return self._s[1642]! } + public var Your_card_has_expired: String { return self._s[1643]! } + public var StickerPacksSettings_StickerPacksSection: String { return self._s[1644]! } + public var GroupInfo_InviteLink_Help: String { return self._s[1645]! } + public var TwoFactorSetup_EmailVerification_ResendAction: String { return self._s[1649]! } + public var Conversation_Report: String { return self._s[1651]! } + public var Notifications_MessageNotificationsSound: String { return self._s[1652]! } + public var Notification_MessageLifetime1m: String { return self._s[1653]! } + public var Privacy_ContactsTitle: String { return self._s[1654]! } + public var Conversation_ShareMyContactInfo: String { return self._s[1655]! } + public var Wallet_WordCheck_Title: String { return self._s[1656]! } + public var ChannelMembers_WhoCanAddMembersAdminsHelp: String { return self._s[1657]! } + public var Channel_Members_Title: String { return self._s[1658]! } + public var Map_OpenInWaze: String { return self._s[1659]! } + public var Appearance_RemoveThemeColorConfirmation: String { return self._s[1660]! } + public var Login_PhoneBannedError: String { return self._s[1661]! } public func LiveLocationUpdated_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1661]!, self._r[1661]!, [_0]) + return formatWithArgumentRanges(self._s[1662]!, self._r[1662]!, [_0]) } - public var IntentsSettings_MainAccount: String { return self._s[1662]! } - public var Group_Management_AddModeratorHelp: String { return self._s[1663]! } - public var AutoDownloadSettings_WifiTitle: String { return self._s[1664]! } - public var Common_OK: String { return self._s[1665]! } - public var Passport_Address_TypeBankStatementUploadScan: String { return self._s[1666]! } - public var Wallet_Words_NotDoneResponse: String { return self._s[1667]! } - public var Cache_Music: String { return self._s[1668]! } - public var Wallet_Configuration_SourceURL: String { return self._s[1669]! } - public var SettingsSearch_Synonyms_EditProfile_PhoneNumber: String { return self._s[1670]! } - public var PasscodeSettings_UnlockWithTouchId: String { return self._s[1673]! } - public var ChatList_EmptyChatListEditFilter: String { return self._s[1674]! } - public var TwoStepAuth_HintPlaceholder: String { return self._s[1675]! } + public var IntentsSettings_MainAccount: String { return self._s[1663]! } + public var Group_Management_AddModeratorHelp: String { return self._s[1664]! } + public var AutoDownloadSettings_WifiTitle: String { return self._s[1665]! } + public var Common_OK: String { return self._s[1666]! } + public var Passport_Address_TypeBankStatementUploadScan: String { return self._s[1667]! } + public var Wallet_Words_NotDoneResponse: String { return self._s[1668]! } + public var Cache_Music: String { return self._s[1669]! } + public var Wallet_Configuration_SourceURL: String { return self._s[1670]! } + public var SettingsSearch_Synonyms_EditProfile_PhoneNumber: String { return self._s[1671]! } + public var PasscodeSettings_UnlockWithTouchId: String { return self._s[1674]! } + public var ChatList_EmptyChatListEditFilter: String { return self._s[1675]! } + public var TwoStepAuth_HintPlaceholder: String { return self._s[1676]! } public func PUSH_PINNED_INVOICE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1676]!, self._r[1676]!, [_1]) + return formatWithArgumentRanges(self._s[1677]!, self._r[1677]!, [_1]) } public func Passport_RequestHeader(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1677]!, self._r[1677]!, [_0]) + return formatWithArgumentRanges(self._s[1678]!, self._r[1678]!, [_0]) } - public var TwoFactorSetup_Done_Action: String { return self._s[1678]! } + public var TwoFactorSetup_Done_Action: String { return self._s[1679]! } public func VoiceOver_Chat_ContactOrganization(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1679]!, self._r[1679]!, [_0]) + return formatWithArgumentRanges(self._s[1680]!, self._r[1680]!, [_0]) } - public var Wallet_Send_ErrorNotEnoughFundsText: String { return self._s[1680]! } - public var Watch_MessageView_ViewOnPhone: String { return self._s[1682]! } - public var Privacy_Calls_CustomShareHelp: String { return self._s[1683]! } - public var Wallet_Receive_CreateInvoiceInfo: String { return self._s[1685]! } - public var ChangePhoneNumberNumber_Title: String { return self._s[1686]! } - public var State_ConnectingToProxyInfo: String { return self._s[1687]! } - public var Conversation_SwipeToReplyHintTitle: String { return self._s[1688]! } - public var Message_VideoMessage: String { return self._s[1690]! } - public var ChannelInfo_DeleteChannel: String { return self._s[1691]! } - public var ContactInfo_PhoneLabelOther: String { return self._s[1692]! } - public var Channel_EditAdmin_CannotEdit: String { return self._s[1693]! } - public var Passport_DeleteAddressConfirmation: String { return self._s[1694]! } + public var Wallet_Send_ErrorNotEnoughFundsText: String { return self._s[1681]! } + public var Watch_MessageView_ViewOnPhone: String { return self._s[1683]! } + public var Privacy_Calls_CustomShareHelp: String { return self._s[1684]! } + public var Wallet_Receive_CreateInvoiceInfo: String { return self._s[1686]! } + public var ChangePhoneNumberNumber_Title: String { return self._s[1687]! } + public var State_ConnectingToProxyInfo: String { return self._s[1688]! } + public var Conversation_SwipeToReplyHintTitle: String { return self._s[1689]! } + public var Message_VideoMessage: String { return self._s[1691]! } + public var ChannelInfo_DeleteChannel: String { return self._s[1692]! } + public var ContactInfo_PhoneLabelOther: String { return self._s[1693]! } + public var Channel_EditAdmin_CannotEdit: String { return self._s[1694]! } + public var Passport_DeleteAddressConfirmation: String { return self._s[1695]! } public func Wallet_Time_PreciseDate_m9(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1695]!, self._r[1695]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1696]!, self._r[1696]!, [_1, _2, _3]) } - public var WallpaperPreview_SwipeBottomText: String { return self._s[1696]! } - public var Activity_RecordingAudio: String { return self._s[1697]! } - public var SettingsSearch_Synonyms_Watch: String { return self._s[1698]! } - public var PasscodeSettings_TryAgainIn1Minute: String { return self._s[1699]! } - public var Wallet_Info_Address: String { return self._s[1700]! } + public var WallpaperPreview_SwipeBottomText: String { return self._s[1697]! } + public var Activity_RecordingAudio: String { return self._s[1698]! } + public var SettingsSearch_Synonyms_Watch: String { return self._s[1699]! } + public var PasscodeSettings_TryAgainIn1Minute: String { return self._s[1700]! } + public var Wallet_Info_Address: String { return self._s[1701]! } public func Notification_ChangedGroupName(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1702]!, self._r[1702]!, [_0, _1]) + return formatWithArgumentRanges(self._s[1703]!, self._r[1703]!, [_0, _1]) } public func EmptyGroupInfo_Line1(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1706]!, self._r[1706]!, [_0]) + return formatWithArgumentRanges(self._s[1707]!, self._r[1707]!, [_0]) } - public var Conversation_ApplyLocalization: String { return self._s[1707]! } - public var TwoFactorSetup_Intro_Action: String { return self._s[1708]! } - public var UserInfo_AddPhone: String { return self._s[1709]! } - public var Map_ShareLiveLocationHelp: String { return self._s[1710]! } + public var Conversation_ApplyLocalization: String { return self._s[1708]! } + public var TwoFactorSetup_Intro_Action: String { return self._s[1709]! } + public var UserInfo_AddPhone: String { return self._s[1710]! } + public var Map_ShareLiveLocationHelp: String { return self._s[1711]! } public func Passport_Identity_NativeNameGenericHelp(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1711]!, self._r[1711]!, [_0]) + return formatWithArgumentRanges(self._s[1712]!, self._r[1712]!, [_0]) } - public var Passport_Scans: String { return self._s[1713]! } - public var BlockedUsers_Unblock: String { return self._s[1714]! } + public var Passport_Scans: String { return self._s[1714]! } + public var BlockedUsers_Unblock: String { return self._s[1715]! } public func PUSH_ENCRYPTION_REQUEST(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1715]!, self._r[1715]!, [_1]) + return formatWithArgumentRanges(self._s[1716]!, self._r[1716]!, [_1]) } - public var Channel_Management_LabelCreator: String { return self._s[1716]! } - public var Conversation_ReportSpamAndLeave: String { return self._s[1717]! } - public var SettingsSearch_Synonyms_EditProfile_Bio: String { return self._s[1718]! } - public var ChatList_UndoArchiveMultipleTitle: String { return self._s[1719]! } - public var Passport_Identity_NativeNameGenericTitle: String { return self._s[1720]! } + public var Channel_Management_LabelCreator: String { return self._s[1717]! } + public var Conversation_ReportSpamAndLeave: String { return self._s[1718]! } + public var SettingsSearch_Synonyms_EditProfile_Bio: String { return self._s[1719]! } + public var ChatList_UndoArchiveMultipleTitle: String { return self._s[1720]! } + public var Passport_Identity_NativeNameGenericTitle: String { return self._s[1721]! } public func Login_EmailPhoneBody(_ _0: String, _ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1721]!, self._r[1721]!, [_0, _1, _2]) + return formatWithArgumentRanges(self._s[1722]!, self._r[1722]!, [_0, _1, _2]) } - public var Login_PhoneNumberHelp: String { return self._s[1722]! } - public var LastSeen_ALongTimeAgo: String { return self._s[1723]! } - public var Channel_AdminLog_CanPinMessages: String { return self._s[1724]! } - public var ChannelIntro_CreateChannel: String { return self._s[1725]! } - public var Conversation_UnreadMessages: String { return self._s[1726]! } - public var SettingsSearch_Synonyms_Stickers_ArchivedPacks: String { return self._s[1727]! } - public var Channel_AdminLog_EmptyText: String { return self._s[1728]! } - public var Theme_Context_Apply: String { return self._s[1729]! } - public var Notification_GroupActivated: String { return self._s[1730]! } - public var NotificationSettings_ContactJoinedInfo: String { return self._s[1731]! } - public var Wallet_Intro_CreateWallet: String { return self._s[1732]! } + public var Login_PhoneNumberHelp: String { return self._s[1723]! } + public var LastSeen_ALongTimeAgo: String { return self._s[1724]! } + public var Channel_AdminLog_CanPinMessages: String { return self._s[1725]! } + public var ChannelIntro_CreateChannel: String { return self._s[1726]! } + public var Conversation_UnreadMessages: String { return self._s[1727]! } + public var SettingsSearch_Synonyms_Stickers_ArchivedPacks: String { return self._s[1728]! } + public var Channel_AdminLog_EmptyText: String { return self._s[1729]! } + public var Theme_Context_Apply: String { return self._s[1730]! } + public var Notification_GroupActivated: String { return self._s[1731]! } + public var NotificationSettings_ContactJoinedInfo: String { return self._s[1732]! } + public var Wallet_Intro_CreateWallet: String { return self._s[1733]! } public func Notification_PinnedContactMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1733]!, self._r[1733]!, [_0]) + return formatWithArgumentRanges(self._s[1734]!, self._r[1734]!, [_0]) } public func DownloadingStatus(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1734]!, self._r[1734]!, [_0, _1]) + return formatWithArgumentRanges(self._s[1735]!, self._r[1735]!, [_0, _1]) } - public var GroupInfo_ConvertToSupergroup: String { return self._s[1736]! } + public var GroupInfo_ConvertToSupergroup: String { return self._s[1737]! } public func PrivacyPolicy_AgeVerificationMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1737]!, self._r[1737]!, [_0]) + return formatWithArgumentRanges(self._s[1738]!, self._r[1738]!, [_0]) } - public var Undo_DeletedChannel: String { return self._s[1738]! } - public var CallFeedback_AddComment: String { return self._s[1739]! } + public var Undo_DeletedChannel: String { return self._s[1739]! } + public var CallFeedback_AddComment: String { return self._s[1740]! } public func Conversation_OpenBotLinkAllowMessages(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1740]!, self._r[1740]!, [_0]) + return formatWithArgumentRanges(self._s[1741]!, self._r[1741]!, [_0]) } - public var Document_TargetConfirmationFormat: String { return self._s[1741]! } + public var Document_TargetConfirmationFormat: String { return self._s[1742]! } public func Call_StatusOngoing(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1742]!, self._r[1742]!, [_0]) + return formatWithArgumentRanges(self._s[1743]!, self._r[1743]!, [_0]) } - public var LogoutOptions_SetPasscodeTitle: String { return self._s[1743]! } + public var LogoutOptions_SetPasscodeTitle: String { return self._s[1744]! } public func PUSH_CHAT_MESSAGE_GAME_SCORE(_ _1: String, _ _2: String, _ _3: String, _ _4: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1744]!, self._r[1744]!, [_1, _2, _3, _4]) + return formatWithArgumentRanges(self._s[1745]!, self._r[1745]!, [_1, _2, _3, _4]) } - public var Wallet_SecureStorageChanged_PasscodeText: String { return self._s[1745]! } - public var Theme_ErrorNotFound: String { return self._s[1746]! } - public var Contacts_SortByName: String { return self._s[1747]! } - public var SettingsSearch_Synonyms_Privacy_Forwards: String { return self._s[1748]! } + public var Wallet_SecureStorageChanged_PasscodeText: String { return self._s[1746]! } + public var Theme_ErrorNotFound: String { return self._s[1747]! } + public var Contacts_SortByName: String { return self._s[1748]! } + public var SettingsSearch_Synonyms_Privacy_Forwards: String { return self._s[1749]! } public func CHAT_MESSAGE_INVOICE(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1750]!, self._r[1750]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1751]!, self._r[1751]!, [_1, _2, _3]) } - public var Notification_Exceptions_RemoveFromExceptions: String { return self._s[1751]! } - public var ScheduledMessages_EditTime: String { return self._s[1752]! } - public var Conversation_ClearSelfHistory: String { return self._s[1753]! } - public var Checkout_NewCard_PostcodePlaceholder: String { return self._s[1754]! } - public var PasscodeSettings_DoNotMatch: String { return self._s[1755]! } - public var Stickers_SuggestNone: String { return self._s[1756]! } - public var ChatSettings_Cache: String { return self._s[1757]! } - public var Settings_SaveIncomingPhotos: String { return self._s[1758]! } - public var Media_ShareThisPhoto: String { return self._s[1759]! } - public var Chat_SlowmodeTooltipPending: String { return self._s[1760]! } - public var InfoPlist_NSContactsUsageDescription: String { return self._s[1761]! } - public var Conversation_ContextMenuCopyLink: String { return self._s[1762]! } - public var PrivacyPolicy_AgeVerificationTitle: String { return self._s[1763]! } - public var SettingsSearch_Synonyms_Stickers_Masks: String { return self._s[1764]! } - public var TwoStepAuth_SetupPasswordEnterPasswordNew: String { return self._s[1765]! } - public var Appearance_ThemePreview_Chat_6_Text: String { return self._s[1766]! } + public var Notification_Exceptions_RemoveFromExceptions: String { return self._s[1752]! } + public var ScheduledMessages_EditTime: String { return self._s[1753]! } + public var Conversation_ClearSelfHistory: String { return self._s[1754]! } + public var Checkout_NewCard_PostcodePlaceholder: String { return self._s[1755]! } + public var PasscodeSettings_DoNotMatch: String { return self._s[1756]! } + public var Stickers_SuggestNone: String { return self._s[1757]! } + public var ChatSettings_Cache: String { return self._s[1758]! } + public var Settings_SaveIncomingPhotos: String { return self._s[1759]! } + public var Media_ShareThisPhoto: String { return self._s[1760]! } + public var Chat_SlowmodeTooltipPending: String { return self._s[1761]! } + public var InfoPlist_NSContactsUsageDescription: String { return self._s[1762]! } + public var Conversation_ContextMenuCopyLink: String { return self._s[1763]! } + public var PrivacyPolicy_AgeVerificationTitle: String { return self._s[1764]! } + public var SettingsSearch_Synonyms_Stickers_Masks: String { return self._s[1765]! } + public var TwoStepAuth_SetupPasswordEnterPasswordNew: String { return self._s[1766]! } + public var Appearance_ThemePreview_Chat_6_Text: String { return self._s[1767]! } public func Wallet_SecureStorageReset_BiometryText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1767]!, self._r[1767]!, [_0]) + return formatWithArgumentRanges(self._s[1768]!, self._r[1768]!, [_0]) } - public var Permissions_CellularDataTitle_v0: String { return self._s[1768]! } - public var WallpaperSearch_ColorWhite: String { return self._s[1770]! } - public var Channel_AdminLog_DefaultRestrictionsUpdated: String { return self._s[1771]! } - public var Conversation_ErrorInaccessibleMessage: String { return self._s[1772]! } - public var Map_OpenIn: String { return self._s[1773]! } - public var PeerInfo_ButtonCall: String { return self._s[1774]! } + public var Permissions_CellularDataTitle_v0: String { return self._s[1769]! } + public var WallpaperSearch_ColorWhite: String { return self._s[1771]! } + public var Channel_AdminLog_DefaultRestrictionsUpdated: String { return self._s[1772]! } + public var Conversation_ErrorInaccessibleMessage: String { return self._s[1773]! } + public var Map_OpenIn: String { return self._s[1774]! } + public var PeerInfo_ButtonCall: String { return self._s[1775]! } public func PUSH_PHONE_CALL_MISSED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1777]!, self._r[1777]!, [_1]) + return formatWithArgumentRanges(self._s[1778]!, self._r[1778]!, [_1]) } public func ChannelInfo_AddParticipantConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1778]!, self._r[1778]!, [_0]) + return formatWithArgumentRanges(self._s[1779]!, self._r[1779]!, [_0]) } - public var GroupInfo_Permissions_SlowmodeHeader: String { return self._s[1779]! } - public var MessagePoll_LabelClosed: String { return self._s[1780]! } - public var GroupPermission_PermissionGloballyDisabled: String { return self._s[1782]! } - public var Wallet_Send_SendAnyway: String { return self._s[1783]! } - public var Passport_Identity_MiddleNamePlaceholder: String { return self._s[1784]! } - public var UserInfo_FirstNamePlaceholder: String { return self._s[1785]! } - public var PrivacyLastSeenSettings_WhoCanSeeMyTimestamp: String { return self._s[1786]! } - public var Map_SetThisPlace: String { return self._s[1787]! } - public var Login_SelectCountry_Title: String { return self._s[1788]! } - public var Channel_EditAdmin_PermissionBanUsers: String { return self._s[1789]! } + public var GroupInfo_Permissions_SlowmodeHeader: String { return self._s[1780]! } + public var MessagePoll_LabelClosed: String { return self._s[1781]! } + public var GroupPermission_PermissionGloballyDisabled: String { return self._s[1783]! } + public var Wallet_Send_SendAnyway: String { return self._s[1784]! } + public var Passport_Identity_MiddleNamePlaceholder: String { return self._s[1785]! } + public var UserInfo_FirstNamePlaceholder: String { return self._s[1786]! } + public var PrivacyLastSeenSettings_WhoCanSeeMyTimestamp: String { return self._s[1787]! } + public var Map_SetThisPlace: String { return self._s[1788]! } + public var Login_SelectCountry_Title: String { return self._s[1789]! } + public var Channel_EditAdmin_PermissionBanUsers: String { return self._s[1790]! } public func Conversation_OpenBotLinkLogin(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1790]!, self._r[1790]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1791]!, self._r[1791]!, [_1, _2]) } - public var Channel_AdminLog_ChangeInfo: String { return self._s[1791]! } - public var Watch_Suggestion_BRB: String { return self._s[1792]! } - public var Passport_Identity_EditIdentityCard: String { return self._s[1793]! } - public var Contacts_PermissionsTitle: String { return self._s[1794]! } - public var Conversation_RestrictedInline: String { return self._s[1795]! } - public var Appearance_RemoveThemeColor: String { return self._s[1797]! } - public var StickerPack_ViewPack: String { return self._s[1798]! } - public var Wallet_UnknownError: String { return self._s[1799]! } + public var Channel_AdminLog_ChangeInfo: String { return self._s[1792]! } + public var Watch_Suggestion_BRB: String { return self._s[1793]! } + public var Passport_Identity_EditIdentityCard: String { return self._s[1794]! } + public var Contacts_PermissionsTitle: String { return self._s[1795]! } + public var Conversation_RestrictedInline: String { return self._s[1796]! } + public var Appearance_RemoveThemeColor: String { return self._s[1798]! } + public var StickerPack_ViewPack: String { return self._s[1799]! } + public var Wallet_UnknownError: String { return self._s[1800]! } public func Update_AppVersion(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1800]!, self._r[1800]!, [_0]) + return formatWithArgumentRanges(self._s[1801]!, self._r[1801]!, [_0]) } - public var Compose_NewChannel: String { return self._s[1802]! } - public var ChatSettings_AutoDownloadSettings_TypePhoto: String { return self._s[1805]! } - public var MessagePoll_LabelQuiz: String { return self._s[1807]! } - public var Conversation_ReportSpamGroupConfirmation: String { return self._s[1808]! } - public var Channel_Info_Stickers: String { return self._s[1809]! } - public var AutoNightTheme_PreferredTheme: String { return self._s[1810]! } - public var PrivacyPolicy_AgeVerificationAgree: String { return self._s[1811]! } - public var Passport_DeletePersonalDetails: String { return self._s[1812]! } - public var LogoutOptions_AddAccountTitle: String { return self._s[1813]! } - public var Channel_DiscussionGroupInfo: String { return self._s[1814]! } - public var Group_EditAdmin_RankOwnerPlaceholder: String { return self._s[1815]! } - public var Conversation_SearchNoResults: String { return self._s[1818]! } - public var Wallet_Configuration_ApplyErrorTextURLInvalid: String { return self._s[1819]! } - public var MessagePoll_LabelAnonymous: String { return self._s[1820]! } - public var Channel_Members_AddAdminErrorNotAMember: String { return self._s[1821]! } - public var Login_Code: String { return self._s[1822]! } - public var EditTheme_Create_BottomInfo: String { return self._s[1823]! } - public var Watch_Suggestion_WhatsUp: String { return self._s[1824]! } - public var Weekday_ShortThursday: String { return self._s[1825]! } - public var Resolve_ErrorNotFound: String { return self._s[1827]! } - public var LastSeen_Offline: String { return self._s[1828]! } - public var PeopleNearby_NoMembers: String { return self._s[1829]! } - public var GroupPermission_AddMembersNotAvailable: String { return self._s[1830]! } - public var Privacy_Calls_AlwaysAllow_Title: String { return self._s[1831]! } - public var GroupInfo_Title: String { return self._s[1833]! } - public var NotificationsSound_Note: String { return self._s[1834]! } - public var Conversation_EditingMessagePanelTitle: String { return self._s[1835]! } - public var Watch_Message_Poll: String { return self._s[1836]! } - public var Privacy_Calls: String { return self._s[1837]! } + public var Compose_NewChannel: String { return self._s[1803]! } + public var ChatSettings_AutoDownloadSettings_TypePhoto: String { return self._s[1806]! } + public var MessagePoll_LabelQuiz: String { return self._s[1808]! } + public var Conversation_ReportSpamGroupConfirmation: String { return self._s[1809]! } + public var Channel_Info_Stickers: String { return self._s[1810]! } + public var AutoNightTheme_PreferredTheme: String { return self._s[1811]! } + public var PrivacyPolicy_AgeVerificationAgree: String { return self._s[1812]! } + public var Passport_DeletePersonalDetails: String { return self._s[1813]! } + public var LogoutOptions_AddAccountTitle: String { return self._s[1814]! } + public var Channel_DiscussionGroupInfo: String { return self._s[1815]! } + public var Group_EditAdmin_RankOwnerPlaceholder: String { return self._s[1816]! } + public var Conversation_SearchNoResults: String { return self._s[1819]! } + public var Wallet_Configuration_ApplyErrorTextURLInvalid: String { return self._s[1820]! } + public var MessagePoll_LabelAnonymous: String { return self._s[1821]! } + public var Channel_Members_AddAdminErrorNotAMember: String { return self._s[1822]! } + public var Login_Code: String { return self._s[1823]! } + public var EditTheme_Create_BottomInfo: String { return self._s[1824]! } + public var Watch_Suggestion_WhatsUp: String { return self._s[1825]! } + public var Weekday_ShortThursday: String { return self._s[1826]! } + public var Resolve_ErrorNotFound: String { return self._s[1828]! } + public var LastSeen_Offline: String { return self._s[1829]! } + public var PeopleNearby_NoMembers: String { return self._s[1830]! } + public var GroupPermission_AddMembersNotAvailable: String { return self._s[1831]! } + public var Privacy_Calls_AlwaysAllow_Title: String { return self._s[1832]! } + public var GroupInfo_Title: String { return self._s[1834]! } + public var NotificationsSound_Note: String { return self._s[1835]! } + public var Conversation_EditingMessagePanelTitle: String { return self._s[1836]! } + public var Watch_Message_Poll: String { return self._s[1837]! } + public var Privacy_Calls: String { return self._s[1838]! } public func Channel_AdminLog_MessageRankUsername(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1838]!, self._r[1838]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1839]!, self._r[1839]!, [_1, _2, _3]) } - public var Month_ShortAugust: String { return self._s[1839]! } - public var TwoStepAuth_SetPasswordHelp: String { return self._s[1840]! } - public var Notifications_Reset: String { return self._s[1841]! } - public var Conversation_Pin: String { return self._s[1842]! } - public var Passport_Language_lv: String { return self._s[1843]! } - public var Permissions_PeopleNearbyAllowInSettings_v0: String { return self._s[1844]! } - public var BlockedUsers_Info: String { return self._s[1845]! } - public var SettingsSearch_Synonyms_Data_AutoplayVideos: String { return self._s[1847]! } - public var Watch_Conversation_Unblock: String { return self._s[1849]! } + public var Month_ShortAugust: String { return self._s[1840]! } + public var TwoStepAuth_SetPasswordHelp: String { return self._s[1841]! } + public var Notifications_Reset: String { return self._s[1842]! } + public var Conversation_Pin: String { return self._s[1843]! } + public var Passport_Language_lv: String { return self._s[1844]! } + public var Permissions_PeopleNearbyAllowInSettings_v0: String { return self._s[1845]! } + public var BlockedUsers_Info: String { return self._s[1846]! } + public var SettingsSearch_Synonyms_Data_AutoplayVideos: String { return self._s[1848]! } + public var Watch_Conversation_Unblock: String { return self._s[1850]! } public func Time_MonthOfYear_m9(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1850]!, self._r[1850]!, [_0]) + return formatWithArgumentRanges(self._s[1851]!, self._r[1851]!, [_0]) } - public var CloudStorage_Title: String { return self._s[1851]! } - public var GroupInfo_DeleteAndExitConfirmation: String { return self._s[1852]! } + public var CloudStorage_Title: String { return self._s[1852]! } + public var GroupInfo_DeleteAndExitConfirmation: String { return self._s[1853]! } public func NetworkUsageSettings_WifiUsageSince(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1853]!, self._r[1853]!, [_0]) + return formatWithArgumentRanges(self._s[1854]!, self._r[1854]!, [_0]) } - public var Channel_AdminLogFilter_AdminsTitle: String { return self._s[1854]! } - public var Watch_Suggestion_OnMyWay: String { return self._s[1855]! } - public var TwoStepAuth_RecoveryEmailTitle: String { return self._s[1856]! } - public var Passport_Address_EditBankStatement: String { return self._s[1857]! } + public var Channel_AdminLogFilter_AdminsTitle: String { return self._s[1855]! } + public var Watch_Suggestion_OnMyWay: String { return self._s[1856]! } + public var TwoStepAuth_RecoveryEmailTitle: String { return self._s[1857]! } + public var Passport_Address_EditBankStatement: String { return self._s[1858]! } public func Channel_AdminLog_MessageChangedUnlinkedGroup(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1858]!, self._r[1858]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1859]!, self._r[1859]!, [_1, _2]) } - public var ChatSettings_DownloadInBackgroundInfo: String { return self._s[1859]! } - public var ShareMenu_Comment: String { return self._s[1860]! } - public var Permissions_ContactsTitle_v0: String { return self._s[1861]! } - public var Notifications_PermissionsTitle: String { return self._s[1862]! } - public var GroupPermission_NoSendLinks: String { return self._s[1863]! } - public var Privacy_Forwards_NeverAllow_Title: String { return self._s[1864]! } - public var Wallet_SecureStorageChanged_ImportWallet: String { return self._s[1865]! } - public var PeerInfo_PaneLinks: String { return self._s[1866]! } - public var Settings_Support: String { return self._s[1867]! } - public var Notifications_ChannelNotificationsSound: String { return self._s[1868]! } - public var SettingsSearch_Synonyms_Data_AutoDownloadReset: String { return self._s[1869]! } - public var Privacy_Forwards_Preview: String { return self._s[1870]! } - public var GroupPermission_ApplyAlertAction: String { return self._s[1871]! } - public var Watch_Stickers_StickerPacks: String { return self._s[1872]! } - public var Common_Select: String { return self._s[1874]! } - public var CheckoutInfo_ErrorEmailInvalid: String { return self._s[1875]! } - public var WallpaperSearch_ColorGray: String { return self._s[1878]! } - public var TwoFactorSetup_Password_PlaceholderPassword: String { return self._s[1879]! } - public var TwoFactorSetup_Hint_SkipAction: String { return self._s[1880]! } - public var ChatAdmins_AllMembersAreAdminsOffHelp: String { return self._s[1881]! } - public var PollResults_Title: String { return self._s[1882]! } - public var PasscodeSettings_AutoLock_IfAwayFor_5hours: String { return self._s[1883]! } - public var Appearance_PreviewReplyAuthor: String { return self._s[1884]! } - public var TwoStepAuth_RecoveryTitle: String { return self._s[1885]! } - public var Widget_AuthRequired: String { return self._s[1886]! } - public var Camera_FlashOn: String { return self._s[1887]! } - public var Conversation_ContextMenuLookUp: String { return self._s[1888]! } - public var Channel_Stickers_NotFoundHelp: String { return self._s[1889]! } - public var Watch_Suggestion_OK: String { return self._s[1890]! } + public var ChatSettings_DownloadInBackgroundInfo: String { return self._s[1860]! } + public var ShareMenu_Comment: String { return self._s[1861]! } + public var Permissions_ContactsTitle_v0: String { return self._s[1862]! } + public var Notifications_PermissionsTitle: String { return self._s[1863]! } + public var GroupPermission_NoSendLinks: String { return self._s[1864]! } + public var Privacy_Forwards_NeverAllow_Title: String { return self._s[1865]! } + public var Wallet_SecureStorageChanged_ImportWallet: String { return self._s[1866]! } + public var PeerInfo_PaneLinks: String { return self._s[1867]! } + public var Settings_Support: String { return self._s[1868]! } + public var Notifications_ChannelNotificationsSound: String { return self._s[1869]! } + public var SettingsSearch_Synonyms_Data_AutoDownloadReset: String { return self._s[1870]! } + public var Privacy_Forwards_Preview: String { return self._s[1871]! } + public var GroupPermission_ApplyAlertAction: String { return self._s[1872]! } + public var Watch_Stickers_StickerPacks: String { return self._s[1873]! } + public var Common_Select: String { return self._s[1875]! } + public var CheckoutInfo_ErrorEmailInvalid: String { return self._s[1876]! } + public var WallpaperSearch_ColorGray: String { return self._s[1879]! } + public var TwoFactorSetup_Password_PlaceholderPassword: String { return self._s[1880]! } + public var TwoFactorSetup_Hint_SkipAction: String { return self._s[1881]! } + public var ChatAdmins_AllMembersAreAdminsOffHelp: String { return self._s[1882]! } + public var PollResults_Title: String { return self._s[1883]! } + public var PasscodeSettings_AutoLock_IfAwayFor_5hours: String { return self._s[1884]! } + public var Appearance_PreviewReplyAuthor: String { return self._s[1885]! } + public var TwoStepAuth_RecoveryTitle: String { return self._s[1886]! } + public var Widget_AuthRequired: String { return self._s[1887]! } + public var Camera_FlashOn: String { return self._s[1888]! } + public var Conversation_ContextMenuLookUp: String { return self._s[1889]! } + public var Channel_Stickers_NotFoundHelp: String { return self._s[1890]! } + public var Watch_Suggestion_OK: String { return self._s[1891]! } public func Username_LinkHint(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1892]!, self._r[1892]!, [_0]) + return formatWithArgumentRanges(self._s[1893]!, self._r[1893]!, [_0]) } public func Notification_PinnedLiveLocationMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1894]!, self._r[1894]!, [_0]) + return formatWithArgumentRanges(self._s[1895]!, self._r[1895]!, [_0]) } - public var TextFormat_Strikethrough: String { return self._s[1895]! } - public var DialogList_AdLabel: String { return self._s[1896]! } - public var WatchRemote_NotificationText: String { return self._s[1897]! } - public var IntentsSettings_SuggestedChatsSavedMessages: String { return self._s[1898]! } - public var SettingsSearch_Synonyms_Notifications_MessageNotificationsAlert: String { return self._s[1899]! } - public var Conversation_ReportSpam: String { return self._s[1900]! } - public var SettingsSearch_Synonyms_Privacy_Data_TopPeers: String { return self._s[1901]! } - public var Settings_LogoutConfirmationTitle: String { return self._s[1903]! } - public var PhoneLabel_Title: String { return self._s[1904]! } - public var Passport_Address_EditRentalAgreement: String { return self._s[1905]! } - public var Settings_ChangePhoneNumber: String { return self._s[1906]! } - public var Notifications_ExceptionsTitle: String { return self._s[1907]! } - public var Notifications_AlertTones: String { return self._s[1908]! } - public var Call_ReportIncludeLogDescription: String { return self._s[1909]! } - public var SettingsSearch_Synonyms_Notifications_ResetAllNotifications: String { return self._s[1910]! } - public var AutoDownloadSettings_PrivateChats: String { return self._s[1911]! } - public var VoiceOver_Chat_Photo: String { return self._s[1913]! } - public var TwoStepAuth_AddHintTitle: String { return self._s[1914]! } - public var ReportPeer_ReasonOther: String { return self._s[1915]! } - public var ChatList_Context_JoinChannel: String { return self._s[1916]! } - public var KeyCommand_ScrollDown: String { return self._s[1918]! } - public var Conversation_ScheduleMessage_Title: String { return self._s[1919]! } + public var TextFormat_Strikethrough: String { return self._s[1896]! } + public var DialogList_AdLabel: String { return self._s[1897]! } + public var WatchRemote_NotificationText: String { return self._s[1898]! } + public var IntentsSettings_SuggestedChatsSavedMessages: String { return self._s[1899]! } + public var SettingsSearch_Synonyms_Notifications_MessageNotificationsAlert: String { return self._s[1900]! } + public var Conversation_ReportSpam: String { return self._s[1901]! } + public var SettingsSearch_Synonyms_Privacy_Data_TopPeers: String { return self._s[1902]! } + public var Settings_LogoutConfirmationTitle: String { return self._s[1904]! } + public var PhoneLabel_Title: String { return self._s[1905]! } + public var Passport_Address_EditRentalAgreement: String { return self._s[1906]! } + public var Settings_ChangePhoneNumber: String { return self._s[1907]! } + public var Notifications_ExceptionsTitle: String { return self._s[1908]! } + public var Notifications_AlertTones: String { return self._s[1909]! } + public var Call_ReportIncludeLogDescription: String { return self._s[1910]! } + public var SettingsSearch_Synonyms_Notifications_ResetAllNotifications: String { return self._s[1911]! } + public var AutoDownloadSettings_PrivateChats: String { return self._s[1912]! } + public var VoiceOver_Chat_Photo: String { return self._s[1914]! } + public var TwoStepAuth_AddHintTitle: String { return self._s[1915]! } + public var ReportPeer_ReasonOther: String { return self._s[1916]! } + public var ChatList_Context_JoinChannel: String { return self._s[1917]! } + public var KeyCommand_ScrollDown: String { return self._s[1919]! } + public var Conversation_ScheduleMessage_Title: String { return self._s[1920]! } public func Login_BannedPhoneSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1920]!, self._r[1920]!, [_0]) + return formatWithArgumentRanges(self._s[1921]!, self._r[1921]!, [_0]) } - public var NetworkUsageSettings_MediaVideoDataSection: String { return self._s[1921]! } - public var ChannelInfo_DeleteGroupConfirmation: String { return self._s[1922]! } - public var AuthSessions_LogOut: String { return self._s[1923]! } - public var Passport_Identity_TypeInternalPassport: String { return self._s[1924]! } - public var ChatSettings_AutoDownloadVoiceMessages: String { return self._s[1925]! } - public var Passport_Phone_Title: String { return self._s[1926]! } - public var ContactList_Context_StartSecretChat: String { return self._s[1927]! } - public var Settings_PhoneNumber: String { return self._s[1928]! } + public var NetworkUsageSettings_MediaVideoDataSection: String { return self._s[1922]! } + public var ChannelInfo_DeleteGroupConfirmation: String { return self._s[1923]! } + public var AuthSessions_LogOut: String { return self._s[1924]! } + public var Passport_Identity_TypeInternalPassport: String { return self._s[1925]! } + public var ChatSettings_AutoDownloadVoiceMessages: String { return self._s[1926]! } + public var Passport_Phone_Title: String { return self._s[1927]! } + public var ContactList_Context_StartSecretChat: String { return self._s[1928]! } + public var Settings_PhoneNumber: String { return self._s[1929]! } public func Conversation_ScheduleMessage_SendToday(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1929]!, self._r[1929]!, [_0]) + return formatWithArgumentRanges(self._s[1930]!, self._r[1930]!, [_0]) } - public var NotificationsSound_Alert: String { return self._s[1931]! } - public var Wallet_SecureStorageChanged_CreateWallet: String { return self._s[1932]! } - public var WebSearch_SearchNoResults: String { return self._s[1933]! } - public var Privacy_ProfilePhoto_AlwaysShareWith_Title: String { return self._s[1935]! } - public var Wallet_Configuration_SourceInfo: String { return self._s[1936]! } - public var LogoutOptions_AlternativeOptionsSection: String { return self._s[1937]! } - public var SettingsSearch_Synonyms_Passport: String { return self._s[1938]! } - public var PhotoEditor_CurvesTool: String { return self._s[1939]! } - public var Checkout_PaymentMethod: String { return self._s[1941]! } + public var NotificationsSound_Alert: String { return self._s[1932]! } + public var Wallet_SecureStorageChanged_CreateWallet: String { return self._s[1933]! } + public var WebSearch_SearchNoResults: String { return self._s[1934]! } + public var Privacy_ProfilePhoto_AlwaysShareWith_Title: String { return self._s[1936]! } + public var Wallet_Configuration_SourceInfo: String { return self._s[1937]! } + public var LogoutOptions_AlternativeOptionsSection: String { return self._s[1938]! } + public var SettingsSearch_Synonyms_Passport: String { return self._s[1939]! } + public var PhotoEditor_CurvesTool: String { return self._s[1940]! } + public var Checkout_PaymentMethod: String { return self._s[1942]! } public func PUSH_CHAT_ADD_YOU(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1942]!, self._r[1942]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1943]!, self._r[1943]!, [_1, _2]) } - public var Contacts_AccessDeniedError: String { return self._s[1943]! } - public var Camera_PhotoMode: String { return self._s[1946]! } - public var EditTheme_Expand_Preview_IncomingText: String { return self._s[1947]! } - public var Appearance_TextSize_Apply: String { return self._s[1948]! } - public var Passport_Address_AddUtilityBill: String { return self._s[1950]! } - public var CallSettings_OnMobile: String { return self._s[1951]! } - public var Tour_Text2: String { return self._s[1952]! } + public var Contacts_AccessDeniedError: String { return self._s[1944]! } + public var Camera_PhotoMode: String { return self._s[1947]! } + public var EditTheme_Expand_Preview_IncomingText: String { return self._s[1948]! } + public var Appearance_TextSize_Apply: String { return self._s[1949]! } + public var Passport_Address_AddUtilityBill: String { return self._s[1951]! } + public var CallSettings_OnMobile: String { return self._s[1952]! } + public var Tour_Text2: String { return self._s[1953]! } public func PUSH_CHAT_MESSAGE_ROUND(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1953]!, self._r[1953]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1954]!, self._r[1954]!, [_1, _2]) } - public var DialogList_EncryptionProcessing: String { return self._s[1955]! } - public var Permissions_Skip: String { return self._s[1956]! } - public var Wallet_Words_NotDoneOk: String { return self._s[1957]! } - public var SecretImage_Title: String { return self._s[1958]! } - public var Watch_MessageView_Title: String { return self._s[1959]! } - public var Channel_DiscussionGroupAdd: String { return self._s[1960]! } - public var AttachmentMenu_Poll: String { return self._s[1961]! } + public var DialogList_EncryptionProcessing: String { return self._s[1956]! } + public var Permissions_Skip: String { return self._s[1957]! } + public var Wallet_Words_NotDoneOk: String { return self._s[1958]! } + public var SecretImage_Title: String { return self._s[1959]! } + public var Watch_MessageView_Title: String { return self._s[1960]! } + public var Channel_DiscussionGroupAdd: String { return self._s[1961]! } + public var AttachmentMenu_Poll: String { return self._s[1962]! } public func Notification_GroupInviter(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1962]!, self._r[1962]!, [_0]) + return formatWithArgumentRanges(self._s[1963]!, self._r[1963]!, [_0]) } public func Channel_DiscussionGroup_PrivateChannelLink(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1963]!, self._r[1963]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1964]!, self._r[1964]!, [_1, _2]) } - public var Notification_CallCanceled: String { return self._s[1964]! } - public var WallpaperPreview_Title: String { return self._s[1965]! } - public var Privacy_PaymentsClear_PaymentInfo: String { return self._s[1966]! } - public var Settings_ProxyConnecting: String { return self._s[1967]! } - public var Settings_CheckPhoneNumberText: String { return self._s[1969]! } - public var VoiceOver_Chat_YourVideo: String { return self._s[1970]! } - public var Wallet_Intro_Title: String { return self._s[1971]! } - public var TwoFactorSetup_Password_Action: String { return self._s[1972]! } - public var Profile_MessageLifetime5s: String { return self._s[1973]! } - public var Username_InvalidCharacters: String { return self._s[1974]! } - public var VoiceOver_Media_PlaybackRateFast: String { return self._s[1975]! } - public var ScheduledMessages_ClearAll: String { return self._s[1976]! } - public var WallpaperPreview_CropBottomText: String { return self._s[1977]! } - public var AutoDownloadSettings_LimitBySize: String { return self._s[1978]! } - public var Settings_AddAccount: String { return self._s[1979]! } - public var Notification_CreatedChannel: String { return self._s[1982]! } + public var Notification_CallCanceled: String { return self._s[1965]! } + public var WallpaperPreview_Title: String { return self._s[1966]! } + public var Privacy_PaymentsClear_PaymentInfo: String { return self._s[1967]! } + public var Settings_ProxyConnecting: String { return self._s[1968]! } + public var Settings_CheckPhoneNumberText: String { return self._s[1970]! } + public var VoiceOver_Chat_YourVideo: String { return self._s[1971]! } + public var Wallet_Intro_Title: String { return self._s[1972]! } + public var TwoFactorSetup_Password_Action: String { return self._s[1973]! } + public var Profile_MessageLifetime5s: String { return self._s[1974]! } + public var Username_InvalidCharacters: String { return self._s[1975]! } + public var VoiceOver_Media_PlaybackRateFast: String { return self._s[1976]! } + public var ScheduledMessages_ClearAll: String { return self._s[1977]! } + public var WallpaperPreview_CropBottomText: String { return self._s[1978]! } + public var AutoDownloadSettings_LimitBySize: String { return self._s[1979]! } + public var Settings_AddAccount: String { return self._s[1980]! } + public var Notification_CreatedChannel: String { return self._s[1983]! } public func PUSH_CHAT_DELETE_MEMBER(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1983]!, self._r[1983]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1984]!, self._r[1984]!, [_1, _2, _3]) } - public var Passcode_AppLockedAlert: String { return self._s[1985]! } - public var StickerPacksSettings_AnimatedStickersInfo: String { return self._s[1986]! } - public var VoiceOver_Media_PlaybackStop: String { return self._s[1987]! } - public var Contacts_TopSection: String { return self._s[1988]! } - public var ChatList_DeleteForEveryoneConfirmationAction: String { return self._s[1989]! } + public var Passcode_AppLockedAlert: String { return self._s[1986]! } + public var StickerPacksSettings_AnimatedStickersInfo: String { return self._s[1987]! } + public var VoiceOver_Media_PlaybackStop: String { return self._s[1988]! } + public var Contacts_TopSection: String { return self._s[1989]! } + public var ChatList_DeleteForEveryoneConfirmationAction: String { return self._s[1990]! } public func Conversation_SetReminder_RemindOn(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1990]!, self._r[1990]!, [_0, _1]) + return formatWithArgumentRanges(self._s[1991]!, self._r[1991]!, [_0, _1]) } - public var Wallet_Info_Receive: String { return self._s[1991]! } - public var Wallet_Completed_ViewWallet: String { return self._s[1992]! } + public var Wallet_Info_Receive: String { return self._s[1992]! } + public var Wallet_Completed_ViewWallet: String { return self._s[1993]! } public func Time_MonthOfYear_m6(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1993]!, self._r[1993]!, [_0]) + return formatWithArgumentRanges(self._s[1994]!, self._r[1994]!, [_0]) } - public var ReportPeer_ReasonSpam: String { return self._s[1994]! } - public var UserInfo_TapToCall: String { return self._s[1995]! } - public var Conversation_ForwardAuthorHiddenTooltip: String { return self._s[1997]! } - public var AutoDownloadSettings_DataUsageCustom: String { return self._s[1998]! } - public var Common_Search: String { return self._s[1999]! } - public var ScheduledMessages_EmptyPlaceholder: String { return self._s[2000]! } + public var ReportPeer_ReasonSpam: String { return self._s[1995]! } + public var UserInfo_TapToCall: String { return self._s[1996]! } + public var Conversation_ForwardAuthorHiddenTooltip: String { return self._s[1998]! } + public var AutoDownloadSettings_DataUsageCustom: String { return self._s[1999]! } + public var Common_Search: String { return self._s[2000]! } + public var ScheduledMessages_EmptyPlaceholder: String { return self._s[2001]! } public func Channel_AdminLog_MessageChangedGroupGeoLocation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2001]!, self._r[2001]!, [_0]) + return formatWithArgumentRanges(self._s[2002]!, self._r[2002]!, [_0]) } - public var Wallet_Month_ShortJuly: String { return self._s[2002]! } - public var AuthSessions_IncompleteAttemptsInfo: String { return self._s[2004]! } - public var Message_InvoiceLabel: String { return self._s[2005]! } - public var Conversation_InputTextPlaceholder: String { return self._s[2006]! } - public var NetworkUsageSettings_MediaImageDataSection: String { return self._s[2007]! } + public var Wallet_Month_ShortJuly: String { return self._s[2003]! } + public var AuthSessions_IncompleteAttemptsInfo: String { return self._s[2005]! } + public var Message_InvoiceLabel: String { return self._s[2006]! } + public var Conversation_InputTextPlaceholder: String { return self._s[2007]! } + public var NetworkUsageSettings_MediaImageDataSection: String { return self._s[2008]! } public func Passport_Address_UploadOneOfScan(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2008]!, self._r[2008]!, [_0]) + return formatWithArgumentRanges(self._s[2009]!, self._r[2009]!, [_0]) } - public var IntentsSettings_Reset: String { return self._s[2009]! } - public var Conversation_Info: String { return self._s[2010]! } - public var Login_InfoDeletePhoto: String { return self._s[2011]! } - public var Passport_Language_vi: String { return self._s[2013]! } - public var UserInfo_ScamUserWarning: String { return self._s[2014]! } - public var Conversation_Search: String { return self._s[2015]! } - public var DialogList_DeleteBotConversationConfirmation: String { return self._s[2017]! } - public var ReportPeer_ReasonPornography: String { return self._s[2018]! } - public var AutoDownloadSettings_PhotosTitle: String { return self._s[2019]! } - public var Conversation_SendMessageErrorGroupRestricted: String { return self._s[2020]! } - public var Map_LiveLocationGroupDescription: String { return self._s[2021]! } - public var Channel_Setup_TypeHeader: String { return self._s[2022]! } - public var AuthSessions_LoggedIn: String { return self._s[2023]! } - public var Privacy_Forwards_AlwaysAllow_Title: String { return self._s[2024]! } - public var Login_SmsRequestState3: String { return self._s[2025]! } - public var Passport_Address_EditUtilityBill: String { return self._s[2026]! } - public var Appearance_ReduceMotionInfo: String { return self._s[2027]! } - public var Join_ChannelsTooMuch: String { return self._s[2028]! } - public var Channel_Edit_LinkItem: String { return self._s[2029]! } - public var Privacy_Calls_P2PNever: String { return self._s[2030]! } - public var Conversation_AddToReadingList: String { return self._s[2032]! } - public var Share_MultipleMessagesDisabled: String { return self._s[2033]! } - public var Message_Animation: String { return self._s[2034]! } - public var Conversation_DefaultRestrictedMedia: String { return self._s[2035]! } - public var Map_Unknown: String { return self._s[2036]! } - public var AutoDownloadSettings_LastDelimeter: String { return self._s[2037]! } + public var IntentsSettings_Reset: String { return self._s[2010]! } + public var Conversation_Info: String { return self._s[2011]! } + public var Login_InfoDeletePhoto: String { return self._s[2012]! } + public var Passport_Language_vi: String { return self._s[2014]! } + public var UserInfo_ScamUserWarning: String { return self._s[2015]! } + public var Conversation_Search: String { return self._s[2016]! } + public var DialogList_DeleteBotConversationConfirmation: String { return self._s[2018]! } + public var ReportPeer_ReasonPornography: String { return self._s[2019]! } + public var AutoDownloadSettings_PhotosTitle: String { return self._s[2020]! } + public var Conversation_SendMessageErrorGroupRestricted: String { return self._s[2021]! } + public var Map_LiveLocationGroupDescription: String { return self._s[2022]! } + public var Channel_Setup_TypeHeader: String { return self._s[2023]! } + public var AuthSessions_LoggedIn: String { return self._s[2024]! } + public var Privacy_Forwards_AlwaysAllow_Title: String { return self._s[2025]! } + public var Login_SmsRequestState3: String { return self._s[2026]! } + public var Passport_Address_EditUtilityBill: String { return self._s[2027]! } + public var Appearance_ReduceMotionInfo: String { return self._s[2028]! } + public var Join_ChannelsTooMuch: String { return self._s[2029]! } + public var Channel_Edit_LinkItem: String { return self._s[2030]! } + public var Privacy_Calls_P2PNever: String { return self._s[2031]! } + public var Conversation_AddToReadingList: String { return self._s[2033]! } + public var Share_MultipleMessagesDisabled: String { return self._s[2034]! } + public var Message_Animation: String { return self._s[2035]! } + public var Conversation_DefaultRestrictedMedia: String { return self._s[2036]! } + public var Map_Unknown: String { return self._s[2037]! } + public var AutoDownloadSettings_LastDelimeter: String { return self._s[2038]! } public func PUSH_PINNED_TEXT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2038]!, self._r[2038]!, [_1, _2]) - } - public func Passport_FieldOneOf_Or(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2039]!, self._r[2039]!, [_1, _2]) } - public var Call_StatusRequesting: String { return self._s[2040]! } - public var Conversation_SecretChatContextBotAlert: String { return self._s[2041]! } - public var SocksProxySetup_ProxyStatusChecking: String { return self._s[2042]! } + public func Passport_FieldOneOf_Or(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2040]!, self._r[2040]!, [_1, _2]) + } + public var Call_StatusRequesting: String { return self._s[2041]! } + public var Conversation_SecretChatContextBotAlert: String { return self._s[2042]! } + public var SocksProxySetup_ProxyStatusChecking: String { return self._s[2043]! } public func PUSH_CHAT_MESSAGE_DOC(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2043]!, self._r[2043]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2044]!, self._r[2044]!, [_1, _2]) } public func Notification_PinnedLocationMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2044]!, self._r[2044]!, [_0]) + return formatWithArgumentRanges(self._s[2045]!, self._r[2045]!, [_0]) } - public var Update_Skip: String { return self._s[2045]! } - public var Group_Username_RemoveExistingUsernamesInfo: String { return self._s[2046]! } - public var BlockedUsers_Title: String { return self._s[2047]! } - public var Weekday_Monday: String { return self._s[2048]! } + public var Update_Skip: String { return self._s[2046]! } + public var Group_Username_RemoveExistingUsernamesInfo: String { return self._s[2047]! } + public var BlockedUsers_Title: String { return self._s[2048]! } + public var Weekday_Monday: String { return self._s[2049]! } public func PUSH_CHANNEL_MESSAGE_AUDIO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2049]!, self._r[2049]!, [_1]) + return formatWithArgumentRanges(self._s[2050]!, self._r[2050]!, [_1]) } - public var Username_CheckingUsername: String { return self._s[2050]! } - public var NotificationsSound_Bell: String { return self._s[2051]! } - public var Conversation_SendMessageErrorFlood: String { return self._s[2052]! } - public var SettingsSearch_Synonyms_Notifications_DisplayNamesOnLockScreen: String { return self._s[2053]! } - public var ChannelMembers_ChannelAdminsTitle: String { return self._s[2054]! } - public var ChatSettings_Groups: String { return self._s[2055]! } - public var WallpaperPreview_PatternPaternDiscard: String { return self._s[2056]! } + public var Username_CheckingUsername: String { return self._s[2051]! } + public var NotificationsSound_Bell: String { return self._s[2052]! } + public var Conversation_SendMessageErrorFlood: String { return self._s[2053]! } + public var SettingsSearch_Synonyms_Notifications_DisplayNamesOnLockScreen: String { return self._s[2054]! } + public var ChannelMembers_ChannelAdminsTitle: String { return self._s[2055]! } + public var ChatSettings_Groups: String { return self._s[2056]! } + public var WallpaperPreview_PatternPaternDiscard: String { return self._s[2057]! } public func Conversation_SetReminder_RemindTomorrow(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2057]!, self._r[2057]!, [_0]) + return formatWithArgumentRanges(self._s[2058]!, self._r[2058]!, [_0]) } - public var Your_card_was_declined: String { return self._s[2058]! } - public var TwoStepAuth_EnterPasswordHelp: String { return self._s[2060]! } - public var Wallet_Month_ShortApril: String { return self._s[2061]! } - public var ChatList_Unmute: String { return self._s[2062]! } - public var AuthSessions_AddDevice_ScanTitle: String { return self._s[2063]! } - public var PhotoEditor_CurvesAll: String { return self._s[2064]! } - public var Weekday_ShortTuesday: String { return self._s[2065]! } - public var DialogList_Read: String { return self._s[2066]! } - public var Appearance_AppIconClassic: String { return self._s[2067]! } - public var ChannelMembers_WhoCanAddMembers_AllMembers: String { return self._s[2068]! } - public var Passport_Identity_Gender: String { return self._s[2069]! } + public var Your_card_was_declined: String { return self._s[2059]! } + public var TwoStepAuth_EnterPasswordHelp: String { return self._s[2061]! } + public var Wallet_Month_ShortApril: String { return self._s[2062]! } + public var ChatList_Unmute: String { return self._s[2063]! } + public var AuthSessions_AddDevice_ScanTitle: String { return self._s[2064]! } + public var PhotoEditor_CurvesAll: String { return self._s[2065]! } + public var Weekday_ShortTuesday: String { return self._s[2066]! } + public var DialogList_Read: String { return self._s[2067]! } + public var Appearance_AppIconClassic: String { return self._s[2068]! } + public var ChannelMembers_WhoCanAddMembers_AllMembers: String { return self._s[2069]! } + public var Passport_Identity_Gender: String { return self._s[2070]! } public func Target_ShareGameConfirmationPrivate(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2070]!, self._r[2070]!, [_0]) + return formatWithArgumentRanges(self._s[2071]!, self._r[2071]!, [_0]) } - public var Target_SelectGroup: String { return self._s[2071]! } - public var Map_HomeAndWorkInfo: String { return self._s[2073]! } + public var Target_SelectGroup: String { return self._s[2072]! } + public var Map_HomeAndWorkInfo: String { return self._s[2074]! } public func DialogList_EncryptedChatStartedIncoming(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2074]!, self._r[2074]!, [_0]) + return formatWithArgumentRanges(self._s[2075]!, self._r[2075]!, [_0]) } - public var Passport_Language_en: String { return self._s[2075]! } - public var AutoDownloadSettings_AutodownloadPhotos: String { return self._s[2076]! } - public var Channel_Username_CreatePublicLinkHelp: String { return self._s[2077]! } - public var Login_CancelPhoneVerificationContinue: String { return self._s[2078]! } - public var ScheduledMessages_SendNow: String { return self._s[2079]! } - public var Checkout_NewCard_PaymentCard: String { return self._s[2081]! } - public var Login_InfoHelp: String { return self._s[2082]! } - public var Appearance_BubbleCorners_AdjustAdjacent: String { return self._s[2083]! } - public var Contacts_PermissionsSuppressWarningTitle: String { return self._s[2084]! } - public var SettingsSearch_Synonyms_Stickers_FeaturedPacks: String { return self._s[2085]! } + public var Passport_Language_en: String { return self._s[2076]! } + public var AutoDownloadSettings_AutodownloadPhotos: String { return self._s[2077]! } + public var Channel_Username_CreatePublicLinkHelp: String { return self._s[2078]! } + public var Login_CancelPhoneVerificationContinue: String { return self._s[2079]! } + public var ScheduledMessages_SendNow: String { return self._s[2080]! } + public var Checkout_NewCard_PaymentCard: String { return self._s[2082]! } + public var Login_InfoHelp: String { return self._s[2083]! } + public var Appearance_BubbleCorners_AdjustAdjacent: String { return self._s[2084]! } + public var Contacts_PermissionsSuppressWarningTitle: String { return self._s[2085]! } + public var SettingsSearch_Synonyms_Stickers_FeaturedPacks: String { return self._s[2086]! } public func Channel_AdminLog_MessageChangedLinkedChannel(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2086]!, self._r[2086]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2087]!, self._r[2087]!, [_1, _2]) } - public var SocksProxySetup_AddProxy: String { return self._s[2089]! } - public var CreatePoll_Title: String { return self._s[2090]! } - public var MessagePoll_QuizNoUsers: String { return self._s[2091]! } - public var Conversation_ViewTheme: String { return self._s[2092]! } - public var SettingsSearch_Synonyms_Privacy_Data_SecretChatLinkPreview: String { return self._s[2093]! } - public var PasscodeSettings_SimplePasscodeHelp: String { return self._s[2094]! } - public var TwoFactorSetup_Intro_Text: String { return self._s[2095]! } - public var UserInfo_GroupsInCommon: String { return self._s[2096]! } - public var TelegramWallet_Intro_TermsUrl: String { return self._s[2097]! } - public var Call_AudioRouteHide: String { return self._s[2098]! } + public var SocksProxySetup_AddProxy: String { return self._s[2090]! } + public var CreatePoll_Title: String { return self._s[2091]! } + public var MessagePoll_QuizNoUsers: String { return self._s[2092]! } + public var Conversation_ViewTheme: String { return self._s[2093]! } + public var SettingsSearch_Synonyms_Privacy_Data_SecretChatLinkPreview: String { return self._s[2094]! } + public var PasscodeSettings_SimplePasscodeHelp: String { return self._s[2095]! } + public var TwoFactorSetup_Intro_Text: String { return self._s[2096]! } + public var UserInfo_GroupsInCommon: String { return self._s[2097]! } + public var TelegramWallet_Intro_TermsUrl: String { return self._s[2098]! } + public var Call_AudioRouteHide: String { return self._s[2099]! } public func Wallet_Info_TransactionDateHeader(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2100]!, self._r[2100]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2101]!, self._r[2101]!, [_1, _2]) } - public var ContactInfo_PhoneLabelMobile: String { return self._s[2101]! } - public var IntentsSettings_SuggestedChatsInfo: String { return self._s[2102]! } - public var CreatePoll_QuizOptionsHeader: String { return self._s[2103]! } + public var ContactInfo_PhoneLabelMobile: String { return self._s[2102]! } + public var IntentsSettings_SuggestedChatsInfo: String { return self._s[2103]! } + public var CreatePoll_QuizOptionsHeader: String { return self._s[2104]! } public func ChatList_LeaveGroupConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2104]!, self._r[2104]!, [_0]) + return formatWithArgumentRanges(self._s[2105]!, self._r[2105]!, [_0]) } - public var TextFormat_Bold: String { return self._s[2105]! } - public var FastTwoStepSetup_EmailSection: String { return self._s[2106]! } - public var StickerPackActionInfo_AddedTitle: String { return self._s[2107]! } - public var Notifications_Title: String { return self._s[2108]! } - public var Group_Username_InvalidTooShort: String { return self._s[2109]! } - public var Channel_ErrorAddTooMuch: String { return self._s[2110]! } + public var TextFormat_Bold: String { return self._s[2106]! } + public var FastTwoStepSetup_EmailSection: String { return self._s[2107]! } + public var StickerPackActionInfo_AddedTitle: String { return self._s[2108]! } + public var Notifications_Title: String { return self._s[2109]! } + public var Group_Username_InvalidTooShort: String { return self._s[2110]! } + public var Channel_ErrorAddTooMuch: String { return self._s[2111]! } public func DialogList_MultipleTypingSuffix(_ _0: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2111]!, self._r[2111]!, ["\(_0)"]) + return formatWithArgumentRanges(self._s[2112]!, self._r[2112]!, ["\(_0)"]) } - public var VoiceOver_DiscardPreparedContent: String { return self._s[2113]! } - public var Stickers_SuggestAdded: String { return self._s[2114]! } - public var Login_CountryCode: String { return self._s[2115]! } - public var ChatSettings_AutoPlayVideos: String { return self._s[2116]! } - public var Map_GetDirections: String { return self._s[2117]! } - public var Wallet_Receive_ShareInvoiceUrl: String { return self._s[2118]! } - public var Login_PhoneFloodError: String { return self._s[2119]! } + public var VoiceOver_DiscardPreparedContent: String { return self._s[2114]! } + public var Stickers_SuggestAdded: String { return self._s[2115]! } + public var Login_CountryCode: String { return self._s[2116]! } + public var ChatSettings_AutoPlayVideos: String { return self._s[2117]! } + public var Map_GetDirections: String { return self._s[2118]! } + public var Wallet_Receive_ShareInvoiceUrl: String { return self._s[2119]! } + public var Login_PhoneFloodError: String { return self._s[2120]! } public func Time_MonthOfYear_m3(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2120]!, self._r[2120]!, [_0]) + return formatWithArgumentRanges(self._s[2121]!, self._r[2121]!, [_0]) } public func Wallet_Time_PreciseDate_m10(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2121]!, self._r[2121]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2122]!, self._r[2122]!, [_1, _2, _3]) } - public var IntentsSettings_SuggestedChatsPrivateChats: String { return self._s[2122]! } - public var Settings_SetUsername: String { return self._s[2124]! } - public var Group_Location_ChangeLocation: String { return self._s[2125]! } - public var Notification_GroupInviterSelf: String { return self._s[2126]! } - public var InstantPage_TapToOpenLink: String { return self._s[2127]! } + public var IntentsSettings_SuggestedChatsPrivateChats: String { return self._s[2123]! } + public var Settings_SetUsername: String { return self._s[2125]! } + public var Group_Location_ChangeLocation: String { return self._s[2126]! } + public var Notification_GroupInviterSelf: String { return self._s[2127]! } + public var InstantPage_TapToOpenLink: String { return self._s[2128]! } public func Notification_ChannelInviter(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2128]!, self._r[2128]!, [_0]) + return formatWithArgumentRanges(self._s[2129]!, self._r[2129]!, [_0]) } - public var Watch_Suggestion_TalkLater: String { return self._s[2129]! } - public var SecretChat_Title: String { return self._s[2130]! } - public var Group_UpgradeNoticeText1: String { return self._s[2131]! } - public var AuthSessions_Title: String { return self._s[2132]! } + public var Watch_Suggestion_TalkLater: String { return self._s[2130]! } + public var SecretChat_Title: String { return self._s[2131]! } + public var Group_UpgradeNoticeText1: String { return self._s[2132]! } + public var AuthSessions_Title: String { return self._s[2133]! } public func TextFormat_AddLinkText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2133]!, self._r[2133]!, [_0]) + return formatWithArgumentRanges(self._s[2134]!, self._r[2134]!, [_0]) } - public var PhotoEditor_CropAuto: String { return self._s[2134]! } - public var Channel_About_Title: String { return self._s[2135]! } - public var Theme_ThemeChanged: String { return self._s[2136]! } - public var FastTwoStepSetup_EmailHelp: String { return self._s[2137]! } + public var PhotoEditor_CropAuto: String { return self._s[2135]! } + public var Channel_About_Title: String { return self._s[2136]! } + public var Theme_ThemeChanged: String { return self._s[2137]! } + public var FastTwoStepSetup_EmailHelp: String { return self._s[2138]! } public func Conversation_Bytes(_ _0: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2139]!, self._r[2139]!, ["\(_0)"]) + return formatWithArgumentRanges(self._s[2140]!, self._r[2140]!, ["\(_0)"]) } - public var VoiceOver_MessageContextReport: String { return self._s[2140]! } - public var Conversation_PinMessageAlert_OnlyPin: String { return self._s[2142]! } - public var Group_Setup_HistoryVisibleHelp: String { return self._s[2143]! } + public var VoiceOver_MessageContextReport: String { return self._s[2141]! } + public var Conversation_PinMessageAlert_OnlyPin: String { return self._s[2143]! } + public var Group_Setup_HistoryVisibleHelp: String { return self._s[2144]! } public func PUSH_MESSAGE_GIF(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2144]!, self._r[2144]!, [_1]) + return formatWithArgumentRanges(self._s[2145]!, self._r[2145]!, [_1]) } public func SharedMedia_SearchNoResultsDescription(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2146]!, self._r[2146]!, [_0]) - } - public func TwoStepAuth_RecoveryEmailUnavailable(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2147]!, self._r[2147]!, [_0]) } - public var Privacy_PaymentsClearInfoHelp: String { return self._s[2148]! } - public var PeopleNearby_DiscoverDescription: String { return self._s[2150]! } - public var Presence_online: String { return self._s[2152]! } - public var PasscodeSettings_Title: String { return self._s[2153]! } - public var Passport_Identity_ExpiryDatePlaceholder: String { return self._s[2154]! } - public var Web_OpenExternal: String { return self._s[2155]! } - public var AutoDownloadSettings_AutoDownload: String { return self._s[2157]! } - public var Channel_OwnershipTransfer_EnterPasswordText: String { return self._s[2158]! } - public var LocalGroup_Title: String { return self._s[2159]! } + public func TwoStepAuth_RecoveryEmailUnavailable(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2148]!, self._r[2148]!, [_0]) + } + public var Privacy_PaymentsClearInfoHelp: String { return self._s[2149]! } + public var PeopleNearby_DiscoverDescription: String { return self._s[2151]! } + public var Presence_online: String { return self._s[2153]! } + public var PasscodeSettings_Title: String { return self._s[2154]! } + public var Passport_Identity_ExpiryDatePlaceholder: String { return self._s[2155]! } + public var Web_OpenExternal: String { return self._s[2156]! } + public var AutoDownloadSettings_AutoDownload: String { return self._s[2158]! } + public var Channel_OwnershipTransfer_EnterPasswordText: String { return self._s[2159]! } + public var LocalGroup_Title: String { return self._s[2160]! } public func AutoNightTheme_AutomaticHelp(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2160]!, self._r[2160]!, [_0]) + return formatWithArgumentRanges(self._s[2161]!, self._r[2161]!, [_0]) } - public var FastTwoStepSetup_PasswordConfirmationPlaceholder: String { return self._s[2161]! } - public var Conversation_StopQuizConfirmation: String { return self._s[2162]! } - public var Map_YouAreHere: String { return self._s[2163]! } + public var FastTwoStepSetup_PasswordConfirmationPlaceholder: String { return self._s[2162]! } + public var Conversation_StopQuizConfirmation: String { return self._s[2163]! } + public var Map_YouAreHere: String { return self._s[2164]! } public func AuthSessions_Message(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2164]!, self._r[2164]!, [_0]) - } - public func ChatList_DeleteChatConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2165]!, self._r[2165]!, [_0]) } - public var Theme_Context_ChangeColors: String { return self._s[2166]! } - public var PrivacyLastSeenSettings_AlwaysShareWith: String { return self._s[2167]! } - public var Target_InviteToGroupErrorAlreadyInvited: String { return self._s[2168]! } - public func AuthSessions_AppUnofficial(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2169]!, self._r[2169]!, [_0]) + public func ChatList_DeleteChatConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2166]!, self._r[2166]!, [_0]) } - public func DialogList_LiveLocationSharingTo(_ _0: String) -> (String, [(Int, NSRange)]) { + public var Theme_Context_ChangeColors: String { return self._s[2167]! } + public var PrivacyLastSeenSettings_AlwaysShareWith: String { return self._s[2168]! } + public var Target_InviteToGroupErrorAlreadyInvited: String { return self._s[2169]! } + public func AuthSessions_AppUnofficial(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2170]!, self._r[2170]!, [_0]) } - public var SocksProxySetup_Username: String { return self._s[2171]! } - public var Bot_Start: String { return self._s[2172]! } - public func Channel_AdminLog_EmptyFilterQueryText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2173]!, self._r[2173]!, [_0]) + public func DialogList_LiveLocationSharingTo(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2171]!, self._r[2171]!, [_0]) } - public func Channel_AdminLog_MessagePinned(_ _0: String) -> (String, [(Int, NSRange)]) { + public var SocksProxySetup_Username: String { return self._s[2172]! } + public var Bot_Start: String { return self._s[2173]! } + public func Channel_AdminLog_EmptyFilterQueryText(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2174]!, self._r[2174]!, [_0]) } - public var Contacts_SortByPresence: String { return self._s[2175]! } - public var AccentColor_Title: String { return self._s[2177]! } - public var Conversation_DiscardVoiceMessageTitle: String { return self._s[2178]! } + public func Channel_AdminLog_MessagePinned(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2175]!, self._r[2175]!, [_0]) + } + public var Contacts_SortByPresence: String { return self._s[2176]! } + public var AccentColor_Title: String { return self._s[2178]! } + public var Conversation_DiscardVoiceMessageTitle: String { return self._s[2179]! } public func PUSH_CHAT_CREATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2179]!, self._r[2179]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2180]!, self._r[2180]!, [_1, _2]) } public func PrivacySettings_LastSeenContactsMinus(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2180]!, self._r[2180]!, [_0]) + return formatWithArgumentRanges(self._s[2181]!, self._r[2181]!, [_0]) } public func Channel_AdminLog_MessageChangedLinkedGroup(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2181]!, self._r[2181]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2182]!, self._r[2182]!, [_1, _2]) } - public var Passport_Email_EnterOtherEmail: String { return self._s[2182]! } - public var Login_InfoAvatarPhoto: String { return self._s[2183]! } - public var Privacy_PaymentsClear_ShippingInfo: String { return self._s[2184]! } - public var Tour_Title4: String { return self._s[2185]! } - public var Passport_Identity_Translation: String { return self._s[2186]! } - public var SettingsSearch_Synonyms_Notifications_ContactJoined: String { return self._s[2187]! } - public var Login_TermsOfServiceLabel: String { return self._s[2189]! } - public var Passport_Language_it: String { return self._s[2190]! } - public var KeyCommand_JumpToNextUnreadChat: String { return self._s[2191]! } - public var Passport_Identity_SelfieHelp: String { return self._s[2192]! } - public var Conversation_ClearAll: String { return self._s[2194]! } - public var Wallet_Send_UninitializedText: String { return self._s[2196]! } - public var Channel_OwnershipTransfer_Title: String { return self._s[2197]! } - public var TwoStepAuth_FloodError: String { return self._s[2198]! } + public var Passport_Email_EnterOtherEmail: String { return self._s[2183]! } + public var Login_InfoAvatarPhoto: String { return self._s[2184]! } + public var Privacy_PaymentsClear_ShippingInfo: String { return self._s[2185]! } + public var Tour_Title4: String { return self._s[2186]! } + public var Passport_Identity_Translation: String { return self._s[2187]! } + public var SettingsSearch_Synonyms_Notifications_ContactJoined: String { return self._s[2188]! } + public var Login_TermsOfServiceLabel: String { return self._s[2190]! } + public var Passport_Language_it: String { return self._s[2191]! } + public var KeyCommand_JumpToNextUnreadChat: String { return self._s[2192]! } + public var Passport_Identity_SelfieHelp: String { return self._s[2193]! } + public var Conversation_ClearAll: String { return self._s[2195]! } + public var Wallet_Send_UninitializedText: String { return self._s[2197]! } + public var Channel_OwnershipTransfer_Title: String { return self._s[2198]! } + public var TwoStepAuth_FloodError: String { return self._s[2199]! } public func PUSH_CHANNEL_MESSAGE_GEO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2199]!, self._r[2199]!, [_1]) + return formatWithArgumentRanges(self._s[2200]!, self._r[2200]!, [_1]) } - public var Paint_Delete: String { return self._s[2200]! } + public var Paint_Delete: String { return self._s[2201]! } public func Wallet_Sent_Text(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2201]!, self._r[2201]!, [_0]) + return formatWithArgumentRanges(self._s[2202]!, self._r[2202]!, [_0]) } - public var Privacy_AddNewPeer: String { return self._s[2202]! } + public var Privacy_AddNewPeer: String { return self._s[2203]! } public func Channel_AdminLog_MessageRank(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2203]!, self._r[2203]!, [_1]) + return formatWithArgumentRanges(self._s[2204]!, self._r[2204]!, [_1]) } - public var LogoutOptions_SetPasscodeText: String { return self._s[2204]! } + public var LogoutOptions_SetPasscodeText: String { return self._s[2205]! } public func Passport_AcceptHelp(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2205]!, self._r[2205]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2206]!, self._r[2206]!, [_1, _2]) } - public var Message_PinnedAudioMessage: String { return self._s[2206]! } + public var Message_PinnedAudioMessage: String { return self._s[2207]! } public func Watch_Time_ShortTodayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2207]!, self._r[2207]!, [_0]) + return formatWithArgumentRanges(self._s[2208]!, self._r[2208]!, [_0]) } - public var Notification_Mute1hMin: String { return self._s[2208]! } - public var Notifications_GroupNotificationsSound: String { return self._s[2209]! } - public var Wallet_Month_GenNovember: String { return self._s[2210]! } - public var SocksProxySetup_ShareProxyList: String { return self._s[2211]! } - public var Conversation_MessageEditedLabel: String { return self._s[2212]! } + public var Notification_Mute1hMin: String { return self._s[2209]! } + public var Notifications_GroupNotificationsSound: String { return self._s[2210]! } + public var Wallet_Month_GenNovember: String { return self._s[2211]! } + public var SocksProxySetup_ShareProxyList: String { return self._s[2212]! } + public var Conversation_MessageEditedLabel: String { return self._s[2213]! } public func ClearCache_Success(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2213]!, self._r[2213]!, [_0, _1]) + return formatWithArgumentRanges(self._s[2214]!, self._r[2214]!, [_0, _1]) } - public var Notification_Exceptions_AlwaysOff: String { return self._s[2214]! } - public var Notification_Exceptions_NewException_MessagePreviewHeader: String { return self._s[2215]! } + public var Notification_Exceptions_AlwaysOff: String { return self._s[2215]! } + public var Notification_Exceptions_NewException_MessagePreviewHeader: String { return self._s[2216]! } public func Channel_AdminLog_MessageAdmin(_ _0: String, _ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2216]!, self._r[2216]!, [_0, _1, _2]) + return formatWithArgumentRanges(self._s[2217]!, self._r[2217]!, [_0, _1, _2]) } - public var NetworkUsageSettings_ResetStats: String { return self._s[2217]! } + public var NetworkUsageSettings_ResetStats: String { return self._s[2218]! } public func PUSH_MESSAGE_GEOLIVE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2218]!, self._r[2218]!, [_1]) + return formatWithArgumentRanges(self._s[2219]!, self._r[2219]!, [_1]) } - public var AccessDenied_LocationTracking: String { return self._s[2219]! } - public var Month_GenOctober: String { return self._s[2220]! } - public var GroupInfo_InviteLink_RevokeAlert_Revoke: String { return self._s[2221]! } - public var EnterPasscode_EnterPasscode: String { return self._s[2222]! } - public var MediaPicker_TimerTooltip: String { return self._s[2224]! } - public var SharedMedia_TitleAll: String { return self._s[2225]! } - public var SettingsSearch_Synonyms_Notifications_ChannelNotificationsExceptions: String { return self._s[2228]! } - public var Conversation_RestrictedMedia: String { return self._s[2229]! } - public var AccessDenied_PhotosRestricted: String { return self._s[2230]! } - public var Privacy_Forwards_WhoCanForward: String { return self._s[2232]! } - public var ChangePhoneNumberCode_Called: String { return self._s[2233]! } + public var AccessDenied_LocationTracking: String { return self._s[2220]! } + public var Month_GenOctober: String { return self._s[2221]! } + public var GroupInfo_InviteLink_RevokeAlert_Revoke: String { return self._s[2222]! } + public var EnterPasscode_EnterPasscode: String { return self._s[2223]! } + public var MediaPicker_TimerTooltip: String { return self._s[2225]! } + public var SharedMedia_TitleAll: String { return self._s[2226]! } + public var SettingsSearch_Synonyms_Notifications_ChannelNotificationsExceptions: String { return self._s[2229]! } + public var Conversation_RestrictedMedia: String { return self._s[2230]! } + public var AccessDenied_PhotosRestricted: String { return self._s[2231]! } + public var Privacy_Forwards_WhoCanForward: String { return self._s[2233]! } + public var ChangePhoneNumberCode_Called: String { return self._s[2234]! } public func Notification_PinnedDocumentMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2234]!, self._r[2234]!, [_0]) + return formatWithArgumentRanges(self._s[2235]!, self._r[2235]!, [_0]) } - public var Conversation_SavedMessages: String { return self._s[2237]! } - public var Your_cards_expiration_month_is_invalid: String { return self._s[2239]! } - public var FastTwoStepSetup_PasswordPlaceholder: String { return self._s[2240]! } + public var Conversation_SavedMessages: String { return self._s[2238]! } + public var Your_cards_expiration_month_is_invalid: String { return self._s[2240]! } + public var FastTwoStepSetup_PasswordPlaceholder: String { return self._s[2241]! } public func Target_ShareGameConfirmationGroup(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2242]!, self._r[2242]!, [_0]) + return formatWithArgumentRanges(self._s[2243]!, self._r[2243]!, [_0]) } - public var VoiceOver_Chat_YourMessage: String { return self._s[2243]! } + public var VoiceOver_Chat_YourMessage: String { return self._s[2244]! } public func VoiceOver_Chat_Title(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2244]!, self._r[2244]!, [_0]) + return formatWithArgumentRanges(self._s[2245]!, self._r[2245]!, [_0]) } - public var ReportPeer_AlertSuccess: String { return self._s[2245]! } - public var PhotoEditor_CropAspectRatioOriginal: String { return self._s[2246]! } + public var ReportPeer_AlertSuccess: String { return self._s[2246]! } + public var PhotoEditor_CropAspectRatioOriginal: String { return self._s[2247]! } public func InstantPage_RelatedArticleAuthorAndDateTitle(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2247]!, self._r[2247]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2248]!, self._r[2248]!, [_1, _2]) } - public var Checkout_PasswordEntry_Title: String { return self._s[2248]! } - public var PhotoEditor_FadeTool: String { return self._s[2249]! } - public var Privacy_ContactsReset: String { return self._s[2250]! } + public var Checkout_PasswordEntry_Title: String { return self._s[2249]! } + public var PhotoEditor_FadeTool: String { return self._s[2250]! } + public var Privacy_ContactsReset: String { return self._s[2251]! } public func Channel_AdminLog_MessageRestrictedUntil(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2252]!, self._r[2252]!, [_0]) + return formatWithArgumentRanges(self._s[2253]!, self._r[2253]!, [_0]) } - public var Message_PinnedVideoMessage: String { return self._s[2253]! } - public var ChatList_Mute: String { return self._s[2254]! } + public var Message_PinnedVideoMessage: String { return self._s[2254]! } + public var ChatList_Mute: String { return self._s[2255]! } public func Wallet_Time_PreciseDate_m5(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2255]!, self._r[2255]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2256]!, self._r[2256]!, [_1, _2, _3]) } - public var Permissions_CellularDataText_v0: String { return self._s[2256]! } - public var Conversation_PinnedQuiz: String { return self._s[2258]! } - public var ShareMenu_SelectChats: String { return self._s[2260]! } - public var ChatList_Context_Unarchive: String { return self._s[2261]! } - public var MusicPlayer_VoiceNote: String { return self._s[2262]! } - public var Conversation_RestrictedText: String { return self._s[2263]! } - public var SettingsSearch_Synonyms_Privacy_Data_DeleteDrafts: String { return self._s[2264]! } - public var Wallet_Month_GenApril: String { return self._s[2265]! } - public var Wallet_Month_ShortMarch: String { return self._s[2266]! } - public var TwoStepAuth_DisableSuccess: String { return self._s[2267]! } - public var Cache_Videos: String { return self._s[2268]! } - public var PrivacySettings_PhoneNumber: String { return self._s[2269]! } - public var Wallet_Month_GenFebruary: String { return self._s[2270]! } - public var FeatureDisabled_Oops: String { return self._s[2272]! } - public var Passport_Address_PostcodePlaceholder: String { return self._s[2273]! } + public var Permissions_CellularDataText_v0: String { return self._s[2257]! } + public var Conversation_PinnedQuiz: String { return self._s[2259]! } + public var ShareMenu_SelectChats: String { return self._s[2261]! } + public var ChatList_Context_Unarchive: String { return self._s[2262]! } + public var MusicPlayer_VoiceNote: String { return self._s[2263]! } + public var Conversation_RestrictedText: String { return self._s[2264]! } + public var SettingsSearch_Synonyms_Privacy_Data_DeleteDrafts: String { return self._s[2265]! } + public var Wallet_Month_GenApril: String { return self._s[2266]! } + public var Wallet_Month_ShortMarch: String { return self._s[2267]! } + public var TwoStepAuth_DisableSuccess: String { return self._s[2268]! } + public var Cache_Videos: String { return self._s[2269]! } + public var PrivacySettings_PhoneNumber: String { return self._s[2270]! } + public var Wallet_Month_GenFebruary: String { return self._s[2271]! } + public var FeatureDisabled_Oops: String { return self._s[2273]! } + public var Passport_Address_PostcodePlaceholder: String { return self._s[2274]! } public func AddContact_StatusSuccess(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2274]!, self._r[2274]!, [_0]) + return formatWithArgumentRanges(self._s[2275]!, self._r[2275]!, [_0]) } - public var Stickers_GroupStickersHelp: String { return self._s[2276]! } - public var GroupPermission_NoSendPolls: String { return self._s[2277]! } - public var Wallet_Qr_ScanCode: String { return self._s[2278]! } - public var Message_VideoExpired: String { return self._s[2280]! } - public var GroupInfo_GroupHistoryVisible: String { return self._s[2281]! } - public var Notifications_Badge: String { return self._s[2282]! } - public var Wallet_Receive_AddressCopied: String { return self._s[2283]! } - public var CreatePoll_OptionPlaceholder: String { return self._s[2284]! } - public var Username_InvalidTooShort: String { return self._s[2285]! } - public var EnterPasscode_EnterNewPasscodeChange: String { return self._s[2286]! } - public var Channel_AdminLog_PinMessages: String { return self._s[2287]! } - public var ArchivedChats_IntroTitle3: String { return self._s[2288]! } + public var Stickers_GroupStickersHelp: String { return self._s[2277]! } + public var GroupPermission_NoSendPolls: String { return self._s[2278]! } + public var Wallet_Qr_ScanCode: String { return self._s[2279]! } + public var Message_VideoExpired: String { return self._s[2281]! } + public var GroupInfo_GroupHistoryVisible: String { return self._s[2282]! } + public var Notifications_Badge: String { return self._s[2283]! } + public var Wallet_Receive_AddressCopied: String { return self._s[2284]! } + public var CreatePoll_OptionPlaceholder: String { return self._s[2285]! } + public var Username_InvalidTooShort: String { return self._s[2286]! } + public var EnterPasscode_EnterNewPasscodeChange: String { return self._s[2287]! } + public var Channel_AdminLog_PinMessages: String { return self._s[2288]! } + public var ArchivedChats_IntroTitle3: String { return self._s[2289]! } public func Notification_MessageLifetimeRemoved(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2289]!, self._r[2289]!, [_1]) + return formatWithArgumentRanges(self._s[2290]!, self._r[2290]!, [_1]) } - public var Permissions_SiriAllowInSettings_v0: String { return self._s[2290]! } - public var Conversation_DefaultRestrictedText: String { return self._s[2291]! } - public var SharedMedia_CategoryDocs: String { return self._s[2294]! } + public var Permissions_SiriAllowInSettings_v0: String { return self._s[2291]! } + public var Conversation_DefaultRestrictedText: String { return self._s[2292]! } + public var SharedMedia_CategoryDocs: String { return self._s[2295]! } public func PUSH_MESSAGE_CONTACT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2295]!, self._r[2295]!, [_1]) + return formatWithArgumentRanges(self._s[2296]!, self._r[2296]!, [_1]) } - public var Wallet_Send_UninitializedTitle: String { return self._s[2296]! } - public var StickerPackActionInfo_ArchivedTitle: String { return self._s[2297]! } - public var Privacy_Forwards_NeverLink: String { return self._s[2299]! } + public var Wallet_Send_UninitializedTitle: String { return self._s[2297]! } + public var StickerPackActionInfo_ArchivedTitle: String { return self._s[2298]! } + public var Privacy_Forwards_NeverLink: String { return self._s[2300]! } public func Notification_MessageLifetimeChangedOutgoing(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2300]!, self._r[2300]!, [_1]) + return formatWithArgumentRanges(self._s[2301]!, self._r[2301]!, [_1]) } - public var CheckoutInfo_ErrorShippingNotAvailable: String { return self._s[2301]! } + public var CheckoutInfo_ErrorShippingNotAvailable: String { return self._s[2302]! } public func Time_MonthOfYear_m12(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2302]!, self._r[2302]!, [_0]) + return formatWithArgumentRanges(self._s[2303]!, self._r[2303]!, [_0]) } - public var ChatSettings_PrivateChats: String { return self._s[2303]! } - public var SettingsSearch_Synonyms_EditProfile_Logout: String { return self._s[2304]! } - public var Conversation_PrivateMessageLinkCopied: String { return self._s[2305]! } - public var Channel_UpdatePhotoItem: String { return self._s[2306]! } - public var GroupInfo_LeftStatus: String { return self._s[2307]! } - public var Watch_MessageView_Forward: String { return self._s[2309]! } - public var ReportPeer_ReasonChildAbuse: String { return self._s[2310]! } - public var Cache_ClearEmpty: String { return self._s[2312]! } - public var Localization_LanguageName: String { return self._s[2313]! } - public var Wallet_AccessDenied_Title: String { return self._s[2314]! } - public var WebSearch_GIFs: String { return self._s[2315]! } - public var Notifications_DisplayNamesOnLockScreenInfoWithLink: String { return self._s[2316]! } - public var Wallet_AccessDenied_Settings: String { return self._s[2317]! } - public var Username_InvalidStartsWithNumber: String { return self._s[2318]! } - public var Common_Back: String { return self._s[2319]! } - public var GroupInfo_Permissions_EditingDisabled: String { return self._s[2320]! } - public var Passport_Identity_DateOfBirthPlaceholder: String { return self._s[2321]! } - public var Wallet_Send_Send: String { return self._s[2322]! } + public var ChatSettings_PrivateChats: String { return self._s[2304]! } + public var SettingsSearch_Synonyms_EditProfile_Logout: String { return self._s[2305]! } + public var Conversation_PrivateMessageLinkCopied: String { return self._s[2306]! } + public var Channel_UpdatePhotoItem: String { return self._s[2307]! } + public var GroupInfo_LeftStatus: String { return self._s[2308]! } + public var Watch_MessageView_Forward: String { return self._s[2310]! } + public var ReportPeer_ReasonChildAbuse: String { return self._s[2311]! } + public var Cache_ClearEmpty: String { return self._s[2313]! } + public var Localization_LanguageName: String { return self._s[2314]! } + public var Wallet_AccessDenied_Title: String { return self._s[2315]! } + public var WebSearch_GIFs: String { return self._s[2316]! } + public var Notifications_DisplayNamesOnLockScreenInfoWithLink: String { return self._s[2317]! } + public var Wallet_AccessDenied_Settings: String { return self._s[2318]! } + public var Username_InvalidStartsWithNumber: String { return self._s[2319]! } + public var Common_Back: String { return self._s[2320]! } + public var GroupInfo_Permissions_EditingDisabled: String { return self._s[2321]! } + public var Passport_Identity_DateOfBirthPlaceholder: String { return self._s[2322]! } + public var Wallet_Send_Send: String { return self._s[2323]! } public func PUSH_CHANNEL_MESSAGE_STICKER(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2324]!, self._r[2324]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2325]!, self._r[2325]!, [_1, _2]) } - public var Wallet_Info_RefreshErrorTitle: String { return self._s[2325]! } - public var Wallet_Month_GenJune: String { return self._s[2326]! } - public var Passport_Email_Help: String { return self._s[2327]! } - public var Watch_Conversation_Reply: String { return self._s[2329]! } - public var Conversation_EditingMessageMediaChange: String { return self._s[2332]! } - public var Passport_Identity_IssueDatePlaceholder: String { return self._s[2333]! } - public var Channel_BanUser_Unban: String { return self._s[2335]! } - public var Channel_EditAdmin_PermissionPostMessages: String { return self._s[2336]! } - public var Group_Username_CreatePublicLinkHelp: String { return self._s[2337]! } - public var TwoStepAuth_ConfirmEmailCodePlaceholder: String { return self._s[2339]! } - public var Wallet_Send_AddressHeader: String { return self._s[2340]! } - public var Passport_Identity_Name: String { return self._s[2341]! } + public var Wallet_Info_RefreshErrorTitle: String { return self._s[2326]! } + public var Wallet_Month_GenJune: String { return self._s[2327]! } + public var Passport_Email_Help: String { return self._s[2328]! } + public var Watch_Conversation_Reply: String { return self._s[2330]! } + public var Conversation_EditingMessageMediaChange: String { return self._s[2333]! } + public var Passport_Identity_IssueDatePlaceholder: String { return self._s[2334]! } + public var Channel_BanUser_Unban: String { return self._s[2336]! } + public var Channel_EditAdmin_PermissionPostMessages: String { return self._s[2337]! } + public var Group_Username_CreatePublicLinkHelp: String { return self._s[2338]! } + public var TwoStepAuth_ConfirmEmailCodePlaceholder: String { return self._s[2340]! } + public var Wallet_Send_AddressHeader: String { return self._s[2341]! } + public var Passport_Identity_Name: String { return self._s[2342]! } public func Channel_DiscussionGroup_HeaderGroupSet(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2342]!, self._r[2342]!, [_0]) + return formatWithArgumentRanges(self._s[2343]!, self._r[2343]!, [_0]) } - public var GroupRemoved_ViewUserInfo: String { return self._s[2343]! } - public var Conversation_BlockUser: String { return self._s[2344]! } - public var Month_GenJanuary: String { return self._s[2345]! } - public var ChatSettings_TextSize: String { return self._s[2346]! } - public var Notification_PassportValuePhone: String { return self._s[2347]! } - public var MediaPlayer_UnknownArtist: String { return self._s[2348]! } - public var Passport_Language_ne: String { return self._s[2349]! } - public var Notification_CallBack: String { return self._s[2350]! } - public var Wallet_SecureStorageReset_BiometryTouchId: String { return self._s[2351]! } - public var TwoStepAuth_EmailHelp: String { return self._s[2352]! } + public var GroupRemoved_ViewUserInfo: String { return self._s[2344]! } + public var Conversation_BlockUser: String { return self._s[2345]! } + public var Month_GenJanuary: String { return self._s[2346]! } + public var ChatSettings_TextSize: String { return self._s[2347]! } + public var Notification_PassportValuePhone: String { return self._s[2348]! } + public var MediaPlayer_UnknownArtist: String { return self._s[2349]! } + public var Passport_Language_ne: String { return self._s[2350]! } + public var Notification_CallBack: String { return self._s[2351]! } + public var Wallet_SecureStorageReset_BiometryTouchId: String { return self._s[2352]! } + public var TwoStepAuth_EmailHelp: String { return self._s[2353]! } public func Time_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2353]!, self._r[2353]!, [_0]) + return formatWithArgumentRanges(self._s[2354]!, self._r[2354]!, [_0]) } - public var Channel_Info_Management: String { return self._s[2354]! } - public var Passport_FieldIdentityUploadHelp: String { return self._s[2355]! } - public var Stickers_FrequentlyUsed: String { return self._s[2356]! } - public var Channel_BanUser_PermissionSendMessages: String { return self._s[2357]! } - public var Passport_Address_OneOfTypeUtilityBill: String { return self._s[2359]! } + public var Channel_Info_Management: String { return self._s[2355]! } + public var Passport_FieldIdentityUploadHelp: String { return self._s[2356]! } + public var Stickers_FrequentlyUsed: String { return self._s[2357]! } + public var Channel_BanUser_PermissionSendMessages: String { return self._s[2358]! } + public var Passport_Address_OneOfTypeUtilityBill: String { return self._s[2360]! } public func LOCAL_CHANNEL_MESSAGE_FWDS(_ _1: String, _ _2: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2360]!, self._r[2360]!, [_1, "\(_2)"]) + return formatWithArgumentRanges(self._s[2361]!, self._r[2361]!, [_1, "\(_2)"]) } - public var TwoFactorSetup_Password_Title: String { return self._s[2361]! } - public var Passport_Address_EditResidentialAddress: String { return self._s[2362]! } - public var PrivacyPolicy_DeclineTitle: String { return self._s[2363]! } - public var CreatePoll_TextHeader: String { return self._s[2364]! } + public var TwoFactorSetup_Password_Title: String { return self._s[2362]! } + public var Passport_Address_EditResidentialAddress: String { return self._s[2363]! } + public var PrivacyPolicy_DeclineTitle: String { return self._s[2364]! } + public var CreatePoll_TextHeader: String { return self._s[2365]! } public func Checkout_SavePasswordTimeoutAndTouchId(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2365]!, self._r[2365]!, [_0]) + return formatWithArgumentRanges(self._s[2366]!, self._r[2366]!, [_0]) } - public var PhotoEditor_QualityMedium: String { return self._s[2366]! } - public var InfoPlist_NSMicrophoneUsageDescription: String { return self._s[2367]! } - public var Conversation_StatusKickedFromChannel: String { return self._s[2369]! } - public var CheckoutInfo_ReceiverInfoName: String { return self._s[2370]! } - public var Group_ErrorSendRestrictedStickers: String { return self._s[2371]! } + public var PhotoEditor_QualityMedium: String { return self._s[2367]! } + public var InfoPlist_NSMicrophoneUsageDescription: String { return self._s[2368]! } + public var Conversation_StatusKickedFromChannel: String { return self._s[2370]! } + public var CheckoutInfo_ReceiverInfoName: String { return self._s[2371]! } + public var Group_ErrorSendRestrictedStickers: String { return self._s[2372]! } public func Conversation_RestrictedInlineTimed(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2372]!, self._r[2372]!, [_0]) + return formatWithArgumentRanges(self._s[2373]!, self._r[2373]!, [_0]) } public func Channel_AdminLog_MessageTransferedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2373]!, self._r[2373]!, [_1]) + return formatWithArgumentRanges(self._s[2374]!, self._r[2374]!, [_1]) } - public var LogoutOptions_LogOutWalletInfo: String { return self._s[2374]! } - public var TwoFactorSetup_Email_SkipConfirmationTitle: String { return self._s[2375]! } - public var Conversation_LinkDialogOpen: String { return self._s[2377]! } - public var TwoFactorSetup_Hint_Title: String { return self._s[2378]! } - public var VoiceOver_Chat_PollNoVotes: String { return self._s[2379]! } - public var Settings_Username: String { return self._s[2381]! } - public var Conversation_Block: String { return self._s[2383]! } - public var Wallpaper_Wallpaper: String { return self._s[2384]! } - public var SocksProxySetup_UseProxy: String { return self._s[2386]! } - public var Wallet_Send_Confirmation: String { return self._s[2387]! } - public var EditTheme_UploadEditedTheme: String { return self._s[2388]! } - public var UserInfo_ShareMyContactInfo: String { return self._s[2389]! } - public var MessageTimer_Forever: String { return self._s[2390]! } - public var Privacy_Calls_WhoCanCallMe: String { return self._s[2391]! } - public var PhotoEditor_DiscardChanges: String { return self._s[2392]! } - public var AuthSessions_TerminateOtherSessionsHelp: String { return self._s[2393]! } - public var Passport_Language_da: String { return self._s[2394]! } - public var SocksProxySetup_PortPlaceholder: String { return self._s[2395]! } + public var LogoutOptions_LogOutWalletInfo: String { return self._s[2375]! } + public var TwoFactorSetup_Email_SkipConfirmationTitle: String { return self._s[2376]! } + public var Conversation_LinkDialogOpen: String { return self._s[2378]! } + public var TwoFactorSetup_Hint_Title: String { return self._s[2379]! } + public var VoiceOver_Chat_PollNoVotes: String { return self._s[2380]! } + public var Settings_Username: String { return self._s[2382]! } + public var Conversation_Block: String { return self._s[2384]! } + public var Wallpaper_Wallpaper: String { return self._s[2385]! } + public var SocksProxySetup_UseProxy: String { return self._s[2387]! } + public var Wallet_Send_Confirmation: String { return self._s[2388]! } + public var EditTheme_UploadEditedTheme: String { return self._s[2389]! } + public var UserInfo_ShareMyContactInfo: String { return self._s[2390]! } + public var MessageTimer_Forever: String { return self._s[2391]! } + public var Privacy_Calls_WhoCanCallMe: String { return self._s[2392]! } + public var PhotoEditor_DiscardChanges: String { return self._s[2393]! } + public var AuthSessions_TerminateOtherSessionsHelp: String { return self._s[2394]! } + public var Passport_Language_da: String { return self._s[2395]! } + public var SocksProxySetup_PortPlaceholder: String { return self._s[2396]! } public func SecretGIF_NotViewedYet(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2396]!, self._r[2396]!, [_0]) + return formatWithArgumentRanges(self._s[2397]!, self._r[2397]!, [_0]) } - public var Passport_Address_EditPassportRegistration: String { return self._s[2397]! } + public var Passport_Address_EditPassportRegistration: String { return self._s[2398]! } public func Channel_AdminLog_MessageChangedGroupAbout(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2399]!, self._r[2399]!, [_0]) + return formatWithArgumentRanges(self._s[2400]!, self._r[2400]!, [_0]) } - public var Settings_AddDevice: String { return self._s[2400]! } - public var Passport_Identity_ResidenceCountryPlaceholder: String { return self._s[2402]! } - public var AuthSessions_AddDeviceIntro_Text1: String { return self._s[2403]! } - public var Conversation_SearchByName_Prefix: String { return self._s[2404]! } - public var Conversation_PinnedPoll: String { return self._s[2405]! } - public var AuthSessions_AddDeviceIntro_Text2: String { return self._s[2406]! } - public var Conversation_EmptyGifPanelPlaceholder: String { return self._s[2407]! } - public var AuthSessions_AddDeviceIntro_Text3: String { return self._s[2408]! } + public var Settings_AddDevice: String { return self._s[2401]! } + public var Passport_Identity_ResidenceCountryPlaceholder: String { return self._s[2403]! } + public var AuthSessions_AddDeviceIntro_Text1: String { return self._s[2404]! } + public var Conversation_SearchByName_Prefix: String { return self._s[2405]! } + public var Conversation_PinnedPoll: String { return self._s[2406]! } + public var AuthSessions_AddDeviceIntro_Text2: String { return self._s[2407]! } + public var Conversation_EmptyGifPanelPlaceholder: String { return self._s[2408]! } + public var AuthSessions_AddDeviceIntro_Text3: String { return self._s[2409]! } public func PUSH_ENCRYPTION_ACCEPT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2409]!, self._r[2409]!, [_1]) + return formatWithArgumentRanges(self._s[2410]!, self._r[2410]!, [_1]) } - public var WallpaperSearch_ColorPurple: String { return self._s[2410]! } - public var Cache_ByPeerHeader: String { return self._s[2411]! } + public var WallpaperSearch_ColorPurple: String { return self._s[2411]! } + public var Cache_ByPeerHeader: String { return self._s[2412]! } public func Conversation_EncryptedPlaceholderTitleIncoming(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2412]!, self._r[2412]!, [_0]) + return formatWithArgumentRanges(self._s[2413]!, self._r[2413]!, [_0]) } - public var ChatSettings_AutoDownloadDocuments: String { return self._s[2413]! } - public var Appearance_ThemePreview_Chat_3_Text: String { return self._s[2416]! } - public var Wallet_Completed_Title: String { return self._s[2417]! } - public var Notification_PinnedMessage: String { return self._s[2418]! } - public var TwoFactorSetup_EmailVerification_Placeholder: String { return self._s[2419]! } - public var VoiceOver_Chat_RecordModeVideoMessage: String { return self._s[2421]! } - public var Contacts_SortBy: String { return self._s[2422]! } + public var ChatSettings_AutoDownloadDocuments: String { return self._s[2414]! } + public var Appearance_ThemePreview_Chat_3_Text: String { return self._s[2417]! } + public var Wallet_Completed_Title: String { return self._s[2418]! } + public var Notification_PinnedMessage: String { return self._s[2419]! } + public var TwoFactorSetup_EmailVerification_Placeholder: String { return self._s[2420]! } + public var VoiceOver_Chat_RecordModeVideoMessage: String { return self._s[2422]! } + public var Contacts_SortBy: String { return self._s[2423]! } public func PUSH_CHANNEL_MESSAGE_NOTEXT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2423]!, self._r[2423]!, [_1]) + return formatWithArgumentRanges(self._s[2424]!, self._r[2424]!, [_1]) } - public var Appearance_ColorThemeNight: String { return self._s[2425]! } + public var Appearance_ColorThemeNight: String { return self._s[2426]! } public func PUSH_MESSAGE_GAME(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2426]!, self._r[2426]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2427]!, self._r[2427]!, [_1, _2]) } - public var Call_EncryptionKey_Title: String { return self._s[2427]! } - public var Watch_UserInfo_Service: String { return self._s[2428]! } - public var SettingsSearch_Synonyms_Data_SaveEditedPhotos: String { return self._s[2430]! } - public var Conversation_Unpin: String { return self._s[2432]! } - public var CancelResetAccount_Title: String { return self._s[2433]! } - public var Map_LiveLocationFor15Minutes: String { return self._s[2434]! } + public var Call_EncryptionKey_Title: String { return self._s[2428]! } + public var Watch_UserInfo_Service: String { return self._s[2429]! } + public var SettingsSearch_Synonyms_Data_SaveEditedPhotos: String { return self._s[2431]! } + public var Conversation_Unpin: String { return self._s[2433]! } + public var CancelResetAccount_Title: String { return self._s[2434]! } + public var Map_LiveLocationFor15Minutes: String { return self._s[2435]! } public func Time_PreciseDate_m8(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2436]!, self._r[2436]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2437]!, self._r[2437]!, [_1, _2, _3]) } - public var Group_Members_AddMemberBotErrorNotAllowed: String { return self._s[2437]! } - public var Appearance_BubbleCorners_Title: String { return self._s[2438]! } - public var CallSettings_Title: String { return self._s[2439]! } - public var SettingsSearch_Synonyms_Appearance_ChatBackground: String { return self._s[2440]! } - public var PasscodeSettings_EncryptDataHelp: String { return self._s[2442]! } - public var AutoDownloadSettings_Contacts: String { return self._s[2443]! } + public var Group_Members_AddMemberBotErrorNotAllowed: String { return self._s[2438]! } + public var Appearance_BubbleCorners_Title: String { return self._s[2439]! } + public var CallSettings_Title: String { return self._s[2440]! } + public var SettingsSearch_Synonyms_Appearance_ChatBackground: String { return self._s[2441]! } + public var PasscodeSettings_EncryptDataHelp: String { return self._s[2443]! } + public var AutoDownloadSettings_Contacts: String { return self._s[2444]! } public func Channel_AdminLog_MessageRankName(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2444]!, self._r[2444]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2445]!, self._r[2445]!, [_1, _2]) } - public var Passport_Identity_DocumentDetails: String { return self._s[2445]! } - public var LoginPassword_PasswordHelp: String { return self._s[2446]! } - public var SettingsSearch_Synonyms_Data_AutoDownloadUsingWifi: String { return self._s[2447]! } - public var PrivacyLastSeenSettings_CustomShareSettings_Delete: String { return self._s[2448]! } - public var ChatContextMenu_TextSelectionTip: String { return self._s[2449]! } - public var Checkout_TotalPaidAmount: String { return self._s[2450]! } + public var Passport_Identity_DocumentDetails: String { return self._s[2446]! } + public var LoginPassword_PasswordHelp: String { return self._s[2447]! } + public var SettingsSearch_Synonyms_Data_AutoDownloadUsingWifi: String { return self._s[2448]! } + public var PrivacyLastSeenSettings_CustomShareSettings_Delete: String { return self._s[2449]! } + public var ChatContextMenu_TextSelectionTip: String { return self._s[2450]! } + public var Checkout_TotalPaidAmount: String { return self._s[2451]! } public func FileSize_KB(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2451]!, self._r[2451]!, [_0]) + return formatWithArgumentRanges(self._s[2452]!, self._r[2452]!, [_0]) } - public var ChatState_Updating: String { return self._s[2452]! } - public var PasscodeSettings_ChangePasscode: String { return self._s[2453]! } - public var Conversation_SecretLinkPreviewAlert: String { return self._s[2455]! } - public var Privacy_SecretChatsLinkPreviews: String { return self._s[2456]! } + public var ChatState_Updating: String { return self._s[2453]! } + public var PasscodeSettings_ChangePasscode: String { return self._s[2454]! } + public var Conversation_SecretLinkPreviewAlert: String { return self._s[2456]! } + public var Privacy_SecretChatsLinkPreviews: String { return self._s[2457]! } public func PUSH_CHANNEL_MESSAGE_DOC(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2457]!, self._r[2457]!, [_1]) + return formatWithArgumentRanges(self._s[2458]!, self._r[2458]!, [_1]) } - public var VoiceOver_Chat_ReplyToYourMessage: String { return self._s[2458]! } - public var Contacts_InviteFriends: String { return self._s[2460]! } - public var Map_ChooseLocationTitle: String { return self._s[2461]! } - public var Conversation_StopPoll: String { return self._s[2463]! } + public var VoiceOver_Chat_ReplyToYourMessage: String { return self._s[2459]! } + public var Contacts_InviteFriends: String { return self._s[2461]! } + public var Map_ChooseLocationTitle: String { return self._s[2462]! } + public var Conversation_StopPoll: String { return self._s[2464]! } public func WebSearch_SearchNoResultsDescription(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2464]!, self._r[2464]!, [_0]) + return formatWithArgumentRanges(self._s[2465]!, self._r[2465]!, [_0]) } - public var Call_Camera: String { return self._s[2465]! } - public var LogoutOptions_ChangePhoneNumberTitle: String { return self._s[2466]! } - public var AppWallet_Intro_Text: String { return self._s[2467]! } - public var Appearance_BubbleCornersSetting: String { return self._s[2468]! } - public var Calls_RatingFeedback: String { return self._s[2469]! } - public var GroupInfo_BroadcastListNamePlaceholder: String { return self._s[2471]! } - public var Wallet_Alert_OK: String { return self._s[2472]! } - public var NotificationsSound_Pulse: String { return self._s[2473]! } - public var Watch_LastSeen_Lately: String { return self._s[2474]! } - public var ReportGroupLocation_Report: String { return self._s[2477]! } - public var Widget_NoUsers: String { return self._s[2478]! } - public var Conversation_UnvotePoll: String { return self._s[2479]! } - public var SettingsSearch_Synonyms_Privacy_ProfilePhoto: String { return self._s[2481]! } - public var Privacy_ProfilePhoto_WhoCanSeeMyPhoto: String { return self._s[2482]! } - public var NotificationsSound_Circles: String { return self._s[2483]! } - public var PrivacyLastSeenSettings_AlwaysShareWith_Title: String { return self._s[2486]! } - public var Wallet_Settings_DeleteWallet: String { return self._s[2487]! } - public var TwoStepAuth_RecoveryCodeExpired: String { return self._s[2488]! } - public var Proxy_TooltipUnavailable: String { return self._s[2489]! } - public var Passport_Identity_CountryPlaceholder: String { return self._s[2491]! } - public var GroupInfo_Permissions_SlowmodeInfo: String { return self._s[2493]! } - public var Conversation_FileDropbox: String { return self._s[2494]! } - public var Notifications_ExceptionsUnmuted: String { return self._s[2495]! } - public var Tour_Text3: String { return self._s[2497]! } - public var Login_ResetAccountProtected_Title: String { return self._s[2499]! } - public var GroupPermission_NoSendMessages: String { return self._s[2500]! } - public var WallpaperSearch_ColorTitle: String { return self._s[2501]! } - public var ChatAdmins_AllMembersAreAdminsOnHelp: String { return self._s[2502]! } + public var Call_Camera: String { return self._s[2466]! } + public var LogoutOptions_ChangePhoneNumberTitle: String { return self._s[2467]! } + public var AppWallet_Intro_Text: String { return self._s[2468]! } + public var Appearance_BubbleCornersSetting: String { return self._s[2469]! } + public var Calls_RatingFeedback: String { return self._s[2470]! } + public var GroupInfo_BroadcastListNamePlaceholder: String { return self._s[2472]! } + public var Wallet_Alert_OK: String { return self._s[2473]! } + public var NotificationsSound_Pulse: String { return self._s[2474]! } + public var Watch_LastSeen_Lately: String { return self._s[2475]! } + public var ReportGroupLocation_Report: String { return self._s[2478]! } + public var Widget_NoUsers: String { return self._s[2479]! } + public var Conversation_UnvotePoll: String { return self._s[2480]! } + public var SettingsSearch_Synonyms_Privacy_ProfilePhoto: String { return self._s[2482]! } + public var Privacy_ProfilePhoto_WhoCanSeeMyPhoto: String { return self._s[2483]! } + public var NotificationsSound_Circles: String { return self._s[2484]! } + public var PrivacyLastSeenSettings_AlwaysShareWith_Title: String { return self._s[2487]! } + public var Wallet_Settings_DeleteWallet: String { return self._s[2488]! } + public var TwoStepAuth_RecoveryCodeExpired: String { return self._s[2489]! } + public var Proxy_TooltipUnavailable: String { return self._s[2490]! } + public var Passport_Identity_CountryPlaceholder: String { return self._s[2492]! } + public var GroupInfo_Permissions_SlowmodeInfo: String { return self._s[2494]! } + public var Conversation_FileDropbox: String { return self._s[2495]! } + public var Notifications_ExceptionsUnmuted: String { return self._s[2496]! } + public var Tour_Text3: String { return self._s[2498]! } + public var Login_ResetAccountProtected_Title: String { return self._s[2500]! } + public var GroupPermission_NoSendMessages: String { return self._s[2501]! } + public var WallpaperSearch_ColorTitle: String { return self._s[2502]! } + public var ChatAdmins_AllMembersAreAdminsOnHelp: String { return self._s[2503]! } public func Conversation_LiveLocationYouAnd(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2504]!, self._r[2504]!, [_0]) + return formatWithArgumentRanges(self._s[2505]!, self._r[2505]!, [_0]) } - public var GroupInfo_AddParticipantTitle: String { return self._s[2505]! } - public var Checkout_ShippingOption_Title: String { return self._s[2506]! } - public var ChatSettings_AutoDownloadTitle: String { return self._s[2507]! } + public var GroupInfo_AddParticipantTitle: String { return self._s[2506]! } + public var Checkout_ShippingOption_Title: String { return self._s[2507]! } + public var ChatSettings_AutoDownloadTitle: String { return self._s[2508]! } public func DialogList_SingleTypingSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2508]!, self._r[2508]!, [_0]) - } - public func ChatSettings_AutoDownloadSettings_TypeVideo(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2509]!, self._r[2509]!, [_0]) } - public var Channel_Management_LabelAdministrator: String { return self._s[2510]! } - public var EditTheme_FileReadError: String { return self._s[2511]! } - public var OwnershipTransfer_ComeBackLater: String { return self._s[2512]! } - public var PrivacyLastSeenSettings_NeverShareWith_Placeholder: String { return self._s[2513]! } - public var AutoDownloadSettings_Photos: String { return self._s[2515]! } - public var Appearance_PreviewIncomingText: String { return self._s[2516]! } - public var ChatList_Context_MarkAllAsRead: String { return self._s[2517]! } - public var ChannelInfo_ConfirmLeave: String { return self._s[2518]! } - public var MediaPicker_MomentsDateRangeSameMonthYearFormat: String { return self._s[2519]! } - public var Passport_Identity_DocumentNumberPlaceholder: String { return self._s[2520]! } - public var Channel_AdminLogFilter_EventsNewMembers: String { return self._s[2521]! } - public var PasscodeSettings_AutoLock_IfAwayFor_5minutes: String { return self._s[2522]! } - public var GroupInfo_SetGroupPhotoStop: String { return self._s[2523]! } - public var Notification_SecretChatScreenshot: String { return self._s[2524]! } - public var AccessDenied_Wallpapers: String { return self._s[2525]! } - public var ChatList_Context_Mute: String { return self._s[2527]! } - public var Passport_Address_City: String { return self._s[2528]! } - public var InfoPlist_NSPhotoLibraryAddUsageDescription: String { return self._s[2529]! } - public var Appearance_ThemeCarouselClassic: String { return self._s[2530]! } - public var SocksProxySetup_SecretPlaceholder: String { return self._s[2531]! } - public var AccessDenied_LocationDisabled: String { return self._s[2532]! } - public var Group_Location_Title: String { return self._s[2533]! } - public var SocksProxySetup_HostnamePlaceholder: String { return self._s[2535]! } - public var GroupInfo_Sound: String { return self._s[2536]! } - public var SettingsSearch_Synonyms_ChatSettings_OpenLinksIn: String { return self._s[2537]! } - public var ChannelInfo_ScamChannelWarning: String { return self._s[2538]! } - public var Stickers_RemoveFromFavorites: String { return self._s[2539]! } - public var Contacts_Title: String { return self._s[2540]! } - public var EditTheme_ThemeTemplateAlertText: String { return self._s[2541]! } - public var Passport_Language_fr: String { return self._s[2542]! } - public var TwoFactorSetup_EmailVerification_Action: String { return self._s[2543]! } - public var Notifications_ResetAllNotifications: String { return self._s[2544]! } - public var IntentsSettings_SuggestedChats: String { return self._s[2546]! } - public var PrivacySettings_SecurityTitle: String { return self._s[2548]! } - public var Checkout_NewCard_Title: String { return self._s[2549]! } - public var Login_HaveNotReceivedCodeInternal: String { return self._s[2550]! } - public var Conversation_ForwardChats: String { return self._s[2551]! } - public var Wallet_SecureStorageReset_PasscodeText: String { return self._s[2553]! } - public var PasscodeSettings_4DigitCode: String { return self._s[2554]! } - public var Settings_FAQ: String { return self._s[2556]! } - public var AutoDownloadSettings_DocumentsTitle: String { return self._s[2557]! } - public var Conversation_ContextMenuForward: String { return self._s[2558]! } - public var VoiceOver_Chat_YourPhoto: String { return self._s[2561]! } - public var PrivacyPolicy_Title: String { return self._s[2564]! } - public var Notifications_TextTone: String { return self._s[2565]! } - public var Profile_CreateNewContact: String { return self._s[2566]! } - public var PrivacyPhoneNumberSettings_WhoCanSeeMyPhoneNumber: String { return self._s[2567]! } - public var TwoFactorSetup_EmailVerification_Title: String { return self._s[2569]! } - public var Call_Speaker: String { return self._s[2570]! } - public var AutoNightTheme_AutomaticSection: String { return self._s[2571]! } - public var Channel_OwnershipTransfer_EnterPassword: String { return self._s[2573]! } - public var Channel_Username_InvalidCharacters: String { return self._s[2574]! } + public func ChatSettings_AutoDownloadSettings_TypeVideo(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2510]!, self._r[2510]!, [_0]) + } + public var Channel_Management_LabelAdministrator: String { return self._s[2511]! } + public var EditTheme_FileReadError: String { return self._s[2512]! } + public var OwnershipTransfer_ComeBackLater: String { return self._s[2513]! } + public var PrivacyLastSeenSettings_NeverShareWith_Placeholder: String { return self._s[2514]! } + public var AutoDownloadSettings_Photos: String { return self._s[2516]! } + public var Appearance_PreviewIncomingText: String { return self._s[2517]! } + public var ChatList_Context_MarkAllAsRead: String { return self._s[2518]! } + public var ChannelInfo_ConfirmLeave: String { return self._s[2519]! } + public var MediaPicker_MomentsDateRangeSameMonthYearFormat: String { return self._s[2520]! } + public var Passport_Identity_DocumentNumberPlaceholder: String { return self._s[2521]! } + public var Channel_AdminLogFilter_EventsNewMembers: String { return self._s[2522]! } + public var PasscodeSettings_AutoLock_IfAwayFor_5minutes: String { return self._s[2523]! } + public var GroupInfo_SetGroupPhotoStop: String { return self._s[2524]! } + public var Notification_SecretChatScreenshot: String { return self._s[2525]! } + public var AccessDenied_Wallpapers: String { return self._s[2526]! } + public var ChatList_Context_Mute: String { return self._s[2528]! } + public var Passport_Address_City: String { return self._s[2529]! } + public var InfoPlist_NSPhotoLibraryAddUsageDescription: String { return self._s[2530]! } + public var Appearance_ThemeCarouselClassic: String { return self._s[2531]! } + public var SocksProxySetup_SecretPlaceholder: String { return self._s[2532]! } + public var AccessDenied_LocationDisabled: String { return self._s[2533]! } + public var Group_Location_Title: String { return self._s[2534]! } + public var SocksProxySetup_HostnamePlaceholder: String { return self._s[2536]! } + public var GroupInfo_Sound: String { return self._s[2537]! } + public var SettingsSearch_Synonyms_ChatSettings_OpenLinksIn: String { return self._s[2538]! } + public var ChannelInfo_ScamChannelWarning: String { return self._s[2539]! } + public var Stickers_RemoveFromFavorites: String { return self._s[2540]! } + public var Contacts_Title: String { return self._s[2541]! } + public var EditTheme_ThemeTemplateAlertText: String { return self._s[2542]! } + public var Passport_Language_fr: String { return self._s[2543]! } + public var TwoFactorSetup_EmailVerification_Action: String { return self._s[2544]! } + public var Notifications_ResetAllNotifications: String { return self._s[2545]! } + public var IntentsSettings_SuggestedChats: String { return self._s[2547]! } + public var PrivacySettings_SecurityTitle: String { return self._s[2549]! } + public var Checkout_NewCard_Title: String { return self._s[2550]! } + public var Login_HaveNotReceivedCodeInternal: String { return self._s[2551]! } + public var Conversation_ForwardChats: String { return self._s[2552]! } + public var Wallet_SecureStorageReset_PasscodeText: String { return self._s[2554]! } + public var PasscodeSettings_4DigitCode: String { return self._s[2555]! } + public var Settings_FAQ: String { return self._s[2557]! } + public var AutoDownloadSettings_DocumentsTitle: String { return self._s[2558]! } + public var Conversation_ContextMenuForward: String { return self._s[2559]! } + public var VoiceOver_Chat_YourPhoto: String { return self._s[2562]! } + public var PrivacyPolicy_Title: String { return self._s[2565]! } + public var Notifications_TextTone: String { return self._s[2566]! } + public var Profile_CreateNewContact: String { return self._s[2567]! } + public var PrivacyPhoneNumberSettings_WhoCanSeeMyPhoneNumber: String { return self._s[2568]! } + public var TwoFactorSetup_EmailVerification_Title: String { return self._s[2570]! } + public var Call_Speaker: String { return self._s[2571]! } + public var AutoNightTheme_AutomaticSection: String { return self._s[2572]! } + public var Channel_OwnershipTransfer_EnterPassword: String { return self._s[2574]! } + public var Channel_Username_InvalidCharacters: String { return self._s[2575]! } public func Channel_AdminLog_MessageChangedChannelUsername(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2575]!, self._r[2575]!, [_0]) + return formatWithArgumentRanges(self._s[2576]!, self._r[2576]!, [_0]) } - public var AutoDownloadSettings_AutodownloadFiles: String { return self._s[2576]! } - public var PrivacySettings_LastSeenTitle: String { return self._s[2577]! } - public var Channel_AdminLog_CanInviteUsers: String { return self._s[2578]! } - public var SettingsSearch_Synonyms_Privacy_Data_ClearPaymentsInfo: String { return self._s[2579]! } - public var OwnershipTransfer_SecurityCheck: String { return self._s[2580]! } - public var Conversation_MessageDeliveryFailed: String { return self._s[2581]! } - public var Watch_ChatList_NoConversationsText: String { return self._s[2582]! } - public var Bot_Unblock: String { return self._s[2583]! } - public var TextFormat_Italic: String { return self._s[2584]! } - public var WallpaperSearch_ColorPink: String { return self._s[2585]! } - public var Settings_About_Help: String { return self._s[2587]! } - public var SearchImages_Title: String { return self._s[2588]! } - public var Weekday_Wednesday: String { return self._s[2589]! } - public var Conversation_ClousStorageInfo_Description1: String { return self._s[2590]! } - public var ExplicitContent_AlertTitle: String { return self._s[2591]! } + public var AutoDownloadSettings_AutodownloadFiles: String { return self._s[2577]! } + public var PrivacySettings_LastSeenTitle: String { return self._s[2578]! } + public var Channel_AdminLog_CanInviteUsers: String { return self._s[2579]! } + public var SettingsSearch_Synonyms_Privacy_Data_ClearPaymentsInfo: String { return self._s[2580]! } + public var OwnershipTransfer_SecurityCheck: String { return self._s[2581]! } + public var Conversation_MessageDeliveryFailed: String { return self._s[2582]! } + public var Watch_ChatList_NoConversationsText: String { return self._s[2583]! } + public var Bot_Unblock: String { return self._s[2584]! } + public var TextFormat_Italic: String { return self._s[2585]! } + public var WallpaperSearch_ColorPink: String { return self._s[2586]! } + public var Settings_About_Help: String { return self._s[2588]! } + public var SearchImages_Title: String { return self._s[2589]! } + public var Weekday_Wednesday: String { return self._s[2590]! } + public var Conversation_ClousStorageInfo_Description1: String { return self._s[2591]! } + public var ExplicitContent_AlertTitle: String { return self._s[2592]! } public func Time_PreciseDate_m5(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2592]!, self._r[2592]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2593]!, self._r[2593]!, [_1, _2, _3]) } - public var Channel_DiscussionGroup_Create: String { return self._s[2593]! } - public var Weekday_Thursday: String { return self._s[2594]! } - public var Channel_BanUser_PermissionChangeGroupInfo: String { return self._s[2595]! } - public var Channel_Members_AddMembersHelp: String { return self._s[2596]! } + public var Channel_DiscussionGroup_Create: String { return self._s[2594]! } + public var Weekday_Thursday: String { return self._s[2595]! } + public var Channel_BanUser_PermissionChangeGroupInfo: String { return self._s[2596]! } + public var Channel_Members_AddMembersHelp: String { return self._s[2597]! } public func Checkout_SavePasswordTimeout(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2597]!, self._r[2597]!, [_0]) + return formatWithArgumentRanges(self._s[2598]!, self._r[2598]!, [_0]) } - public var Channel_DiscussionGroup_LinkGroup: String { return self._s[2598]! } - public var SettingsSearch_Synonyms_Notifications_InAppNotificationsVibrate: String { return self._s[2599]! } - public var Passport_RequestedInformation: String { return self._s[2600]! } - public var Login_PhoneAndCountryHelp: String { return self._s[2601]! } - public var Conversation_EncryptionProcessing: String { return self._s[2603]! } - public var Notifications_PermissionsSuppressWarningTitle: String { return self._s[2604]! } - public var PhotoEditor_EnhanceTool: String { return self._s[2606]! } - public var Channel_Setup_Title: String { return self._s[2607]! } - public var Conversation_SearchPlaceholder: String { return self._s[2608]! } - public var OldChannels_GroupEmptyFormat: String { return self._s[2609]! } - public var AccessDenied_LocationAlwaysDenied: String { return self._s[2610]! } - public var Checkout_ErrorGeneric: String { return self._s[2611]! } - public var Passport_Language_hu: String { return self._s[2612]! } - public var GroupPermission_EditingDisabled: String { return self._s[2613]! } - public var Wallet_Month_ShortSeptember: String { return self._s[2615]! } + public var Channel_DiscussionGroup_LinkGroup: String { return self._s[2599]! } + public var SettingsSearch_Synonyms_Notifications_InAppNotificationsVibrate: String { return self._s[2600]! } + public var Passport_RequestedInformation: String { return self._s[2601]! } + public var Login_PhoneAndCountryHelp: String { return self._s[2602]! } + public var Conversation_EncryptionProcessing: String { return self._s[2604]! } + public var Notifications_PermissionsSuppressWarningTitle: String { return self._s[2605]! } + public var PhotoEditor_EnhanceTool: String { return self._s[2607]! } + public var Channel_Setup_Title: String { return self._s[2608]! } + public var Conversation_SearchPlaceholder: String { return self._s[2609]! } + public var OldChannels_GroupEmptyFormat: String { return self._s[2610]! } + public var AccessDenied_LocationAlwaysDenied: String { return self._s[2611]! } + public var Checkout_ErrorGeneric: String { return self._s[2612]! } + public var Passport_Language_hu: String { return self._s[2613]! } + public var GroupPermission_EditingDisabled: String { return self._s[2614]! } + public var Wallet_Month_ShortSeptember: String { return self._s[2616]! } public func Passport_Identity_UploadOneOfScan(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2616]!, self._r[2616]!, [_0]) + return formatWithArgumentRanges(self._s[2617]!, self._r[2617]!, [_0]) } public func PUSH_MESSAGE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2619]!, self._r[2619]!, [_1]) + return formatWithArgumentRanges(self._s[2620]!, self._r[2620]!, [_1]) } - public var ChatList_DeleteSavedMessagesConfirmationTitle: String { return self._s[2620]! } + public var ChatList_DeleteSavedMessagesConfirmationTitle: String { return self._s[2621]! } public func UserInfo_BlockConfirmationTitle(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2621]!, self._r[2621]!, [_0]) + return formatWithArgumentRanges(self._s[2622]!, self._r[2622]!, [_0]) } - public var Conversation_CloudStorageInfo_Title: String { return self._s[2622]! } - public var Group_Location_Info: String { return self._s[2623]! } - public var PhotoEditor_CropAspectRatioSquare: String { return self._s[2624]! } - public var Permissions_PeopleNearbyAllow_v0: String { return self._s[2625]! } + public var Conversation_CloudStorageInfo_Title: String { return self._s[2623]! } + public var Group_Location_Info: String { return self._s[2624]! } + public var PhotoEditor_CropAspectRatioSquare: String { return self._s[2625]! } + public var Permissions_PeopleNearbyAllow_v0: String { return self._s[2626]! } public func Notification_Exceptions_MutedUntil(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2626]!, self._r[2626]!, [_0]) + return formatWithArgumentRanges(self._s[2627]!, self._r[2627]!, [_0]) } - public var Conversation_ClearPrivateHistory: String { return self._s[2627]! } - public var ContactInfo_PhoneLabelHome: String { return self._s[2628]! } - public var Appearance_RemoveThemeConfirmation: String { return self._s[2629]! } - public var PrivacySettings_LastSeenContacts: String { return self._s[2630]! } + public var Conversation_ClearPrivateHistory: String { return self._s[2628]! } + public var ContactInfo_PhoneLabelHome: String { return self._s[2629]! } + public var Appearance_RemoveThemeConfirmation: String { return self._s[2630]! } + public var PrivacySettings_LastSeenContacts: String { return self._s[2631]! } public func ChangePhone_ErrorOccupied(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2631]!, self._r[2631]!, [_0]) - } - public func Notification_PinnedQuizMessage(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2632]!, self._r[2632]!, [_0]) } - public var Passport_Language_cs: String { return self._s[2633]! } - public var Message_PinnedAnimationMessage: String { return self._s[2635]! } - public var Passport_Identity_ReverseSideHelp: String { return self._s[2637]! } - public var SettingsSearch_Synonyms_Data_Storage_Title: String { return self._s[2638]! } - public var Wallet_Info_TransactionTo: String { return self._s[2640]! } - public var Stats_ViewsBySourceTitle: String { return self._s[2641]! } - public var ChatList_DeleteForEveryoneConfirmationText: String { return self._s[2642]! } - public var SettingsSearch_Synonyms_Privacy_PasscodeAndTouchId: String { return self._s[2643]! } - public var Embed_PlayingInPIP: String { return self._s[2644]! } - public var Appearance_ThemePreview_Chat_3_TextWithLink: String { return self._s[2645]! } - public var AutoNightTheme_ScheduleSection: String { return self._s[2646]! } + public func Notification_PinnedQuizMessage(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2633]!, self._r[2633]!, [_0]) + } + public var Passport_Language_cs: String { return self._s[2634]! } + public var Message_PinnedAnimationMessage: String { return self._s[2636]! } + public var Passport_Identity_ReverseSideHelp: String { return self._s[2638]! } + public var SettingsSearch_Synonyms_Data_Storage_Title: String { return self._s[2639]! } + public var Wallet_Info_TransactionTo: String { return self._s[2641]! } + public var Stats_ViewsBySourceTitle: String { return self._s[2642]! } + public var ChatList_DeleteForEveryoneConfirmationText: String { return self._s[2643]! } + public var SettingsSearch_Synonyms_Privacy_PasscodeAndTouchId: String { return self._s[2644]! } + public var Embed_PlayingInPIP: String { return self._s[2645]! } + public var Appearance_ThemePreview_Chat_3_TextWithLink: String { return self._s[2646]! } + public var AutoNightTheme_ScheduleSection: String { return self._s[2647]! } public func Call_EmojiDescription(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2647]!, self._r[2647]!, [_0]) + return formatWithArgumentRanges(self._s[2648]!, self._r[2648]!, [_0]) } - public var MediaPicker_LivePhotoDescription: String { return self._s[2648]! } + public var MediaPicker_LivePhotoDescription: String { return self._s[2649]! } public func Channel_AdminLog_MessageRestrictedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2649]!, self._r[2649]!, [_1]) + return formatWithArgumentRanges(self._s[2650]!, self._r[2650]!, [_1]) } - public var Notification_PaymentSent: String { return self._s[2650]! } - public var PhotoEditor_CurvesGreen: String { return self._s[2651]! } - public var Notification_Exceptions_PreviewAlwaysOff: String { return self._s[2652]! } - public var AutoNightTheme_System: String { return self._s[2653]! } - public var SaveIncomingPhotosSettings_Title: String { return self._s[2654]! } - public var CreatePoll_QuizTitle: String { return self._s[2655]! } - public var NotificationSettings_ShowNotificationsAllAccounts: String { return self._s[2656]! } - public var VoiceOver_Chat_PagePreview: String { return self._s[2657]! } + public var Notification_PaymentSent: String { return self._s[2651]! } + public var PhotoEditor_CurvesGreen: String { return self._s[2652]! } + public var Notification_Exceptions_PreviewAlwaysOff: String { return self._s[2653]! } + public var AutoNightTheme_System: String { return self._s[2654]! } + public var SaveIncomingPhotosSettings_Title: String { return self._s[2655]! } + public var CreatePoll_QuizTitle: String { return self._s[2656]! } + public var NotificationSettings_ShowNotificationsAllAccounts: String { return self._s[2657]! } + public var VoiceOver_Chat_PagePreview: String { return self._s[2658]! } public func PUSH_MESSAGE_SCREENSHOT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2660]!, self._r[2660]!, [_1]) - } - public func PUSH_MESSAGE_PHOTO_SECRET(_ _1: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2661]!, self._r[2661]!, [_1]) } - public func ApplyLanguage_UnsufficientDataText(_ _1: String) -> (String, [(Int, NSRange)]) { + public func PUSH_MESSAGE_PHOTO_SECRET(_ _1: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2662]!, self._r[2662]!, [_1]) } - public var NetworkUsageSettings_CallDataSection: String { return self._s[2664]! } - public var PasscodeSettings_HelpTop: String { return self._s[2665]! } - public var Conversation_WalletRequiredTitle: String { return self._s[2666]! } - public var PeerInfo_AddToContacts: String { return self._s[2667]! } - public var Group_OwnershipTransfer_ErrorAdminsTooMuch: String { return self._s[2668]! } - public var Passport_Address_TypeRentalAgreement: String { return self._s[2669]! } - public var EditTheme_ShortLink: String { return self._s[2670]! } - public var Theme_Colors_ColorWallpaperWarning: String { return self._s[2671]! } - public var ProxyServer_VoiceOver_Active: String { return self._s[2672]! } - public var ReportPeer_ReasonOther_Placeholder: String { return self._s[2673]! } - public var CheckoutInfo_ErrorPhoneInvalid: String { return self._s[2674]! } - public var Call_Accept: String { return self._s[2676]! } - public var GroupRemoved_RemoveInfo: String { return self._s[2677]! } - public var Month_GenMarch: String { return self._s[2679]! } - public var PhotoEditor_ShadowsTool: String { return self._s[2680]! } - public var LoginPassword_Title: String { return self._s[2681]! } - public var Call_End: String { return self._s[2682]! } - public var Watch_Conversation_GroupInfo: String { return self._s[2683]! } - public var VoiceOver_Chat_Contact: String { return self._s[2684]! } - public var EditTheme_Create_Preview_IncomingText: String { return self._s[2685]! } - public var CallSettings_Always: String { return self._s[2686]! } - public var CallFeedback_Success: String { return self._s[2687]! } - public var TwoStepAuth_SetupHint: String { return self._s[2688]! } + public func ApplyLanguage_UnsufficientDataText(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2663]!, self._r[2663]!, [_1]) + } + public var NetworkUsageSettings_CallDataSection: String { return self._s[2665]! } + public var PasscodeSettings_HelpTop: String { return self._s[2666]! } + public var Conversation_WalletRequiredTitle: String { return self._s[2667]! } + public var PeerInfo_AddToContacts: String { return self._s[2668]! } + public var Group_OwnershipTransfer_ErrorAdminsTooMuch: String { return self._s[2669]! } + public var Passport_Address_TypeRentalAgreement: String { return self._s[2670]! } + public var EditTheme_ShortLink: String { return self._s[2671]! } + public var Theme_Colors_ColorWallpaperWarning: String { return self._s[2672]! } + public var ProxyServer_VoiceOver_Active: String { return self._s[2673]! } + public var ReportPeer_ReasonOther_Placeholder: String { return self._s[2674]! } + public var CheckoutInfo_ErrorPhoneInvalid: String { return self._s[2675]! } + public var Call_Accept: String { return self._s[2677]! } + public var GroupRemoved_RemoveInfo: String { return self._s[2678]! } + public var Month_GenMarch: String { return self._s[2680]! } + public var PhotoEditor_ShadowsTool: String { return self._s[2681]! } + public var LoginPassword_Title: String { return self._s[2682]! } + public var Call_End: String { return self._s[2683]! } + public var Watch_Conversation_GroupInfo: String { return self._s[2684]! } + public var VoiceOver_Chat_Contact: String { return self._s[2685]! } + public var EditTheme_Create_Preview_IncomingText: String { return self._s[2686]! } + public var CallSettings_Always: String { return self._s[2687]! } + public var CallFeedback_Success: String { return self._s[2688]! } + public var TwoStepAuth_SetupHint: String { return self._s[2689]! } public func AddContact_ContactWillBeSharedAfterMutual(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2689]!, self._r[2689]!, [_1]) + return formatWithArgumentRanges(self._s[2690]!, self._r[2690]!, [_1]) } - public var ConversationProfile_UsersTooMuchError: String { return self._s[2690]! } - public var PeerInfo_ButtonAddMember: String { return self._s[2691]! } - public var Login_PhoneTitle: String { return self._s[2692]! } - public var Passport_FieldPhoneHelp: String { return self._s[2693]! } - public var Weekday_ShortSunday: String { return self._s[2694]! } - public var Passport_InfoFAQ_URL: String { return self._s[2695]! } - public var ContactInfo_Job: String { return self._s[2697]! } - public var UserInfo_InviteBotToGroup: String { return self._s[2698]! } - public var Appearance_ThemeCarouselNightBlue: String { return self._s[2699]! } - public var CreatePoll_QuizTip: String { return self._s[2700]! } - public var TwoFactorSetup_Email_Text: String { return self._s[2701]! } - public var TwoStepAuth_PasswordRemovePassportConfirmation: String { return self._s[2702]! } - public var Invite_ChannelsTooMuch: String { return self._s[2703]! } - public var Wallet_Send_ConfirmationConfirm: String { return self._s[2704]! } - public var Wallet_TransactionInfo_OtherFeeInfo: String { return self._s[2705]! } - public var SettingsSearch_Synonyms_Notifications_InAppNotificationsPreview: String { return self._s[2706]! } - public var Wallet_Receive_AmountText: String { return self._s[2707]! } - public var Passport_DeletePersonalDetailsConfirmation: String { return self._s[2708]! } - public var CallFeedback_ReasonNoise: String { return self._s[2709]! } - public var Appearance_AppIconDefault: String { return self._s[2711]! } - public var Passport_Identity_AddInternalPassport: String { return self._s[2712]! } - public var MediaPicker_AddCaption: String { return self._s[2713]! } - public var CallSettings_TabIconDescription: String { return self._s[2714]! } + public var ConversationProfile_UsersTooMuchError: String { return self._s[2691]! } + public var PeerInfo_ButtonAddMember: String { return self._s[2692]! } + public var Login_PhoneTitle: String { return self._s[2693]! } + public var Passport_FieldPhoneHelp: String { return self._s[2694]! } + public var Weekday_ShortSunday: String { return self._s[2695]! } + public var Passport_InfoFAQ_URL: String { return self._s[2696]! } + public var ContactInfo_Job: String { return self._s[2698]! } + public var UserInfo_InviteBotToGroup: String { return self._s[2699]! } + public var Appearance_ThemeCarouselNightBlue: String { return self._s[2700]! } + public var CreatePoll_QuizTip: String { return self._s[2701]! } + public var TwoFactorSetup_Email_Text: String { return self._s[2702]! } + public var TwoStepAuth_PasswordRemovePassportConfirmation: String { return self._s[2703]! } + public var Invite_ChannelsTooMuch: String { return self._s[2704]! } + public var Wallet_Send_ConfirmationConfirm: String { return self._s[2705]! } + public var Wallet_TransactionInfo_OtherFeeInfo: String { return self._s[2706]! } + public var SettingsSearch_Synonyms_Notifications_InAppNotificationsPreview: String { return self._s[2707]! } + public var Wallet_Receive_AmountText: String { return self._s[2708]! } + public var Passport_DeletePersonalDetailsConfirmation: String { return self._s[2709]! } + public var CallFeedback_ReasonNoise: String { return self._s[2710]! } + public var Appearance_AppIconDefault: String { return self._s[2712]! } + public var Passport_Identity_AddInternalPassport: String { return self._s[2713]! } + public var MediaPicker_AddCaption: String { return self._s[2714]! } + public var CallSettings_TabIconDescription: String { return self._s[2715]! } public func VoiceOver_Chat_Caption(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2715]!, self._r[2715]!, [_0]) + return formatWithArgumentRanges(self._s[2716]!, self._r[2716]!, [_0]) } - public var IntentsSettings_SuggestedChatsGroups: String { return self._s[2716]! } + public var IntentsSettings_SuggestedChatsGroups: String { return self._s[2717]! } public func Map_SearchNoResultsDescription(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2717]!, self._r[2717]!, [_0]) + return formatWithArgumentRanges(self._s[2718]!, self._r[2718]!, [_0]) } - public var ChatList_UndoArchiveHiddenTitle: String { return self._s[2718]! } - public var Privacy_GroupsAndChannels_AlwaysAllow: String { return self._s[2719]! } - public var Passport_Identity_TypePersonalDetails: String { return self._s[2720]! } - public var DialogList_SearchSectionRecent: String { return self._s[2721]! } - public var PrivacyPolicy_DeclineMessage: String { return self._s[2722]! } - public var CreatePoll_Anonymous: String { return self._s[2723]! } - public var LogoutOptions_ClearCacheText: String { return self._s[2726]! } - public var LastSeen_WithinAWeek: String { return self._s[2727]! } - public var ChannelMembers_GroupAdminsTitle: String { return self._s[2728]! } - public var Conversation_CloudStorage_ChatStatus: String { return self._s[2730]! } - public var VoiceOver_Media_PlaybackRateNormal: String { return self._s[2731]! } + public var ChatList_UndoArchiveHiddenTitle: String { return self._s[2719]! } + public var Privacy_GroupsAndChannels_AlwaysAllow: String { return self._s[2720]! } + public var Passport_Identity_TypePersonalDetails: String { return self._s[2721]! } + public var DialogList_SearchSectionRecent: String { return self._s[2722]! } + public var PrivacyPolicy_DeclineMessage: String { return self._s[2723]! } + public var CreatePoll_Anonymous: String { return self._s[2724]! } + public var LogoutOptions_ClearCacheText: String { return self._s[2727]! } + public var LastSeen_WithinAWeek: String { return self._s[2728]! } + public var ChannelMembers_GroupAdminsTitle: String { return self._s[2729]! } + public var Conversation_CloudStorage_ChatStatus: String { return self._s[2731]! } + public var VoiceOver_Media_PlaybackRateNormal: String { return self._s[2732]! } public func AddContact_SharedContactExceptionInfo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2732]!, self._r[2732]!, [_0]) + return formatWithArgumentRanges(self._s[2733]!, self._r[2733]!, [_0]) } - public var Passport_Address_TypeResidentialAddress: String { return self._s[2733]! } - public var Conversation_StatusLeftGroup: String { return self._s[2734]! } - public var SocksProxySetup_ProxyDetailsTitle: String { return self._s[2735]! } - public var SettingsSearch_Synonyms_Calls_Title: String { return self._s[2737]! } - public var GroupPermission_AddSuccess: String { return self._s[2738]! } - public var PhotoEditor_BlurToolRadial: String { return self._s[2740]! } - public var Conversation_ContextMenuCopy: String { return self._s[2741]! } - public var AccessDenied_CallMicrophone: String { return self._s[2742]! } + public var Passport_Address_TypeResidentialAddress: String { return self._s[2734]! } + public var Conversation_StatusLeftGroup: String { return self._s[2735]! } + public var SocksProxySetup_ProxyDetailsTitle: String { return self._s[2736]! } + public var SettingsSearch_Synonyms_Calls_Title: String { return self._s[2738]! } + public var GroupPermission_AddSuccess: String { return self._s[2739]! } + public var PhotoEditor_BlurToolRadial: String { return self._s[2741]! } + public var Conversation_ContextMenuCopy: String { return self._s[2742]! } + public var AccessDenied_CallMicrophone: String { return self._s[2743]! } public func Time_PreciseDate_m2(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2743]!, self._r[2743]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2744]!, self._r[2744]!, [_1, _2, _3]) } - public var Login_InvalidFirstNameError: String { return self._s[2744]! } - public var Notifications_Badge_CountUnreadMessages_InfoOn: String { return self._s[2745]! } - public var Checkout_PaymentMethod_New: String { return self._s[2746]! } - public var ShareMenu_CopyShareLinkGame: String { return self._s[2747]! } - public var PhotoEditor_QualityTool: String { return self._s[2748]! } - public var Login_SendCodeViaSms: String { return self._s[2749]! } - public var SettingsSearch_Synonyms_Privacy_DeleteAccountIfAwayFor: String { return self._s[2750]! } - public var Chat_SlowmodeAttachmentLimitReached: String { return self._s[2751]! } - public var Wallet_Receive_CopyAddress: String { return self._s[2752]! } - public var Login_EmailNotConfiguredError: String { return self._s[2753]! } - public var SocksProxySetup_Status: String { return self._s[2754]! } - public var Conversation_ScheduleMessage_SendWhenOnline: String { return self._s[2755]! } - public var PrivacyPolicy_Accept: String { return self._s[2756]! } - public var Notifications_ExceptionsMessagePlaceholder: String { return self._s[2757]! } - public var Appearance_AppIconClassicX: String { return self._s[2758]! } + public var Login_InvalidFirstNameError: String { return self._s[2745]! } + public var Notifications_Badge_CountUnreadMessages_InfoOn: String { return self._s[2746]! } + public var Checkout_PaymentMethod_New: String { return self._s[2747]! } + public var ShareMenu_CopyShareLinkGame: String { return self._s[2748]! } + public var PhotoEditor_QualityTool: String { return self._s[2749]! } + public var Login_SendCodeViaSms: String { return self._s[2750]! } + public var SettingsSearch_Synonyms_Privacy_DeleteAccountIfAwayFor: String { return self._s[2751]! } + public var Chat_SlowmodeAttachmentLimitReached: String { return self._s[2752]! } + public var Wallet_Receive_CopyAddress: String { return self._s[2753]! } + public var Login_EmailNotConfiguredError: String { return self._s[2754]! } + public var SocksProxySetup_Status: String { return self._s[2755]! } + public var Conversation_ScheduleMessage_SendWhenOnline: String { return self._s[2756]! } + public var PrivacyPolicy_Accept: String { return self._s[2757]! } + public var Notifications_ExceptionsMessagePlaceholder: String { return self._s[2758]! } + public var Appearance_AppIconClassicX: String { return self._s[2759]! } public func PUSH_CHAT_MESSAGE_TEXT(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2759]!, self._r[2759]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2760]!, self._r[2760]!, [_1, _2, _3]) } - public var OwnershipTransfer_SecurityRequirements: String { return self._s[2760]! } - public var InfoPlist_NSLocationAlwaysUsageDescription: String { return self._s[2762]! } - public var AutoNightTheme_Automatic: String { return self._s[2763]! } - public var Channel_Username_InvalidStartsWithNumber: String { return self._s[2764]! } - public var Privacy_ContactsSyncHelp: String { return self._s[2765]! } - public var Cache_Help: String { return self._s[2766]! } - public var Group_ErrorAccessDenied: String { return self._s[2767]! } - public var Passport_Language_fa: String { return self._s[2768]! } - public var Wallet_Intro_Text: String { return self._s[2769]! } - public var Login_ResetAccountProtected_TimerTitle: String { return self._s[2770]! } - public var VoiceOver_Chat_YourVideoMessage: String { return self._s[2771]! } - public var PrivacySettings_LastSeen: String { return self._s[2772]! } + public var OwnershipTransfer_SecurityRequirements: String { return self._s[2761]! } + public var InfoPlist_NSLocationAlwaysUsageDescription: String { return self._s[2763]! } + public var AutoNightTheme_Automatic: String { return self._s[2764]! } + public var Channel_Username_InvalidStartsWithNumber: String { return self._s[2765]! } + public var Privacy_ContactsSyncHelp: String { return self._s[2766]! } + public var Cache_Help: String { return self._s[2767]! } + public var Group_ErrorAccessDenied: String { return self._s[2768]! } + public var Passport_Language_fa: String { return self._s[2769]! } + public var Wallet_Intro_Text: String { return self._s[2770]! } + public var Login_ResetAccountProtected_TimerTitle: String { return self._s[2771]! } + public var VoiceOver_Chat_YourVideoMessage: String { return self._s[2772]! } + public var PrivacySettings_LastSeen: String { return self._s[2773]! } public func DialogList_MultipleTyping(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2773]!, self._r[2773]!, [_0, _1]) + return formatWithArgumentRanges(self._s[2774]!, self._r[2774]!, [_0, _1]) } - public var Wallet_Configuration_Apply: String { return self._s[2777]! } - public var Preview_SaveGif: String { return self._s[2778]! } - public var SettingsSearch_Synonyms_Privacy_TwoStepAuth: String { return self._s[2779]! } - public var Profile_About: String { return self._s[2780]! } - public var Channel_About_Placeholder: String { return self._s[2781]! } - public var Login_InfoTitle: String { return self._s[2782]! } + public var Wallet_Configuration_Apply: String { return self._s[2778]! } + public var Preview_SaveGif: String { return self._s[2779]! } + public var SettingsSearch_Synonyms_Privacy_TwoStepAuth: String { return self._s[2780]! } + public var Profile_About: String { return self._s[2781]! } + public var Channel_About_Placeholder: String { return self._s[2782]! } + public var Login_InfoTitle: String { return self._s[2783]! } public func TwoStepAuth_SetupPendingEmail(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2783]!, self._r[2783]!, [_0]) + return formatWithArgumentRanges(self._s[2784]!, self._r[2784]!, [_0]) } - public var EditTheme_Expand_Preview_IncomingReplyText: String { return self._s[2784]! } - public var Watch_Suggestion_CantTalk: String { return self._s[2786]! } - public var ContactInfo_Title: String { return self._s[2787]! } - public var Media_ShareThisVideo: String { return self._s[2788]! } - public var Weekday_ShortFriday: String { return self._s[2789]! } - public var AccessDenied_Contacts: String { return self._s[2791]! } - public var Notification_CallIncomingShort: String { return self._s[2792]! } - public var Group_Setup_TypePublic: String { return self._s[2793]! } - public var Notifications_MessageNotificationsExceptions: String { return self._s[2794]! } - public var Notifications_Badge_IncludeChannels: String { return self._s[2795]! } - public var Notifications_MessageNotificationsPreview: String { return self._s[2798]! } - public var ConversationProfile_ErrorCreatingConversation: String { return self._s[2799]! } - public var Group_ErrorAddTooMuchBots: String { return self._s[2800]! } - public var Privacy_GroupsAndChannels_CustomShareHelp: String { return self._s[2801]! } - public var Permissions_CellularDataAllowInSettings_v0: String { return self._s[2802]! } + public var EditTheme_Expand_Preview_IncomingReplyText: String { return self._s[2785]! } + public var Watch_Suggestion_CantTalk: String { return self._s[2787]! } + public var ContactInfo_Title: String { return self._s[2788]! } + public var Media_ShareThisVideo: String { return self._s[2789]! } + public var Weekday_ShortFriday: String { return self._s[2790]! } + public var AccessDenied_Contacts: String { return self._s[2792]! } + public var Notification_CallIncomingShort: String { return self._s[2793]! } + public var Group_Setup_TypePublic: String { return self._s[2794]! } + public var Notifications_MessageNotificationsExceptions: String { return self._s[2795]! } + public var Notifications_Badge_IncludeChannels: String { return self._s[2796]! } + public var Notifications_MessageNotificationsPreview: String { return self._s[2799]! } + public var ConversationProfile_ErrorCreatingConversation: String { return self._s[2800]! } + public var Group_ErrorAddTooMuchBots: String { return self._s[2801]! } + public var Privacy_GroupsAndChannels_CustomShareHelp: String { return self._s[2802]! } + public var Permissions_CellularDataAllowInSettings_v0: String { return self._s[2803]! } public func Wallet_SecureStorageChanged_BiometryText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2803]!, self._r[2803]!, [_0]) + return formatWithArgumentRanges(self._s[2804]!, self._r[2804]!, [_0]) } - public var DialogList_Typing: String { return self._s[2804]! } - public var CallFeedback_IncludeLogs: String { return self._s[2806]! } - public var Checkout_Phone: String { return self._s[2808]! } - public var Login_InfoFirstNamePlaceholder: String { return self._s[2811]! } - public var Privacy_Calls_Integration: String { return self._s[2812]! } - public var Notifications_PermissionsAllow: String { return self._s[2813]! } - public var TwoStepAuth_AddHintDescription: String { return self._s[2818]! } - public var Settings_ChatSettings: String { return self._s[2819]! } - public var Conversation_SendingOptionsTooltip: String { return self._s[2820]! } + public var DialogList_Typing: String { return self._s[2805]! } + public var CallFeedback_IncludeLogs: String { return self._s[2807]! } + public var Checkout_Phone: String { return self._s[2809]! } + public var Login_InfoFirstNamePlaceholder: String { return self._s[2812]! } + public var Privacy_Calls_Integration: String { return self._s[2813]! } + public var Notifications_PermissionsAllow: String { return self._s[2814]! } + public var TwoStepAuth_AddHintDescription: String { return self._s[2819]! } + public var Settings_ChatSettings: String { return self._s[2820]! } + public var Conversation_SendingOptionsTooltip: String { return self._s[2821]! } public func UserInfo_StartSecretChatConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2822]!, self._r[2822]!, [_0]) + return formatWithArgumentRanges(self._s[2823]!, self._r[2823]!, [_0]) } public func Channel_AdminLog_MessageInvitedNameUsername(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2823]!, self._r[2823]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2824]!, self._r[2824]!, [_1, _2]) } - public var GroupRemoved_DeleteUser: String { return self._s[2825]! } + public var GroupRemoved_DeleteUser: String { return self._s[2826]! } public func Channel_AdminLog_PollStopped(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2826]!, self._r[2826]!, [_0]) + return formatWithArgumentRanges(self._s[2827]!, self._r[2827]!, [_0]) } public func PUSH_MESSAGE_PHOTO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2827]!, self._r[2827]!, [_1]) + return formatWithArgumentRanges(self._s[2828]!, self._r[2828]!, [_1]) } - public var Login_ContinueWithLocalization: String { return self._s[2828]! } - public var Watch_Message_ForwardedFrom: String { return self._s[2829]! } - public var TwoStepAuth_EnterEmailCode: String { return self._s[2831]! } - public var Conversation_Unblock: String { return self._s[2832]! } - public var PrivacySettings_DataSettings: String { return self._s[2833]! } - public var WallpaperPreview_PatternPaternApply: String { return self._s[2834]! } - public var Group_PublicLink_Info: String { return self._s[2835]! } + public var Login_ContinueWithLocalization: String { return self._s[2829]! } + public var Watch_Message_ForwardedFrom: String { return self._s[2830]! } + public var TwoStepAuth_EnterEmailCode: String { return self._s[2832]! } + public var Conversation_Unblock: String { return self._s[2833]! } + public var PrivacySettings_DataSettings: String { return self._s[2834]! } + public var WallpaperPreview_PatternPaternApply: String { return self._s[2835]! } + public var Group_PublicLink_Info: String { return self._s[2836]! } public func Wallet_Time_PreciseDate_m1(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2836]!, self._r[2836]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2837]!, self._r[2837]!, [_1, _2, _3]) } - public var Notifications_InAppNotificationsVibrate: String { return self._s[2837]! } + public var Notifications_InAppNotificationsVibrate: String { return self._s[2838]! } public func Privacy_GroupsAndChannels_InviteToChannelError(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2838]!, self._r[2838]!, [_0, _1]) + return formatWithArgumentRanges(self._s[2839]!, self._r[2839]!, [_0, _1]) } - public var OldChannels_ChannelsHeader: String { return self._s[2840]! } - public var Wallet_RestoreFailed_CreateWallet: String { return self._s[2841]! } - public var PrivacySettings_Passcode: String { return self._s[2843]! } - public var Call_Mute: String { return self._s[2844]! } - public var Wallet_Weekday_Yesterday: String { return self._s[2845]! } - public var Passport_Language_dz: String { return self._s[2846]! } - public var Wallet_Receive_AmountHeader: String { return self._s[2847]! } - public var Wallet_TransactionInfo_OtherFeeInfoUrl: String { return self._s[2848]! } - public var Passport_Language_tk: String { return self._s[2849]! } + public var OldChannels_ChannelsHeader: String { return self._s[2841]! } + public var Wallet_RestoreFailed_CreateWallet: String { return self._s[2842]! } + public var PrivacySettings_Passcode: String { return self._s[2844]! } + public var Call_Mute: String { return self._s[2845]! } + public var Wallet_Weekday_Yesterday: String { return self._s[2846]! } + public var Passport_Language_dz: String { return self._s[2847]! } + public var Wallet_Receive_AmountHeader: String { return self._s[2848]! } + public var Wallet_TransactionInfo_OtherFeeInfoUrl: String { return self._s[2849]! } + public var Passport_Language_tk: String { return self._s[2850]! } public func Login_EmailCodeSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2850]!, self._r[2850]!, [_0]) + return formatWithArgumentRanges(self._s[2851]!, self._r[2851]!, [_0]) } - public var Settings_Search: String { return self._s[2851]! } - public var Wallet_Month_ShortFebruary: String { return self._s[2852]! } - public var InfoPlist_NSPhotoLibraryUsageDescription: String { return self._s[2853]! } - public var Wallet_Configuration_SourceJSON: String { return self._s[2854]! } - public var Conversation_ContextMenuReply: String { return self._s[2855]! } - public var WallpaperSearch_ColorBrown: String { return self._s[2856]! } - public var Chat_AttachmentMultipleForwardDisabled: String { return self._s[2857]! } - public var Tour_Title1: String { return self._s[2858]! } - public var Wallet_Alert_Cancel: String { return self._s[2859]! } - public var Conversation_ClearGroupHistory: String { return self._s[2861]! } - public var Wallet_TransactionInfo_RecipientHeader: String { return self._s[2862]! } - public var WallpaperPreview_Motion: String { return self._s[2863]! } + public var Settings_Search: String { return self._s[2852]! } + public var Wallet_Month_ShortFebruary: String { return self._s[2853]! } + public var InfoPlist_NSPhotoLibraryUsageDescription: String { return self._s[2854]! } + public var Wallet_Configuration_SourceJSON: String { return self._s[2855]! } + public var Conversation_ContextMenuReply: String { return self._s[2856]! } + public var WallpaperSearch_ColorBrown: String { return self._s[2857]! } + public var Chat_AttachmentMultipleForwardDisabled: String { return self._s[2858]! } + public var Tour_Title1: String { return self._s[2859]! } + public var Wallet_Alert_Cancel: String { return self._s[2860]! } + public var Conversation_ClearGroupHistory: String { return self._s[2862]! } + public var Wallet_TransactionInfo_RecipientHeader: String { return self._s[2863]! } + public var WallpaperPreview_Motion: String { return self._s[2864]! } public func Checkout_PasswordEntry_Text(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2864]!, self._r[2864]!, [_0]) + return formatWithArgumentRanges(self._s[2865]!, self._r[2865]!, [_0]) } - public var Wallet_Configuration_ApplyErrorTextJSONInvalidData: String { return self._s[2865]! } - public var Call_RateCall: String { return self._s[2866]! } - public var Channel_AdminLog_BanSendStickersAndGifs: String { return self._s[2867]! } - public var Passport_PasswordCompleteSetup: String { return self._s[2868]! } - public var Conversation_InputTextSilentBroadcastPlaceholder: String { return self._s[2869]! } - public var UserInfo_LastNamePlaceholder: String { return self._s[2871]! } + public var Wallet_Configuration_ApplyErrorTextJSONInvalidData: String { return self._s[2866]! } + public var Call_RateCall: String { return self._s[2867]! } + public var Channel_AdminLog_BanSendStickersAndGifs: String { return self._s[2868]! } + public var Passport_PasswordCompleteSetup: String { return self._s[2869]! } + public var Conversation_InputTextSilentBroadcastPlaceholder: String { return self._s[2870]! } + public var UserInfo_LastNamePlaceholder: String { return self._s[2872]! } public func Login_WillCallYou(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2873]!, self._r[2873]!, [_0]) + return formatWithArgumentRanges(self._s[2874]!, self._r[2874]!, [_0]) } - public var Compose_Create: String { return self._s[2874]! } - public var Contacts_InviteToTelegram: String { return self._s[2875]! } - public var GroupInfo_Notifications: String { return self._s[2876]! } - public var ChatList_DeleteSavedMessagesConfirmationAction: String { return self._s[2878]! } - public var Message_PinnedLiveLocationMessage: String { return self._s[2879]! } - public var Month_GenApril: String { return self._s[2880]! } - public var Appearance_AutoNightTheme: String { return self._s[2881]! } - public var ChatSettings_AutomaticAudioDownload: String { return self._s[2883]! } - public var Login_CodeSentSms: String { return self._s[2885]! } + public var Compose_Create: String { return self._s[2875]! } + public var Contacts_InviteToTelegram: String { return self._s[2876]! } + public var GroupInfo_Notifications: String { return self._s[2877]! } + public var ChatList_DeleteSavedMessagesConfirmationAction: String { return self._s[2879]! } + public var Message_PinnedLiveLocationMessage: String { return self._s[2880]! } + public var Month_GenApril: String { return self._s[2881]! } + public var Appearance_AutoNightTheme: String { return self._s[2882]! } + public var ChatSettings_AutomaticAudioDownload: String { return self._s[2884]! } + public var Login_CodeSentSms: String { return self._s[2886]! } public func UserInfo_UnblockConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2886]!, self._r[2886]!, [_0]) + return formatWithArgumentRanges(self._s[2887]!, self._r[2887]!, [_0]) } - public var EmptyGroupInfo_Line3: String { return self._s[2887]! } - public var LogoutOptions_ContactSupportText: String { return self._s[2888]! } - public var Passport_Language_hr: String { return self._s[2889]! } - public var Common_ActionNotAllowedError: String { return self._s[2890]! } + public var EmptyGroupInfo_Line3: String { return self._s[2888]! } + public var LogoutOptions_ContactSupportText: String { return self._s[2889]! } + public var Passport_Language_hr: String { return self._s[2890]! } + public var Common_ActionNotAllowedError: String { return self._s[2891]! } public func Channel_AdminLog_MessageRestrictedNewSetting(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2891]!, self._r[2891]!, [_0]) + return formatWithArgumentRanges(self._s[2892]!, self._r[2892]!, [_0]) } - public var GroupInfo_InviteLink_CopyLink: String { return self._s[2892]! } - public var Wallet_Info_TransactionFrom: String { return self._s[2893]! } - public var Wallet_Send_ErrorDecryptionFailed: String { return self._s[2894]! } - public var Conversation_InputTextBroadcastPlaceholder: String { return self._s[2895]! } - public var Privacy_SecretChatsTitle: String { return self._s[2896]! } - public var Notification_SecretChatMessageScreenshotSelf: String { return self._s[2898]! } - public var GroupInfo_AddUserLeftError: String { return self._s[2899]! } - public var AutoDownloadSettings_TypePrivateChats: String { return self._s[2900]! } - public var LogoutOptions_ContactSupportTitle: String { return self._s[2901]! } - public var Appearance_ThemePreview_Chat_7_Text: String { return self._s[2902]! } - public var Channel_AddBotErrorHaveRights: String { return self._s[2903]! } - public var Preview_DeleteGif: String { return self._s[2904]! } - public var GroupInfo_Permissions_Exceptions: String { return self._s[2905]! } - public var Group_ErrorNotMutualContact: String { return self._s[2906]! } - public var Notification_MessageLifetime5s: String { return self._s[2907]! } - public var Wallet_Send_OwnAddressAlertText: String { return self._s[2908]! } - public var OldChannels_ChannelFormat: String { return self._s[2909]! } + public var GroupInfo_InviteLink_CopyLink: String { return self._s[2893]! } + public var Wallet_Info_TransactionFrom: String { return self._s[2894]! } + public var Wallet_Send_ErrorDecryptionFailed: String { return self._s[2895]! } + public var Conversation_InputTextBroadcastPlaceholder: String { return self._s[2896]! } + public var Privacy_SecretChatsTitle: String { return self._s[2897]! } + public var Notification_SecretChatMessageScreenshotSelf: String { return self._s[2899]! } + public var GroupInfo_AddUserLeftError: String { return self._s[2900]! } + public var AutoDownloadSettings_TypePrivateChats: String { return self._s[2901]! } + public var LogoutOptions_ContactSupportTitle: String { return self._s[2902]! } + public var Appearance_ThemePreview_Chat_7_Text: String { return self._s[2903]! } + public var Channel_AddBotErrorHaveRights: String { return self._s[2904]! } + public var Preview_DeleteGif: String { return self._s[2905]! } + public var GroupInfo_Permissions_Exceptions: String { return self._s[2906]! } + public var Group_ErrorNotMutualContact: String { return self._s[2907]! } + public var Notification_MessageLifetime5s: String { return self._s[2908]! } + public var Wallet_Send_OwnAddressAlertText: String { return self._s[2909]! } + public var OldChannels_ChannelFormat: String { return self._s[2910]! } public func Watch_LastSeen_AtDate(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2910]!, self._r[2910]!, [_0]) + return formatWithArgumentRanges(self._s[2911]!, self._r[2911]!, [_0]) } - public var VoiceOver_Chat_Video: String { return self._s[2911]! } - public var Channel_OwnershipTransfer_ErrorPublicChannelsTooMuch: String { return self._s[2913]! } - public var ReportSpam_DeleteThisChat: String { return self._s[2914]! } - public var Passport_Address_AddBankStatement: String { return self._s[2915]! } - public var Notification_CallIncoming: String { return self._s[2916]! } - public var Wallet_Words_NotDoneTitle: String { return self._s[2917]! } - public var Compose_NewGroupTitle: String { return self._s[2918]! } - public var TwoStepAuth_RecoveryCodeHelp: String { return self._s[2920]! } - public var Passport_Address_Postcode: String { return self._s[2922]! } + public var VoiceOver_Chat_Video: String { return self._s[2912]! } + public var Channel_OwnershipTransfer_ErrorPublicChannelsTooMuch: String { return self._s[2914]! } + public var ReportSpam_DeleteThisChat: String { return self._s[2915]! } + public var Passport_Address_AddBankStatement: String { return self._s[2916]! } + public var Notification_CallIncoming: String { return self._s[2917]! } + public var Wallet_Words_NotDoneTitle: String { return self._s[2918]! } + public var Compose_NewGroupTitle: String { return self._s[2919]! } + public var TwoStepAuth_RecoveryCodeHelp: String { return self._s[2921]! } + public var Passport_Address_Postcode: String { return self._s[2923]! } public func LastSeen_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2923]!, self._r[2923]!, [_0]) + return formatWithArgumentRanges(self._s[2924]!, self._r[2924]!, [_0]) } - public var Checkout_NewCard_SaveInfoHelp: String { return self._s[2924]! } - public var Wallet_Month_ShortOctober: String { return self._s[2925]! } - public var VoiceOver_Chat_YourMusic: String { return self._s[2926]! } - public var WallpaperColors_Title: String { return self._s[2927]! } - public var SocksProxySetup_ShareQRCodeInfo: String { return self._s[2928]! } - public var VoiceOver_MessageContextForward: String { return self._s[2929]! } - public var GroupPermission_Duration: String { return self._s[2930]! } + public var Checkout_NewCard_SaveInfoHelp: String { return self._s[2925]! } + public var Wallet_Month_ShortOctober: String { return self._s[2926]! } + public var VoiceOver_Chat_YourMusic: String { return self._s[2927]! } + public var WallpaperColors_Title: String { return self._s[2928]! } + public var SocksProxySetup_ShareQRCodeInfo: String { return self._s[2929]! } + public var VoiceOver_MessageContextForward: String { return self._s[2930]! } + public var GroupPermission_Duration: String { return self._s[2931]! } public func Cache_Clear(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2931]!, self._r[2931]!, [_0]) + return formatWithArgumentRanges(self._s[2932]!, self._r[2932]!, [_0]) } - public var Bot_GroupStatusDoesNotReadHistory: String { return self._s[2932]! } - public var Username_Placeholder: String { return self._s[2933]! } - public var CallFeedback_WhatWentWrong: String { return self._s[2934]! } - public var Passport_FieldAddressUploadHelp: String { return self._s[2935]! } - public var Permissions_NotificationsAllowInSettings_v0: String { return self._s[2936]! } + public var Bot_GroupStatusDoesNotReadHistory: String { return self._s[2933]! } + public var Username_Placeholder: String { return self._s[2934]! } + public var CallFeedback_WhatWentWrong: String { return self._s[2935]! } + public var Passport_FieldAddressUploadHelp: String { return self._s[2936]! } + public var Permissions_NotificationsAllowInSettings_v0: String { return self._s[2937]! } public func Channel_AdminLog_MessageChangedUnlinkedChannel(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2938]!, self._r[2938]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2939]!, self._r[2939]!, [_1, _2]) } - public var Passport_PasswordDescription: String { return self._s[2939]! } - public var Channel_MessagePhotoUpdated: String { return self._s[2940]! } - public var MediaPicker_TapToUngroupDescription: String { return self._s[2941]! } - public var SettingsSearch_Synonyms_Notifications_BadgeCountUnreadMessages: String { return self._s[2942]! } - public var AttachmentMenu_PhotoOrVideo: String { return self._s[2943]! } - public var Conversation_ContextMenuMore: String { return self._s[2944]! } - public var Privacy_PaymentsClearInfo: String { return self._s[2945]! } - public var CallSettings_TabIcon: String { return self._s[2946]! } - public var KeyCommand_Find: String { return self._s[2947]! } - public var ClearCache_FreeSpaceDescription: String { return self._s[2948]! } - public var Appearance_ThemePreview_ChatList_7_Text: String { return self._s[2949]! } - public var EditTheme_Edit_Preview_IncomingText: String { return self._s[2950]! } - public var Message_PinnedGame: String { return self._s[2951]! } - public var VoiceOver_Chat_ForwardedFromYou: String { return self._s[2952]! } - public var Notifications_Badge_CountUnreadMessages_InfoOff: String { return self._s[2954]! } - public var Login_CallRequestState2: String { return self._s[2956]! } - public var CheckoutInfo_ReceiverInfoNamePlaceholder: String { return self._s[2958]! } + public var Passport_PasswordDescription: String { return self._s[2940]! } + public var Channel_MessagePhotoUpdated: String { return self._s[2941]! } + public var MediaPicker_TapToUngroupDescription: String { return self._s[2942]! } + public var SettingsSearch_Synonyms_Notifications_BadgeCountUnreadMessages: String { return self._s[2943]! } + public var AttachmentMenu_PhotoOrVideo: String { return self._s[2944]! } + public var Conversation_ContextMenuMore: String { return self._s[2945]! } + public var Privacy_PaymentsClearInfo: String { return self._s[2946]! } + public var CallSettings_TabIcon: String { return self._s[2947]! } + public var KeyCommand_Find: String { return self._s[2948]! } + public var ClearCache_FreeSpaceDescription: String { return self._s[2949]! } + public var Appearance_ThemePreview_ChatList_7_Text: String { return self._s[2950]! } + public var EditTheme_Edit_Preview_IncomingText: String { return self._s[2951]! } + public var Message_PinnedGame: String { return self._s[2952]! } + public var VoiceOver_Chat_ForwardedFromYou: String { return self._s[2953]! } + public var Notifications_Badge_CountUnreadMessages_InfoOff: String { return self._s[2955]! } + public var Login_CallRequestState2: String { return self._s[2957]! } + public var CheckoutInfo_ReceiverInfoNamePlaceholder: String { return self._s[2959]! } public func VoiceOver_Chat_PhotoFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2959]!, self._r[2959]!, [_0]) + return formatWithArgumentRanges(self._s[2960]!, self._r[2960]!, [_0]) } public func Checkout_PayPrice(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2961]!, self._r[2961]!, [_0]) + return formatWithArgumentRanges(self._s[2962]!, self._r[2962]!, [_0]) } - public var AuthSessions_AddDevice: String { return self._s[2962]! } - public var WallpaperPreview_Blurred: String { return self._s[2963]! } - public var Conversation_InstantPagePreview: String { return self._s[2964]! } - public var PeerInfo_ButtonUnmute: String { return self._s[2965]! } + public var AuthSessions_AddDevice: String { return self._s[2963]! } + public var WallpaperPreview_Blurred: String { return self._s[2964]! } + public var Conversation_InstantPagePreview: String { return self._s[2965]! } + public var PeerInfo_ButtonUnmute: String { return self._s[2966]! } public func DialogList_SingleUploadingVideoSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2966]!, self._r[2966]!, [_0]) + return formatWithArgumentRanges(self._s[2967]!, self._r[2967]!, [_0]) } - public var SecretTimer_VideoDescription: String { return self._s[2969]! } - public var WallpaperSearch_ColorRed: String { return self._s[2970]! } - public var GroupPermission_NoPinMessages: String { return self._s[2971]! } - public var Passport_Language_es: String { return self._s[2972]! } - public var Permissions_ContactsAllow_v0: String { return self._s[2974]! } - public var Conversation_EditingMessageMediaEditCurrentVideo: String { return self._s[2975]! } + public var SecretTimer_VideoDescription: String { return self._s[2970]! } + public var WallpaperSearch_ColorRed: String { return self._s[2971]! } + public var GroupPermission_NoPinMessages: String { return self._s[2972]! } + public var Passport_Language_es: String { return self._s[2973]! } + public var Permissions_ContactsAllow_v0: String { return self._s[2975]! } + public var Conversation_EditingMessageMediaEditCurrentVideo: String { return self._s[2976]! } public func PUSH_CHAT_MESSAGE_CONTACT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2976]!, self._r[2976]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2977]!, self._r[2977]!, [_1, _2]) } - public var Privacy_Forwards_CustomHelp: String { return self._s[2977]! } - public var WebPreview_GettingLinkInfo: String { return self._s[2978]! } - public var Watch_UserInfo_Unmute: String { return self._s[2979]! } - public var GroupInfo_ChannelListNamePlaceholder: String { return self._s[2980]! } - public var AccessDenied_CameraRestricted: String { return self._s[2982]! } + public var Privacy_Forwards_CustomHelp: String { return self._s[2978]! } + public var WebPreview_GettingLinkInfo: String { return self._s[2979]! } + public var Watch_UserInfo_Unmute: String { return self._s[2980]! } + public var GroupInfo_ChannelListNamePlaceholder: String { return self._s[2981]! } + public var AccessDenied_CameraRestricted: String { return self._s[2983]! } public func Conversation_Kilobytes(_ _0: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2983]!, self._r[2983]!, ["\(_0)"]) + return formatWithArgumentRanges(self._s[2984]!, self._r[2984]!, ["\(_0)"]) } - public var ChatList_ReadAll: String { return self._s[2985]! } - public var Settings_CopyUsername: String { return self._s[2986]! } - public var Contacts_SearchLabel: String { return self._s[2987]! } - public var Map_OpenInYandexNavigator: String { return self._s[2989]! } - public var PasscodeSettings_EncryptData: String { return self._s[2990]! } - public var Settings_Wallet: String { return self._s[2991]! } - public var Group_ErrorSupergroupConversionNotPossible: String { return self._s[2992]! } - public var WallpaperSearch_ColorPrefix: String { return self._s[2993]! } - public var Notifications_GroupNotificationsPreview: String { return self._s[2994]! } - public var DialogList_AdNoticeAlert: String { return self._s[2995]! } - public var Wallet_Month_GenMay: String { return self._s[2997]! } - public var CheckoutInfo_ShippingInfoAddress1: String { return self._s[2998]! } - public var CheckoutInfo_ShippingInfoAddress2: String { return self._s[2999]! } - public var Localization_LanguageCustom: String { return self._s[3000]! } - public var Passport_Identity_TypeDriversLicenseUploadScan: String { return self._s[3001]! } - public var CallFeedback_Title: String { return self._s[3002]! } - public var VoiceOver_Chat_RecordPreviewVoiceMessage: String { return self._s[3005]! } - public var Passport_Address_OneOfTypePassportRegistration: String { return self._s[3006]! } - public var Wallet_Intro_CreateErrorTitle: String { return self._s[3007]! } - public var Conversation_InfoGroup: String { return self._s[3008]! } - public var Compose_NewMessage: String { return self._s[3009]! } - public var FastTwoStepSetup_HintPlaceholder: String { return self._s[3010]! } - public var ChatSettings_AutoDownloadVideoMessages: String { return self._s[3011]! } - public var Wallet_SecureStorageReset_BiometryFaceId: String { return self._s[3012]! } - public var Channel_DiscussionGroup_UnlinkChannel: String { return self._s[3013]! } + public var ChatList_ReadAll: String { return self._s[2986]! } + public var Settings_CopyUsername: String { return self._s[2987]! } + public var Contacts_SearchLabel: String { return self._s[2988]! } + public var Map_OpenInYandexNavigator: String { return self._s[2990]! } + public var PasscodeSettings_EncryptData: String { return self._s[2991]! } + public var Settings_Wallet: String { return self._s[2992]! } + public var Group_ErrorSupergroupConversionNotPossible: String { return self._s[2993]! } + public var WallpaperSearch_ColorPrefix: String { return self._s[2994]! } + public var Notifications_GroupNotificationsPreview: String { return self._s[2995]! } + public var DialogList_AdNoticeAlert: String { return self._s[2996]! } + public var Wallet_Month_GenMay: String { return self._s[2998]! } + public var CheckoutInfo_ShippingInfoAddress1: String { return self._s[2999]! } + public var CheckoutInfo_ShippingInfoAddress2: String { return self._s[3000]! } + public var Localization_LanguageCustom: String { return self._s[3001]! } + public var Passport_Identity_TypeDriversLicenseUploadScan: String { return self._s[3002]! } + public var CallFeedback_Title: String { return self._s[3003]! } + public var VoiceOver_Chat_RecordPreviewVoiceMessage: String { return self._s[3006]! } + public var Passport_Address_OneOfTypePassportRegistration: String { return self._s[3007]! } + public var Wallet_Intro_CreateErrorTitle: String { return self._s[3008]! } + public var Conversation_InfoGroup: String { return self._s[3009]! } + public var Compose_NewMessage: String { return self._s[3010]! } + public var FastTwoStepSetup_HintPlaceholder: String { return self._s[3011]! } + public var ChatSettings_AutoDownloadVideoMessages: String { return self._s[3012]! } + public var Wallet_SecureStorageReset_BiometryFaceId: String { return self._s[3013]! } + public var Channel_DiscussionGroup_UnlinkChannel: String { return self._s[3014]! } public func Passport_Scans_ScanIndex(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3014]!, self._r[3014]!, [_0]) + return formatWithArgumentRanges(self._s[3015]!, self._r[3015]!, [_0]) } - public var Channel_AdminLog_CanDeleteMessages: String { return self._s[3015]! } - public var Login_CancelSignUpConfirmation: String { return self._s[3016]! } - public var ChangePhoneNumberCode_Help: String { return self._s[3017]! } - public var PrivacySettings_DeleteAccountHelp: String { return self._s[3018]! } - public var Channel_BlackList_Title: String { return self._s[3019]! } - public var UserInfo_PhoneCall: String { return self._s[3020]! } - public var Passport_Address_OneOfTypeBankStatement: String { return self._s[3022]! } - public var Wallet_Month_ShortJanuary: String { return self._s[3023]! } - public var State_connecting: String { return self._s[3024]! } - public var Appearance_ThemePreview_ChatList_6_Text: String { return self._s[3025]! } - public var Wallet_Month_GenMarch: String { return self._s[3026]! } - public var EditTheme_Expand_BottomInfo: String { return self._s[3027]! } - public var AuthSessions_AddedDeviceTerminate: String { return self._s[3028]! } + public var Channel_AdminLog_CanDeleteMessages: String { return self._s[3016]! } + public var Login_CancelSignUpConfirmation: String { return self._s[3017]! } + public var ChangePhoneNumberCode_Help: String { return self._s[3018]! } + public var PrivacySettings_DeleteAccountHelp: String { return self._s[3019]! } + public var Channel_BlackList_Title: String { return self._s[3020]! } + public var UserInfo_PhoneCall: String { return self._s[3021]! } + public var Passport_Address_OneOfTypeBankStatement: String { return self._s[3023]! } + public var Wallet_Month_ShortJanuary: String { return self._s[3024]! } + public var State_connecting: String { return self._s[3025]! } + public var Appearance_ThemePreview_ChatList_6_Text: String { return self._s[3026]! } + public var Wallet_Month_GenMarch: String { return self._s[3027]! } + public var EditTheme_Expand_BottomInfo: String { return self._s[3028]! } + public var AuthSessions_AddedDeviceTerminate: String { return self._s[3029]! } public func LastSeen_TodayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3029]!, self._r[3029]!, [_0]) - } - public func DialogList_SingleRecordingAudioSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[3030]!, self._r[3030]!, [_0]) } - public var Notifications_GroupNotifications: String { return self._s[3031]! } - public var Conversation_SendMessageErrorTooMuchScheduled: String { return self._s[3032]! } - public var Passport_Identity_EditPassport: String { return self._s[3033]! } - public var EnterPasscode_RepeatNewPasscode: String { return self._s[3035]! } - public var Localization_EnglishLanguageName: String { return self._s[3036]! } - public var Share_AuthDescription: String { return self._s[3037]! } - public var SettingsSearch_Synonyms_Notifications_ChannelNotificationsAlert: String { return self._s[3038]! } - public var Passport_Identity_Surname: String { return self._s[3039]! } - public var Compose_TokenListPlaceholder: String { return self._s[3040]! } - public var Wallet_AccessDenied_Camera: String { return self._s[3041]! } - public var Passport_Identity_OneOfTypePassport: String { return self._s[3042]! } - public var Settings_AboutEmpty: String { return self._s[3043]! } - public var Conversation_Unmute: String { return self._s[3044]! } - public var CreateGroup_ChannelsTooMuch: String { return self._s[3046]! } - public var Wallet_Sending_Text: String { return self._s[3047]! } - public func PUSH_CONTACT_JOINED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3048]!, self._r[3048]!, [_1]) + public func DialogList_SingleRecordingAudioSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3031]!, self._r[3031]!, [_0]) } - public var Login_CodeSentCall: String { return self._s[3049]! } - public var ContactInfo_PhoneLabelHomeFax: String { return self._s[3051]! } - public var ChatSettings_Appearance: String { return self._s[3052]! } - public var ClearCache_StorageUsage: String { return self._s[3053]! } - public var Appearance_PickAccentColor: String { return self._s[3054]! } + public var Notifications_GroupNotifications: String { return self._s[3032]! } + public var Conversation_SendMessageErrorTooMuchScheduled: String { return self._s[3033]! } + public var Passport_Identity_EditPassport: String { return self._s[3034]! } + public var EnterPasscode_RepeatNewPasscode: String { return self._s[3036]! } + public var Localization_EnglishLanguageName: String { return self._s[3037]! } + public var Share_AuthDescription: String { return self._s[3038]! } + public var SettingsSearch_Synonyms_Notifications_ChannelNotificationsAlert: String { return self._s[3039]! } + public var Passport_Identity_Surname: String { return self._s[3040]! } + public var Compose_TokenListPlaceholder: String { return self._s[3041]! } + public var Wallet_AccessDenied_Camera: String { return self._s[3042]! } + public var Passport_Identity_OneOfTypePassport: String { return self._s[3043]! } + public var Settings_AboutEmpty: String { return self._s[3044]! } + public var Conversation_Unmute: String { return self._s[3045]! } + public var CreateGroup_ChannelsTooMuch: String { return self._s[3047]! } + public var Wallet_Sending_Text: String { return self._s[3048]! } + public func PUSH_CONTACT_JOINED(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3049]!, self._r[3049]!, [_1]) + } + public var Login_CodeSentCall: String { return self._s[3050]! } + public var ContactInfo_PhoneLabelHomeFax: String { return self._s[3052]! } + public var ChatSettings_Appearance: String { return self._s[3053]! } + public var ClearCache_StorageUsage: String { return self._s[3054]! } + public var Appearance_PickAccentColor: String { return self._s[3055]! } public func PUSH_CHAT_MESSAGE_NOTEXT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3055]!, self._r[3055]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3056]!, self._r[3056]!, [_1, _2]) } public func PUSH_MESSAGE_GEO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3056]!, self._r[3056]!, [_1]) + return formatWithArgumentRanges(self._s[3057]!, self._r[3057]!, [_1]) } - public var Notification_CallMissed: String { return self._s[3057]! } - public var SettingsSearch_Synonyms_Appearance_ChatBackground_Custom: String { return self._s[3058]! } - public var Channel_AdminLogFilter_EventsInfo: String { return self._s[3059]! } - public var Wallet_Month_GenOctober: String { return self._s[3061]! } - public var ChatAdmins_AdminLabel: String { return self._s[3062]! } - public var KeyCommand_JumpToNextChat: String { return self._s[3063]! } - public var Conversation_StopPollConfirmationTitle: String { return self._s[3065]! } - public var ChangePhoneNumberCode_CodePlaceholder: String { return self._s[3066]! } - public var Month_GenJune: String { return self._s[3067]! } - public var IntentsSettings_MainAccountInfo: String { return self._s[3068]! } - public var Watch_Location_Current: String { return self._s[3069]! } - public var Wallet_Receive_CopyInvoiceUrl: String { return self._s[3070]! } - public var Conversation_TitleMute: String { return self._s[3071]! } - public var Map_PlacesInThisArea: String { return self._s[3072]! } + public var Notification_CallMissed: String { return self._s[3058]! } + public var SettingsSearch_Synonyms_Appearance_ChatBackground_Custom: String { return self._s[3059]! } + public var Channel_AdminLogFilter_EventsInfo: String { return self._s[3060]! } + public var Wallet_Month_GenOctober: String { return self._s[3062]! } + public var ChatAdmins_AdminLabel: String { return self._s[3063]! } + public var KeyCommand_JumpToNextChat: String { return self._s[3064]! } + public var Conversation_StopPollConfirmationTitle: String { return self._s[3066]! } + public var ChangePhoneNumberCode_CodePlaceholder: String { return self._s[3067]! } + public var Month_GenJune: String { return self._s[3068]! } + public var IntentsSettings_MainAccountInfo: String { return self._s[3069]! } + public var Watch_Location_Current: String { return self._s[3070]! } + public var Wallet_Receive_CopyInvoiceUrl: String { return self._s[3071]! } + public var Conversation_TitleMute: String { return self._s[3072]! } + public var Map_PlacesInThisArea: String { return self._s[3073]! } public func PUSH_CHANNEL_MESSAGE_ROUND(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3073]!, self._r[3073]!, [_1]) + return formatWithArgumentRanges(self._s[3074]!, self._r[3074]!, [_1]) } - public var GroupInfo_DeleteAndExit: String { return self._s[3074]! } + public var GroupInfo_DeleteAndExit: String { return self._s[3075]! } public func Conversation_Moderate_DeleteAllMessages(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3075]!, self._r[3075]!, [_0]) + return formatWithArgumentRanges(self._s[3076]!, self._r[3076]!, [_0]) } - public var Call_ReportPlaceholder: String { return self._s[3076]! } - public var Chat_SlowmodeSendError: String { return self._s[3077]! } - public var MaskStickerSettings_Info: String { return self._s[3078]! } - public var EditTheme_Expand_TopInfo: String { return self._s[3079]! } + public var Call_ReportPlaceholder: String { return self._s[3077]! } + public var Chat_SlowmodeSendError: String { return self._s[3078]! } + public var MaskStickerSettings_Info: String { return self._s[3079]! } + public var EditTheme_Expand_TopInfo: String { return self._s[3080]! } public func GroupInfo_AddParticipantConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3080]!, self._r[3080]!, [_0]) + return formatWithArgumentRanges(self._s[3081]!, self._r[3081]!, [_0]) } - public var Checkout_NewCard_PostcodeTitle: String { return self._s[3081]! } - public var Passport_Address_RegionPlaceholder: String { return self._s[3083]! } - public var Contacts_ShareTelegram: String { return self._s[3084]! } - public var EnterPasscode_EnterNewPasscodeNew: String { return self._s[3085]! } - public var Map_AddressOnMap: String { return self._s[3086]! } - public var Channel_ErrorAccessDenied: String { return self._s[3087]! } - public var UserInfo_ScamBotWarning: String { return self._s[3089]! } - public var Stickers_GroupChooseStickerPack: String { return self._s[3090]! } - public var Call_ConnectionErrorTitle: String { return self._s[3091]! } - public var UserInfo_NotificationsEnable: String { return self._s[3092]! } - public var ArchivedChats_IntroText1: String { return self._s[3093]! } - public var Tour_Text4: String { return self._s[3096]! } - public var WallpaperSearch_Recent: String { return self._s[3097]! } - public var GroupInfo_ScamGroupWarning: String { return self._s[3098]! } - public var PeopleNearby_MakeVisibleTitle: String { return self._s[3099]! } - public var Profile_MessageLifetime2s: String { return self._s[3101]! } - public var Appearance_ThemePreview_ChatList_5_Text: String { return self._s[3102]! } - public var Notification_MessageLifetime2s: String { return self._s[3103]! } + public var Checkout_NewCard_PostcodeTitle: String { return self._s[3082]! } + public var Passport_Address_RegionPlaceholder: String { return self._s[3084]! } + public var Contacts_ShareTelegram: String { return self._s[3085]! } + public var EnterPasscode_EnterNewPasscodeNew: String { return self._s[3086]! } + public var Map_AddressOnMap: String { return self._s[3087]! } + public var Channel_ErrorAccessDenied: String { return self._s[3088]! } + public var UserInfo_ScamBotWarning: String { return self._s[3090]! } + public var Stickers_GroupChooseStickerPack: String { return self._s[3091]! } + public var Call_ConnectionErrorTitle: String { return self._s[3092]! } + public var UserInfo_NotificationsEnable: String { return self._s[3093]! } + public var ArchivedChats_IntroText1: String { return self._s[3094]! } + public var Tour_Text4: String { return self._s[3097]! } + public var WallpaperSearch_Recent: String { return self._s[3098]! } + public var GroupInfo_ScamGroupWarning: String { return self._s[3099]! } + public var PeopleNearby_MakeVisibleTitle: String { return self._s[3100]! } + public var Profile_MessageLifetime2s: String { return self._s[3102]! } + public var Appearance_ThemePreview_ChatList_5_Text: String { return self._s[3103]! } + public var Notification_MessageLifetime2s: String { return self._s[3104]! } public func Time_PreciseDate_m10(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3104]!, self._r[3104]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3105]!, self._r[3105]!, [_1, _2, _3]) } - public var Cache_ClearCache: String { return self._s[3105]! } - public var AutoNightTheme_UpdateLocation: String { return self._s[3106]! } - public var Permissions_NotificationsUnreachableText_v0: String { return self._s[3107]! } + public var Cache_ClearCache: String { return self._s[3106]! } + public var AutoNightTheme_UpdateLocation: String { return self._s[3107]! } + public var Permissions_NotificationsUnreachableText_v0: String { return self._s[3108]! } public func Channel_AdminLog_MessageChangedGroupUsername(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3111]!, self._r[3111]!, [_0]) + return formatWithArgumentRanges(self._s[3112]!, self._r[3112]!, [_0]) } public func Conversation_ShareMyPhoneNumber_StatusSuccess(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3113]!, self._r[3113]!, [_0]) + return formatWithArgumentRanges(self._s[3114]!, self._r[3114]!, [_0]) } - public var LocalGroup_Text: String { return self._s[3114]! } - public var PeerInfo_PaneMembers: String { return self._s[3115]! } - public var Channel_AdminLog_EmptyFilterTitle: String { return self._s[3116]! } - public var SocksProxySetup_TypeSocks: String { return self._s[3117]! } - public var ChatList_UnarchiveAction: String { return self._s[3118]! } - public var AutoNightTheme_Title: String { return self._s[3119]! } - public var InstantPage_FeedbackButton: String { return self._s[3120]! } - public var Passport_FieldAddress: String { return self._s[3121]! } + public var LocalGroup_Text: String { return self._s[3115]! } + public var PeerInfo_PaneMembers: String { return self._s[3116]! } + public var Channel_AdminLog_EmptyFilterTitle: String { return self._s[3117]! } + public var SocksProxySetup_TypeSocks: String { return self._s[3118]! } + public var ChatList_UnarchiveAction: String { return self._s[3119]! } + public var AutoNightTheme_Title: String { return self._s[3120]! } + public var InstantPage_FeedbackButton: String { return self._s[3121]! } + public var Passport_FieldAddress: String { return self._s[3122]! } public func Channel_AdminLog_SetSlowmode(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3122]!, self._r[3122]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3123]!, self._r[3123]!, [_1, _2]) } - public var Month_ShortMarch: String { return self._s[3123]! } + public var Month_ShortMarch: String { return self._s[3124]! } public func PUSH_MESSAGE_INVOICE(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3124]!, self._r[3124]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3125]!, self._r[3125]!, [_1, _2]) } - public var SocksProxySetup_UsernamePlaceholder: String { return self._s[3125]! } - public var Conversation_ShareInlineBotLocationConfirmation: String { return self._s[3126]! } - public var Passport_FloodError: String { return self._s[3127]! } - public var SecretGif_Title: String { return self._s[3128]! } - public var NotificationSettings_ShowNotificationsAllAccountsInfoOn: String { return self._s[3129]! } - public var ChatList_Context_UnhideArchive: String { return self._s[3130]! } - public var Passport_Language_th: String { return self._s[3132]! } - public var Passport_Address_Address: String { return self._s[3133]! } - public var Login_InvalidLastNameError: String { return self._s[3134]! } - public var Notifications_InAppNotificationsPreview: String { return self._s[3135]! } - public var Notifications_PermissionsUnreachableTitle: String { return self._s[3136]! } - public var ChatList_Context_Archive: String { return self._s[3137]! } - public var SettingsSearch_FAQ: String { return self._s[3138]! } - public var ShareMenu_Send: String { return self._s[3139]! } - public var ChatState_Connecting: String { return self._s[3140]! } - public var WallpaperSearch_ColorYellow: String { return self._s[3142]! } - public var Month_GenNovember: String { return self._s[3144]! } - public var SettingsSearch_Synonyms_Appearance_LargeEmoji: String { return self._s[3146]! } + public var SocksProxySetup_UsernamePlaceholder: String { return self._s[3126]! } + public var Conversation_ShareInlineBotLocationConfirmation: String { return self._s[3127]! } + public var Passport_FloodError: String { return self._s[3128]! } + public var SecretGif_Title: String { return self._s[3129]! } + public var NotificationSettings_ShowNotificationsAllAccountsInfoOn: String { return self._s[3130]! } + public var ChatList_Context_UnhideArchive: String { return self._s[3131]! } + public var Passport_Language_th: String { return self._s[3133]! } + public var Passport_Address_Address: String { return self._s[3134]! } + public var Login_InvalidLastNameError: String { return self._s[3135]! } + public var Notifications_InAppNotificationsPreview: String { return self._s[3136]! } + public var Notifications_PermissionsUnreachableTitle: String { return self._s[3137]! } + public var ChatList_Context_Archive: String { return self._s[3138]! } + public var SettingsSearch_FAQ: String { return self._s[3139]! } + public var ShareMenu_Send: String { return self._s[3140]! } + public var ChatState_Connecting: String { return self._s[3141]! } + public var WallpaperSearch_ColorYellow: String { return self._s[3143]! } + public var Month_GenNovember: String { return self._s[3145]! } + public var SettingsSearch_Synonyms_Appearance_LargeEmoji: String { return self._s[3147]! } public func Conversation_ShareMyPhoneNumberConfirmation(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3147]!, self._r[3147]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3148]!, self._r[3148]!, [_1, _2]) } - public var Conversation_SwipeToReplyHintText: String { return self._s[3148]! } - public var Checkout_Email: String { return self._s[3149]! } - public var NotificationsSound_Tritone: String { return self._s[3150]! } - public var StickerPacksSettings_ManagingHelp: String { return self._s[3152]! } - public var Wallet_ContextMenuCopy: String { return self._s[3154]! } + public var Conversation_SwipeToReplyHintText: String { return self._s[3149]! } + public var Checkout_Email: String { return self._s[3150]! } + public var NotificationsSound_Tritone: String { return self._s[3151]! } + public var StickerPacksSettings_ManagingHelp: String { return self._s[3153]! } + public var Wallet_ContextMenuCopy: String { return self._s[3155]! } public func Wallet_Time_PreciseDate_m6(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3156]!, self._r[3156]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3157]!, self._r[3157]!, [_1, _2, _3]) } - public var Appearance_TextSize_Automatic: String { return self._s[3157]! } + public var Appearance_TextSize_Automatic: String { return self._s[3158]! } public func PUSH_PINNED_ROUND(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3158]!, self._r[3158]!, [_1]) + return formatWithArgumentRanges(self._s[3159]!, self._r[3159]!, [_1]) } public func StickerPackActionInfo_AddedText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3159]!, self._r[3159]!, [_0]) + return formatWithArgumentRanges(self._s[3160]!, self._r[3160]!, [_0]) } - public var ChangePhoneNumberNumber_Help: String { return self._s[3160]! } + public var ChangePhoneNumberNumber_Help: String { return self._s[3161]! } public func Checkout_LiabilityAlert(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3161]!, self._r[3161]!, [_1, _1, _1, _2]) + return formatWithArgumentRanges(self._s[3162]!, self._r[3162]!, [_1, _1, _1, _2]) } - public var ChatList_UndoArchiveTitle: String { return self._s[3162]! } - public var Notification_Exceptions_Add: String { return self._s[3163]! } - public var DialogList_You: String { return self._s[3164]! } - public var MediaPicker_Send: String { return self._s[3167]! } - public var SettingsSearch_Synonyms_Stickers_Title: String { return self._s[3168]! } - public var Appearance_ThemePreview_ChatList_4_Text: String { return self._s[3169]! } - public var Call_AudioRouteSpeaker: String { return self._s[3170]! } - public var Watch_UserInfo_Title: String { return self._s[3171]! } - public var VoiceOver_Chat_PollFinalResults: String { return self._s[3172]! } - public var Appearance_AccentColor: String { return self._s[3174]! } + public var ChatList_UndoArchiveTitle: String { return self._s[3163]! } + public var Notification_Exceptions_Add: String { return self._s[3164]! } + public var DialogList_You: String { return self._s[3165]! } + public var MediaPicker_Send: String { return self._s[3168]! } + public var SettingsSearch_Synonyms_Stickers_Title: String { return self._s[3169]! } + public var Appearance_ThemePreview_ChatList_4_Text: String { return self._s[3170]! } + public var Call_AudioRouteSpeaker: String { return self._s[3171]! } + public var Watch_UserInfo_Title: String { return self._s[3172]! } + public var VoiceOver_Chat_PollFinalResults: String { return self._s[3173]! } + public var Appearance_AccentColor: String { return self._s[3175]! } public func Login_EmailPhoneSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3175]!, self._r[3175]!, [_0]) + return formatWithArgumentRanges(self._s[3176]!, self._r[3176]!, [_0]) } - public var Permissions_ContactsAllowInSettings_v0: String { return self._s[3176]! } + public var Permissions_ContactsAllowInSettings_v0: String { return self._s[3177]! } public func PUSH_CHANNEL_MESSAGE_GAME(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3177]!, self._r[3177]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3178]!, self._r[3178]!, [_1, _2]) } - public var Conversation_ClousStorageInfo_Description2: String { return self._s[3178]! } - public var WebSearch_RecentClearConfirmation: String { return self._s[3179]! } - public var Notification_CallOutgoing: String { return self._s[3180]! } - public var PrivacySettings_PasscodeAndFaceId: String { return self._s[3181]! } - public var Channel_DiscussionGroup_MakeHistoryPublic: String { return self._s[3182]! } - public var Call_RecordingDisabledMessage: String { return self._s[3183]! } - public var Message_Game: String { return self._s[3184]! } - public var Conversation_PressVolumeButtonForSound: String { return self._s[3185]! } - public var PrivacyLastSeenSettings_CustomHelp: String { return self._s[3186]! } - public var Channel_DiscussionGroup_PrivateGroup: String { return self._s[3187]! } - public var Channel_EditAdmin_PermissionAddAdmins: String { return self._s[3188]! } - public var Date_DialogDateFormat: String { return self._s[3190]! } - public var WallpaperColors_SetCustomColor: String { return self._s[3191]! } - public var Notifications_InAppNotifications: String { return self._s[3192]! } + public var Conversation_ClousStorageInfo_Description2: String { return self._s[3179]! } + public var WebSearch_RecentClearConfirmation: String { return self._s[3180]! } + public var Notification_CallOutgoing: String { return self._s[3181]! } + public var PrivacySettings_PasscodeAndFaceId: String { return self._s[3182]! } + public var Channel_DiscussionGroup_MakeHistoryPublic: String { return self._s[3183]! } + public var Call_RecordingDisabledMessage: String { return self._s[3184]! } + public var Message_Game: String { return self._s[3185]! } + public var Conversation_PressVolumeButtonForSound: String { return self._s[3186]! } + public var PrivacyLastSeenSettings_CustomHelp: String { return self._s[3187]! } + public var Channel_DiscussionGroup_PrivateGroup: String { return self._s[3188]! } + public var Channel_EditAdmin_PermissionAddAdmins: String { return self._s[3189]! } + public var Date_DialogDateFormat: String { return self._s[3191]! } + public var WallpaperColors_SetCustomColor: String { return self._s[3192]! } + public var Notifications_InAppNotifications: String { return self._s[3193]! } public func Channel_Management_RemovedBy(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3193]!, self._r[3193]!, [_0]) + return formatWithArgumentRanges(self._s[3194]!, self._r[3194]!, [_0]) } public func Settings_ApplyProxyAlert(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3194]!, self._r[3194]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3195]!, self._r[3195]!, [_1, _2]) } - public var NewContact_Title: String { return self._s[3195]! } + public var NewContact_Title: String { return self._s[3196]! } public func AutoDownloadSettings_UpToForAll(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3196]!, self._r[3196]!, [_0]) + return formatWithArgumentRanges(self._s[3197]!, self._r[3197]!, [_0]) } - public var Conversation_ViewContactDetails: String { return self._s[3197]! } + public var Conversation_ViewContactDetails: String { return self._s[3198]! } public func PUSH_CHANNEL_MESSAGE_CONTACT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3199]!, self._r[3199]!, [_1]) + return formatWithArgumentRanges(self._s[3200]!, self._r[3200]!, [_1]) } - public var Checkout_NewCard_CardholderNameTitle: String { return self._s[3200]! } - public var Passport_Identity_ExpiryDateNone: String { return self._s[3201]! } - public var PrivacySettings_Title: String { return self._s[3202]! } - public var Conversation_SilentBroadcastTooltipOff: String { return self._s[3205]! } - public var GroupRemoved_UsersSectionTitle: String { return self._s[3206]! } - public var VoiceOver_Chat_ContactEmail: String { return self._s[3207]! } - public var Contacts_PhoneNumber: String { return self._s[3208]! } - public var PeerInfo_ButtonMute: String { return self._s[3209]! } - public var TwoFactorSetup_Password_PlaceholderConfirmPassword: String { return self._s[3211]! } - public var Map_ShowPlaces: String { return self._s[3212]! } - public var ChatAdmins_Title: String { return self._s[3213]! } - public var InstantPage_Reference: String { return self._s[3215]! } - public var Wallet_Info_Updating: String { return self._s[3216]! } - public var ReportGroupLocation_Text: String { return self._s[3217]! } + public var Checkout_NewCard_CardholderNameTitle: String { return self._s[3201]! } + public var Passport_Identity_ExpiryDateNone: String { return self._s[3202]! } + public var PrivacySettings_Title: String { return self._s[3203]! } + public var Conversation_SilentBroadcastTooltipOff: String { return self._s[3206]! } + public var GroupRemoved_UsersSectionTitle: String { return self._s[3207]! } + public var VoiceOver_Chat_ContactEmail: String { return self._s[3208]! } + public var Contacts_PhoneNumber: String { return self._s[3209]! } + public var PeerInfo_ButtonMute: String { return self._s[3210]! } + public var TwoFactorSetup_Password_PlaceholderConfirmPassword: String { return self._s[3212]! } + public var Map_ShowPlaces: String { return self._s[3213]! } + public var ChatAdmins_Title: String { return self._s[3214]! } + public var InstantPage_Reference: String { return self._s[3216]! } + public var Wallet_Info_Updating: String { return self._s[3217]! } + public var ReportGroupLocation_Text: String { return self._s[3218]! } public func PUSH_CHAT_MESSAGE_FWD(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3218]!, self._r[3218]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3219]!, self._r[3219]!, [_1, _2]) } - public var Camera_FlashOff: String { return self._s[3219]! } - public var Watch_UserInfo_Block: String { return self._s[3220]! } - public var ChatSettings_Stickers: String { return self._s[3221]! } - public var ChatSettings_DownloadInBackground: String { return self._s[3222]! } - public var Appearance_ThemeCarouselTintedNight: String { return self._s[3223]! } + public var Camera_FlashOff: String { return self._s[3220]! } + public var Watch_UserInfo_Block: String { return self._s[3221]! } + public var ChatSettings_Stickers: String { return self._s[3222]! } + public var ChatSettings_DownloadInBackground: String { return self._s[3223]! } + public var Appearance_ThemeCarouselTintedNight: String { return self._s[3224]! } public func UserInfo_BlockConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3224]!, self._r[3224]!, [_0]) + return formatWithArgumentRanges(self._s[3225]!, self._r[3225]!, [_0]) } - public var Settings_ViewPhoto: String { return self._s[3225]! } - public var Login_CheckOtherSessionMessages: String { return self._s[3226]! } - public var AutoDownloadSettings_Cellular: String { return self._s[3227]! } - public var Wallet_Created_ExportErrorTitle: String { return self._s[3228]! } - public var SettingsSearch_Synonyms_Notifications_GroupNotificationsExceptions: String { return self._s[3229]! } - public var VoiceOver_MessageContextShare: String { return self._s[3230]! } + public var Settings_ViewPhoto: String { return self._s[3226]! } + public var Login_CheckOtherSessionMessages: String { return self._s[3227]! } + public var AutoDownloadSettings_Cellular: String { return self._s[3228]! } + public var Wallet_Created_ExportErrorTitle: String { return self._s[3229]! } + public var SettingsSearch_Synonyms_Notifications_GroupNotificationsExceptions: String { return self._s[3230]! } + public var VoiceOver_MessageContextShare: String { return self._s[3231]! } public func Target_InviteToGroupConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3232]!, self._r[3232]!, [_0]) + return formatWithArgumentRanges(self._s[3233]!, self._r[3233]!, [_0]) } - public var Privacy_DeleteDrafts: String { return self._s[3233]! } - public var Wallpaper_SetCustomBackgroundInfo: String { return self._s[3234]! } + public var Privacy_DeleteDrafts: String { return self._s[3234]! } + public var Wallpaper_SetCustomBackgroundInfo: String { return self._s[3235]! } public func LastSeen_AtDate(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3235]!, self._r[3235]!, [_0]) + return formatWithArgumentRanges(self._s[3236]!, self._r[3236]!, [_0]) } - public var DialogList_SavedMessagesHelp: String { return self._s[3236]! } - public var Wallet_SecureStorageNotAvailable_Title: String { return self._s[3237]! } - public var DialogList_SavedMessages: String { return self._s[3238]! } - public var GroupInfo_UpgradeButton: String { return self._s[3239]! } - public var Appearance_ThemePreview_ChatList_3_Text: String { return self._s[3241]! } - public var DialogList_Pin: String { return self._s[3242]! } + public var DialogList_SavedMessagesHelp: String { return self._s[3237]! } + public var Wallet_SecureStorageNotAvailable_Title: String { return self._s[3238]! } + public var DialogList_SavedMessages: String { return self._s[3239]! } + public var GroupInfo_UpgradeButton: String { return self._s[3240]! } + public var Appearance_ThemePreview_ChatList_3_Text: String { return self._s[3242]! } + public var DialogList_Pin: String { return self._s[3243]! } public func ForwardedAuthors2(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3243]!, self._r[3243]!, [_0, _1]) + return formatWithArgumentRanges(self._s[3244]!, self._r[3244]!, [_0, _1]) } public func Login_PhoneGenericEmailSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3244]!, self._r[3244]!, [_0]) + return formatWithArgumentRanges(self._s[3245]!, self._r[3245]!, [_0]) } - public var Notification_Exceptions_AlwaysOn: String { return self._s[3245]! } - public var UserInfo_NotificationsDisable: String { return self._s[3246]! } - public var Conversation_ContextMenuCancelEditing: String { return self._s[3247]! } - public var Paint_Outlined: String { return self._s[3248]! } - public var Activity_PlayingGame: String { return self._s[3249]! } - public var SearchImages_NoImagesFound: String { return self._s[3250]! } - public var SocksProxySetup_ProxyType: String { return self._s[3251]! } - public var AppleWatch_ReplyPresetsHelp: String { return self._s[3253]! } - public var Conversation_ContextMenuCancelSending: String { return self._s[3254]! } - public var Settings_AppLanguage: String { return self._s[3255]! } - public var TwoStepAuth_ResetAccountHelp: String { return self._s[3256]! } - public var Common_ChoosePhoto: String { return self._s[3257]! } - public var AuthSessions_AddDevice_InvalidQRCode: String { return self._s[3258]! } - public var CallFeedback_ReasonEcho: String { return self._s[3259]! } + public var Notification_Exceptions_AlwaysOn: String { return self._s[3246]! } + public var UserInfo_NotificationsDisable: String { return self._s[3247]! } + public var Conversation_ContextMenuCancelEditing: String { return self._s[3248]! } + public var Paint_Outlined: String { return self._s[3249]! } + public var Activity_PlayingGame: String { return self._s[3250]! } + public var SearchImages_NoImagesFound: String { return self._s[3251]! } + public var SocksProxySetup_ProxyType: String { return self._s[3252]! } + public var AppleWatch_ReplyPresetsHelp: String { return self._s[3254]! } + public var Conversation_ContextMenuCancelSending: String { return self._s[3255]! } + public var Settings_AppLanguage: String { return self._s[3256]! } + public var TwoStepAuth_ResetAccountHelp: String { return self._s[3257]! } + public var Common_ChoosePhoto: String { return self._s[3258]! } + public var AuthSessions_AddDevice_InvalidQRCode: String { return self._s[3259]! } + public var CallFeedback_ReasonEcho: String { return self._s[3260]! } public func PUSH_PINNED_AUDIO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3260]!, self._r[3260]!, [_1]) + return formatWithArgumentRanges(self._s[3261]!, self._r[3261]!, [_1]) } - public var Privacy_Calls_AlwaysAllow: String { return self._s[3261]! } - public var PollResults_Collapse: String { return self._s[3262]! } - public var Activity_UploadingVideo: String { return self._s[3263]! } - public var Conversation_WalletRequiredNotNow: String { return self._s[3264]! } - public var ChannelInfo_DeleteChannelConfirmation: String { return self._s[3265]! } - public var NetworkUsageSettings_Wifi: String { return self._s[3266]! } - public var VoiceOver_Editing_ClearText: String { return self._s[3267]! } - public var PUSH_SENDER_YOU: String { return self._s[3268]! } - public var Channel_BanUser_PermissionReadMessages: String { return self._s[3269]! } - public var Checkout_PayWithTouchId: String { return self._s[3270]! } - public var Wallpaper_ResetWallpapersConfirmation: String { return self._s[3271]! } + public var Privacy_Calls_AlwaysAllow: String { return self._s[3262]! } + public var PollResults_Collapse: String { return self._s[3263]! } + public var Activity_UploadingVideo: String { return self._s[3264]! } + public var Conversation_WalletRequiredNotNow: String { return self._s[3265]! } + public var ChannelInfo_DeleteChannelConfirmation: String { return self._s[3266]! } + public var NetworkUsageSettings_Wifi: String { return self._s[3267]! } + public var VoiceOver_Editing_ClearText: String { return self._s[3268]! } + public var PUSH_SENDER_YOU: String { return self._s[3269]! } + public var Channel_BanUser_PermissionReadMessages: String { return self._s[3270]! } + public var Checkout_PayWithTouchId: String { return self._s[3271]! } + public var Wallpaper_ResetWallpapersConfirmation: String { return self._s[3272]! } public func PUSH_LOCKED_MESSAGE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3273]!, self._r[3273]!, [_1]) + return formatWithArgumentRanges(self._s[3274]!, self._r[3274]!, [_1]) } - public var Notifications_ExceptionsNone: String { return self._s[3274]! } + public var Notifications_ExceptionsNone: String { return self._s[3275]! } public func Message_ForwardedMessageShort(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3275]!, self._r[3275]!, [_0]) + return formatWithArgumentRanges(self._s[3276]!, self._r[3276]!, [_0]) } public func PUSH_PINNED_GEO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3276]!, self._r[3276]!, [_1]) + return formatWithArgumentRanges(self._s[3277]!, self._r[3277]!, [_1]) } - public var AuthSessions_IncompleteAttempts: String { return self._s[3278]! } - public var Passport_Address_Region: String { return self._s[3281]! } - public var ChatList_DeleteChat: String { return self._s[3282]! } - public var LogoutOptions_ClearCacheTitle: String { return self._s[3283]! } - public var PhotoEditor_TiltShift: String { return self._s[3284]! } - public var Settings_FAQ_URL: String { return self._s[3285]! } - public var TwoFactorSetup_EmailVerification_ChangeAction: String { return self._s[3286]! } - public var Passport_Language_sl: String { return self._s[3287]! } - public var Settings_PrivacySettings: String { return self._s[3289]! } - public var SharedMedia_TitleLink: String { return self._s[3290]! } - public var Passport_Identity_TypePassportUploadScan: String { return self._s[3291]! } - public var Settings_SetProfilePhoto: String { return self._s[3292]! } - public var Channel_About_Help: String { return self._s[3293]! } - public var Contacts_PermissionsEnable: String { return self._s[3294]! } - public var Wallet_Sending_Title: String { return self._s[3295]! } - public var PeerInfo_PaneMedia: String { return self._s[3296]! } - public var SettingsSearch_Synonyms_Notifications_GroupNotificationsAlert: String { return self._s[3297]! } - public var AttachmentMenu_SendAsFiles: String { return self._s[3298]! } - public var CallFeedback_ReasonInterruption: String { return self._s[3300]! } - public var Passport_Address_AddTemporaryRegistration: String { return self._s[3301]! } - public var AutoDownloadSettings_AutodownloadVideos: String { return self._s[3302]! } - public var ChatSettings_AutoDownloadSettings_Delimeter: String { return self._s[3303]! } - public var OldChannels_Title: String { return self._s[3304]! } - public var PrivacySettings_DeleteAccountTitle: String { return self._s[3305]! } - public var AccessDenied_VideoMessageCamera: String { return self._s[3307]! } - public var Map_OpenInYandexMaps: String { return self._s[3309]! } - public var CreateGroup_ErrorLocatedGroupsTooMuch: String { return self._s[3310]! } - public var VoiceOver_MessageContextReply: String { return self._s[3311]! } - public var PhotoEditor_SaturationTool: String { return self._s[3313]! } + public var AuthSessions_IncompleteAttempts: String { return self._s[3279]! } + public var Passport_Address_Region: String { return self._s[3282]! } + public var ChatList_DeleteChat: String { return self._s[3283]! } + public var LogoutOptions_ClearCacheTitle: String { return self._s[3284]! } + public var PhotoEditor_TiltShift: String { return self._s[3285]! } + public var Settings_FAQ_URL: String { return self._s[3286]! } + public var TwoFactorSetup_EmailVerification_ChangeAction: String { return self._s[3287]! } + public var Passport_Language_sl: String { return self._s[3288]! } + public var Settings_PrivacySettings: String { return self._s[3290]! } + public var SharedMedia_TitleLink: String { return self._s[3291]! } + public var Passport_Identity_TypePassportUploadScan: String { return self._s[3292]! } + public var Settings_SetProfilePhoto: String { return self._s[3293]! } + public var Channel_About_Help: String { return self._s[3294]! } + public var Contacts_PermissionsEnable: String { return self._s[3295]! } + public var Wallet_Sending_Title: String { return self._s[3296]! } + public var PeerInfo_PaneMedia: String { return self._s[3297]! } + public var SettingsSearch_Synonyms_Notifications_GroupNotificationsAlert: String { return self._s[3298]! } + public var AttachmentMenu_SendAsFiles: String { return self._s[3299]! } + public var CallFeedback_ReasonInterruption: String { return self._s[3301]! } + public var Passport_Address_AddTemporaryRegistration: String { return self._s[3302]! } + public var AutoDownloadSettings_AutodownloadVideos: String { return self._s[3303]! } + public var ChatSettings_AutoDownloadSettings_Delimeter: String { return self._s[3304]! } + public var OldChannels_Title: String { return self._s[3305]! } + public var PrivacySettings_DeleteAccountTitle: String { return self._s[3306]! } + public var AccessDenied_VideoMessageCamera: String { return self._s[3308]! } + public var Map_OpenInYandexMaps: String { return self._s[3310]! } + public var CreateGroup_ErrorLocatedGroupsTooMuch: String { return self._s[3311]! } + public var VoiceOver_MessageContextReply: String { return self._s[3312]! } + public var PhotoEditor_SaturationTool: String { return self._s[3314]! } public func PUSH_MESSAGE_STICKER(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3314]!, self._r[3314]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3315]!, self._r[3315]!, [_1, _2]) } - public var PrivacyPhoneNumberSettings_CustomHelp: String { return self._s[3315]! } - public var Notification_Exceptions_NewException_NotificationHeader: String { return self._s[3316]! } - public var Group_OwnershipTransfer_ErrorLocatedGroupsTooMuch: String { return self._s[3317]! } + public var PrivacyPhoneNumberSettings_CustomHelp: String { return self._s[3316]! } + public var Notification_Exceptions_NewException_NotificationHeader: String { return self._s[3317]! } + public var Group_OwnershipTransfer_ErrorLocatedGroupsTooMuch: String { return self._s[3318]! } public func LOCAL_MESSAGE_FWDS(_ _1: String, _ _2: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3318]!, self._r[3318]!, [_1, "\(_2)"]) + return formatWithArgumentRanges(self._s[3319]!, self._r[3319]!, [_1, "\(_2)"]) } - public var Appearance_ThemePreview_ChatList_2_Text: String { return self._s[3319]! } - public var Channel_Username_InvalidTooShort: String { return self._s[3321]! } - public var SettingsSearch_Synonyms_Wallet: String { return self._s[3322]! } + public var Appearance_ThemePreview_ChatList_2_Text: String { return self._s[3320]! } + public var Channel_Username_InvalidTooShort: String { return self._s[3322]! } + public var SettingsSearch_Synonyms_Wallet: String { return self._s[3323]! } public func Group_OwnershipTransfer_DescriptionInfo(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3323]!, self._r[3323]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3324]!, self._r[3324]!, [_1, _2]) } - public var Forward_ErrorPublicPollDisabledInChannels: String { return self._s[3324]! } + public var Forward_ErrorPublicPollDisabledInChannels: String { return self._s[3325]! } public func PUSH_CHAT_MESSAGE_GAME(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3325]!, self._r[3325]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3326]!, self._r[3326]!, [_1, _2, _3]) } - public var WallpaperPreview_PatternTitle: String { return self._s[3326]! } - public var GroupInfo_PublicLinkAdd: String { return self._s[3327]! } - public var Passport_PassportInformation: String { return self._s[3330]! } - public var Theme_Unsupported: String { return self._s[3331]! } - public var WatchRemote_AlertTitle: String { return self._s[3332]! } - public var Privacy_GroupsAndChannels_NeverAllow: String { return self._s[3333]! } - public var ConvertToSupergroup_HelpText: String { return self._s[3335]! } + public var WallpaperPreview_PatternTitle: String { return self._s[3327]! } + public var GroupInfo_PublicLinkAdd: String { return self._s[3328]! } + public var Passport_PassportInformation: String { return self._s[3331]! } + public var Theme_Unsupported: String { return self._s[3332]! } + public var WatchRemote_AlertTitle: String { return self._s[3333]! } + public var Privacy_GroupsAndChannels_NeverAllow: String { return self._s[3334]! } + public var ConvertToSupergroup_HelpText: String { return self._s[3336]! } public func Time_MonthOfYear_m7(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3336]!, self._r[3336]!, [_0]) + return formatWithArgumentRanges(self._s[3337]!, self._r[3337]!, [_0]) } public func PUSH_PHONE_CALL_REQUEST(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3337]!, self._r[3337]!, [_1]) + return formatWithArgumentRanges(self._s[3338]!, self._r[3338]!, [_1]) } - public var Privacy_GroupsAndChannels_CustomHelp: String { return self._s[3338]! } - public var Wallet_Navigation_Done: String { return self._s[3340]! } - public var TwoStepAuth_RecoveryCodeInvalid: String { return self._s[3341]! } - public var AccessDenied_CameraDisabled: String { return self._s[3342]! } + public var Privacy_GroupsAndChannels_CustomHelp: String { return self._s[3339]! } + public var Wallet_Navigation_Done: String { return self._s[3341]! } + public var TwoStepAuth_RecoveryCodeInvalid: String { return self._s[3342]! } + public var AccessDenied_CameraDisabled: String { return self._s[3343]! } public func Channel_Username_UsernameIsAvailable(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3343]!, self._r[3343]!, [_0]) + return formatWithArgumentRanges(self._s[3344]!, self._r[3344]!, [_0]) } - public var ClearCache_Forever: String { return self._s[3344]! } - public var AuthSessions_AddDeviceIntro_Title: String { return self._s[3345]! } - public var CreatePoll_Quiz: String { return self._s[3346]! } - public var PhotoEditor_ContrastTool: String { return self._s[3349]! } + public var ClearCache_Forever: String { return self._s[3345]! } + public var AuthSessions_AddDeviceIntro_Title: String { return self._s[3346]! } + public var CreatePoll_Quiz: String { return self._s[3347]! } + public var PhotoEditor_ContrastTool: String { return self._s[3350]! } public func PUSH_PINNED_DOC(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3350]!, self._r[3350]!, [_1]) + return formatWithArgumentRanges(self._s[3351]!, self._r[3351]!, [_1]) } - public var DialogList_Draft: String { return self._s[3351]! } - public var Wallet_Configuration_BlockchainIdInfo: String { return self._s[3352]! } + public var DialogList_Draft: String { return self._s[3352]! } + public var Wallet_Configuration_BlockchainIdInfo: String { return self._s[3353]! } public func PeopleNearby_VisibleUntil(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3353]!, self._r[3353]!, [_0]) + return formatWithArgumentRanges(self._s[3354]!, self._r[3354]!, [_0]) } - public var Privacy_TopPeersDelete: String { return self._s[3355]! } - public var LoginPassword_PasswordPlaceholder: String { return self._s[3356]! } - public var Passport_Identity_TypeIdentityCardUploadScan: String { return self._s[3357]! } - public var WebSearch_RecentSectionClear: String { return self._s[3358]! } - public var EditTheme_ErrorInvalidCharacters: String { return self._s[3359]! } - public var Watch_ChatList_NoConversationsTitle: String { return self._s[3361]! } - public var PeerInfo_ButtonMore: String { return self._s[3363]! } - public var Common_Done: String { return self._s[3364]! } - public var Shortcut_SwitchAccount: String { return self._s[3365]! } - public var AuthSessions_EmptyText: String { return self._s[3366]! } - public var Wallet_Configuration_BlockchainNameChangedTitle: String { return self._s[3367]! } - public var Conversation_ShareBotContactConfirmation: String { return self._s[3368]! } - public var Tour_Title5: String { return self._s[3369]! } - public var Wallet_Settings_Title: String { return self._s[3370]! } + public var Privacy_TopPeersDelete: String { return self._s[3356]! } + public var LoginPassword_PasswordPlaceholder: String { return self._s[3357]! } + public var Passport_Identity_TypeIdentityCardUploadScan: String { return self._s[3358]! } + public var WebSearch_RecentSectionClear: String { return self._s[3359]! } + public var EditTheme_ErrorInvalidCharacters: String { return self._s[3360]! } + public var Watch_ChatList_NoConversationsTitle: String { return self._s[3362]! } + public var PeerInfo_ButtonMore: String { return self._s[3364]! } + public var Common_Done: String { return self._s[3365]! } + public var Shortcut_SwitchAccount: String { return self._s[3366]! } + public var AuthSessions_EmptyText: String { return self._s[3367]! } + public var Wallet_Configuration_BlockchainNameChangedTitle: String { return self._s[3368]! } + public var Conversation_ShareBotContactConfirmation: String { return self._s[3369]! } + public var Tour_Title5: String { return self._s[3370]! } + public var Wallet_Settings_Title: String { return self._s[3371]! } public func Map_DirectionsDriveEta(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3371]!, self._r[3371]!, [_0]) + return formatWithArgumentRanges(self._s[3372]!, self._r[3372]!, [_0]) } - public var ApplyLanguage_UnsufficientDataTitle: String { return self._s[3372]! } - public var Conversation_LinkDialogSave: String { return self._s[3373]! } - public var GroupInfo_ActionRestrict: String { return self._s[3374]! } - public var Checkout_Title: String { return self._s[3375]! } - public var Channel_DiscussionGroup_HeaderLabel: String { return self._s[3377]! } - public var Channel_AdminLog_CanChangeInfo: String { return self._s[3379]! } - public var Notification_RenamedGroup: String { return self._s[3380]! } - public var PeopleNearby_Groups: String { return self._s[3381]! } - public var Checkout_PayWithFaceId: String { return self._s[3382]! } - public var Channel_BanList_BlockedTitle: String { return self._s[3383]! } - public var SettingsSearch_Synonyms_Notifications_InAppNotificationsSound: String { return self._s[3385]! } - public var Checkout_WebConfirmation_Title: String { return self._s[3386]! } - public var Notifications_MessageNotificationsAlert: String { return self._s[3387]! } + public var ApplyLanguage_UnsufficientDataTitle: String { return self._s[3373]! } + public var Conversation_LinkDialogSave: String { return self._s[3374]! } + public var GroupInfo_ActionRestrict: String { return self._s[3375]! } + public var Checkout_Title: String { return self._s[3376]! } + public var Channel_DiscussionGroup_HeaderLabel: String { return self._s[3378]! } + public var Channel_AdminLog_CanChangeInfo: String { return self._s[3380]! } + public var Notification_RenamedGroup: String { return self._s[3381]! } + public var PeopleNearby_Groups: String { return self._s[3382]! } + public var Checkout_PayWithFaceId: String { return self._s[3383]! } + public var Channel_BanList_BlockedTitle: String { return self._s[3384]! } + public var SettingsSearch_Synonyms_Notifications_InAppNotificationsSound: String { return self._s[3386]! } + public var Checkout_WebConfirmation_Title: String { return self._s[3387]! } + public var Notifications_MessageNotificationsAlert: String { return self._s[3388]! } public func Activity_RemindAboutGroup(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3388]!, self._r[3388]!, [_0]) + return formatWithArgumentRanges(self._s[3389]!, self._r[3389]!, [_0]) } - public var Profile_AddToExisting: String { return self._s[3390]! } + public var Profile_AddToExisting: String { return self._s[3391]! } public func Profile_CreateEncryptedChatOutdatedError(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3391]!, self._r[3391]!, [_0, _1]) + return formatWithArgumentRanges(self._s[3392]!, self._r[3392]!, [_0, _1]) } - public var Cache_Files: String { return self._s[3393]! } - public var Permissions_PrivacyPolicy: String { return self._s[3394]! } - public var SocksProxySetup_ConnectAndSave: String { return self._s[3395]! } - public var UserInfo_NotificationsDefaultDisabled: String { return self._s[3396]! } - public var AutoDownloadSettings_TypeContacts: String { return self._s[3398]! } - public var Appearance_ThemePreview_ChatList_1_Text: String { return self._s[3400]! } - public var Calls_NoCallsPlaceholder: String { return self._s[3401]! } + public var Cache_Files: String { return self._s[3394]! } + public var Permissions_PrivacyPolicy: String { return self._s[3395]! } + public var SocksProxySetup_ConnectAndSave: String { return self._s[3396]! } + public var UserInfo_NotificationsDefaultDisabled: String { return self._s[3397]! } + public var AutoDownloadSettings_TypeContacts: String { return self._s[3399]! } + public var Appearance_ThemePreview_ChatList_1_Text: String { return self._s[3401]! } + public var Calls_NoCallsPlaceholder: String { return self._s[3402]! } public func Wallet_Receive_ShareInvoiceUrlInfo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3402]!, self._r[3402]!, [_0]) + return formatWithArgumentRanges(self._s[3403]!, self._r[3403]!, [_0]) } - public var Channel_Username_RevokeExistingUsernamesInfo: String { return self._s[3403]! } - public var VoiceOver_AttachMedia: String { return self._s[3406]! } - public var ChatList_EmptyChatFilterList: String { return self._s[3407]! } - public var Notifications_ExceptionsGroupPlaceholder: String { return self._s[3408]! } + public var Channel_Username_RevokeExistingUsernamesInfo: String { return self._s[3404]! } + public var VoiceOver_AttachMedia: String { return self._s[3407]! } + public var ChatList_EmptyChatFilterList: String { return self._s[3408]! } + public var Notifications_ExceptionsGroupPlaceholder: String { return self._s[3409]! } public func PUSH_CHAT_MESSAGE_INVOICE(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3409]!, self._r[3409]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3410]!, self._r[3410]!, [_1, _2, _3]) } - public var SettingsSearch_Synonyms_Notifications_GroupNotificationsSound: String { return self._s[3410]! } - public var Conversation_SetReminder_Title: String { return self._s[3411]! } - public var Passport_FieldAddressHelp: String { return self._s[3412]! } - public var Privacy_GroupsAndChannels_InviteToChannelMultipleError: String { return self._s[3413]! } - public var PUSH_REMINDER_TITLE: String { return self._s[3414]! } + public var SettingsSearch_Synonyms_Notifications_GroupNotificationsSound: String { return self._s[3411]! } + public var Conversation_SetReminder_Title: String { return self._s[3412]! } + public var Passport_FieldAddressHelp: String { return self._s[3413]! } + public var Privacy_GroupsAndChannels_InviteToChannelMultipleError: String { return self._s[3414]! } + public var PUSH_REMINDER_TITLE: String { return self._s[3415]! } public func Login_TermsOfService_ProceedBot(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3415]!, self._r[3415]!, [_0]) + return formatWithArgumentRanges(self._s[3416]!, self._r[3416]!, [_0]) } - public var Channel_AdminLog_EmptyTitle: String { return self._s[3416]! } - public var Privacy_Calls_NeverAllow_Title: String { return self._s[3417]! } - public var Login_UnknownError: String { return self._s[3418]! } - public var Group_UpgradeNoticeText2: String { return self._s[3421]! } - public var Watch_Compose_AddContact: String { return self._s[3422]! } - public var ClearCache_StorageServiceFiles: String { return self._s[3423]! } - public var Web_Error: String { return self._s[3424]! } - public var Gif_Search: String { return self._s[3425]! } - public var Profile_MessageLifetime1h: String { return self._s[3426]! } - public var CheckoutInfo_ReceiverInfoEmailPlaceholder: String { return self._s[3427]! } - public var Channel_Username_CheckingUsername: String { return self._s[3428]! } - public var CallFeedback_ReasonSilentRemote: String { return self._s[3429]! } - public var AutoDownloadSettings_TypeChannels: String { return self._s[3430]! } - public var Channel_AboutItem: String { return self._s[3431]! } - public var Privacy_GroupsAndChannels_AlwaysAllow_Placeholder: String { return self._s[3433]! } - public var VoiceOver_Chat_VoiceMessage: String { return self._s[3434]! } - public var GroupInfo_SharedMedia: String { return self._s[3435]! } + public var Channel_AdminLog_EmptyTitle: String { return self._s[3417]! } + public var Privacy_Calls_NeverAllow_Title: String { return self._s[3418]! } + public var Login_UnknownError: String { return self._s[3419]! } + public var Group_UpgradeNoticeText2: String { return self._s[3422]! } + public var Watch_Compose_AddContact: String { return self._s[3423]! } + public var ClearCache_StorageServiceFiles: String { return self._s[3424]! } + public var Web_Error: String { return self._s[3425]! } + public var Gif_Search: String { return self._s[3426]! } + public var Profile_MessageLifetime1h: String { return self._s[3427]! } + public var CheckoutInfo_ReceiverInfoEmailPlaceholder: String { return self._s[3428]! } + public var Channel_Username_CheckingUsername: String { return self._s[3429]! } + public var CallFeedback_ReasonSilentRemote: String { return self._s[3430]! } + public var AutoDownloadSettings_TypeChannels: String { return self._s[3431]! } + public var Channel_AboutItem: String { return self._s[3432]! } + public var Privacy_GroupsAndChannels_AlwaysAllow_Placeholder: String { return self._s[3434]! } + public var VoiceOver_Chat_VoiceMessage: String { return self._s[3435]! } + public var GroupInfo_SharedMedia: String { return self._s[3436]! } public func Channel_AdminLog_MessagePromotedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3436]!, self._r[3436]!, [_1]) + return formatWithArgumentRanges(self._s[3437]!, self._r[3437]!, [_1]) } - public var Call_PhoneCallInProgressMessage: String { return self._s[3437]! } + public var Call_PhoneCallInProgressMessage: String { return self._s[3438]! } public func PUSH_CHANNEL_ALBUM(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3438]!, self._r[3438]!, [_1]) + return formatWithArgumentRanges(self._s[3439]!, self._r[3439]!, [_1]) } - public var ChatList_UndoArchiveRevealedText: String { return self._s[3439]! } - public var GroupInfo_InviteLink_RevokeAlert_Text: String { return self._s[3440]! } - public var Conversation_SearchByName_Placeholder: String { return self._s[3441]! } - public var CreatePoll_AddOption: String { return self._s[3442]! } - public var GroupInfo_Permissions_SearchPlaceholder: String { return self._s[3443]! } - public var Group_UpgradeNoticeHeader: String { return self._s[3444]! } - public var Channel_Management_AddModerator: String { return self._s[3445]! } - public var AutoDownloadSettings_MaxFileSize: String { return self._s[3446]! } - public var StickerPacksSettings_ShowStickersButton: String { return self._s[3447]! } - public var Wallet_Info_RefreshErrorNetworkText: String { return self._s[3448]! } - public var Theme_Colors_Background: String { return self._s[3449]! } - public var NotificationsSound_Hello: String { return self._s[3451]! } - public var SocksProxySetup_SavedProxies: String { return self._s[3452]! } - public var Channel_Stickers_Placeholder: String { return self._s[3454]! } + public var ChatList_UndoArchiveRevealedText: String { return self._s[3440]! } + public var GroupInfo_InviteLink_RevokeAlert_Text: String { return self._s[3441]! } + public var Conversation_SearchByName_Placeholder: String { return self._s[3442]! } + public var CreatePoll_AddOption: String { return self._s[3443]! } + public var GroupInfo_Permissions_SearchPlaceholder: String { return self._s[3444]! } + public var Group_UpgradeNoticeHeader: String { return self._s[3445]! } + public var Channel_Management_AddModerator: String { return self._s[3446]! } + public var AutoDownloadSettings_MaxFileSize: String { return self._s[3447]! } + public var StickerPacksSettings_ShowStickersButton: String { return self._s[3448]! } + public var Wallet_Info_RefreshErrorNetworkText: String { return self._s[3449]! } + public var Theme_Colors_Background: String { return self._s[3450]! } + public var NotificationsSound_Hello: String { return self._s[3452]! } + public var SocksProxySetup_SavedProxies: String { return self._s[3453]! } + public var Channel_Stickers_Placeholder: String { return self._s[3455]! } public func Login_EmailCodeBody(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3455]!, self._r[3455]!, [_0]) + return formatWithArgumentRanges(self._s[3456]!, self._r[3456]!, [_0]) } - public var PrivacyPolicy_DeclineDeclineAndDelete: String { return self._s[3456]! } - public var Channel_Management_AddModeratorHelp: String { return self._s[3457]! } - public var ContactInfo_BirthdayLabel: String { return self._s[3458]! } - public var ChangePhoneNumberCode_RequestingACall: String { return self._s[3459]! } - public var AutoDownloadSettings_Channels: String { return self._s[3460]! } - public var Passport_Language_mn: String { return self._s[3461]! } - public var Notifications_ResetAllNotificationsHelp: String { return self._s[3464]! } - public var GroupInfo_Permissions_SlowmodeValue_Off: String { return self._s[3465]! } - public var Passport_Language_ja: String { return self._s[3467]! } - public var Settings_About_Title: String { return self._s[3468]! } - public var Settings_NotificationsAndSounds: String { return self._s[3469]! } - public var ChannelInfo_DeleteGroup: String { return self._s[3470]! } - public var Settings_BlockedUsers: String { return self._s[3471]! } + public var PrivacyPolicy_DeclineDeclineAndDelete: String { return self._s[3457]! } + public var Channel_Management_AddModeratorHelp: String { return self._s[3458]! } + public var ContactInfo_BirthdayLabel: String { return self._s[3459]! } + public var ChangePhoneNumberCode_RequestingACall: String { return self._s[3460]! } + public var AutoDownloadSettings_Channels: String { return self._s[3461]! } + public var Passport_Language_mn: String { return self._s[3462]! } + public var Notifications_ResetAllNotificationsHelp: String { return self._s[3465]! } + public var GroupInfo_Permissions_SlowmodeValue_Off: String { return self._s[3466]! } + public var Passport_Language_ja: String { return self._s[3468]! } + public var Settings_About_Title: String { return self._s[3469]! } + public var Settings_NotificationsAndSounds: String { return self._s[3470]! } + public var ChannelInfo_DeleteGroup: String { return self._s[3471]! } + public var Settings_BlockedUsers: String { return self._s[3472]! } public func Time_MonthOfYear_m4(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3472]!, self._r[3472]!, [_0]) + return formatWithArgumentRanges(self._s[3473]!, self._r[3473]!, [_0]) } - public var EditTheme_Create_Preview_OutgoingText: String { return self._s[3473]! } - public var Wallet_Weekday_Today: String { return self._s[3474]! } - public var AutoDownloadSettings_PreloadVideo: String { return self._s[3475]! } - public var Widget_ApplicationLocked: String { return self._s[3476]! } - public var Passport_Address_AddResidentialAddress: String { return self._s[3477]! } - public var Channel_Username_Title: String { return self._s[3478]! } + public var EditTheme_Create_Preview_OutgoingText: String { return self._s[3474]! } + public var Wallet_Weekday_Today: String { return self._s[3475]! } + public var AutoDownloadSettings_PreloadVideo: String { return self._s[3476]! } + public var Widget_ApplicationLocked: String { return self._s[3477]! } + public var Passport_Address_AddResidentialAddress: String { return self._s[3478]! } + public var Channel_Username_Title: String { return self._s[3479]! } public func Notification_RemovedGroupPhoto(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3479]!, self._r[3479]!, [_0]) + return formatWithArgumentRanges(self._s[3480]!, self._r[3480]!, [_0]) } - public var AttachmentMenu_File: String { return self._s[3481]! } - public var AppleWatch_Title: String { return self._s[3482]! } - public var Activity_RecordingVideoMessage: String { return self._s[3483]! } + public var AttachmentMenu_File: String { return self._s[3482]! } + public var AppleWatch_Title: String { return self._s[3483]! } + public var Activity_RecordingVideoMessage: String { return self._s[3484]! } public func Channel_DiscussionGroup_PublicChannelLink(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3484]!, self._r[3484]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3485]!, self._r[3485]!, [_1, _2]) } - public var Theme_Colors_Messages: String { return self._s[3485]! } - public var Weekday_Saturday: String { return self._s[3486]! } - public var WallpaperPreview_SwipeColorsTopText: String { return self._s[3487]! } - public var Profile_CreateEncryptedChatError: String { return self._s[3488]! } - public var Common_Next: String { return self._s[3490]! } - public var Channel_Stickers_YourStickers: String { return self._s[3492]! } - public var Message_Theme: String { return self._s[3493]! } - public var Call_AudioRouteHeadphones: String { return self._s[3494]! } - public var TwoStepAuth_EnterPasswordForgot: String { return self._s[3496]! } - public var Watch_Contacts_NoResults: String { return self._s[3498]! } - public var PhotoEditor_TintTool: String { return self._s[3501]! } - public var LoginPassword_ResetAccount: String { return self._s[3503]! } - public var Settings_SavedMessages: String { return self._s[3504]! } - public var SettingsSearch_Synonyms_Appearance_Animations: String { return self._s[3505]! } - public var Bot_GenericSupportStatus: String { return self._s[3506]! } - public var StickerPack_Add: String { return self._s[3507]! } - public var Checkout_TotalAmount: String { return self._s[3508]! } - public var Your_cards_number_is_invalid: String { return self._s[3509]! } - public var SettingsSearch_Synonyms_Appearance_AutoNightTheme: String { return self._s[3510]! } - public var VoiceOver_Chat_VideoMessage: String { return self._s[3511]! } + public var Theme_Colors_Messages: String { return self._s[3486]! } + public var Weekday_Saturday: String { return self._s[3487]! } + public var WallpaperPreview_SwipeColorsTopText: String { return self._s[3488]! } + public var Profile_CreateEncryptedChatError: String { return self._s[3489]! } + public var Common_Next: String { return self._s[3491]! } + public var Channel_Stickers_YourStickers: String { return self._s[3493]! } + public var Message_Theme: String { return self._s[3494]! } + public var Call_AudioRouteHeadphones: String { return self._s[3495]! } + public var TwoStepAuth_EnterPasswordForgot: String { return self._s[3497]! } + public var Watch_Contacts_NoResults: String { return self._s[3499]! } + public var PhotoEditor_TintTool: String { return self._s[3502]! } + public var LoginPassword_ResetAccount: String { return self._s[3504]! } + public var Settings_SavedMessages: String { return self._s[3505]! } + public var SettingsSearch_Synonyms_Appearance_Animations: String { return self._s[3506]! } + public var Bot_GenericSupportStatus: String { return self._s[3507]! } + public var StickerPack_Add: String { return self._s[3508]! } + public var Checkout_TotalAmount: String { return self._s[3509]! } + public var Your_cards_number_is_invalid: String { return self._s[3510]! } + public var SettingsSearch_Synonyms_Appearance_AutoNightTheme: String { return self._s[3511]! } + public var VoiceOver_Chat_VideoMessage: String { return self._s[3512]! } public func ChangePhoneNumberCode_CallTimer(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3512]!, self._r[3512]!, [_0]) + return formatWithArgumentRanges(self._s[3513]!, self._r[3513]!, [_0]) } public func GroupPermission_AddedInfo(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3513]!, self._r[3513]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3514]!, self._r[3514]!, [_1, _2]) } - public var ChatSettings_ConnectionType_UseSocks5: String { return self._s[3514]! } + public var ChatSettings_ConnectionType_UseSocks5: String { return self._s[3515]! } public func PUSH_CHAT_PHOTO_EDITED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3516]!, self._r[3516]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3517]!, self._r[3517]!, [_1, _2]) } public func Conversation_RestrictedTextTimed(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3517]!, self._r[3517]!, [_0]) + return formatWithArgumentRanges(self._s[3518]!, self._r[3518]!, [_0]) } - public var GroupInfo_InviteLink_ShareLink: String { return self._s[3518]! } - public var StickerPack_Share: String { return self._s[3519]! } - public var Passport_DeleteAddress: String { return self._s[3520]! } - public var Settings_Passport: String { return self._s[3521]! } - public var SharedMedia_EmptyFilesText: String { return self._s[3522]! } - public var Conversation_DeleteMessagesForMe: String { return self._s[3523]! } - public var PasscodeSettings_AutoLock_IfAwayFor_1hour: String { return self._s[3524]! } - public var Contacts_PermissionsText: String { return self._s[3525]! } - public var Group_Setup_HistoryVisible: String { return self._s[3526]! } - public var Wallet_Month_ShortDecember: String { return self._s[3528]! } - public var Channel_EditAdmin_PermissionEnabledByDefault: String { return self._s[3529]! } - public var Passport_Address_AddRentalAgreement: String { return self._s[3530]! } - public var SocksProxySetup_Title: String { return self._s[3531]! } - public var Notification_Mute1h: String { return self._s[3532]! } + public var GroupInfo_InviteLink_ShareLink: String { return self._s[3519]! } + public var StickerPack_Share: String { return self._s[3520]! } + public var Passport_DeleteAddress: String { return self._s[3521]! } + public var Settings_Passport: String { return self._s[3522]! } + public var SharedMedia_EmptyFilesText: String { return self._s[3523]! } + public var Conversation_DeleteMessagesForMe: String { return self._s[3524]! } + public var PasscodeSettings_AutoLock_IfAwayFor_1hour: String { return self._s[3525]! } + public var Contacts_PermissionsText: String { return self._s[3526]! } + public var Group_Setup_HistoryVisible: String { return self._s[3527]! } + public var Wallet_Month_ShortDecember: String { return self._s[3529]! } + public var Channel_EditAdmin_PermissionEnabledByDefault: String { return self._s[3530]! } + public var Passport_Address_AddRentalAgreement: String { return self._s[3531]! } + public var SocksProxySetup_Title: String { return self._s[3532]! } + public var Notification_Mute1h: String { return self._s[3533]! } public func Passport_Email_CodeHelp(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3533]!, self._r[3533]!, [_0]) + return formatWithArgumentRanges(self._s[3534]!, self._r[3534]!, [_0]) } - public var NotificationSettings_ShowNotificationsAllAccountsInfoOff: String { return self._s[3534]! } + public var NotificationSettings_ShowNotificationsAllAccountsInfoOff: String { return self._s[3535]! } public func PUSH_PINNED_GEOLIVE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3535]!, self._r[3535]!, [_1]) + return formatWithArgumentRanges(self._s[3536]!, self._r[3536]!, [_1]) } - public var FastTwoStepSetup_PasswordSection: String { return self._s[3536]! } - public var NetworkUsageSettings_ResetStatsConfirmation: String { return self._s[3539]! } - public var InfoPlist_NSFaceIDUsageDescription: String { return self._s[3541]! } - public var DialogList_NoMessagesText: String { return self._s[3542]! } - public var Privacy_ContactsResetConfirmation: String { return self._s[3543]! } - public var Privacy_Calls_P2PHelp: String { return self._s[3544]! } - public var Channel_DiscussionGroup_SearchPlaceholder: String { return self._s[3546]! } - public var Your_cards_expiration_year_is_invalid: String { return self._s[3547]! } - public var Common_TakePhotoOrVideo: String { return self._s[3548]! } - public var Wallet_Words_Text: String { return self._s[3549]! } - public var Call_StatusBusy: String { return self._s[3550]! } - public var Conversation_PinnedMessage: String { return self._s[3551]! } - public var AutoDownloadSettings_VoiceMessagesTitle: String { return self._s[3552]! } - public var ChatList_EmptyChatListNewMessage: String { return self._s[3553]! } - public var Wallet_Configuration_BlockchainNameChangedProceed: String { return self._s[3554]! } - public var TwoStepAuth_SetupPasswordConfirmFailed: String { return self._s[3555]! } - public var Undo_ChatCleared: String { return self._s[3556]! } - public var AppleWatch_ReplyPresets: String { return self._s[3557]! } - public var Passport_DiscardMessageDescription: String { return self._s[3559]! } - public var Login_NetworkError: String { return self._s[3560]! } + public var FastTwoStepSetup_PasswordSection: String { return self._s[3537]! } + public var NetworkUsageSettings_ResetStatsConfirmation: String { return self._s[3540]! } + public var InfoPlist_NSFaceIDUsageDescription: String { return self._s[3542]! } + public var DialogList_NoMessagesText: String { return self._s[3543]! } + public var Privacy_ContactsResetConfirmation: String { return self._s[3544]! } + public var Privacy_Calls_P2PHelp: String { return self._s[3545]! } + public var Channel_DiscussionGroup_SearchPlaceholder: String { return self._s[3547]! } + public var Your_cards_expiration_year_is_invalid: String { return self._s[3548]! } + public var Common_TakePhotoOrVideo: String { return self._s[3549]! } + public var Wallet_Words_Text: String { return self._s[3550]! } + public var Call_StatusBusy: String { return self._s[3551]! } + public var Conversation_PinnedMessage: String { return self._s[3552]! } + public var AutoDownloadSettings_VoiceMessagesTitle: String { return self._s[3553]! } + public var ChatList_EmptyChatListNewMessage: String { return self._s[3554]! } + public var Wallet_Configuration_BlockchainNameChangedProceed: String { return self._s[3555]! } + public var TwoStepAuth_SetupPasswordConfirmFailed: String { return self._s[3556]! } + public var Undo_ChatCleared: String { return self._s[3557]! } + public var AppleWatch_ReplyPresets: String { return self._s[3558]! } + public var Passport_DiscardMessageDescription: String { return self._s[3560]! } + public var Login_NetworkError: String { return self._s[3561]! } public func Notification_PinnedRoundMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3561]!, self._r[3561]!, [_0]) - } - public func Channel_AdminLog_MessageRemovedChannelUsername(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[3562]!, self._r[3562]!, [_0]) } - public var SocksProxySetup_PasswordPlaceholder: String { return self._s[3563]! } - public var Wallet_WordCheck_ViewWords: String { return self._s[3565]! } - public var Login_ResetAccountProtected_LimitExceeded: String { return self._s[3566]! } + public func Channel_AdminLog_MessageRemovedChannelUsername(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3563]!, self._r[3563]!, [_0]) + } + public var SocksProxySetup_PasswordPlaceholder: String { return self._s[3564]! } + public var Wallet_WordCheck_ViewWords: String { return self._s[3566]! } + public var Login_ResetAccountProtected_LimitExceeded: String { return self._s[3567]! } public func Watch_LastSeen_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3568]!, self._r[3568]!, [_0]) + return formatWithArgumentRanges(self._s[3569]!, self._r[3569]!, [_0]) } - public var Call_ConnectionErrorMessage: String { return self._s[3569]! } - public var VoiceOver_Chat_Music: String { return self._s[3570]! } - public var SettingsSearch_Synonyms_Notifications_MessageNotificationsSound: String { return self._s[3571]! } - public var Compose_GroupTokenListPlaceholder: String { return self._s[3573]! } - public var ConversationMedia_Title: String { return self._s[3574]! } - public var EncryptionKey_Title: String { return self._s[3576]! } - public var TwoStepAuth_EnterPasswordTitle: String { return self._s[3577]! } - public var Notification_Exceptions_AddException: String { return self._s[3578]! } - public var PrivacySettings_BlockedPeersEmpty: String { return self._s[3579]! } - public var Profile_MessageLifetime1m: String { return self._s[3580]! } + public var Call_ConnectionErrorMessage: String { return self._s[3570]! } + public var VoiceOver_Chat_Music: String { return self._s[3571]! } + public var SettingsSearch_Synonyms_Notifications_MessageNotificationsSound: String { return self._s[3572]! } + public var Compose_GroupTokenListPlaceholder: String { return self._s[3574]! } + public var ConversationMedia_Title: String { return self._s[3575]! } + public var EncryptionKey_Title: String { return self._s[3577]! } + public var TwoStepAuth_EnterPasswordTitle: String { return self._s[3578]! } + public var Notification_Exceptions_AddException: String { return self._s[3579]! } + public var PrivacySettings_BlockedPeersEmpty: String { return self._s[3580]! } + public var Profile_MessageLifetime1m: String { return self._s[3581]! } public func Channel_AdminLog_MessageUnkickedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3581]!, self._r[3581]!, [_1]) + return formatWithArgumentRanges(self._s[3582]!, self._r[3582]!, [_1]) } - public var Month_GenMay: String { return self._s[3582]! } + public var Month_GenMay: String { return self._s[3583]! } public func LiveLocationUpdated_TodayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3583]!, self._r[3583]!, [_0]) + return formatWithArgumentRanges(self._s[3584]!, self._r[3584]!, [_0]) } - public var PeopleNearby_Users: String { return self._s[3584]! } - public var Wallet_Send_AddressInfo: String { return self._s[3585]! } - public var ChannelMembers_WhoCanAddMembersAllHelp: String { return self._s[3586]! } - public var AutoDownloadSettings_ResetSettings: String { return self._s[3587]! } + public var PeopleNearby_Users: String { return self._s[3585]! } + public var Wallet_Send_AddressInfo: String { return self._s[3586]! } + public var ChannelMembers_WhoCanAddMembersAllHelp: String { return self._s[3587]! } + public var AutoDownloadSettings_ResetSettings: String { return self._s[3588]! } public func Wallet_Updated_AtDate(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3589]!, self._r[3589]!, [_0]) + return formatWithArgumentRanges(self._s[3590]!, self._r[3590]!, [_0]) } - public var Conversation_EmptyPlaceholder: String { return self._s[3590]! } - public var Passport_Address_AddPassportRegistration: String { return self._s[3591]! } - public var Notifications_ChannelNotificationsAlert: String { return self._s[3592]! } - public var ChatSettings_AutoDownloadUsingCellular: String { return self._s[3593]! } - public var Camera_TapAndHoldForVideo: String { return self._s[3594]! } - public var Channel_JoinChannel: String { return self._s[3596]! } - public var Appearance_Animations: String { return self._s[3599]! } + public var Conversation_EmptyPlaceholder: String { return self._s[3591]! } + public var Passport_Address_AddPassportRegistration: String { return self._s[3592]! } + public var Notifications_ChannelNotificationsAlert: String { return self._s[3593]! } + public var ChatSettings_AutoDownloadUsingCellular: String { return self._s[3594]! } + public var Camera_TapAndHoldForVideo: String { return self._s[3595]! } + public var Channel_JoinChannel: String { return self._s[3597]! } + public var Appearance_Animations: String { return self._s[3600]! } public func Notification_MessageLifetimeChanged(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3600]!, self._r[3600]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3601]!, self._r[3601]!, [_1, _2]) } - public var Stickers_GroupStickers: String { return self._s[3602]! } - public var Appearance_ShareTheme: String { return self._s[3603]! } - public var TwoFactorSetup_Hint_Placeholder: String { return self._s[3604]! } - public var ConvertToSupergroup_HelpTitle: String { return self._s[3606]! } - public var StickerPackActionInfo_RemovedTitle: String { return self._s[3607]! } - public var Passport_Address_Street: String { return self._s[3608]! } - public var Conversation_AddContact: String { return self._s[3609]! } - public var Login_PhonePlaceholder: String { return self._s[3610]! } - public var Channel_Members_InviteLink: String { return self._s[3612]! } - public var Bot_Stop: String { return self._s[3613]! } - public var SettingsSearch_Synonyms_Proxy_UseForCalls: String { return self._s[3615]! } - public var Notification_PassportValueAddress: String { return self._s[3616]! } - public var Month_ShortJuly: String { return self._s[3617]! } - public var Passport_Address_TypeTemporaryRegistrationUploadScan: String { return self._s[3618]! } - public var Channel_AdminLog_BanSendMedia: String { return self._s[3619]! } - public var Passport_Identity_ReverseSide: String { return self._s[3620]! } - public var Watch_Stickers_Recents: String { return self._s[3623]! } - public var PrivacyLastSeenSettings_EmpryUsersPlaceholder: String { return self._s[3625]! } - public var Map_SendThisLocation: String { return self._s[3626]! } + public var Stickers_GroupStickers: String { return self._s[3603]! } + public var Appearance_ShareTheme: String { return self._s[3604]! } + public var TwoFactorSetup_Hint_Placeholder: String { return self._s[3605]! } + public var ConvertToSupergroup_HelpTitle: String { return self._s[3607]! } + public var StickerPackActionInfo_RemovedTitle: String { return self._s[3608]! } + public var Passport_Address_Street: String { return self._s[3609]! } + public var Conversation_AddContact: String { return self._s[3610]! } + public var Login_PhonePlaceholder: String { return self._s[3611]! } + public var Channel_Members_InviteLink: String { return self._s[3613]! } + public var Bot_Stop: String { return self._s[3614]! } + public var SettingsSearch_Synonyms_Proxy_UseForCalls: String { return self._s[3616]! } + public var Notification_PassportValueAddress: String { return self._s[3617]! } + public var Month_ShortJuly: String { return self._s[3618]! } + public var Passport_Address_TypeTemporaryRegistrationUploadScan: String { return self._s[3619]! } + public var Channel_AdminLog_BanSendMedia: String { return self._s[3620]! } + public var Passport_Identity_ReverseSide: String { return self._s[3621]! } + public var Watch_Stickers_Recents: String { return self._s[3624]! } + public var PrivacyLastSeenSettings_EmpryUsersPlaceholder: String { return self._s[3626]! } + public var Map_SendThisLocation: String { return self._s[3627]! } public func Time_MonthOfYear_m1(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3627]!, self._r[3627]!, [_0]) - } - public func InviteText_SingleContact(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[3628]!, self._r[3628]!, [_0]) } - public var ConvertToSupergroup_Note: String { return self._s[3629]! } - public var Wallet_Intro_NotNow: String { return self._s[3630]! } + public func InviteText_SingleContact(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3629]!, self._r[3629]!, [_0]) + } + public var ConvertToSupergroup_Note: String { return self._s[3630]! } + public var Wallet_Intro_NotNow: String { return self._s[3631]! } public func FileSize_MB(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3631]!, self._r[3631]!, [_0]) + return formatWithArgumentRanges(self._s[3632]!, self._r[3632]!, [_0]) } - public var NetworkUsageSettings_GeneralDataSection: String { return self._s[3632]! } + public var NetworkUsageSettings_GeneralDataSection: String { return self._s[3633]! } public func Compatibility_SecretMediaVersionTooLow(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3633]!, self._r[3633]!, [_0, _1]) + return formatWithArgumentRanges(self._s[3634]!, self._r[3634]!, [_0, _1]) } - public var Login_CallRequestState3: String { return self._s[3635]! } - public var Wallpaper_SearchShort: String { return self._s[3636]! } - public var SettingsSearch_Synonyms_Appearance_ColorTheme: String { return self._s[3638]! } - public var PasscodeSettings_UnlockWithFaceId: String { return self._s[3639]! } - public var Channel_BotDoesntSupportGroups: String { return self._s[3640]! } + public var Login_CallRequestState3: String { return self._s[3636]! } + public var Wallpaper_SearchShort: String { return self._s[3637]! } + public var SettingsSearch_Synonyms_Appearance_ColorTheme: String { return self._s[3639]! } + public var PasscodeSettings_UnlockWithFaceId: String { return self._s[3640]! } + public var Channel_BotDoesntSupportGroups: String { return self._s[3641]! } public func PUSH_CHAT_MESSAGE_GEOLIVE(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3641]!, self._r[3641]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3642]!, self._r[3642]!, [_1, _2]) } - public var Channel_AdminLogFilter_Title: String { return self._s[3642]! } - public var Appearance_ThemePreview_Chat_4_Text: String { return self._s[3644]! } - public var Notifications_GroupNotificationsExceptions: String { return self._s[3647]! } + public var Channel_AdminLogFilter_Title: String { return self._s[3643]! } + public var Appearance_ThemePreview_Chat_4_Text: String { return self._s[3645]! } + public var Notifications_GroupNotificationsExceptions: String { return self._s[3648]! } public func FileSize_B(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3648]!, self._r[3648]!, [_0]) + return formatWithArgumentRanges(self._s[3649]!, self._r[3649]!, [_0]) } - public var Passport_CorrectErrors: String { return self._s[3649]! } - public var VoiceOver_Chat_YourAnonymousPoll: String { return self._s[3650]! } + public var Passport_CorrectErrors: String { return self._s[3650]! } + public var VoiceOver_Chat_YourAnonymousPoll: String { return self._s[3651]! } public func Channel_MessageTitleUpdated(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3651]!, self._r[3651]!, [_0]) + return formatWithArgumentRanges(self._s[3652]!, self._r[3652]!, [_0]) } - public var Map_SendMyCurrentLocation: String { return self._s[3652]! } - public var Channel_DiscussionGroup: String { return self._s[3653]! } - public var TwoFactorSetup_Email_SkipConfirmationSkip: String { return self._s[3654]! } + public var Map_SendMyCurrentLocation: String { return self._s[3653]! } + public var Channel_DiscussionGroup: String { return self._s[3654]! } + public var TwoFactorSetup_Email_SkipConfirmationSkip: String { return self._s[3655]! } public func PUSH_PINNED_CONTACT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3655]!, self._r[3655]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3656]!, self._r[3656]!, [_1, _2]) } - public var SharedMedia_SearchNoResults: String { return self._s[3656]! } - public var Permissions_NotificationsText_v0: String { return self._s[3657]! } - public var Channel_EditAdmin_PermissionDeleteMessagesOfOthers: String { return self._s[3658]! } - public var Appearance_AppIcon: String { return self._s[3659]! } - public var Appearance_ThemePreview_ChatList_3_AuthorName: String { return self._s[3660]! } - public var LoginPassword_FloodError: String { return self._s[3661]! } - public var Wallet_Send_OwnAddressAlertProceed: String { return self._s[3663]! } - public var Group_Setup_HistoryHiddenHelp: String { return self._s[3664]! } + public var SharedMedia_SearchNoResults: String { return self._s[3657]! } + public var Permissions_NotificationsText_v0: String { return self._s[3658]! } + public var Channel_EditAdmin_PermissionDeleteMessagesOfOthers: String { return self._s[3659]! } + public var Appearance_AppIcon: String { return self._s[3660]! } + public var Appearance_ThemePreview_ChatList_3_AuthorName: String { return self._s[3661]! } + public var LoginPassword_FloodError: String { return self._s[3662]! } + public var Wallet_Send_OwnAddressAlertProceed: String { return self._s[3664]! } + public var Group_Setup_HistoryHiddenHelp: String { return self._s[3665]! } public func TwoStepAuth_PendingEmailHelp(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3665]!, self._r[3665]!, [_0]) + return formatWithArgumentRanges(self._s[3666]!, self._r[3666]!, [_0]) } - public var Passport_Language_bn: String { return self._s[3666]! } + public var Passport_Language_bn: String { return self._s[3667]! } public func DialogList_SingleUploadingPhotoSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3667]!, self._r[3667]!, [_0]) + return formatWithArgumentRanges(self._s[3668]!, self._r[3668]!, [_0]) } - public var ChatList_Context_Pin: String { return self._s[3668]! } + public var ChatList_Context_Pin: String { return self._s[3669]! } public func Notification_PinnedAudioMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3669]!, self._r[3669]!, [_0]) - } - public func Channel_AdminLog_MessageChangedGroupStickerPack(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[3670]!, self._r[3670]!, [_0]) } - public var Wallet_Navigation_Close: String { return self._s[3671]! } - public var GroupInfo_InvitationLinkGroupFull: String { return self._s[3675]! } - public var Group_EditAdmin_PermissionChangeInfo: String { return self._s[3677]! } - public var Wallet_Month_GenDecember: String { return self._s[3678]! } - public var Contacts_PermissionsAllow: String { return self._s[3679]! } - public var ReportPeer_ReasonCopyright: String { return self._s[3680]! } - public var Channel_EditAdmin_PermissinAddAdminOn: String { return self._s[3681]! } - public var WallpaperPreview_Pattern: String { return self._s[3682]! } - public var Paint_Duplicate: String { return self._s[3683]! } - public var Passport_Address_Country: String { return self._s[3684]! } - public var Notification_RenamedChannel: String { return self._s[3686]! } - public var ChatList_Context_Unmute: String { return self._s[3687]! } - public var CheckoutInfo_ErrorPostcodeInvalid: String { return self._s[3688]! } - public var Group_MessagePhotoUpdated: String { return self._s[3689]! } - public var Channel_BanUser_PermissionSendMedia: String { return self._s[3690]! } - public var Conversation_ContextMenuBan: String { return self._s[3691]! } - public var TwoStepAuth_EmailSent: String { return self._s[3692]! } - public var MessagePoll_NoVotes: String { return self._s[3693]! } - public var Wallet_Send_ErrorNotEnoughFundsTitle: String { return self._s[3694]! } - public var Passport_Language_is: String { return self._s[3696]! } - public var PeopleNearby_UsersEmpty: String { return self._s[3698]! } - public var Tour_Text5: String { return self._s[3699]! } + public func Channel_AdminLog_MessageChangedGroupStickerPack(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3671]!, self._r[3671]!, [_0]) + } + public var Wallet_Navigation_Close: String { return self._s[3672]! } + public var GroupInfo_InvitationLinkGroupFull: String { return self._s[3676]! } + public var Group_EditAdmin_PermissionChangeInfo: String { return self._s[3678]! } + public var Wallet_Month_GenDecember: String { return self._s[3679]! } + public var Contacts_PermissionsAllow: String { return self._s[3680]! } + public var ReportPeer_ReasonCopyright: String { return self._s[3681]! } + public var Channel_EditAdmin_PermissinAddAdminOn: String { return self._s[3682]! } + public var WallpaperPreview_Pattern: String { return self._s[3683]! } + public var Paint_Duplicate: String { return self._s[3684]! } + public var Passport_Address_Country: String { return self._s[3685]! } + public var Notification_RenamedChannel: String { return self._s[3687]! } + public var ChatList_Context_Unmute: String { return self._s[3688]! } + public var CheckoutInfo_ErrorPostcodeInvalid: String { return self._s[3689]! } + public var Group_MessagePhotoUpdated: String { return self._s[3690]! } + public var Channel_BanUser_PermissionSendMedia: String { return self._s[3691]! } + public var Conversation_ContextMenuBan: String { return self._s[3692]! } + public var TwoStepAuth_EmailSent: String { return self._s[3693]! } + public var MessagePoll_NoVotes: String { return self._s[3694]! } + public var Wallet_Send_ErrorNotEnoughFundsTitle: String { return self._s[3695]! } + public var Passport_Language_is: String { return self._s[3697]! } + public var PeopleNearby_UsersEmpty: String { return self._s[3699]! } + public var Tour_Text5: String { return self._s[3700]! } public func Call_GroupFormat(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3702]!, self._r[3702]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3703]!, self._r[3703]!, [_1, _2]) } - public var Undo_SecretChatDeleted: String { return self._s[3703]! } - public var SocksProxySetup_ShareQRCode: String { return self._s[3704]! } + public var Undo_SecretChatDeleted: String { return self._s[3704]! } + public var SocksProxySetup_ShareQRCode: String { return self._s[3705]! } public func VoiceOver_Chat_Size(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3705]!, self._r[3705]!, [_0]) + return formatWithArgumentRanges(self._s[3706]!, self._r[3706]!, [_0]) } - public var Forward_ErrorDisabledForChat: String { return self._s[3706]! } - public var LogoutOptions_ChangePhoneNumberText: String { return self._s[3707]! } - public var Paint_Edit: String { return self._s[3709]! } - public var ScheduledMessages_ReminderNotification: String { return self._s[3711]! } - public var Undo_DeletedGroup: String { return self._s[3713]! } - public var LoginPassword_ForgotPassword: String { return self._s[3714]! } - public var Wallet_WordImport_IncorrectTitle: String { return self._s[3715]! } - public var GroupInfo_GroupNamePlaceholder: String { return self._s[3716]! } + public var Forward_ErrorDisabledForChat: String { return self._s[3707]! } + public var LogoutOptions_ChangePhoneNumberText: String { return self._s[3708]! } + public var Paint_Edit: String { return self._s[3710]! } + public var ScheduledMessages_ReminderNotification: String { return self._s[3712]! } + public var Undo_DeletedGroup: String { return self._s[3714]! } + public var LoginPassword_ForgotPassword: String { return self._s[3715]! } + public var Wallet_WordImport_IncorrectTitle: String { return self._s[3716]! } + public var GroupInfo_GroupNamePlaceholder: String { return self._s[3717]! } public func Notification_Kicked(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3717]!, self._r[3717]!, [_0, _1]) + return formatWithArgumentRanges(self._s[3718]!, self._r[3718]!, [_0, _1]) } - public var AppWallet_TransactionInfo_FeeInfoURL: String { return self._s[3718]! } - public var Conversation_InputTextCaptionPlaceholder: String { return self._s[3719]! } - public var AutoDownloadSettings_VideoMessagesTitle: String { return self._s[3720]! } - public var Passport_Language_uz: String { return self._s[3721]! } - public var Conversation_PinMessageAlertGroup: String { return self._s[3722]! } - public var SettingsSearch_Synonyms_Privacy_GroupsAndChannels: String { return self._s[3723]! } - public var Map_StopLiveLocation: String { return self._s[3725]! } - public var VoiceOver_MessageContextSend: String { return self._s[3727]! } - public var PasscodeSettings_Help: String { return self._s[3728]! } - public var NotificationsSound_Input: String { return self._s[3729]! } - public var Share_Title: String { return self._s[3732]! } - public var LogoutOptions_Title: String { return self._s[3733]! } - public var Wallet_Send_AddressText: String { return self._s[3734]! } - public var Login_TermsOfServiceAgree: String { return self._s[3735]! } - public var Compose_NewEncryptedChatTitle: String { return self._s[3736]! } - public var Channel_AdminLog_TitleSelectedEvents: String { return self._s[3737]! } - public var Channel_EditAdmin_PermissionEditMessages: String { return self._s[3738]! } - public var EnterPasscode_EnterTitle: String { return self._s[3739]! } + public var AppWallet_TransactionInfo_FeeInfoURL: String { return self._s[3719]! } + public var Conversation_InputTextCaptionPlaceholder: String { return self._s[3720]! } + public var AutoDownloadSettings_VideoMessagesTitle: String { return self._s[3721]! } + public var Passport_Language_uz: String { return self._s[3722]! } + public var Conversation_PinMessageAlertGroup: String { return self._s[3723]! } + public var SettingsSearch_Synonyms_Privacy_GroupsAndChannels: String { return self._s[3724]! } + public var Map_StopLiveLocation: String { return self._s[3726]! } + public var VoiceOver_MessageContextSend: String { return self._s[3728]! } + public var PasscodeSettings_Help: String { return self._s[3729]! } + public var NotificationsSound_Input: String { return self._s[3730]! } + public var Share_Title: String { return self._s[3733]! } + public var LogoutOptions_Title: String { return self._s[3734]! } + public var Wallet_Send_AddressText: String { return self._s[3735]! } + public var Login_TermsOfServiceAgree: String { return self._s[3736]! } + public var Compose_NewEncryptedChatTitle: String { return self._s[3737]! } + public var Channel_AdminLog_TitleSelectedEvents: String { return self._s[3738]! } + public var Channel_EditAdmin_PermissionEditMessages: String { return self._s[3739]! } + public var EnterPasscode_EnterTitle: String { return self._s[3740]! } public func Call_PrivacyErrorMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3740]!, self._r[3740]!, [_0]) + return formatWithArgumentRanges(self._s[3741]!, self._r[3741]!, [_0]) } - public var Settings_CopyPhoneNumber: String { return self._s[3741]! } - public var Conversation_AddToContacts: String { return self._s[3742]! } + public var Settings_CopyPhoneNumber: String { return self._s[3742]! } + public var Conversation_AddToContacts: String { return self._s[3743]! } public func VoiceOver_Chat_ReplyFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3743]!, self._r[3743]!, [_0]) + return formatWithArgumentRanges(self._s[3744]!, self._r[3744]!, [_0]) } - public var NotificationsSound_Keys: String { return self._s[3744]! } + public var NotificationsSound_Keys: String { return self._s[3745]! } public func Call_ParticipantVersionOutdatedError(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3745]!, self._r[3745]!, [_0]) + return formatWithArgumentRanges(self._s[3746]!, self._r[3746]!, [_0]) } - public var Notification_MessageLifetime1w: String { return self._s[3746]! } - public var Message_Video: String { return self._s[3747]! } - public var AutoDownloadSettings_CellularTitle: String { return self._s[3748]! } + public var Notification_MessageLifetime1w: String { return self._s[3747]! } + public var Message_Video: String { return self._s[3748]! } + public var AutoDownloadSettings_CellularTitle: String { return self._s[3749]! } public func PUSH_CHANNEL_MESSAGE_PHOTO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3749]!, self._r[3749]!, [_1]) + return formatWithArgumentRanges(self._s[3750]!, self._r[3750]!, [_1]) } - public var Wallet_Receive_AmountInfo: String { return self._s[3752]! } - public var Stats_Overview: String { return self._s[3753]! } + public var Wallet_Receive_AmountInfo: String { return self._s[3753]! } + public var Stats_Overview: String { return self._s[3754]! } public func Notification_JoinedChat(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3754]!, self._r[3754]!, [_0]) - } - public func PrivacySettings_LastSeenContactsPlus(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[3755]!, self._r[3755]!, [_0]) } - public var Passport_Language_mk: String { return self._s[3756]! } - public func Wallet_Time_PreciseDate_m2(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3757]!, self._r[3757]!, [_1, _2, _3]) + public func PrivacySettings_LastSeenContactsPlus(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3756]!, self._r[3756]!, [_0]) } - public var CreatePoll_CancelConfirmation: String { return self._s[3758]! } - public var MessagePoll_LabelAnonymousQuiz: String { return self._s[3759]! } - public var Conversation_SilentBroadcastTooltipOn: String { return self._s[3761]! } - public var PrivacyPolicy_Decline: String { return self._s[3762]! } - public var Passport_Identity_DoesNotExpire: String { return self._s[3763]! } - public var Channel_AdminLogFilter_EventsRestrictions: String { return self._s[3764]! } - public var AuthSessions_AddDeviceIntro_Action: String { return self._s[3765]! } - public var Permissions_SiriAllow_v0: String { return self._s[3767]! } - public var Wallet_Month_ShortAugust: String { return self._s[3768]! } - public var Appearance_ThemeCarouselNight: String { return self._s[3769]! } + public var Passport_Language_mk: String { return self._s[3757]! } + public func Wallet_Time_PreciseDate_m2(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3758]!, self._r[3758]!, [_1, _2, _3]) + } + public var CreatePoll_CancelConfirmation: String { return self._s[3759]! } + public var MessagePoll_LabelAnonymousQuiz: String { return self._s[3760]! } + public var Conversation_SilentBroadcastTooltipOn: String { return self._s[3762]! } + public var PrivacyPolicy_Decline: String { return self._s[3763]! } + public var Passport_Identity_DoesNotExpire: String { return self._s[3764]! } + public var Channel_AdminLogFilter_EventsRestrictions: String { return self._s[3765]! } + public var AuthSessions_AddDeviceIntro_Action: String { return self._s[3766]! } + public var Permissions_SiriAllow_v0: String { return self._s[3768]! } + public var Wallet_Month_ShortAugust: String { return self._s[3769]! } + public var Appearance_ThemeCarouselNight: String { return self._s[3770]! } public func LOCAL_CHAT_MESSAGE_FWDS(_ _1: String, _ _2: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3770]!, self._r[3770]!, [_1, "\(_2)"]) + return formatWithArgumentRanges(self._s[3771]!, self._r[3771]!, [_1, "\(_2)"]) } public func Notification_RenamedChat(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3771]!, self._r[3771]!, [_0]) + return formatWithArgumentRanges(self._s[3772]!, self._r[3772]!, [_0]) } - public var Paint_Regular: String { return self._s[3772]! } - public var ChatSettings_AutoDownloadReset: String { return self._s[3773]! } - public var SocksProxySetup_ShareLink: String { return self._s[3774]! } - public var Wallet_Qr_Title: String { return self._s[3775]! } - public var BlockedUsers_SelectUserTitle: String { return self._s[3776]! } - public var VoiceOver_Chat_RecordModeVoiceMessage: String { return self._s[3778]! } - public var Wallet_Settings_Configuration: String { return self._s[3779]! } - public var GroupInfo_InviteByLink: String { return self._s[3780]! } - public var MessageTimer_Custom: String { return self._s[3781]! } - public var UserInfo_NotificationsDefaultEnabled: String { return self._s[3782]! } - public var Conversation_StopQuizConfirmationTitle: String { return self._s[3783]! } - public var Passport_Address_TypeTemporaryRegistration: String { return self._s[3785]! } - public var Conversation_SendMessage_SetReminder: String { return self._s[3786]! } - public var VoiceOver_Chat_Selected: String { return self._s[3787]! } - public var ChatSettings_AutoDownloadUsingWiFi: String { return self._s[3788]! } - public var Channel_Username_InvalidTaken: String { return self._s[3789]! } - public var Conversation_ClousStorageInfo_Description3: String { return self._s[3790]! } - public var Wallet_WordCheck_TryAgain: String { return self._s[3791]! } - public var Wallet_Info_TransactionPendingHeader: String { return self._s[3792]! } - public var Settings_ChatBackground: String { return self._s[3793]! } - public var Channel_Subscribers_Title: String { return self._s[3794]! } - public var Wallet_Receive_InvoiceUrlHeader: String { return self._s[3795]! } - public var ApplyLanguage_ChangeLanguageTitle: String { return self._s[3796]! } - public var Watch_ConnectionDescription: String { return self._s[3797]! } - public var OldChannels_NoticeText: String { return self._s[3800]! } - public var Wallet_Configuration_ApplyErrorTitle: String { return self._s[3801]! } - public var IntentsSettings_SuggestBy: String { return self._s[3803]! } - public var Theme_ThemeChangedText: String { return self._s[3804]! } - public var ChatList_ArchivedChatsTitle: String { return self._s[3805]! } - public var Wallpaper_ResetWallpapers: String { return self._s[3806]! } - public var Wallet_Send_TransactionInProgress: String { return self._s[3807]! } - public var EditProfile_Title: String { return self._s[3808]! } - public var NotificationsSound_Bamboo: String { return self._s[3810]! } - public var Channel_AdminLog_MessagePreviousMessage: String { return self._s[3812]! } - public var Login_SmsRequestState2: String { return self._s[3813]! } - public var Passport_Language_ar: String { return self._s[3814]! } + public var Paint_Regular: String { return self._s[3773]! } + public var ChatSettings_AutoDownloadReset: String { return self._s[3774]! } + public var SocksProxySetup_ShareLink: String { return self._s[3775]! } + public var Wallet_Qr_Title: String { return self._s[3776]! } + public var BlockedUsers_SelectUserTitle: String { return self._s[3777]! } + public var VoiceOver_Chat_RecordModeVoiceMessage: String { return self._s[3779]! } + public var Wallet_Settings_Configuration: String { return self._s[3780]! } + public var GroupInfo_InviteByLink: String { return self._s[3781]! } + public var MessageTimer_Custom: String { return self._s[3782]! } + public var UserInfo_NotificationsDefaultEnabled: String { return self._s[3783]! } + public var Conversation_StopQuizConfirmationTitle: String { return self._s[3784]! } + public var Passport_Address_TypeTemporaryRegistration: String { return self._s[3786]! } + public var Conversation_SendMessage_SetReminder: String { return self._s[3787]! } + public var VoiceOver_Chat_Selected: String { return self._s[3788]! } + public var ChatSettings_AutoDownloadUsingWiFi: String { return self._s[3789]! } + public var Channel_Username_InvalidTaken: String { return self._s[3790]! } + public var Conversation_ClousStorageInfo_Description3: String { return self._s[3791]! } + public var Wallet_WordCheck_TryAgain: String { return self._s[3792]! } + public var Wallet_Info_TransactionPendingHeader: String { return self._s[3793]! } + public var Settings_ChatBackground: String { return self._s[3794]! } + public var Channel_Subscribers_Title: String { return self._s[3795]! } + public var Wallet_Receive_InvoiceUrlHeader: String { return self._s[3796]! } + public var ApplyLanguage_ChangeLanguageTitle: String { return self._s[3797]! } + public var Watch_ConnectionDescription: String { return self._s[3798]! } + public var OldChannels_NoticeText: String { return self._s[3801]! } + public var Wallet_Configuration_ApplyErrorTitle: String { return self._s[3802]! } + public var IntentsSettings_SuggestBy: String { return self._s[3804]! } + public var Theme_ThemeChangedText: String { return self._s[3805]! } + public var ChatList_ArchivedChatsTitle: String { return self._s[3806]! } + public var Wallpaper_ResetWallpapers: String { return self._s[3807]! } + public var Wallet_Send_TransactionInProgress: String { return self._s[3808]! } + public var EditProfile_Title: String { return self._s[3809]! } + public var NotificationsSound_Bamboo: String { return self._s[3811]! } + public var Channel_AdminLog_MessagePreviousMessage: String { return self._s[3813]! } + public var Login_SmsRequestState2: String { return self._s[3814]! } + public var Passport_Language_ar: String { return self._s[3815]! } public func Message_AuthorPinnedGame(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3815]!, self._r[3815]!, [_0]) + return formatWithArgumentRanges(self._s[3816]!, self._r[3816]!, [_0]) } - public var SettingsSearch_Synonyms_EditProfile_Title: String { return self._s[3816]! } - public var Wallet_Created_Text: String { return self._s[3817]! } - public var Conversation_MessageDialogEdit: String { return self._s[3819]! } - public var Wallet_Created_Proceed: String { return self._s[3820]! } - public var Wallet_Words_Done: String { return self._s[3821]! } - public var VoiceOver_Media_PlaybackPause: String { return self._s[3822]! } + public var SettingsSearch_Synonyms_EditProfile_Title: String { return self._s[3817]! } + public var Wallet_Created_Text: String { return self._s[3818]! } + public var Conversation_MessageDialogEdit: String { return self._s[3820]! } + public var Wallet_Created_Proceed: String { return self._s[3821]! } + public var Wallet_Words_Done: String { return self._s[3822]! } + public var VoiceOver_Media_PlaybackPause: String { return self._s[3823]! } public func PUSH_AUTH_UNKNOWN(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3823]!, self._r[3823]!, [_1]) + return formatWithArgumentRanges(self._s[3824]!, self._r[3824]!, [_1]) } - public var Common_Close: String { return self._s[3824]! } - public var GroupInfo_PublicLink: String { return self._s[3825]! } - public var Channel_OwnershipTransfer_ErrorPrivacyRestricted: String { return self._s[3826]! } - public var SettingsSearch_Synonyms_Notifications_GroupNotificationsPreview: String { return self._s[3827]! } + public var Common_Close: String { return self._s[3825]! } + public var GroupInfo_PublicLink: String { return self._s[3826]! } + public var Channel_OwnershipTransfer_ErrorPrivacyRestricted: String { return self._s[3827]! } + public var SettingsSearch_Synonyms_Notifications_GroupNotificationsPreview: String { return self._s[3828]! } public func Channel_AdminLog_MessageToggleInvitesOff(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3831]!, self._r[3831]!, [_0]) + return formatWithArgumentRanges(self._s[3832]!, self._r[3832]!, [_0]) } - public var UserInfo_About_Placeholder: String { return self._s[3832]! } + public var UserInfo_About_Placeholder: String { return self._s[3833]! } public func Conversation_FileHowToText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3833]!, self._r[3833]!, [_0]) + return formatWithArgumentRanges(self._s[3834]!, self._r[3834]!, [_0]) } - public var GroupInfo_Permissions_SectionTitle: String { return self._s[3834]! } - public var Channel_Info_Banned: String { return self._s[3836]! } + public var GroupInfo_Permissions_SectionTitle: String { return self._s[3835]! } + public var Channel_Info_Banned: String { return self._s[3837]! } public func Time_MonthOfYear_m11(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3837]!, self._r[3837]!, [_0]) + return formatWithArgumentRanges(self._s[3838]!, self._r[3838]!, [_0]) } - public var Appearance_Other: String { return self._s[3838]! } - public var Passport_Language_my: String { return self._s[3839]! } - public var Group_Setup_BasicHistoryHiddenHelp: String { return self._s[3840]! } + public var Appearance_Other: String { return self._s[3839]! } + public var Passport_Language_my: String { return self._s[3840]! } + public var Group_Setup_BasicHistoryHiddenHelp: String { return self._s[3841]! } public func Time_PreciseDate_m9(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3841]!, self._r[3841]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3842]!, self._r[3842]!, [_1, _2, _3]) } - public var SettingsSearch_Synonyms_Privacy_PasscodeAndFaceId: String { return self._s[3842]! } - public var IntentsSettings_SuggestedAndSpotlightChatsInfo: String { return self._s[3843]! } - public var Preview_CopyAddress: String { return self._s[3844]! } + public var SettingsSearch_Synonyms_Privacy_PasscodeAndFaceId: String { return self._s[3843]! } + public var IntentsSettings_SuggestedAndSpotlightChatsInfo: String { return self._s[3844]! } + public var Preview_CopyAddress: String { return self._s[3845]! } public func DialogList_SinglePlayingGameSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3845]!, self._r[3845]!, [_0]) + return formatWithArgumentRanges(self._s[3846]!, self._r[3846]!, [_0]) } - public var KeyCommand_JumpToPreviousChat: String { return self._s[3846]! } - public var UserInfo_BotSettings: String { return self._s[3847]! } - public var LiveLocation_MenuStopAll: String { return self._s[3849]! } - public var Passport_PasswordCreate: String { return self._s[3850]! } - public var StickerSettings_MaskContextInfo: String { return self._s[3851]! } - public var Message_PinnedLocationMessage: String { return self._s[3852]! } - public var Map_Satellite: String { return self._s[3853]! } - public var Watch_Message_Unsupported: String { return self._s[3854]! } - public var Username_TooManyPublicUsernamesError: String { return self._s[3855]! } - public var TwoStepAuth_EnterPasswordInvalid: String { return self._s[3856]! } + public var KeyCommand_JumpToPreviousChat: String { return self._s[3847]! } + public var UserInfo_BotSettings: String { return self._s[3848]! } + public var LiveLocation_MenuStopAll: String { return self._s[3850]! } + public var Passport_PasswordCreate: String { return self._s[3851]! } + public var StickerSettings_MaskContextInfo: String { return self._s[3852]! } + public var Message_PinnedLocationMessage: String { return self._s[3853]! } + public var Map_Satellite: String { return self._s[3854]! } + public var Watch_Message_Unsupported: String { return self._s[3855]! } + public var Username_TooManyPublicUsernamesError: String { return self._s[3856]! } + public var TwoStepAuth_EnterPasswordInvalid: String { return self._s[3857]! } public func Notification_PinnedTextMessage(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3857]!, self._r[3857]!, [_0, _1]) + return formatWithArgumentRanges(self._s[3858]!, self._r[3858]!, [_0, _1]) } public func Conversation_OpenBotLinkText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3858]!, self._r[3858]!, [_0]) + return formatWithArgumentRanges(self._s[3859]!, self._r[3859]!, [_0]) } - public var Wallet_WordImport_Continue: String { return self._s[3859]! } + public var Wallet_WordImport_Continue: String { return self._s[3860]! } public func TwoFactorSetup_EmailVerification_Text(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3860]!, self._r[3860]!, [_0]) + return formatWithArgumentRanges(self._s[3861]!, self._r[3861]!, [_0]) } - public var Notifications_ChannelNotificationsHelp: String { return self._s[3861]! } - public var Privacy_Calls_P2PContacts: String { return self._s[3862]! } - public var NotificationsSound_None: String { return self._s[3863]! } - public var Wallet_TransactionInfo_StorageFeeHeader: String { return self._s[3864]! } - public var Channel_DiscussionGroup_UnlinkGroup: String { return self._s[3866]! } - public var AccessDenied_VoiceMicrophone: String { return self._s[3867]! } + public var Notifications_ChannelNotificationsHelp: String { return self._s[3862]! } + public var Privacy_Calls_P2PContacts: String { return self._s[3863]! } + public var NotificationsSound_None: String { return self._s[3864]! } + public var Wallet_TransactionInfo_StorageFeeHeader: String { return self._s[3865]! } + public var Channel_DiscussionGroup_UnlinkGroup: String { return self._s[3867]! } + public var AccessDenied_VoiceMicrophone: String { return self._s[3868]! } public func ApplyLanguage_ChangeLanguageAlreadyActive(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3868]!, self._r[3868]!, [_1]) + return formatWithArgumentRanges(self._s[3869]!, self._r[3869]!, [_1]) } - public var Cache_Indexing: String { return self._s[3869]! } - public var DialogList_RecentTitlePeople: String { return self._s[3871]! } - public var DialogList_EncryptionRejected: String { return self._s[3872]! } - public var GroupInfo_Administrators: String { return self._s[3873]! } - public var Passport_ScanPassportHelp: String { return self._s[3874]! } - public var Application_Name: String { return self._s[3875]! } - public var Channel_AdminLogFilter_ChannelEventsInfo: String { return self._s[3876]! } - public var PeopleNearby_MakeVisible: String { return self._s[3878]! } - public var Appearance_ThemeCarouselDay: String { return self._s[3879]! } - public var Stats_GrowthTitle: String { return self._s[3880]! } - public var Passport_Identity_TranslationHelp: String { return self._s[3881]! } + public var Cache_Indexing: String { return self._s[3870]! } + public var DialogList_RecentTitlePeople: String { return self._s[3872]! } + public var DialogList_EncryptionRejected: String { return self._s[3873]! } + public var GroupInfo_Administrators: String { return self._s[3874]! } + public var Passport_ScanPassportHelp: String { return self._s[3875]! } + public var Application_Name: String { return self._s[3876]! } + public var Channel_AdminLogFilter_ChannelEventsInfo: String { return self._s[3877]! } + public var PeopleNearby_MakeVisible: String { return self._s[3879]! } + public var Appearance_ThemeCarouselDay: String { return self._s[3880]! } + public var Stats_GrowthTitle: String { return self._s[3881]! } + public var Passport_Identity_TranslationHelp: String { return self._s[3882]! } public func VoiceOver_Chat_VideoMessageFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3882]!, self._r[3882]!, [_0]) - } - public func Notification_JoinedGroupByLink(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[3883]!, self._r[3883]!, [_0]) } - public func DialogList_EncryptedChatStartedOutgoing(_ _0: String) -> (String, [(Int, NSRange)]) { + public func Notification_JoinedGroupByLink(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[3884]!, self._r[3884]!, [_0]) } - public var Channel_EditAdmin_PermissionDeleteMessages: String { return self._s[3885]! } - public var Privacy_ChatsTitle: String { return self._s[3886]! } - public var DialogList_ClearHistoryConfirmation: String { return self._s[3887]! } - public var SettingsSearch_Synonyms_Data_Storage_ClearCache: String { return self._s[3888]! } - public var Watch_Suggestion_HoldOn: String { return self._s[3889]! } - public var Group_EditAdmin_TransferOwnership: String { return self._s[3890]! } - public var WebBrowser_Title: String { return self._s[3891]! } - public var Group_LinkedChannel: String { return self._s[3892]! } - public var VoiceOver_Chat_SeenByRecipient: String { return self._s[3893]! } - public var SocksProxySetup_RequiredCredentials: String { return self._s[3894]! } - public var Passport_Address_TypeRentalAgreementUploadScan: String { return self._s[3895]! } - public var Appearance_TextSize_UseSystem: String { return self._s[3896]! } - public var TwoStepAuth_EmailSkipAlert: String { return self._s[3897]! } - public var ScheduledMessages_RemindersTitle: String { return self._s[3899]! } - public var Channel_Setup_TypePublic: String { return self._s[3901]! } + public func DialogList_EncryptedChatStartedOutgoing(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3885]!, self._r[3885]!, [_0]) + } + public var Channel_EditAdmin_PermissionDeleteMessages: String { return self._s[3886]! } + public var Privacy_ChatsTitle: String { return self._s[3887]! } + public var DialogList_ClearHistoryConfirmation: String { return self._s[3888]! } + public var SettingsSearch_Synonyms_Data_Storage_ClearCache: String { return self._s[3889]! } + public var Watch_Suggestion_HoldOn: String { return self._s[3890]! } + public var Group_EditAdmin_TransferOwnership: String { return self._s[3891]! } + public var WebBrowser_Title: String { return self._s[3892]! } + public var Group_LinkedChannel: String { return self._s[3893]! } + public var VoiceOver_Chat_SeenByRecipient: String { return self._s[3894]! } + public var SocksProxySetup_RequiredCredentials: String { return self._s[3895]! } + public var Passport_Address_TypeRentalAgreementUploadScan: String { return self._s[3896]! } + public var Appearance_TextSize_UseSystem: String { return self._s[3897]! } + public var TwoStepAuth_EmailSkipAlert: String { return self._s[3898]! } + public var ScheduledMessages_RemindersTitle: String { return self._s[3900]! } + public var Channel_Setup_TypePublic: String { return self._s[3902]! } public func Channel_AdminLog_MessageToggleInvitesOn(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3902]!, self._r[3902]!, [_0]) + return formatWithArgumentRanges(self._s[3903]!, self._r[3903]!, [_0]) } - public var Channel_TypeSetup_Title: String { return self._s[3904]! } - public var MessagePoll_ViewResults: String { return self._s[3905]! } - public var Map_OpenInMaps: String { return self._s[3907]! } + public var Channel_TypeSetup_Title: String { return self._s[3905]! } + public var MessagePoll_ViewResults: String { return self._s[3906]! } + public var Map_OpenInMaps: String { return self._s[3908]! } public func PUSH_PINNED_NOTEXT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3908]!, self._r[3908]!, [_1]) + return formatWithArgumentRanges(self._s[3909]!, self._r[3909]!, [_1]) } - public var NotificationsSound_Tremolo: String { return self._s[3910]! } + public var NotificationsSound_Tremolo: String { return self._s[3911]! } public func Date_ChatDateHeaderYear(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3911]!, self._r[3911]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3912]!, self._r[3912]!, [_1, _2, _3]) } - public var ConversationProfile_UnknownAddMemberError: String { return self._s[3912]! } - public var Channel_OwnershipTransfer_PasswordPlaceholder: String { return self._s[3913]! } - public var Passport_PasswordHelp: String { return self._s[3914]! } - public var Login_CodeExpiredError: String { return self._s[3915]! } - public var Channel_EditAdmin_PermissionChangeInfo: String { return self._s[3916]! } - public var Conversation_TitleUnmute: String { return self._s[3917]! } - public var Passport_Identity_ScansHelp: String { return self._s[3918]! } - public var Passport_Language_lo: String { return self._s[3919]! } - public var Camera_FlashAuto: String { return self._s[3920]! } - public var Conversation_OpenBotLinkOpen: String { return self._s[3921]! } - public var Common_Cancel: String { return self._s[3922]! } - public var DialogList_SavedMessagesTooltip: String { return self._s[3923]! } - public var TwoStepAuth_SetupPasswordTitle: String { return self._s[3924]! } - public var Appearance_TintAllColors: String { return self._s[3925]! } + public var ConversationProfile_UnknownAddMemberError: String { return self._s[3913]! } + public var Channel_OwnershipTransfer_PasswordPlaceholder: String { return self._s[3914]! } + public var Passport_PasswordHelp: String { return self._s[3915]! } + public var Login_CodeExpiredError: String { return self._s[3916]! } + public var Channel_EditAdmin_PermissionChangeInfo: String { return self._s[3917]! } + public var Conversation_TitleUnmute: String { return self._s[3918]! } + public var Passport_Identity_ScansHelp: String { return self._s[3919]! } + public var Passport_Language_lo: String { return self._s[3920]! } + public var Camera_FlashAuto: String { return self._s[3921]! } + public var Conversation_OpenBotLinkOpen: String { return self._s[3922]! } + public var Common_Cancel: String { return self._s[3923]! } + public var DialogList_SavedMessagesTooltip: String { return self._s[3924]! } + public var TwoStepAuth_SetupPasswordTitle: String { return self._s[3925]! } + public var Appearance_TintAllColors: String { return self._s[3926]! } public func PUSH_MESSAGE_FWD(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3926]!, self._r[3926]!, [_1]) + return formatWithArgumentRanges(self._s[3927]!, self._r[3927]!, [_1]) } - public var Conversation_ReportSpamConfirmation: String { return self._s[3927]! } - public var ChatSettings_Title: String { return self._s[3929]! } - public var Passport_PasswordReset: String { return self._s[3930]! } - public var SocksProxySetup_TypeNone: String { return self._s[3931]! } - public var EditTheme_Title: String { return self._s[3934]! } - public var PhoneNumberHelp_Help: String { return self._s[3935]! } - public var Checkout_EnterPassword: String { return self._s[3936]! } - public var Activity_UploadingDocument: String { return self._s[3938]! } - public var Share_AuthTitle: String { return self._s[3939]! } - public var State_Connecting: String { return self._s[3940]! } - public var Profile_MessageLifetime1w: String { return self._s[3941]! } - public var Conversation_ContextMenuReport: String { return self._s[3942]! } - public var CheckoutInfo_ReceiverInfoPhone: String { return self._s[3943]! } - public var AutoNightTheme_ScheduledTo: String { return self._s[3944]! } + public var Conversation_ReportSpamConfirmation: String { return self._s[3928]! } + public var ChatSettings_Title: String { return self._s[3930]! } + public var Passport_PasswordReset: String { return self._s[3931]! } + public var SocksProxySetup_TypeNone: String { return self._s[3932]! } + public var EditTheme_Title: String { return self._s[3935]! } + public var PhoneNumberHelp_Help: String { return self._s[3936]! } + public var Checkout_EnterPassword: String { return self._s[3937]! } + public var Activity_UploadingDocument: String { return self._s[3939]! } + public var Share_AuthTitle: String { return self._s[3940]! } + public var State_Connecting: String { return self._s[3941]! } + public var Profile_MessageLifetime1w: String { return self._s[3942]! } + public var Conversation_ContextMenuReport: String { return self._s[3943]! } + public var CheckoutInfo_ReceiverInfoPhone: String { return self._s[3944]! } + public var AutoNightTheme_ScheduledTo: String { return self._s[3945]! } public func VoiceOver_Chat_AnonymousPollFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3945]!, self._r[3945]!, [_0]) + return formatWithArgumentRanges(self._s[3946]!, self._r[3946]!, [_0]) } - public var AuthSessions_Terminate: String { return self._s[3946]! } - public var Wallet_WordImport_CanNotRemember: String { return self._s[3947]! } - public var PeerInfo_PaneAudio: String { return self._s[3948]! } - public var Checkout_NewCard_CardholderNamePlaceholder: String { return self._s[3950]! } - public var KeyCommand_JumpToPreviousUnreadChat: String { return self._s[3951]! } - public var PhotoEditor_Set: String { return self._s[3952]! } - public var EmptyGroupInfo_Title: String { return self._s[3953]! } - public var Login_PadPhoneHelp: String { return self._s[3954]! } - public var AutoDownloadSettings_TypeGroupChats: String { return self._s[3956]! } - public var PrivacyPolicy_DeclineLastWarning: String { return self._s[3958]! } - public var NotificationsSound_Complete: String { return self._s[3959]! } - public var SettingsSearch_Synonyms_Privacy_Data_Title: String { return self._s[3960]! } - public var Group_Info_AdminLog: String { return self._s[3961]! } - public var GroupPermission_NotAvailableInPublicGroups: String { return self._s[3962]! } + public var AuthSessions_Terminate: String { return self._s[3947]! } + public var Wallet_WordImport_CanNotRemember: String { return self._s[3948]! } + public var PeerInfo_PaneAudio: String { return self._s[3949]! } + public var Checkout_NewCard_CardholderNamePlaceholder: String { return self._s[3951]! } + public var KeyCommand_JumpToPreviousUnreadChat: String { return self._s[3952]! } + public var PhotoEditor_Set: String { return self._s[3953]! } + public var EmptyGroupInfo_Title: String { return self._s[3954]! } + public var Login_PadPhoneHelp: String { return self._s[3955]! } + public var AutoDownloadSettings_TypeGroupChats: String { return self._s[3957]! } + public var PrivacyPolicy_DeclineLastWarning: String { return self._s[3959]! } + public var NotificationsSound_Complete: String { return self._s[3960]! } + public var SettingsSearch_Synonyms_Privacy_Data_Title: String { return self._s[3961]! } + public var Group_Info_AdminLog: String { return self._s[3962]! } + public var GroupPermission_NotAvailableInPublicGroups: String { return self._s[3963]! } public func Wallet_Time_PreciseDate_m11(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3963]!, self._r[3963]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3964]!, self._r[3964]!, [_1, _2, _3]) } - public var Channel_AdminLog_InfoPanelAlertText: String { return self._s[3964]! } - public var Group_Location_CreateInThisPlace: String { return self._s[3966]! } - public var Conversation_Admin: String { return self._s[3967]! } - public var Conversation_GifTooltip: String { return self._s[3968]! } - public var Passport_NotLoggedInMessage: String { return self._s[3969]! } + public var Channel_AdminLog_InfoPanelAlertText: String { return self._s[3965]! } + public var Group_Location_CreateInThisPlace: String { return self._s[3967]! } + public var Conversation_Admin: String { return self._s[3968]! } + public var Conversation_GifTooltip: String { return self._s[3969]! } + public var Passport_NotLoggedInMessage: String { return self._s[3970]! } public func AutoDownloadSettings_OnFor(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3971]!, self._r[3971]!, [_0]) + return formatWithArgumentRanges(self._s[3972]!, self._r[3972]!, [_0]) } - public var Profile_MessageLifetimeForever: String { return self._s[3972]! } - public var SharedMedia_EmptyTitle: String { return self._s[3974]! } - public var Channel_Edit_PrivatePublicLinkAlert: String { return self._s[3976]! } - public var Username_Help: String { return self._s[3977]! } - public var DialogList_LanguageTooltip: String { return self._s[3979]! } - public var Map_LoadError: String { return self._s[3980]! } - public var Login_PhoneNumberAlreadyAuthorized: String { return self._s[3981]! } - public var Channel_AdminLog_AddMembers: String { return self._s[3982]! } - public var ArchivedChats_IntroTitle2: String { return self._s[3983]! } - public var Notification_Exceptions_NewException: String { return self._s[3984]! } - public var TwoStepAuth_EmailTitle: String { return self._s[3985]! } - public var WatchRemote_AlertText: String { return self._s[3986]! } + public var Profile_MessageLifetimeForever: String { return self._s[3973]! } + public var SharedMedia_EmptyTitle: String { return self._s[3975]! } + public var Channel_Edit_PrivatePublicLinkAlert: String { return self._s[3977]! } + public var Username_Help: String { return self._s[3978]! } + public var DialogList_LanguageTooltip: String { return self._s[3980]! } + public var Map_LoadError: String { return self._s[3981]! } + public var Login_PhoneNumberAlreadyAuthorized: String { return self._s[3982]! } + public var Channel_AdminLog_AddMembers: String { return self._s[3983]! } + public var ArchivedChats_IntroTitle2: String { return self._s[3984]! } + public var Notification_Exceptions_NewException: String { return self._s[3985]! } + public var TwoStepAuth_EmailTitle: String { return self._s[3986]! } + public var WatchRemote_AlertText: String { return self._s[3987]! } public func Wallet_Send_ConfirmationText(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3987]!, self._r[3987]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3988]!, self._r[3988]!, [_1, _2, _3]) } - public var ChatSettings_ConnectionType_Title: String { return self._s[3991]! } + public var ChatSettings_ConnectionType_Title: String { return self._s[3992]! } public func PUSH_PINNED_QUIZ(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3992]!, self._r[3992]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3993]!, self._r[3993]!, [_1, _2]) } public func Settings_CheckPhoneNumberTitle(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3993]!, self._r[3993]!, [_0]) + return formatWithArgumentRanges(self._s[3994]!, self._r[3994]!, [_0]) } - public var SettingsSearch_Synonyms_Calls_CallTab: String { return self._s[3994]! } - public var WebBrowser_DefaultBrowser: String { return self._s[3995]! } - public var Passport_Address_CountryPlaceholder: String { return self._s[3996]! } + public var SettingsSearch_Synonyms_Calls_CallTab: String { return self._s[3995]! } + public var WebBrowser_DefaultBrowser: String { return self._s[3996]! } + public var Passport_Address_CountryPlaceholder: String { return self._s[3997]! } public func DialogList_AwaitingEncryption(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3997]!, self._r[3997]!, [_0]) + return formatWithArgumentRanges(self._s[3998]!, self._r[3998]!, [_0]) } public func Time_PreciseDate_m6(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3998]!, self._r[3998]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3999]!, self._r[3999]!, [_1, _2, _3]) } - public var Group_AdminLog_EmptyText: String { return self._s[3999]! } - public var SettingsSearch_Synonyms_Appearance_Title: String { return self._s[4000]! } - public var Conversation_PrivateChannelTooltip: String { return self._s[4002]! } - public var Wallet_Created_ExportErrorText: String { return self._s[4003]! } - public var ChatList_UndoArchiveText1: String { return self._s[4004]! } - public var AccessDenied_VideoMicrophone: String { return self._s[4005]! } - public var Conversation_ContextMenuStickerPackAdd: String { return self._s[4006]! } - public var Cache_ClearNone: String { return self._s[4007]! } - public var SocksProxySetup_FailedToConnect: String { return self._s[4008]! } - public var Permissions_NotificationsTitle_v0: String { return self._s[4009]! } + public var Group_AdminLog_EmptyText: String { return self._s[4000]! } + public var SettingsSearch_Synonyms_Appearance_Title: String { return self._s[4001]! } + public var Conversation_PrivateChannelTooltip: String { return self._s[4003]! } + public var Wallet_Created_ExportErrorText: String { return self._s[4004]! } + public var ChatList_UndoArchiveText1: String { return self._s[4005]! } + public var AccessDenied_VideoMicrophone: String { return self._s[4006]! } + public var Conversation_ContextMenuStickerPackAdd: String { return self._s[4007]! } + public var Cache_ClearNone: String { return self._s[4008]! } + public var SocksProxySetup_FailedToConnect: String { return self._s[4009]! } + public var Permissions_NotificationsTitle_v0: String { return self._s[4010]! } public func Channel_AdminLog_MessageEdited(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4010]!, self._r[4010]!, [_0]) + return formatWithArgumentRanges(self._s[4011]!, self._r[4011]!, [_0]) } - public var Passport_Identity_Country: String { return self._s[4011]! } + public var Passport_Identity_Country: String { return self._s[4012]! } public func ChatSettings_AutoDownloadSettings_TypeFile(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4012]!, self._r[4012]!, [_0]) - } - public func Notification_CreatedChat(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[4013]!, self._r[4013]!, [_0]) } - public var Exceptions_AddToExceptions: String { return self._s[4014]! } - public var AccessDenied_Settings: String { return self._s[4015]! } - public var Passport_Address_TypeUtilityBillUploadScan: String { return self._s[4016]! } - public var Month_ShortMay: String { return self._s[4017]! } - public var Compose_NewGroup: String { return self._s[4019]! } - public var Group_Setup_TypePrivate: String { return self._s[4021]! } - public var Login_PadPhoneHelpTitle: String { return self._s[4023]! } - public var Appearance_ThemeDayClassic: String { return self._s[4024]! } - public var Channel_AdminLog_MessagePreviousCaption: String { return self._s[4025]! } - public var AutoDownloadSettings_OffForAll: String { return self._s[4026]! } - public var Privacy_GroupsAndChannels_WhoCanAddMe: String { return self._s[4027]! } - public var Conversation_typing: String { return self._s[4029]! } - public var Undo_ScheduledMessagesCleared: String { return self._s[4030]! } - public var Paint_Masks: String { return self._s[4031]! } - public var Contacts_DeselectAll: String { return self._s[4032]! } - public func Wallet_Updated_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4033]!, self._r[4033]!, [_0]) + public func Notification_CreatedChat(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[4014]!, self._r[4014]!, [_0]) } - public var CreatePoll_MultipleChoiceQuizAlert: String { return self._s[4034]! } - public var Username_InvalidTaken: String { return self._s[4035]! } - public var Call_StatusNoAnswer: String { return self._s[4036]! } - public var TwoStepAuth_EmailAddSuccess: String { return self._s[4037]! } - public var SettingsSearch_Synonyms_Privacy_BlockedUsers: String { return self._s[4038]! } - public var Passport_Identity_Selfie: String { return self._s[4039]! } - public var Login_InfoLastNamePlaceholder: String { return self._s[4040]! } - public var Privacy_SecretChatsLinkPreviewsHelp: String { return self._s[4041]! } - public var Conversation_ClearSecretHistory: String { return self._s[4042]! } - public var PeopleNearby_Description: String { return self._s[4044]! } - public var NetworkUsageSettings_Title: String { return self._s[4045]! } - public var Your_cards_security_code_is_invalid: String { return self._s[4047]! } - public var Stats_EnabledNotifications: String { return self._s[4048]! } + public var Exceptions_AddToExceptions: String { return self._s[4015]! } + public var AccessDenied_Settings: String { return self._s[4016]! } + public var Passport_Address_TypeUtilityBillUploadScan: String { return self._s[4017]! } + public var Month_ShortMay: String { return self._s[4018]! } + public var Compose_NewGroup: String { return self._s[4020]! } + public var Group_Setup_TypePrivate: String { return self._s[4022]! } + public var Login_PadPhoneHelpTitle: String { return self._s[4024]! } + public var Appearance_ThemeDayClassic: String { return self._s[4025]! } + public var Channel_AdminLog_MessagePreviousCaption: String { return self._s[4026]! } + public var AutoDownloadSettings_OffForAll: String { return self._s[4027]! } + public var Privacy_GroupsAndChannels_WhoCanAddMe: String { return self._s[4028]! } + public var Conversation_typing: String { return self._s[4030]! } + public var Undo_ScheduledMessagesCleared: String { return self._s[4031]! } + public var Paint_Masks: String { return self._s[4032]! } + public var Contacts_DeselectAll: String { return self._s[4033]! } + public func Wallet_Updated_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[4034]!, self._r[4034]!, [_0]) + } + public var CreatePoll_MultipleChoiceQuizAlert: String { return self._s[4035]! } + public var Username_InvalidTaken: String { return self._s[4036]! } + public var Call_StatusNoAnswer: String { return self._s[4037]! } + public var TwoStepAuth_EmailAddSuccess: String { return self._s[4038]! } + public var SettingsSearch_Synonyms_Privacy_BlockedUsers: String { return self._s[4039]! } + public var Passport_Identity_Selfie: String { return self._s[4040]! } + public var Login_InfoLastNamePlaceholder: String { return self._s[4041]! } + public var Privacy_SecretChatsLinkPreviewsHelp: String { return self._s[4042]! } + public var Conversation_ClearSecretHistory: String { return self._s[4043]! } + public var PeopleNearby_Description: String { return self._s[4045]! } + public var NetworkUsageSettings_Title: String { return self._s[4046]! } + public var Your_cards_security_code_is_invalid: String { return self._s[4048]! } + public var Stats_EnabledNotifications: String { return self._s[4049]! } public func Notification_LeftChannel(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4050]!, self._r[4050]!, [_0]) + return formatWithArgumentRanges(self._s[4051]!, self._r[4051]!, [_0]) } public func Call_CallInProgressMessage(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4051]!, self._r[4051]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4052]!, self._r[4052]!, [_1, _2]) } - public var SaveIncomingPhotosSettings_From: String { return self._s[4053]! } - public var VoiceOver_Navigation_Search: String { return self._s[4054]! } - public var Map_LiveLocationTitle: String { return self._s[4055]! } - public var Login_InfoAvatarAdd: String { return self._s[4056]! } - public var Passport_Identity_FilesView: String { return self._s[4057]! } - public var UserInfo_GenericPhoneLabel: String { return self._s[4058]! } - public var Privacy_Calls_NeverAllow: String { return self._s[4059]! } - public var VoiceOver_Chat_File: String { return self._s[4060]! } - public var Wallet_Settings_DeleteWalletInfo: String { return self._s[4061]! } + public var SaveIncomingPhotosSettings_From: String { return self._s[4054]! } + public var VoiceOver_Navigation_Search: String { return self._s[4055]! } + public var Map_LiveLocationTitle: String { return self._s[4056]! } + public var Login_InfoAvatarAdd: String { return self._s[4057]! } + public var Passport_Identity_FilesView: String { return self._s[4058]! } + public var UserInfo_GenericPhoneLabel: String { return self._s[4059]! } + public var Privacy_Calls_NeverAllow: String { return self._s[4060]! } + public var VoiceOver_Chat_File: String { return self._s[4061]! } + public var Wallet_Settings_DeleteWalletInfo: String { return self._s[4062]! } public func Contacts_AddPhoneNumber(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4062]!, self._r[4062]!, [_0]) + return formatWithArgumentRanges(self._s[4063]!, self._r[4063]!, [_0]) } - public var ChatList_EmptyChatList: String { return self._s[4063]! } - public var ContactInfo_PhoneNumberHidden: String { return self._s[4064]! } - public var TwoStepAuth_ConfirmationText: String { return self._s[4065]! } - public var ChatSettings_AutomaticVideoMessageDownload: String { return self._s[4066]! } + public var ChatList_EmptyChatList: String { return self._s[4064]! } + public var ContactInfo_PhoneNumberHidden: String { return self._s[4065]! } + public var TwoStepAuth_ConfirmationText: String { return self._s[4066]! } + public var ChatSettings_AutomaticVideoMessageDownload: String { return self._s[4067]! } public func PUSH_CHAT_MESSAGE_VIDEOS(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4067]!, self._r[4067]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[4068]!, self._r[4068]!, [_1, _2, _3]) } - public var Channel_AdminLogFilter_AdminsAll: String { return self._s[4068]! } - public var Wallet_Intro_CreateErrorText: String { return self._s[4069]! } - public var Tour_Title2: String { return self._s[4070]! } - public var Wallet_Sent_ViewWallet: String { return self._s[4071]! } - public var Conversation_FileOpenIn: String { return self._s[4072]! } - public var Checkout_ErrorPrecheckoutFailed: String { return self._s[4073]! } - public var Wallet_Send_ErrorInvalidAddress: String { return self._s[4074]! } - public var Wallpaper_Set: String { return self._s[4075]! } - public var Passport_Identity_Translations: String { return self._s[4077]! } + public var Channel_AdminLogFilter_AdminsAll: String { return self._s[4069]! } + public var Wallet_Intro_CreateErrorText: String { return self._s[4070]! } + public var Tour_Title2: String { return self._s[4071]! } + public var Wallet_Sent_ViewWallet: String { return self._s[4072]! } + public var Conversation_FileOpenIn: String { return self._s[4073]! } + public var Checkout_ErrorPrecheckoutFailed: String { return self._s[4074]! } + public var Wallet_Send_ErrorInvalidAddress: String { return self._s[4075]! } + public var Wallpaper_Set: String { return self._s[4076]! } + public var Passport_Identity_Translations: String { return self._s[4078]! } public func Channel_AdminLog_MessageChangedChannelAbout(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4078]!, self._r[4078]!, [_0]) + return formatWithArgumentRanges(self._s[4079]!, self._r[4079]!, [_0]) } - public var Channel_LeaveChannel: String { return self._s[4079]! } + public var Channel_LeaveChannel: String { return self._s[4080]! } public func PINNED_INVOICE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4080]!, self._r[4080]!, [_1]) + return formatWithArgumentRanges(self._s[4081]!, self._r[4081]!, [_1]) } - public var SettingsSearch_Synonyms_Proxy_AddProxy: String { return self._s[4082]! } - public var PhotoEditor_HighlightsTint: String { return self._s[4083]! } - public var MessagePoll_LabelPoll: String { return self._s[4084]! } - public var Passport_Email_Delete: String { return self._s[4085]! } - public var Conversation_Mute: String { return self._s[4087]! } - public var Channel_AddBotAsAdmin: String { return self._s[4088]! } - public var Channel_AdminLog_CanSendMessages: String { return self._s[4090]! } - public var Wallet_Configuration_BlockchainNameChangedText: String { return self._s[4091]! } - public var ChatSettings_IntentsSettings: String { return self._s[4093]! } - public var Channel_Management_LabelOwner: String { return self._s[4094]! } + public var SettingsSearch_Synonyms_Proxy_AddProxy: String { return self._s[4083]! } + public var PhotoEditor_HighlightsTint: String { return self._s[4084]! } + public var MessagePoll_LabelPoll: String { return self._s[4085]! } + public var Passport_Email_Delete: String { return self._s[4086]! } + public var Conversation_Mute: String { return self._s[4088]! } + public var Channel_AddBotAsAdmin: String { return self._s[4089]! } + public var Channel_AdminLog_CanSendMessages: String { return self._s[4091]! } + public var Wallet_Configuration_BlockchainNameChangedText: String { return self._s[4092]! } + public var ChatSettings_IntentsSettings: String { return self._s[4094]! } + public var Channel_Management_LabelOwner: String { return self._s[4095]! } public func Notification_PassportValuesSentMessage(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4095]!, self._r[4095]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4096]!, self._r[4096]!, [_1, _2]) } - public var Calls_CallTabDescription: String { return self._s[4096]! } - public var Passport_Identity_NativeNameHelp: String { return self._s[4097]! } - public var Common_No: String { return self._s[4098]! } - public var Weekday_Sunday: String { return self._s[4099]! } - public var Notification_Reply: String { return self._s[4100]! } - public var Conversation_ViewMessage: String { return self._s[4101]! } + public var Calls_CallTabDescription: String { return self._s[4097]! } + public var Passport_Identity_NativeNameHelp: String { return self._s[4098]! } + public var Common_No: String { return self._s[4099]! } + public var Weekday_Sunday: String { return self._s[4100]! } + public var Notification_Reply: String { return self._s[4101]! } + public var Conversation_ViewMessage: String { return self._s[4102]! } public func Checkout_SavePasswordTimeoutAndFaceId(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4102]!, self._r[4102]!, [_0]) - } - public func Map_LiveLocationPrivateDescription(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[4103]!, self._r[4103]!, [_0]) } + public func Map_LiveLocationPrivateDescription(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[4104]!, self._r[4104]!, [_0]) + } public func Wallet_Time_PreciseDate_m7(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4104]!, self._r[4104]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[4105]!, self._r[4105]!, [_1, _2, _3]) } - public var SettingsSearch_Synonyms_EditProfile_AddAccount: String { return self._s[4105]! } - public var Wallet_Send_Title: String { return self._s[4106]! } - public var Message_PinnedDocumentMessage: String { return self._s[4107]! } - public var Wallet_Info_RefreshErrorText: String { return self._s[4108]! } - public var DialogList_TabTitle: String { return self._s[4110]! } - public var ChatSettings_AutoPlayTitle: String { return self._s[4111]! } - public var Passport_FieldEmail: String { return self._s[4112]! } - public var Conversation_UnpinMessageAlert: String { return self._s[4113]! } - public var Passport_Address_TypeBankStatement: String { return self._s[4114]! } - public var Wallet_SecureStorageReset_Title: String { return self._s[4115]! } - public var Passport_Identity_ExpiryDate: String { return self._s[4116]! } - public var Privacy_Calls_P2P: String { return self._s[4117]! } + public var SettingsSearch_Synonyms_EditProfile_AddAccount: String { return self._s[4106]! } + public var Wallet_Send_Title: String { return self._s[4107]! } + public var Message_PinnedDocumentMessage: String { return self._s[4108]! } + public var Wallet_Info_RefreshErrorText: String { return self._s[4109]! } + public var DialogList_TabTitle: String { return self._s[4111]! } + public var ChatSettings_AutoPlayTitle: String { return self._s[4112]! } + public var Passport_FieldEmail: String { return self._s[4113]! } + public var Conversation_UnpinMessageAlert: String { return self._s[4114]! } + public var Passport_Address_TypeBankStatement: String { return self._s[4115]! } + public var Wallet_SecureStorageReset_Title: String { return self._s[4116]! } + public var Passport_Identity_ExpiryDate: String { return self._s[4117]! } + public var Privacy_Calls_P2P: String { return self._s[4118]! } public func CancelResetAccount_Success(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4119]!, self._r[4119]!, [_0]) + return formatWithArgumentRanges(self._s[4120]!, self._r[4120]!, [_0]) } - public var SocksProxySetup_UseForCallsHelp: String { return self._s[4120]! } + public var SocksProxySetup_UseForCallsHelp: String { return self._s[4121]! } public func PUSH_CHAT_ALBUM(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4121]!, self._r[4121]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4122]!, self._r[4122]!, [_1, _2]) } - public var Stickers_ClearRecent: String { return self._s[4122]! } - public var EnterPasscode_ChangeTitle: String { return self._s[4123]! } - public var TwoFactorSetup_Email_Title: String { return self._s[4124]! } - public var Passport_InfoText: String { return self._s[4125]! } - public var Checkout_NewCard_SaveInfoEnableHelp: String { return self._s[4126]! } + public var Stickers_ClearRecent: String { return self._s[4123]! } + public var EnterPasscode_ChangeTitle: String { return self._s[4124]! } + public var TwoFactorSetup_Email_Title: String { return self._s[4125]! } + public var Passport_InfoText: String { return self._s[4126]! } + public var Checkout_NewCard_SaveInfoEnableHelp: String { return self._s[4127]! } public func Login_InvalidPhoneEmailSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4127]!, self._r[4127]!, [_0]) + return formatWithArgumentRanges(self._s[4128]!, self._r[4128]!, [_0]) } public func Time_PreciseDate_m3(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4128]!, self._r[4128]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[4129]!, self._r[4129]!, [_1, _2, _3]) } - public var SettingsSearch_Synonyms_Notifications_BadgeIncludeMutedChannels: String { return self._s[4129]! } - public var ScheduledMessages_PollUnavailable: String { return self._s[4130]! } - public var VoiceOver_Navigation_Compose: String { return self._s[4131]! } - public var Passport_Identity_EditDriversLicense: String { return self._s[4132]! } - public var Conversation_TapAndHoldToRecord: String { return self._s[4134]! } - public var SettingsSearch_Synonyms_Notifications_BadgeIncludeMutedChats: String { return self._s[4135]! } + public var SettingsSearch_Synonyms_Notifications_BadgeIncludeMutedChannels: String { return self._s[4130]! } + public var ScheduledMessages_PollUnavailable: String { return self._s[4131]! } + public var VoiceOver_Navigation_Compose: String { return self._s[4132]! } + public var Passport_Identity_EditDriversLicense: String { return self._s[4133]! } + public var Conversation_TapAndHoldToRecord: String { return self._s[4135]! } + public var SettingsSearch_Synonyms_Notifications_BadgeIncludeMutedChats: String { return self._s[4136]! } public func Notification_CallTimeFormat(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4136]!, self._r[4136]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4137]!, self._r[4137]!, [_1, _2]) } - public var Channel_EditAdmin_PermissionInviteViaLink: String { return self._s[4139]! } - public var ChatSettings_OpenLinksIn: String { return self._s[4140]! } - public var Map_HomeAndWorkTitle: String { return self._s[4141]! } + public var Channel_EditAdmin_PermissionInviteViaLink: String { return self._s[4140]! } + public var ChatSettings_OpenLinksIn: String { return self._s[4141]! } + public var Map_HomeAndWorkTitle: String { return self._s[4142]! } public func Generic_OpenHiddenLinkAlert(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4143]!, self._r[4143]!, [_0]) + return formatWithArgumentRanges(self._s[4144]!, self._r[4144]!, [_0]) } - public var DialogList_Unread: String { return self._s[4144]! } + public var DialogList_Unread: String { return self._s[4145]! } public func PUSH_CHAT_MESSAGE_GIF(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4145]!, self._r[4145]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4146]!, self._r[4146]!, [_1, _2]) } - public var User_DeletedAccount: String { return self._s[4146]! } - public var OwnershipTransfer_SetupTwoStepAuth: String { return self._s[4147]! } + public var User_DeletedAccount: String { return self._s[4147]! } + public var OwnershipTransfer_SetupTwoStepAuth: String { return self._s[4148]! } public func Watch_Time_ShortYesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4148]!, self._r[4148]!, [_0]) + return formatWithArgumentRanges(self._s[4149]!, self._r[4149]!, [_0]) } - public var UserInfo_NotificationsDefault: String { return self._s[4149]! } - public var SharedMedia_CategoryMedia: String { return self._s[4150]! } - public var SocksProxySetup_ProxyStatusUnavailable: String { return self._s[4151]! } - public var Channel_AdminLog_MessageRestrictedForever: String { return self._s[4152]! } - public var Watch_ChatList_Compose: String { return self._s[4153]! } - public var Notifications_MessageNotificationsExceptionsHelp: String { return self._s[4154]! } - public var AutoDownloadSettings_Delimeter: String { return self._s[4155]! } - public var Watch_Microphone_Access: String { return self._s[4156]! } - public var Group_Setup_HistoryHeader: String { return self._s[4157]! } - public var Map_SetThisLocation: String { return self._s[4158]! } - public var Appearance_ThemePreview_Chat_2_ReplyName: String { return self._s[4159]! } - public var Activity_UploadingPhoto: String { return self._s[4160]! } - public var Conversation_Edit: String { return self._s[4162]! } - public var Group_ErrorSendRestrictedMedia: String { return self._s[4163]! } - public var Login_TermsOfServiceDecline: String { return self._s[4164]! } - public var Message_PinnedContactMessage: String { return self._s[4165]! } + public var UserInfo_NotificationsDefault: String { return self._s[4150]! } + public var SharedMedia_CategoryMedia: String { return self._s[4151]! } + public var SocksProxySetup_ProxyStatusUnavailable: String { return self._s[4152]! } + public var Channel_AdminLog_MessageRestrictedForever: String { return self._s[4153]! } + public var Watch_ChatList_Compose: String { return self._s[4154]! } + public var Notifications_MessageNotificationsExceptionsHelp: String { return self._s[4155]! } + public var AutoDownloadSettings_Delimeter: String { return self._s[4156]! } + public var Watch_Microphone_Access: String { return self._s[4157]! } + public var Group_Setup_HistoryHeader: String { return self._s[4158]! } + public var Map_SetThisLocation: String { return self._s[4159]! } + public var Appearance_ThemePreview_Chat_2_ReplyName: String { return self._s[4160]! } + public var Activity_UploadingPhoto: String { return self._s[4161]! } + public var Conversation_Edit: String { return self._s[4163]! } + public var Group_ErrorSendRestrictedMedia: String { return self._s[4164]! } + public var Login_TermsOfServiceDecline: String { return self._s[4165]! } + public var Message_PinnedContactMessage: String { return self._s[4166]! } public func Channel_AdminLog_MessageRestrictedNameUsername(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4166]!, self._r[4166]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4167]!, self._r[4167]!, [_1, _2]) } public func Login_PhoneBannedEmailBody(_ _1: String, _ _2: String, _ _3: String, _ _4: String, _ _5: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4167]!, self._r[4167]!, [_1, _2, _3, _4, _5]) + return formatWithArgumentRanges(self._s[4168]!, self._r[4168]!, [_1, _2, _3, _4, _5]) } - public var Appearance_LargeEmoji: String { return self._s[4168]! } - public var TwoStepAuth_AdditionalPassword: String { return self._s[4170]! } - public var EditTheme_Edit_Preview_IncomingReplyText: String { return self._s[4171]! } + public var Appearance_LargeEmoji: String { return self._s[4169]! } + public var TwoStepAuth_AdditionalPassword: String { return self._s[4171]! } + public var EditTheme_Edit_Preview_IncomingReplyText: String { return self._s[4172]! } public func PUSH_CHAT_DELETE_YOU(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4172]!, self._r[4172]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4173]!, self._r[4173]!, [_1, _2]) } - public var Passport_Phone_EnterOtherNumber: String { return self._s[4173]! } - public var Message_PinnedPhotoMessage: String { return self._s[4174]! } - public var Passport_FieldPhone: String { return self._s[4175]! } - public var TwoStepAuth_RecoveryEmailAddDescription: String { return self._s[4176]! } - public var Stats_NotificationsTitle: String { return self._s[4177]! } - public var ChatSettings_AutoPlayGifs: String { return self._s[4178]! } - public var InfoPlist_NSCameraUsageDescription: String { return self._s[4180]! } - public var Conversation_Call: String { return self._s[4181]! } - public var Common_TakePhoto: String { return self._s[4183]! } - public var Group_EditAdmin_RankTitle: String { return self._s[4184]! } - public var Wallet_Receive_CommentHeader: String { return self._s[4185]! } - public var Channel_NotificationLoading: String { return self._s[4186]! } + public var Passport_Phone_EnterOtherNumber: String { return self._s[4174]! } + public var Message_PinnedPhotoMessage: String { return self._s[4175]! } + public var Passport_FieldPhone: String { return self._s[4176]! } + public var TwoStepAuth_RecoveryEmailAddDescription: String { return self._s[4177]! } + public var Stats_NotificationsTitle: String { return self._s[4178]! } + public var ChatSettings_AutoPlayGifs: String { return self._s[4179]! } + public var InfoPlist_NSCameraUsageDescription: String { return self._s[4181]! } + public var Conversation_Call: String { return self._s[4182]! } + public var Common_TakePhoto: String { return self._s[4184]! } + public var Group_EditAdmin_RankTitle: String { return self._s[4185]! } + public var Wallet_Receive_CommentHeader: String { return self._s[4186]! } + public var Channel_NotificationLoading: String { return self._s[4187]! } public func Notification_Exceptions_Sound(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4187]!, self._r[4187]!, [_0]) - } - public func ScheduledMessages_ScheduledDate(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[4188]!, self._r[4188]!, [_0]) } + public func ScheduledMessages_ScheduledDate(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[4189]!, self._r[4189]!, [_0]) + } public func PUSH_CHANNEL_MESSAGE_VIDEO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4189]!, self._r[4189]!, [_1]) + return formatWithArgumentRanges(self._s[4190]!, self._r[4190]!, [_1]) } - public var Permissions_SiriTitle_v0: String { return self._s[4190]! } + public var Permissions_SiriTitle_v0: String { return self._s[4191]! } public func VoiceOver_Chat_VoiceMessageFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4191]!, self._r[4191]!, [_0]) - } - public func Login_ResetAccountProtected_Text(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[4192]!, self._r[4192]!, [_0]) } - public var Channel_MessagePhotoRemoved: String { return self._s[4193]! } - public var Wallet_Info_ReceiveGrams: String { return self._s[4194]! } - public var ClearCache_FreeSpace: String { return self._s[4195]! } - public var Appearance_BubbleCorners_Apply: String { return self._s[4196]! } - public var Common_edit: String { return self._s[4197]! } - public var PrivacySettings_AuthSessions: String { return self._s[4198]! } - public var Month_ShortJune: String { return self._s[4199]! } - public var PrivacyLastSeenSettings_AlwaysShareWith_Placeholder: String { return self._s[4200]! } - public var Call_ReportSend: String { return self._s[4201]! } - public var Watch_LastSeen_JustNow: String { return self._s[4202]! } - public var Notifications_MessageNotifications: String { return self._s[4203]! } - public var WallpaperSearch_ColorGreen: String { return self._s[4204]! } - public var BroadcastListInfo_AddRecipient: String { return self._s[4206]! } - public var Group_Status: String { return self._s[4207]! } + public func Login_ResetAccountProtected_Text(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[4193]!, self._r[4193]!, [_0]) + } + public var Channel_MessagePhotoRemoved: String { return self._s[4194]! } + public var Wallet_Info_ReceiveGrams: String { return self._s[4195]! } + public var ClearCache_FreeSpace: String { return self._s[4196]! } + public var Appearance_BubbleCorners_Apply: String { return self._s[4197]! } + public var Common_edit: String { return self._s[4198]! } + public var PrivacySettings_AuthSessions: String { return self._s[4199]! } + public var Month_ShortJune: String { return self._s[4200]! } + public var PrivacyLastSeenSettings_AlwaysShareWith_Placeholder: String { return self._s[4201]! } + public var Call_ReportSend: String { return self._s[4202]! } + public var Watch_LastSeen_JustNow: String { return self._s[4203]! } + public var Notifications_MessageNotifications: String { return self._s[4204]! } + public var WallpaperSearch_ColorGreen: String { return self._s[4205]! } + public var BroadcastListInfo_AddRecipient: String { return self._s[4207]! } + public var Group_Status: String { return self._s[4208]! } public func AutoNightTheme_LocationHelp(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4208]!, self._r[4208]!, [_0, _1]) + return formatWithArgumentRanges(self._s[4209]!, self._r[4209]!, [_0, _1]) } - public var TextFormat_AddLinkTitle: String { return self._s[4209]! } - public var ShareMenu_ShareTo: String { return self._s[4210]! } - public var Conversation_Moderate_Ban: String { return self._s[4211]! } + public var TextFormat_AddLinkTitle: String { return self._s[4210]! } + public var ShareMenu_ShareTo: String { return self._s[4211]! } + public var Conversation_Moderate_Ban: String { return self._s[4212]! } public func Conversation_DeleteMessagesFor(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4212]!, self._r[4212]!, [_0]) + return formatWithArgumentRanges(self._s[4213]!, self._r[4213]!, [_0]) } - public var SharedMedia_ViewInChat: String { return self._s[4213]! } - public var Map_LiveLocationFor8Hours: String { return self._s[4214]! } + public var SharedMedia_ViewInChat: String { return self._s[4214]! } + public var Map_LiveLocationFor8Hours: String { return self._s[4215]! } public func PUSH_PINNED_PHOTO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4215]!, self._r[4215]!, [_1]) + return formatWithArgumentRanges(self._s[4216]!, self._r[4216]!, [_1]) } public func PUSH_PINNED_POLL(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4216]!, self._r[4216]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4217]!, self._r[4217]!, [_1, _2]) } public func Map_AccurateTo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4218]!, self._r[4218]!, [_0]) + return formatWithArgumentRanges(self._s[4219]!, self._r[4219]!, [_0]) } - public var Map_OpenInHereMaps: String { return self._s[4219]! } - public var Appearance_ReduceMotion: String { return self._s[4220]! } + public var Map_OpenInHereMaps: String { return self._s[4220]! } + public var Appearance_ReduceMotion: String { return self._s[4221]! } public func PUSH_MESSAGE_TEXT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4221]!, self._r[4221]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4222]!, self._r[4222]!, [_1, _2]) } - public var Channel_Setup_TypePublicHelp: String { return self._s[4222]! } - public var Passport_Identity_EditInternalPassport: String { return self._s[4223]! } - public var PhotoEditor_Skip: String { return self._s[4224]! } - public func PasscodeSettings_FailedAttempts(_ value: Int32) -> String { + public var Channel_Setup_TypePublicHelp: String { return self._s[4223]! } + public var Passport_Identity_EditInternalPassport: String { return self._s[4224]! } + public var PhotoEditor_Skip: String { return self._s[4225]! } + public func Conversation_StatusSubscribers(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[0 * 6 + Int(form.rawValue)]!, stringValue) } - public func MessageTimer_ShortMinutes(_ value: Int32) -> String { + public func StickerPack_RemoveStickerCount(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[1 * 6 + Int(form.rawValue)]!, stringValue) } - public func ServiceMessage_GameScoreSelfSimple(_ value: Int32) -> String { + public func MuteFor_Hours(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[2 * 6 + Int(form.rawValue)]!, stringValue) } - public func Map_ETAHours(_ value: Int32) -> String { + public func Media_SharePhoto(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[3 * 6 + Int(form.rawValue)]!, stringValue) } - public func Wallpaper_DeleteConfirmation(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[4 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Wallet_Updated_HoursAgo(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[5 * 6 + Int(form.rawValue)]!, stringValue) - } - public func StickerPack_StickerCount(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[6 * 6 + Int(form.rawValue)]!, stringValue) - } - public func SharedMedia_Link(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[7 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Call_Seconds(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[8 * 6 + Int(form.rawValue)]!, stringValue) - } - public func PUSH_MESSAGE_FWDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + public func PUSH_CHANNEL_MESSAGES(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[9 * 6 + Int(form.rawValue)]!, _1, _2) - } - public func Media_ShareItem(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[10 * 6 + Int(form.rawValue)]!, stringValue) - } - public func PUSH_MESSAGES(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[11 * 6 + Int(form.rawValue)]!, _1, _2) - } - public func ForwardedPolls(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[12 * 6 + Int(form.rawValue)]!, stringValue) - } - public func GroupInfo_ParticipantCount(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[13 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MessageTimer_Years(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[14 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Notifications_ExceptionMuteExpires_Days(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[15 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Conversation_StatusMembers(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[16 * 6 + Int(form.rawValue)]!, stringValue) - } - public func PUSH_CHAT_MESSAGE_VIDEOS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[17 * 6 + Int(form.rawValue)]!, _2, _1, _3) - } - public func SharedMedia_Generic(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[18 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MessageTimer_ShortHours(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[19 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Conversation_StatusSubscribers(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[20 * 6 + Int(form.rawValue)]!, stringValue) - } - public func PUSH_CHANNEL_MESSAGE_ROUNDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[21 * 6 + Int(form.rawValue)]!, _1, _2) - } - public func MessagePoll_VotedCount(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[22 * 6 + Int(form.rawValue)]!, stringValue) - } - public func CreatePoll_AddMoreOptions(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[23 * 6 + Int(form.rawValue)]!, stringValue) - } - public func SharedMedia_File(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[24 * 6 + Int(form.rawValue)]!, stringValue) - } - public func PUSH_MESSAGE_ROUNDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[25 * 6 + Int(form.rawValue)]!, _1, _2) - } - public func Call_ShortMinutes(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[26 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ChatList_DeletedChats(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[27 * 6 + Int(form.rawValue)]!, stringValue) - } - public func SharedMedia_Photo(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[28 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Conversation_LiveLocationMembersCount(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[29 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Conversation_SelectedMessages(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[30 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Media_ShareVideo(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[31 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MuteExpires_Hours(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[32 * 6 + Int(form.rawValue)]!, stringValue) - } - public func StickerPack_AddStickerCount(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[33 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Call_Minutes(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[34 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Notification_GameScoreSelfSimple(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[35 * 6 + Int(form.rawValue)]!, stringValue) - } - public func PUSH_CHAT_MESSAGE_FWDS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[36 * 6 + Int(form.rawValue)]!, _2, _1, _3) - } - public func MessageTimer_Days(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[37 * 6 + Int(form.rawValue)]!, stringValue) - } - public func GroupInfo_ShowMoreMembers(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[38 * 6 + Int(form.rawValue)]!, stringValue) - } - public func LiveLocationUpdated_MinutesAgo(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[39 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MessageTimer_ShortSeconds(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[40 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ForwardedVideoMessages(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[41 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Map_ETAMinutes(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[42 * 6 + Int(form.rawValue)]!, stringValue) - } - public func OldChannels_InactiveYear(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[43 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ForwardedFiles(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[44 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Notification_GameScoreExtended(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[45 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Forward_ConfirmMultipleFiles(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[46 * 6 + Int(form.rawValue)]!, stringValue) - } - public func PrivacyLastSeenSettings_AddUsers(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[47 * 6 + Int(form.rawValue)]!, stringValue) - } - public func PUSH_CHAT_MESSAGE_ROUNDS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[48 * 6 + Int(form.rawValue)]!, _2, _1, _3) - } - public func MessageTimer_ShortWeeks(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[49 * 6 + Int(form.rawValue)]!, stringValue) - } - public func PUSH_MESSAGE_PHOTOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[50 * 6 + Int(form.rawValue)]!, _1, _2) - } - public func UserCount(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[51 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ChatList_DeleteConfirmation(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[52 * 6 + Int(form.rawValue)]!, stringValue) - } - public func SharedMedia_Video(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[53 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Conversation_StatusOnline(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[54 * 6 + Int(form.rawValue)]!, stringValue) - } - public func AttachmentMenu_SendPhoto(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[55 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Passport_Scans(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[56 * 6 + Int(form.rawValue)]!, stringValue) - } - public func StickerPack_RemoveMaskCount(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[57 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MessageTimer_Seconds(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[58 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MessageTimer_Hours(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[59 * 6 + Int(form.rawValue)]!, stringValue) - } - public func VoiceOver_Chat_ContactPhoneNumberCount(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[60 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ServiceMessage_GameScoreSelfExtended(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[61 * 6 + Int(form.rawValue)]!, stringValue) - } - public func StickerPack_AddMaskCount(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[62 * 6 + Int(form.rawValue)]!, stringValue) - } - public func AttachmentMenu_SendItem(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[63 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[4 * 6 + Int(form.rawValue)]!, _1, _2) } public func MuteExpires_Days(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[64 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[5 * 6 + Int(form.rawValue)]!, stringValue) } - public func Watch_UserInfo_Mute(_ value: Int32) -> String { + public func MessageTimer_ShortWeeks(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[65 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[6 * 6 + Int(form.rawValue)]!, stringValue) } - public func LiveLocation_MenuChatsCount(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[66 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ForwardedGifs(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[67 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ForwardedContacts(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[68 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ForwardedPhotos(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[69 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ForwardedMessages(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[70 * 6 + Int(form.rawValue)]!, stringValue) - } - public func AttachmentMenu_SendVideo(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[71 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Watch_LastSeen_MinutesAgo(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[72 * 6 + Int(form.rawValue)]!, stringValue) - } - public func PUSH_CHAT_MESSAGES(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { + public func PUSH_CHAT_MESSAGE_VIDEOS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[73 * 6 + Int(form.rawValue)]!, _2, _1, _3) + return String(format: self._ps[7 * 6 + Int(form.rawValue)]!, _2, _1, _3) } - public func DialogList_LiveLocationChatsCount(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[74 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MessageTimer_Months(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[75 * 6 + Int(form.rawValue)]!, stringValue) - } - public func LastSeen_MinutesAgo(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[76 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ForwardedLocations(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[77 * 6 + Int(form.rawValue)]!, stringValue) - } - public func PUSH_CHANNEL_MESSAGE_FWDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + public func ForwardedAuthorsOthers(_ selector: Int32, _ _0: String, _ _1: String) -> String { let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[78 * 6 + Int(form.rawValue)]!, _1, _2) + return String(format: self._ps[8 * 6 + Int(form.rawValue)]!, _0, _1) } - public func Invitation_Members(_ value: Int32) -> String { + public func PUSH_CHANNEL_MESSAGE_PHOTOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[9 * 6 + Int(form.rawValue)]!, _1, _2) + } + public func Call_Seconds(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[79 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[10 * 6 + Int(form.rawValue)]!, stringValue) } - public func PeopleNearby_ShowMorePeople(_ value: Int32) -> String { + public func PrivacyLastSeenSettings_AddUsers(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[80 * 6 + Int(form.rawValue)]!, stringValue) - } - public func OldChannels_InactiveMonth(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[81 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MessagePoll_QuizCount(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[82 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MessageTimer_Minutes(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[83 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MuteExpires_Minutes(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[84 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MuteFor_Hours(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[85 * 6 + Int(form.rawValue)]!, stringValue) - } - public func VoiceOver_Chat_PollOptionCount(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[86 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[11 * 6 + Int(form.rawValue)]!, stringValue) } public func Contacts_ImportersCount(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[87 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[12 * 6 + Int(form.rawValue)]!, stringValue) } - public func Chat_DeleteMessagesConfirmation(_ value: Int32) -> String { + public func Invitation_Members(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[88 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[13 * 6 + Int(form.rawValue)]!, stringValue) } - public func Contacts_InviteContacts(_ value: Int32) -> String { + public func OldChannels_InactiveMonth(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[89 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[14 * 6 + Int(form.rawValue)]!, stringValue) } - public func VoiceOver_Chat_ContactEmailCount(_ value: Int32) -> String { + public func Notification_GameScoreSelfSimple(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[90 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[15 * 6 + Int(form.rawValue)]!, stringValue) } - public func InviteText_ContactsCountText(_ value: Int32) -> String { + public func ForwardedContacts(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[91 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[16 * 6 + Int(form.rawValue)]!, stringValue) } - public func ChatList_SelectedChats(_ value: Int32) -> String { + public func SharedMedia_Photo(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[92 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[17 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Conversation_StatusOnline(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[18 * 6 + Int(form.rawValue)]!, stringValue) + } + public func PUSH_MESSAGES(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[19 * 6 + Int(form.rawValue)]!, _1, _2) + } + public func CreatePoll_AddMoreOptions(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[20 * 6 + Int(form.rawValue)]!, stringValue) + } + public func OldChannels_InactiveYear(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[21 * 6 + Int(form.rawValue)]!, stringValue) } public func MuteFor_Days(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[93 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[22 * 6 + Int(form.rawValue)]!, stringValue) } - public func PUSH_CHAT_MESSAGE_PHOTOS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[94 * 6 + Int(form.rawValue)]!, _2, _1, _3) - } - public func QuickSend_Photos(_ value: Int32) -> String { + public func SharedMedia_Link(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[95 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[23 * 6 + Int(form.rawValue)]!, stringValue) } - public func OldChannels_InactiveWeek(_ value: Int32) -> String { + public func ChatList_DeleteConfirmation(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[96 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[24 * 6 + Int(form.rawValue)]!, stringValue) } - public func MessageTimer_ShortDays(_ value: Int32) -> String { + public func PeopleNearby_ShowMorePeople(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[97 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[25 * 6 + Int(form.rawValue)]!, stringValue) } - public func PollResults_ShowMore(_ value: Int32) -> String { + public func MessageTimer_Minutes(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[98 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[26 * 6 + Int(form.rawValue)]!, stringValue) } - public func ForwardedAudios(_ value: Int32) -> String { + public func MessageTimer_ShortSeconds(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[99 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[27 * 6 + Int(form.rawValue)]!, stringValue) } - public func StickerPack_RemoveStickerCount(_ value: Int32) -> String { + public func Passport_Scans(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[100 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[28 * 6 + Int(form.rawValue)]!, stringValue) } - public func AttachmentMenu_SendGif(_ value: Int32) -> String { + public func MessageTimer_ShortMinutes(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[101 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[29 * 6 + Int(form.rawValue)]!, stringValue) } - public func PUSH_CHANNEL_MESSAGE_PHOTOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[102 * 6 + Int(form.rawValue)]!, _1, _2) - } - public func VoiceOver_Chat_PollVotes(_ value: Int32) -> String { + public func MessagePoll_VotedCount(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[103 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[30 * 6 + Int(form.rawValue)]!, stringValue) } - public func Theme_UsersCount(_ value: Int32) -> String { + public func Map_ETAHours(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[104 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[31 * 6 + Int(form.rawValue)]!, stringValue) } - public func ForwardedStickers(_ value: Int32) -> String { + public func MessageTimer_Days(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[105 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[32 * 6 + Int(form.rawValue)]!, stringValue) } - public func Notifications_Exceptions(_ value: Int32) -> String { + public func Map_ETAMinutes(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[106 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[33 * 6 + Int(form.rawValue)]!, stringValue) } - public func ServiceMessage_GameScoreSimple(_ value: Int32) -> String { + public func Conversation_LiveLocationMembersCount(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[107 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[34 * 6 + Int(form.rawValue)]!, stringValue) } - public func Media_SharePhoto(_ value: Int32) -> String { + public func MuteExpires_Hours(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[108 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[35 * 6 + Int(form.rawValue)]!, stringValue) } - public func Notification_GameScoreSimple(_ value: Int32) -> String { + public func LiveLocationUpdated_MinutesAgo(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[109 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Notifications_ExceptionMuteExpires_Minutes(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[110 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[36 * 6 + Int(form.rawValue)]!, stringValue) } public func OldChannels_Leave(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[111 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[37 * 6 + Int(form.rawValue)]!, stringValue) + } + public func SharedMedia_Generic(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[38 * 6 + Int(form.rawValue)]!, stringValue) + } + public func StickerPack_RemoveMaskCount(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[39 * 6 + Int(form.rawValue)]!, stringValue) + } + public func SharedMedia_Video(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[40 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ChatList_SelectedChats(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[41 * 6 + Int(form.rawValue)]!, stringValue) + } + public func DialogList_LiveLocationChatsCount(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[42 * 6 + Int(form.rawValue)]!, stringValue) + } + public func StickerPack_AddStickerCount(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[43 * 6 + Int(form.rawValue)]!, stringValue) + } + public func SharedMedia_DeleteItemsConfirmation(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[44 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ServiceMessage_GameScoreSelfExtended(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[45 * 6 + Int(form.rawValue)]!, stringValue) + } + public func LiveLocation_MenuChatsCount(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[46 * 6 + Int(form.rawValue)]!, stringValue) + } + public func PUSH_MESSAGE_ROUNDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[47 * 6 + Int(form.rawValue)]!, _1, _2) + } + public func AttachmentMenu_SendPhoto(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[48 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Media_ShareItem(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[49 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ForwardedMessages(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[50 * 6 + Int(form.rawValue)]!, stringValue) + } + public func VoiceOver_Chat_ContactEmailCount(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[51 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ForwardedGifs(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[52 * 6 + Int(form.rawValue)]!, stringValue) + } + public func MessageTimer_Weeks(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[53 * 6 + Int(form.rawValue)]!, stringValue) + } + public func MessageTimer_Seconds(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[54 * 6 + Int(form.rawValue)]!, stringValue) + } + public func QuickSend_Photos(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[55 * 6 + Int(form.rawValue)]!, stringValue) + } + public func PUSH_CHAT_MESSAGES(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[56 * 6 + Int(form.rawValue)]!, _2, _1, _3) + } + public func MessageTimer_ShortDays(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[57 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Wallpaper_DeleteConfirmation(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[58 * 6 + Int(form.rawValue)]!, stringValue) + } + public func UserCount(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[59 * 6 + Int(form.rawValue)]!, stringValue) + } + public func OldChannels_InactiveWeek(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[60 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ForwardedAudios(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[61 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ForwardedStickers(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[62 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Conversation_SelectedMessages(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[63 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Notifications_Exceptions(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[64 * 6 + Int(form.rawValue)]!, stringValue) + } + public func SharedMedia_File(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[65 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Wallet_Updated_MinutesAgo(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[66 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Notifications_ExceptionMuteExpires_Days(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[67 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Media_ShareVideo(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[68 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Watch_UserInfo_Mute(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[69 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ForwardedPhotos(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[70 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Theme_UsersCount(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[71 * 6 + Int(form.rawValue)]!, stringValue) + } + public func AttachmentMenu_SendItem(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[72 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ForwardedLocations(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[73 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Contacts_InviteContacts(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[74 * 6 + Int(form.rawValue)]!, stringValue) + } + public func PUSH_MESSAGE_FWDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[75 * 6 + Int(form.rawValue)]!, _1, _2) + } + public func Call_ShortSeconds(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[76 * 6 + Int(form.rawValue)]!, stringValue) + } + public func PUSH_MESSAGE_VIDEOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[77 * 6 + Int(form.rawValue)]!, _1, _2) + } + public func Notifications_ExceptionMuteExpires_Minutes(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[78 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Notifications_ExceptionMuteExpires_Hours(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[79 * 6 + Int(form.rawValue)]!, stringValue) } public func PUSH_CHANNEL_MESSAGE_VIDEOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[112 * 6 + Int(form.rawValue)]!, _1, _2) + return String(format: self._ps[80 * 6 + Int(form.rawValue)]!, _1, _2) } - public func SharedMedia_DeleteItemsConfirmation(_ value: Int32) -> String { + public func VoiceOver_Chat_ContactPhoneNumberCount(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[81 * 6 + Int(form.rawValue)]!, stringValue) + } + public func StickerPack_AddMaskCount(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[82 * 6 + Int(form.rawValue)]!, stringValue) + } + public func StickerPack_StickerCount(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[83 * 6 + Int(form.rawValue)]!, stringValue) + } + public func AttachmentMenu_SendGif(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[84 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Notification_GameScoreSimple(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[85 * 6 + Int(form.rawValue)]!, stringValue) + } + public func PUSH_MESSAGE_PHOTOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[86 * 6 + Int(form.rawValue)]!, _1, _2) + } + public func VoiceOver_Chat_PollOptionCount(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[87 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ForwardedVideoMessages(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[88 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Watch_LastSeen_MinutesAgo(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[89 * 6 + Int(form.rawValue)]!, stringValue) + } + public func LastSeen_HoursAgo(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[90 * 6 + Int(form.rawValue)]!, stringValue) + } + public func PUSH_CHANNEL_MESSAGE_ROUNDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[91 * 6 + Int(form.rawValue)]!, _1, _2) + } + public func PUSH_CHAT_MESSAGE_PHOTOS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[92 * 6 + Int(form.rawValue)]!, _2, _1, _3) + } + public func Wallet_Updated_HoursAgo(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[93 * 6 + Int(form.rawValue)]!, stringValue) + } + public func OldChannels_GroupFormat(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[94 * 6 + Int(form.rawValue)]!, stringValue) + } + public func InviteText_ContactsCountText(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[95 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ServiceMessage_GameScoreSimple(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[96 * 6 + Int(form.rawValue)]!, stringValue) + } + public func PUSH_CHAT_MESSAGE_ROUNDS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[97 * 6 + Int(form.rawValue)]!, _2, _1, _3) + } + public func Call_ShortMinutes(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[98 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Chat_DeleteMessagesConfirmation(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[99 * 6 + Int(form.rawValue)]!, stringValue) + } + public func MessageTimer_Hours(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[100 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Watch_LastSeen_HoursAgo(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[101 * 6 + Int(form.rawValue)]!, stringValue) + } + public func PUSH_CHAT_MESSAGE_FWDS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[102 * 6 + Int(form.rawValue)]!, _2, _1, _3) + } + public func MuteExpires_Minutes(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[103 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ServiceMessage_GameScoreExtended(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[104 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ChatList_DeletedChats(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[105 * 6 + Int(form.rawValue)]!, stringValue) + } + public func PUSH_CHANNEL_MESSAGE_FWDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[106 * 6 + Int(form.rawValue)]!, _1, _2) + } + public func PasscodeSettings_FailedAttempts(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[107 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ForwardedFiles(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[108 * 6 + Int(form.rawValue)]!, stringValue) + } + public func MessageTimer_ShortHours(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[109 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ForwardedVideos(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[110 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Conversation_StatusMembers(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[111 * 6 + Int(form.rawValue)]!, stringValue) + } + public func GroupInfo_ShowMoreMembers(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[112 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Forward_ConfirmMultipleFiles(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[113 * 6 + Int(form.rawValue)]!, stringValue) @@ -5321,59 +5319,62 @@ public final class PresentationStrings: Equatable { let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[114 * 6 + Int(form.rawValue)]!, stringValue) } - public func Call_ShortSeconds(_ value: Int32) -> String { + public func Call_Minutes(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[115 * 6 + Int(form.rawValue)]!, stringValue) } - public func PUSH_CHANNEL_MESSAGES(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[116 * 6 + Int(form.rawValue)]!, _1, _2) + public func ForwardedPolls(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[116 * 6 + Int(form.rawValue)]!, stringValue) } - public func ForwardedVideos(_ value: Int32) -> String { + public func AttachmentMenu_SendVideo(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[117 * 6 + Int(form.rawValue)]!, stringValue) } - public func Watch_LastSeen_HoursAgo(_ value: Int32) -> String { + public func MessagePoll_QuizCount(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[118 * 6 + Int(form.rawValue)]!, stringValue) } - public func PUSH_MESSAGE_VIDEOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[119 * 6 + Int(form.rawValue)]!, _1, _2) + public func VoiceOver_Chat_PollVotes(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[119 * 6 + Int(form.rawValue)]!, stringValue) } - public func Notifications_ExceptionMuteExpires_Hours(_ value: Int32) -> String { + public func LastSeen_MinutesAgo(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[120 * 6 + Int(form.rawValue)]!, stringValue) } - public func ForwardedAuthorsOthers(_ selector: Int32, _ _0: String, _ _1: String) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[121 * 6 + Int(form.rawValue)]!, _0, _1) + public func PollResults_ShowMore(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[121 * 6 + Int(form.rawValue)]!, stringValue) } - public func MessageTimer_Weeks(_ value: Int32) -> String { + public func Notification_GameScoreExtended(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[122 * 6 + Int(form.rawValue)]!, stringValue) } - public func Wallet_Updated_MinutesAgo(_ value: Int32) -> String { + public func MessageTimer_Years(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[123 * 6 + Int(form.rawValue)]!, stringValue) } - public func LastSeen_HoursAgo(_ value: Int32) -> String { + public func GroupInfo_ParticipantCount(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[124 * 6 + Int(form.rawValue)]!, stringValue) } - public func OldChannels_GroupFormat(_ value: Int32) -> String { + public func ServiceMessage_GameScoreSelfSimple(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[125 * 6 + Int(form.rawValue)]!, stringValue) } - public func ServiceMessage_GameScoreExtended(_ value: Int32) -> String { + public func MessageTimer_Months(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[126 * 6 + Int(form.rawValue)]!, stringValue) diff --git a/submodules/TelegramUI/Images.xcassets/Chat/Context Menu/List.imageset/Contents.json b/submodules/TelegramUI/Images.xcassets/Chat/Context Menu/List.imageset/Contents.json index f9fa203bb7..75a938d28b 100644 --- a/submodules/TelegramUI/Images.xcassets/Chat/Context Menu/List.imageset/Contents.json +++ b/submodules/TelegramUI/Images.xcassets/Chat/Context Menu/List.imageset/Contents.json @@ -2,7 +2,7 @@ "images" : [ { "idiom" : "universal", - "filename" : "ic_list.pdf" + "filename" : "ic_folder.pdf" } ], "info" : { diff --git a/submodules/TelegramUI/Images.xcassets/Chat/Context Menu/List.imageset/ic_list.pdf b/submodules/TelegramUI/Images.xcassets/Chat/Context Menu/List.imageset/ic_folder.pdf similarity index 76% rename from submodules/TelegramUI/Images.xcassets/Chat/Context Menu/List.imageset/ic_list.pdf rename to submodules/TelegramUI/Images.xcassets/Chat/Context Menu/List.imageset/ic_folder.pdf index 2f376dc2736a2e9366cb1b5795124b5ec996794f..842ae3b9533bb5ff291e220b659f2711e8eb88e2 100644 GIT binary patch delta 892 zcmX@EFi&wpKz(Y6cV4t1&z=3jAD9ANy_TFP^_vjNpRmBA@i|lDd;Ss)+naxnbWcd` zobxc?-y;5BN-K~0WL~IkkGk?(;z;0?8@*L8jV!D-ikn^MTk=(F??v8-G~fQopH!5r zKGsi-sJ#7s>z8MDrrz3@e^k0WS%j%=ck{Vq*Pahd7q@Tra=yE|-l0hPkr{hKjH8HGVAIxc-zAG)draIKvh@`Ej2++aIr84% zYCNki{5VKiYgO-~xz@J|GL;vwo>;M2P+U6s2;&jA;FG^%Vr(KAydPO!3+KrS{?~e7 zlj^)&%aSFX!8Wg-UdY{jGP3?{<|ohjE49_nW}hkNF^yg)qPNbZeZP|SgB!CFuIQ*0 zKhfc>UYL5o&*VZk-_g#isx03I-?P1*(5hawB}-IIXF>Chs#~11SFKuh<)m5rxks~t>euaj z!{!jJ43;OT>s(pKKvK*5Xv#F`!W@{!%9)4qm7!9Y=%$yVjLrWKPv&qSP zy4psjhUO+Frj}6#2I@ehsi5zhpW>2OlB%HLVr67tWME(fQ!;rspM|!$p|OGi2q@$! zaDf>H24-ev=wimE7Dkih_*K)*Ow7^c49rcisK=tt!q5a=ud%5ShIz(jX2z3O@!Q8) zm>HR;B`29Ao2D9=r8W>v`8X4Mg*_aVhq7bWKXUA1sl2}wyQIwj- QWo%(?&ZVmA>hHz{0QDqY7XSbN delta 824 zcmbQIcwAvZKz(dTbQZHA&!6v_C5?Hy`~Th*ezKZ9LPIl$TlIT;pHAgo&PEsI*H0xa z>q{2fpStp*{nNB!4qu0bR*XKk9%@8;Z7qsRWUXXPKj{~B?m2DurD4&@%_2?e*KbW! zuKiNi&S!8?R;FOjgm(>Gg#p{zI%_H_Hb{%TJu~UFg{>s3SNf7>$tNYD(T#z>=RH~c zko)(uz&_atAL7-YFW&UAzy6|2!-gO2?ko?E?yqoRxOG<``oqcttTR}i1+HRj<2d#w z!`AOu$Reg6rh+M1fr*_8^SZgpbSEb&nU_>V)lGYwe*0G9D!yI+!(~(c|9r{F(D+r7 zGx(cZozK;!&3hP2qO4vdtqFfHLFJUsy05Z2vP(YMTy8J8>L`Ec(!oTH%Z}gc13p|z zY+Tt~<-=ahvx=F`IotYRh`v?AD{Iwaw)%Rx~Z7~x}1TTDHiou)R`NZqw6&` zF~Km;*wox?GNXWfoS|Wwp^-sys;Om~iJ`e=l5vVTSTmam8If4KH diff --git a/submodules/TelegramUI/TelegramUI/ContactMultiselectionController.swift b/submodules/TelegramUI/TelegramUI/ContactMultiselectionController.swift index 0e48b3d6f4..0de42883d4 100644 --- a/submodules/TelegramUI/TelegramUI/ContactMultiselectionController.swift +++ b/submodules/TelegramUI/TelegramUI/ContactMultiselectionController.swift @@ -83,7 +83,7 @@ class ContactMultiselectionControllerImpl: ViewController, ContactMultiselection self.scrollToTop = { [weak self] in if let strongSelf = self { - strongSelf.contactsNode.contactListNode.scrollToTop() + strongSelf.contactsNode.scrollToTop() } } @@ -132,33 +132,51 @@ class ContactMultiselectionControllerImpl: ViewController, ContactMultiselection private func updateTitle() { switch self.mode { - case .groupCreation: - let maxCount: Int32 = self.limitsConfiguration?.maxSupergroupMemberCount ?? 5000 - let count = self.contactsNode.contactListNode.selectionState?.selectedPeerIndices.count ?? 0 - self.titleView.title = CounterContollerTitle(title: self.presentationData.strings.Compose_NewGroupTitle, counter: "\(count)/\(maxCount)") - let rightNavigationButton = UIBarButtonItem(title: self.presentationData.strings.Common_Next, style: .done, target: self, action: #selector(self.rightNavigationButtonPressed)) - self.rightNavigationButton = rightNavigationButton - self.navigationItem.rightBarButtonItem = self.rightNavigationButton - rightNavigationButton.isEnabled = count != 0 - case .channelCreation: - self.titleView.title = CounterContollerTitle(title: self.presentationData.strings.GroupInfo_AddParticipantTitle, counter: "") - let rightNavigationButton = UIBarButtonItem(title: self.presentationData.strings.Common_Next, style: .done, target: self, action: #selector(self.rightNavigationButtonPressed)) - self.rightNavigationButton = rightNavigationButton - self.navigationItem.rightBarButtonItem = self.rightNavigationButton - rightNavigationButton.isEnabled = true - case .peerSelection: - self.titleView.title = CounterContollerTitle(title: self.presentationData.strings.PrivacyLastSeenSettings_EmpryUsersPlaceholder, counter: "") - let rightNavigationButton = UIBarButtonItem(title: self.presentationData.strings.Common_Done, style: .done, target: self, action: #selector(self.rightNavigationButtonPressed)) - self.rightNavigationButton = rightNavigationButton - self.navigationItem.leftBarButtonItem = UIBarButtonItem(title: self.presentationData.strings.Common_Cancel, style: .plain, target: self, action: #selector(cancelPressed)) - self.navigationItem.rightBarButtonItem = self.rightNavigationButton - rightNavigationButton.isEnabled = false + case .groupCreation: + let maxCount: Int32 = self.limitsConfiguration?.maxSupergroupMemberCount ?? 5000 + let count: Int + switch self.contactsNode.contentNode { + case let .contacts(contactsNode): + count = contactsNode.selectionState?.selectedPeerIndices.count ?? 0 + case let .chats(chatsNode): + count = chatsNode.currentState.selectedPeerIds.count + } + self.titleView.title = CounterContollerTitle(title: self.presentationData.strings.Compose_NewGroupTitle, counter: "\(count)/\(maxCount)") + let rightNavigationButton = UIBarButtonItem(title: self.presentationData.strings.Common_Next, style: .done, target: self, action: #selector(self.rightNavigationButtonPressed)) + self.rightNavigationButton = rightNavigationButton + self.navigationItem.rightBarButtonItem = self.rightNavigationButton + rightNavigationButton.isEnabled = count != 0 + case .channelCreation: + self.titleView.title = CounterContollerTitle(title: self.presentationData.strings.GroupInfo_AddParticipantTitle, counter: "") + let rightNavigationButton = UIBarButtonItem(title: self.presentationData.strings.Common_Next, style: .done, target: self, action: #selector(self.rightNavigationButtonPressed)) + self.rightNavigationButton = rightNavigationButton + self.navigationItem.rightBarButtonItem = self.rightNavigationButton + rightNavigationButton.isEnabled = true + case .peerSelection: + self.titleView.title = CounterContollerTitle(title: self.presentationData.strings.PrivacyLastSeenSettings_EmpryUsersPlaceholder, counter: "") + let rightNavigationButton = UIBarButtonItem(title: self.presentationData.strings.Common_Done, style: .done, target: self, action: #selector(self.rightNavigationButtonPressed)) + self.rightNavigationButton = rightNavigationButton + self.navigationItem.leftBarButtonItem = UIBarButtonItem(title: self.presentationData.strings.Common_Cancel, style: .plain, target: self, action: #selector(cancelPressed)) + self.navigationItem.rightBarButtonItem = self.rightNavigationButton + rightNavigationButton.isEnabled = false + case .chatSelection: + self.titleView.title = CounterContollerTitle(title: self.presentationData.strings.ChatListFilter_AddChatsTitle, counter: "") + let rightNavigationButton = UIBarButtonItem(title: self.presentationData.strings.Common_Done, style: .done, target: self, action: #selector(self.rightNavigationButtonPressed)) + self.rightNavigationButton = rightNavigationButton + self.navigationItem.leftBarButtonItem = UIBarButtonItem(title: self.presentationData.strings.Common_Cancel, style: .plain, target: self, action: #selector(cancelPressed)) + self.navigationItem.rightBarButtonItem = self.rightNavigationButton + rightNavigationButton.isEnabled = false } } override func loadDisplayNode() { self.displayNode = ContactMultiselectionControllerNode(context: self.context, mode: self.mode, options: self.options, filters: filters) - self._listReady.set(self.contactsNode.contactListNode.ready) + switch self.contactsNode.contentNode { + case let .contacts(contactsNode): + self._listReady.set(contactsNode.ready) + case let .chats(chatsNode): + self._listReady.set(chatsNode.ready) + } self.contactsNode.dismiss = { [weak self] in self?.presentingViewController?.dismiss(animated: true, completion: nil) @@ -174,25 +192,47 @@ class ContactMultiselectionControllerImpl: ViewController, ContactMultiselection var displayCountAlert = false var selectionState: ContactListNodeGroupSelectionState? - strongSelf.contactsNode.contactListNode.updateSelectionState { state in - if let state = state { - var updatedState = state.withToggledPeerId(.peer(peer.id)) - if updatedState.selectedPeerIndices[.peer(peer.id)] == nil { + switch strongSelf.contactsNode.contentNode { + case let .contacts(contactsNode): + contactsNode.updateSelectionState { state in + if let state = state { + var updatedState = state.withToggledPeerId(.peer(peer.id)) + if updatedState.selectedPeerIndices[.peer(peer.id)] == nil { + removedTokenId = peer.id + } else { + if updatedState.selectedPeerIndices.count >= maxRegularCount { + displayCountAlert = true + updatedState = updatedState.withToggledPeerId(.peer(peer.id)) + } else { + addedToken = EditableTokenListToken(id: peer.id, title: peer.displayTitle(strings: strongSelf.presentationData.strings, displayOrder: strongSelf.presentationData.nameDisplayOrder)) + } + } + updatedCount = updatedState.selectedPeerIndices.count + selectionState = updatedState + return updatedState + } else { + return nil + } + } + case let .chats(chatsNode): + chatsNode.updateState { state in + var state = state + if state.selectedPeerIds.contains(peer.id) { + state.selectedPeerIds.remove(peer.id) removedTokenId = peer.id } else { - if updatedState.selectedPeerIndices.count >= maxRegularCount { - displayCountAlert = true - updatedState = updatedState.withToggledPeerId(.peer(peer.id)) - } else { - addedToken = EditableTokenListToken(id: peer.id, title: peer.displayTitle(strings: strongSelf.presentationData.strings, displayOrder: strongSelf.presentationData.nameDisplayOrder)) - } + addedToken = EditableTokenListToken(id: peer.id, title: peer.displayTitle(strings: strongSelf.presentationData.strings, displayOrder: strongSelf.presentationData.nameDisplayOrder)) + state.selectedPeerIds.insert(peer.id) + } + updatedCount = state.selectedPeerIds.count + var updatedState = ContactListNodeGroupSelectionState() + for peerId in state.selectedPeerIds { + updatedState = updatedState.withToggledPeerId(.peer(peerId)) } - updatedCount = updatedState.selectedPeerIndices.count selectionState = updatedState - return updatedState - } else { - return nil + return state } + break } if let searchResultsNode = strongSelf.contactsNode.searchResultsNode { searchResultsNode.updateSelectionState { _ in @@ -202,7 +242,7 @@ class ContactMultiselectionControllerImpl: ViewController, ContactMultiselection if let updatedCount = updatedCount { switch strongSelf.mode { - case .groupCreation, .peerSelection: + case .groupCreation, .peerSelection, .chatSelection: strongSelf.rightNavigationButton?.isEnabled = updatedCount != 0 case .channelCreation: break @@ -212,7 +252,7 @@ class ContactMultiselectionControllerImpl: ViewController, ContactMultiselection case .groupCreation: let maxCount: Int32 = strongSelf.limitsConfiguration?.maxSupergroupMemberCount ?? 5000 strongSelf.titleView.title = CounterContollerTitle(title: strongSelf.presentationData.strings.Compose_NewGroupTitle, counter: "\(updatedCount)/\(maxCount)") - case .peerSelection, .channelCreation: + case .peerSelection, .channelCreation, .chatSelection: break } } @@ -238,19 +278,39 @@ class ContactMultiselectionControllerImpl: ViewController, ContactMultiselection var removedTokenId: AnyHashable? var selectionState: ContactListNodeGroupSelectionState? - strongSelf.contactsNode.contactListNode.updateSelectionState { state in - if let state = state { - let updatedState = state.withToggledPeerId(peerId) - if updatedState.selectedPeerIndices[peerId] == nil { - if case let .peer(peerId) = peerId { + switch strongSelf.contactsNode.contentNode { + case let .contacts(contactsNode): + contactsNode.updateSelectionState { state in + if let state = state { + let updatedState = state.withToggledPeerId(peerId) + if updatedState.selectedPeerIndices[peerId] == nil { + if case let .peer(peerId) = peerId { + removedTokenId = peerId + } + } + updatedCount = updatedState.selectedPeerIndices.count + selectionState = updatedState + return updatedState + } else { + return nil + } + } + case let .chats(chatsNode): + chatsNode.updateState { state in + var state = state + if case let .peer(peerIdValue) = peerId { + if state.selectedPeerIds.contains(peerIdValue) { + state.selectedPeerIds.remove(peerIdValue) removedTokenId = peerId } } - updatedCount = updatedState.selectedPeerIndices.count + updatedCount = state.selectedPeerIds.count + var updatedState = ContactListNodeGroupSelectionState() + for peerId in state.selectedPeerIds { + updatedState = updatedState.withToggledPeerId(.peer(peerId)) + } selectionState = updatedState - return updatedState - } else { - return nil + return state } } if let searchResultsNode = strongSelf.contactsNode.searchResultsNode { @@ -261,7 +321,7 @@ class ContactMultiselectionControllerImpl: ViewController, ContactMultiselection if let updatedCount = updatedCount { switch strongSelf.mode { - case .groupCreation, .peerSelection: + case .groupCreation, .peerSelection, .chatSelection: strongSelf.rightNavigationButton?.isEnabled = updatedCount != 0 case .channelCreation: break @@ -270,7 +330,7 @@ class ContactMultiselectionControllerImpl: ViewController, ContactMultiselection case .groupCreation: let maxCount: Int32 = strongSelf.limitsConfiguration?.maxSupergroupMemberCount ?? 5000 strongSelf.titleView.title = CounterContollerTitle(title: strongSelf.presentationData.strings.Compose_NewGroupTitle, counter: "\(updatedCount)/\(maxCount)") - case .peerSelection, .channelCreation: + case .peerSelection, .channelCreation, .chatSelection: break } } @@ -290,7 +350,12 @@ class ContactMultiselectionControllerImpl: ViewController, ContactMultiselection override func viewWillAppear(_ animated: Bool) { super.viewWillAppear(animated) - self.contactsNode.contactListNode.enableUpdates = true + switch self.contactsNode.contentNode { + case let .contacts(contactsNode): + contactsNode.enableUpdates = true + case .chats: + break + } } override func viewDidAppear(_ animated: Bool) { @@ -307,7 +372,12 @@ class ContactMultiselectionControllerImpl: ViewController, ContactMultiselection override func viewDidDisappear(_ animated: Bool) { super.viewDidDisappear(animated) - self.contactsNode.contactListNode.enableUpdates = false + switch self.contactsNode.contentNode { + case let .contacts(contactsNode): + contactsNode.enableUpdates = false + case .chats: + break + } } override func containerLayoutUpdated(_ layout: ContainerViewLayout, transition: ContainedViewLayoutTransition) { @@ -323,11 +393,18 @@ class ContactMultiselectionControllerImpl: ViewController, ContactMultiselection @objc func rightNavigationButtonPressed() { var peerIds: [ContactListPeerId] = [] - self.contactsNode.contactListNode.updateSelectionState { state in - if let state = state { - peerIds = Array(state.selectedPeerIndices.keys) + switch self.contactsNode.contentNode { + case let .contacts(contactsNode): + contactsNode.updateSelectionState { state in + if let state = state { + peerIds = Array(state.selectedPeerIndices.keys) + } + return state + } + case let .chats(chatsNode): + for peerId in chatsNode.currentState.selectedPeerIds { + peerIds.append(.peer(peerId)) } - return state } self._result.set(.single(peerIds)) } diff --git a/submodules/TelegramUI/TelegramUI/ContactMultiselectionControllerNode.swift b/submodules/TelegramUI/TelegramUI/ContactMultiselectionControllerNode.swift index bf5aa6a548..60ed433094 100644 --- a/submodules/TelegramUI/TelegramUI/ContactMultiselectionControllerNode.swift +++ b/submodules/TelegramUI/TelegramUI/ContactMultiselectionControllerNode.swift @@ -9,6 +9,7 @@ import TelegramPresentationData import MergeLists import AccountContext import ContactListUI +import ChatListUI private struct SearchResultEntry: Identifiable { let index: Int @@ -27,8 +28,22 @@ private struct SearchResultEntry: Identifiable { } } +enum ContactMultiselectionContentNode { + case contacts(ContactListNode) + case chats(ChatListNode) + + var node: ASDisplayNode { + switch self { + case let .contacts(contacts): + return contacts + case let .chats(chats): + return chats + } + } +} + final class ContactMultiselectionControllerNode: ASDisplayNode { - let contactListNode: ContactListNode + let contentNode: ContactMultiselectionContentNode let tokenListNode: EditableTokenListNode var searchResultsNode: ContactListNode? @@ -53,7 +68,7 @@ final class ContactMultiselectionControllerNode: ASDisplayNode { self.context = context self.presentationData = context.sharedContext.currentPresentationData.with { $0 } - let placeholder: String + var placeholder: String var includeChatList = false switch mode { case let .peerSelection(_, searchGroups, searchChannels): @@ -67,7 +82,13 @@ final class ContactMultiselectionControllerNode: ASDisplayNode { placeholder = self.presentationData.strings.Compose_TokenListPlaceholder } - self.contactListNode = ContactListNode(context: context, presentation: .single(.natural(options: options, includeChatList: includeChatList)), filters: filters, selectionState: ContactListNodeGroupSelectionState()) + if case .chatSelection = mode { + placeholder = self.presentationData.strings.Common_Search + self.contentNode = .chats(ChatListNode(context: context, groupId: .root, previewing: false, controlsHistoryPreload: false, mode: .peers(filter: [.excludeSavedMessages], isSelecting: true), theme: self.presentationData.theme, fontSize: self.presentationData.listsFontSize, strings: self.presentationData.strings, dateTimeFormat: self.presentationData.dateTimeFormat, nameSortOrder: self.presentationData.nameSortOrder, nameDisplayOrder: self.presentationData.nameDisplayOrder, disableAnimations: true)) + } else { + self.contentNode = .contacts(ContactListNode(context: context, presentation: .single(.natural(options: options, includeChatList: includeChatList)), filters: filters, selectionState: ContactListNodeGroupSelectionState())) + } + self.tokenListNode = EditableTokenListNode(theme: EditableTokenListNodeTheme(backgroundColor: self.presentationData.theme.rootController.navigationBar.backgroundColor, separatorColor: self.presentationData.theme.rootController.navigationBar.separatorColor, placeholderTextColor: self.presentationData.theme.list.itemPlaceholderTextColor, primaryTextColor: self.presentationData.theme.list.itemPrimaryTextColor, selectedTextColor: self.presentationData.theme.list.itemCheckColors.foregroundColor, selectedBackgroundColor: self.presentationData.theme.list.itemCheckColors.fillColor, accentColor: self.presentationData.theme.list.itemAccentColor, keyboardColor: self.presentationData.theme.rootController.keyboardColor), placeholder: placeholder) super.init() @@ -78,11 +99,18 @@ final class ContactMultiselectionControllerNode: ASDisplayNode { self.backgroundColor = self.presentationData.theme.chatList.backgroundColor - self.addSubnode(self.contactListNode) + self.addSubnode(self.contentNode.node) self.addSubnode(self.tokenListNode) - self.contactListNode.openPeer = { [weak self] peer in - self?.openPeer?(peer) + switch self.contentNode { + case let .contacts(contactsNode): + contactsNode.openPeer = { [weak self] peer in + self?.openPeer?(peer) + } + case let .chats(chatsNode): + chatsNode.peerSelected = { [weak self] peer, _, _ in + self?.openPeer?(.peer(peer: peer, isGlobal: false, participantCount: nil)) + } } let searchText = ValuePromise() @@ -102,9 +130,14 @@ final class ContactMultiselectionControllerNode: ASDisplayNode { } else { if strongSelf.searchResultsNode == nil { var selectionState: ContactListNodeGroupSelectionState? - strongSelf.contactListNode.updateSelectionState { state in - selectionState = state - return state + switch strongSelf.contentNode { + case let .contacts(contactsNode): + contactsNode.updateSelectionState { state in + selectionState = state + return state + } + case .chats: + break } var searchChatList = false var searchGroups = false @@ -113,6 +146,10 @@ final class ContactMultiselectionControllerNode: ASDisplayNode { searchChatList = peerSelection.searchChatList searchGroups = peerSelection.searchGroups searchChannels = peerSelection.searchChannels + } else if case .chatSelection = mode { + searchChatList = true + searchGroups = true + searchChannels = true } let searchResultsNode = ContactListNode(context: context, presentation: .single(.search(signal: searchText.get(), searchChatList: searchChatList, searchDeviceContacts: false, searchGroups: searchGroups, searchChannels: searchChannels)), filters: filters, selectionState: selectionState) searchResultsNode.openPeer = { peer in @@ -136,7 +173,7 @@ final class ContactMultiselectionControllerNode: ASDisplayNode { strongSelf.searchResultsReadyDisposable.set((searchResultsNode.ready |> deliverOnMainQueue).start(next: { _ in if let strongSelf = self, let searchResultsNode = strongSelf.searchResultsNode { - strongSelf.insertSubnode(searchResultsNode, aboveSubnode: strongSelf.contactListNode) + strongSelf.insertSubnode(searchResultsNode, aboveSubnode: strongSelf.contentNode.node) } })) } @@ -167,6 +204,15 @@ final class ContactMultiselectionControllerNode: ASDisplayNode { self.backgroundColor = self.presentationData.theme.chatList.backgroundColor } + func scrollToTop() { + switch self.contentNode { + case let .contacts(contactsNode): + contactsNode.scrollToTop() + case let .chats(chatsNode): + chatsNode.scrollToPosition(.top) + } + } + func containerLayoutUpdated(_ layout: ContainerViewLayout, navigationBarHeight: CGFloat, actualNavigationBarHeight: CGFloat, transition: ContainedViewLayoutTransition) { self.containerLayout = (layout, navigationBarHeight, actualNavigationBarHeight) @@ -183,8 +229,15 @@ final class ContactMultiselectionControllerNode: ASDisplayNode { insets.top += tokenListHeight headerInsets.top += tokenListHeight - self.contactListNode.containerLayoutUpdated(ContainerViewLayout(size: layout.size, metrics: layout.metrics, deviceMetrics: layout.deviceMetrics, intrinsicInsets: insets, safeInsets: layout.safeInsets, statusBarHeight: layout.statusBarHeight, inputHeight: layout.inputHeight, inputHeightIsInteractivellyChanging: layout.inputHeightIsInteractivellyChanging, inVoiceOver: layout.inVoiceOver), headerInsets: headerInsets, transition: transition) - self.contactListNode.frame = CGRect(origin: CGPoint(), size: layout.size) + switch self.contentNode { + case let .contacts(contactsNode): + contactsNode.containerLayoutUpdated(ContainerViewLayout(size: layout.size, metrics: layout.metrics, deviceMetrics: layout.deviceMetrics, intrinsicInsets: insets, safeInsets: layout.safeInsets, statusBarHeight: layout.statusBarHeight, inputHeight: layout.inputHeight, inputHeightIsInteractivellyChanging: layout.inputHeightIsInteractivellyChanging, inVoiceOver: layout.inVoiceOver), headerInsets: headerInsets, transition: transition) + case let .chats(chatsNode): + let (duration, curve) = listViewAnimationDurationAndCurve(transition: transition) + let updateSizeAndInsets = ListViewUpdateSizeAndInsets(size: layout.size, insets: insets, headerInsets: headerInsets, duration: duration, curve: curve) + chatsNode.updateLayout(transition: transition, updateSizeAndInsets: updateSizeAndInsets) + } + self.contentNode.node.frame = CGRect(origin: CGPoint(), size: layout.size) if let searchResultsNode = self.searchResultsNode { searchResultsNode.containerLayoutUpdated(ContainerViewLayout(size: layout.size, metrics: layout.metrics, deviceMetrics: layout.deviceMetrics, intrinsicInsets: insets, safeInsets: layout.safeInsets, statusBarHeight: layout.statusBarHeight, inputHeight: layout.inputHeight, inputHeightIsInteractivellyChanging: layout.inputHeightIsInteractivellyChanging, inVoiceOver: layout.inVoiceOver), headerInsets: headerInsets, transition: transition) diff --git a/submodules/TelegramUI/TelegramUI/PeerInfo/PeerInfoPaneContainerNode.swift b/submodules/TelegramUI/TelegramUI/PeerInfo/PeerInfoPaneContainerNode.swift index 070320143f..3212d5c133 100644 --- a/submodules/TelegramUI/TelegramUI/PeerInfo/PeerInfoPaneContainerNode.swift +++ b/submodules/TelegramUI/TelegramUI/PeerInfo/PeerInfoPaneContainerNode.swift @@ -509,7 +509,7 @@ final class PeerInfoPaneContainerNode: ASDisplayNode, UIGestureRecognizerDelegat override func didLoad() { super.didLoad() - let panRecognizer = InteractiveTransitionGestureRecognizer(target: self, action: #selector(self.panGesture(_:)), allowedDirections: { [weak self] in + let panRecognizer = InteractiveTransitionGestureRecognizer(target: self, action: #selector(self.panGesture(_:)), allowedDirections: { [weak self] _ in guard let strongSelf = self, let currentPaneKey = strongSelf.currentPaneKey, let availablePanes = strongSelf.currentParams?.data?.availablePanes, let index = availablePanes.index(of: currentPaneKey) else { return [] } diff --git a/submodules/TelegramUI/TelegramUI/PeerSelectionControllerNode.swift b/submodules/TelegramUI/TelegramUI/PeerSelectionControllerNode.swift index 8d30cec7a7..00083acf52 100644 --- a/submodules/TelegramUI/TelegramUI/PeerSelectionControllerNode.swift +++ b/submodules/TelegramUI/TelegramUI/PeerSelectionControllerNode.swift @@ -85,7 +85,7 @@ final class PeerSelectionControllerNode: ASDisplayNode { self.segmentedControlNode = nil } - self.chatListNode = ChatListNode(context: context, groupId: .root, previewing: false, controlsHistoryPreload: false, mode: .peers(filter: filter), theme: presentationData.theme, fontSize: presentationData.listsFontSize, strings: presentationData.strings, dateTimeFormat: presentationData.dateTimeFormat, nameSortOrder: presentationData.nameSortOrder, nameDisplayOrder: presentationData.nameDisplayOrder, disableAnimations: presentationData.disableAnimations) + self.chatListNode = ChatListNode(context: context, groupId: .root, previewing: false, controlsHistoryPreload: false, mode: .peers(filter: filter, isSelecting: false), theme: presentationData.theme, fontSize: presentationData.listsFontSize, strings: presentationData.strings, dateTimeFormat: presentationData.dateTimeFormat, nameSortOrder: presentationData.nameSortOrder, nameDisplayOrder: presentationData.nameDisplayOrder, disableAnimations: presentationData.disableAnimations) super.init() @@ -99,8 +99,8 @@ final class PeerSelectionControllerNode: ASDisplayNode { self?.requestActivateSearch?() } - self.chatListNode.peerSelected = { [weak self] peerId, _, _ in - self?.requestOpenPeer?(peerId) + self.chatListNode.peerSelected = { [weak self] peer, _, _ in + self?.requestOpenPeer?(peer.id) } self.chatListNode.disabledPeerSelected = { [weak self] peer in diff --git a/submodules/TelegramUI/TelegramUI/Resources/PresentationStrings.mapping b/submodules/TelegramUI/TelegramUI/Resources/PresentationStrings.mapping index 989b8c032d1c7068f30a0b7e9a2a8d8c506f4201..0aa86834bd865c9278a4a1648f389b2140950d5d 100644 GIT binary patch delta 41745 zcmZU62Y6J)_cn8rn`}uXWp}eZy>1eEhY&h}gx(=bSRfFxA%$L51Vri)j*Vu;LQ_#u zq*#9{)n1TdML~+aP`-EWrr`g39!)YcXXehGJ9ExE?>RI4`n&F-KXl^Hy~3E5Vr$l{ zS>aS~ZBcnmZLji*T3@xNVA3R+Q!})@w!(+vX6;FzmacXb&6-)cz@a2iNt#aWgk&P+ zSI6a1rMzeZoy-UpCG>HITOEXa8y}e>oT_}c z!Q{-$R)-+d%uAb#*f6|$Wu>n|mJOw5C*2*J?{gqaR!h9r!HbU4Zjy)%5( zUe91(t#`WC-%)ffGg%#tVkhnSH=dkXQDO|`Wu=(MBF`wB^w(8;w1I6SpD>PQWLd=o zTA5`RrL@NtM+dTEg_llcC94xrC55AP!a_0GF=`o-J$UJJB7;v$ANB8&5E%eWr;jNtH8B$j5 zuc#PSC3`fL5_8hjatNhxq*d5ydQPM=P0-m*CZe2JbvjBcw9aKVG|Y|)v8l7jrhjt6 z)EOvD)AQmqW-&hyHSg`R3HhzO6)tqhT?qbS~c*cQ3MZ zC>r3c@{I6TYp=h0Lkowp1~ciZFok<(`AVw&bF|l9OFde+#d@0DB1_$XiWa^ct=OEh z>HCn3!0#cx+S>BUDK&xFBTF{YsTQpSQ%K7c^?pcM>Du_1s1d%2Lwq$g<^IYVDf9ph zX_>4%DEO)zlyxnm)rTNzrlr4|=(UzQ@i4vJGD~cxUs|?Mwg?_HU)Ve)Q~kC69{$;t z6@Kp|*~nH@iNfz;HNNV;m6QFR?*7_7z6x!^Y@@1H*;;!CX6Ojp*U6^$x4? z2G;PSbgosBc#MKuCn=8$KARw{)T4Ej`UKj)Q{=;dYk$f&dY;~F;}$Pq$;HwVXUK-OkzyZ3we^S>scYL-DKDXFEW`$2 zB=H`ezBBN%=bWnYYM(YB`%#`Cr;&+vw>7A*Aelr}0}`~E@+$q<)-4W@v0aLIjq=;2 zC? z<1IlmO)*?d&~FRc>&4r2cl$*3e-N}%)$#=W5MQO%wRh=cd%HMFm)mz#kI7QbYX^N$ zP*#g6A)j!Z26adlC$KbfqWV_O@>Y~jk{?VKouubGB&(-TE14$rNuWPEM2ine*D+mu zO!*zN#V0hrqgDMBYRX35sRqRdWK^$eu#V3dT6?)~ zq2u$!cQm21UHM+{xk$|Ejh*f8AJB?aY6JbX<&(?Hyz*T={ru&XKB*y_UBEKl%91xI%}zWT{tC z>Y&mGV=1U>bmBFnqS5?dUzNYQw!{b98Tb=<&3-{)63-kX>|APAf(?xd`B(CGO%=b< zimu7xciP$2D*m8%ySkM>1)n4lAJ)%XS?8_R)WTmB(Jf2)ThLa$iCpi5(x`4m^0*{j+wHFmQgrCBorewPdz(q}?JQTJg3WUfj}3o=CrJzL;XbP6qHQ)E$j<@B1N z_2Z&f=x`Sk8N0_|Mjjp+OD(&{sYW#Aq(L{#F@<$Cwf-3m%Q_tSF19QdPJM&jh@frV z)73~6nE6^O#j47OM$ymR9U_{-3frm8QIxJ(Gx8Ri)EFcaC^|MaqR>Cd=aD~9p;;_# zEp)^F9VyI#*|~zhO%&b3t(vul-K~&0pod;bPS=Kgi)xjvu?QA+?YVY3 z)FV-KAk#(p?0O8i=_oUjlxYUdOAfS?da(iN%UUNRFO>AdM2qU z+SAUj6;=&Zq*D7{i6V{0_Hu}Hn%^r)WYSjroka(GC8^mE&Y`V3I|cPNi5#-_P81&M zf}gqM?d?|b6u#C4uk=7~qb(n@(pEOA|04esf1PG@TF~L%cBQ34*WR$DHkg=Jke73^ z9>!?edPptMoE)px-5CSG?M(EGuGX7glJl=xCYI;g$@{%Wl!Q|P^cb}@}EpyqVa7h9DI z%&jeej|1)#F&eC@L`^e$mjK&V7Ke%|npK>r%v7kv<)D{~?MgM?@tlJ{9WBBm`uluU z1ALRpy>i6rD5@k=%%YAZS?X*wlE_;>7b&!^Bv_fF(3Qzf+E-#y<|-O)*41bLXdb?= zD~4|^5|I=&C=!V46*~4?HH5_Ty|nmqUjE_Ewz&bQhnx5 ztS;9q!Cj;qoTDsL*qx=sgby0lSEBA_%OUF|aouhxpXBpvQ)&e*8k{Ru(yqY;;$FHs zI9;s9x{0NnA$oN!#8YX|x>#NpB|>S!BhA%y$a2w=6AoH6L=Qx^afn;lfH4bFVyG%K zOh3wBCtscvUK*x2=+HMhL!q~#LVMJGP!&Z0WaEa~#QijHs8xLct(gM&eD_ejc#!rF zO%xB&>7i!j;lRL9#IO*+uef2!VheQ`mZ)s4f7r}nG3qu{&yq?igTDGp50G_WSf28T zB7p#j;W6S-iW}Yn*y`u*7DH?K{*R+VEZun86e2tMghHZ43_Ud5AfBWrhI_;g`gpiY zc}n4vx1c2>Mi|7?WEtU5pFy=~-s@6gsboYju+^{;E@h`e+rLSr%_G7(??SoU@C@)* zVp;U|Rraf^&87FL5s#(m6J*Ug1SR9JDH=y6eqnqKFoX;$=g&}&q?Llyg5fdkIzug zqYz3pRxyRt$_f89wVU7+-_Xbj$>LjDI3e5d9VE2(uO~GC$pV|0?@)$9Q=EUJ{pRRWp}%q#%vk_~4xQ=?e4Kyil(((;m-G`;fZ1{< zy2T9|G%?@WEGV$O8&)~Vk3Gud+Qu!4pv@DLg+i}SOjUy+<)A30iu@ViwBz$R)FIR~R(zJVM zwT9W_X^}5UHOc4Eo&qx+^y$#ccYJom62#ZWiWuJ3Ul@4VLJ_Uu)C5S{Y3T%)W{9jv znW*H;1S*{z+|7oRhGV31^$f;nR!(Vz&~_BYp+nF_zUuNaPtWRVf3>uE4T{GRME5L9 zpo5cjsuQwS%Kalj-vC@)ba`@HAi2~j4mA;_sn9%bnl>d&NeZH()d?LNS9dZ>rBcu| zyk|gpO-*2(q&Mc5P4xw~%bEem2%?D6__%?7P-p{uP!s`FlL>L4^%HRvK2;A4=(*D@ z(R}o<%Bpg3P1+VE8#17`9>(k(JJkhHxNxc)pm6I{kCKbQ+k#=g{(^xnO^p!w^zT%= z+5#04so?%t$}f-8wM0syB8f#}mDWLYxx3lWLavZDC~

F5ze#fVQ-=yp7rp1vc7U z8AmtDBLD%zrey*Gww;zPI#TI0hv-C$rzI<$gLr!_F!Za_qC^)uI?V$P@84;t(|<* z0J^WjV;=|!`SuOl^+1OL+udS1TagX!FKk8a1mE5n zb}<|ariFb(eM^NEK5uoQSAJgYPx-8oO_d;aX}I+ z@tO4oTJ5)}WwIunc-pMl^hrUywi}H1Ie(1s(Qp0~F_{vo>|zSFtIANPLe@?NZ@M&l zQckO?T*|Z{$%uqY9-&WprPihCbfPLtt$?tTwmMsx6~yOyiUfzZVs2H9rbT9>S}3Z^nT7vlOLOQ{ZLEY}(STnC zm6M8Vr~0a8hvo&*k&(`(t;u|{)ubp3v^VC`I3<|I*62(N(V|o__2Ae)S+=LP$dN7dyiYwG7xfOK9nx>u0r5@5fWzm<2Y9 zn4+Vrvx1cef>;biodXvQ6f@hTJQ&35GL*Pn@FfMau*vaG3^4rx!c52<=il37tB(K zneLk#Z`+Lm4Jl~rw9z{3LAITvlNAe{ooiI~22s?)Uym!iBB zr0pW8YMu^Ya_&4={3~ce&KS)q%OCRfU!~piQo-weGEee)*XNl*127dx(W!l0h<-;I8k}BdNKvM+({72|fs%DyASZG#04x*(IF;P8yHD%T1RSksU zCvUfXIKq!G-iKH1QSL7U!yG z(0D!aC@C%~lASqAGZ#C>dFbIxMtlwXG!Z&?>l0}uQc|K zWKefY@$+|j;tprQpAe7>2A{H`fp-jSA&}YZulmx!zG(~}_q ze*g=z01!vtnWOjHS(Y#;Z4wvIHDu@821&-bB(4_Q*_UPU$p_a0|oH4@k>; zSCrB$m~!sQQa}r=J>{gicg2VxT76f#H8?ncGo@DT0UBGQgSFWQX5_9sAV{&y0R-t< z<^*=^w#+SzG;vufoJK2`C5dp_xhx&#`xE3x(qGFGEm3H%0UCL38{24Vd3TZ$6U4hK?Pcz3!IAIwY7ig>OXEP^Ajjgqbe?eV5yZ5z{~QHPmHEVqLvcP@8}1S(jb ziNUW}o~GD>sp4Q#*wFGBzIp=8PH!&HRbA+bgU;N;KSYY@JgL63n{6Tnmm0ik!qHW>>O%fp6Kk#xQThlia}9f zMS0akKb#yM$>BHJ)O-}nsihGvCFNz)K`(2DMH{vjD2+vFBc9O6s-}HwOO&T-B>mb} z`iKGLm31|;|E-XnpiTE}_vl4yditI$FoB=klLRL4pL=Y8fu>c7fPo!W*=-#mD~Caj zxMwJE08sYq0&UyXiE384MQ7T$Dix^kz$%;C6~Zpf)j+?mid4HH3FogjmhAVM)B>bT z^z)Sj4d{1A%E?zp3TwE8%vGt#rxJI0xG_=CJ9jS%QbG$ zfj8FJKnEtQwJD>5DfiBVX!-r>=b84AMpN0^L}g4cuS>x4+`87Hj16Yj3SkZ#GPG}D z|DJ>8CmBa)*1E-n4eQ)$sT>(PJjYC3)e6Up1ZD&?>1G5^{c) z`21BBzJb8Y6XD8jVE5}#njYY2dQ+5T7LpC#&_4damUs^GGBlWSFU7)vyPeuA^MX0I zJqQOmt!LLeedg0G%2XFZ+C(#B;|z_o>>?U)pGRGSf>^rNJx-UOC&zPXumlK!sD%CZ zHHTmK=zU25byx4p6nBwzqg7cJ%>Ht`bIC?ky&JW2cxk#~rMit4z`3;>C0lrCW3sr1 zzTKFntP0k)uH@R}1b^6VQ?jx;n2wAy)1pn`Vh!E9sijy;hd0^9Iy$o{TWlaByHrA} zh$m>N#5YaU`>2F-#YS4fDZp({K#C!i#rge3T3G%JtkA$l;C{Nv7WDy?S$NP)VbfIn zLs%W(36rr2U_4Bv_d5W_7T=#Lw$c;#r-2?ket!l)*kAXjfEjc=kOpS3*8^_l@nE`i z!bvM0hyo4xzylf19cWvAxe?ylvZ3-i2khb*y7hn?o>ljQ9mH-L z`(UcN2eq=VJ9H$giJ>+)nLy6QLjhtaY z-4rnO@(C}Z$W6CCa~PXA?w4rsLmr^7T@SfH<(+M1vI1&TCd5(r;`zV;8O zE1QblnAYPjQJh43-%p^!TcZHdPHlCoUm-8B(~jI0EzXd8Tb_Crc`5wbH^SPypsdVS zRa@^zk_+n`-MK9X*lq8&B;D7Lljetaj}T@cx8JuVs^23ooufyJEN%Ds0~Kvg1;JLc zJzM-p+qOFa(GG8KpEBPjr5KR=Re{S75DJfbl)q49hCPT7w-z|i%7)DDKO{86{~i&j0FEdHiF zk7fgCef6ltaUHcamI=hRw+!B>q27s&4ctU`!5lqi61S-LV{Qc=(P@vhfFpJDV|G=+ zJG!)O%<0DrN{||u5Fw9819_PrPlbu;`gkj_bG47BE1_yY-<;f|+H|NV;X#QPd+{c2 zL67VP)*~7KOgxbS0G9Sd8UR@F6DdkK9#9KYwDJj~BLcFr)9?hAS89IH+x9h)^xPBa zY7|7`B{^i&I3@@;i&g_01KX1(rMaqkfvMk<;Yy6E#r9M^8LP&kRtAYJE_&+8DC`(s zc`^yi&zUE!Kyv>)nF=)K-jR#QnL#^}R6AsCh?9wws7VmFa6y(5ZzG~;dfxOYps zYtU|&Ivh1}wD7p~yDh*n&+PUnBh`BPQZD)_jb!R5h}xwWDvqpsB2A-_l>WE?zy*NI zm(yzu73}eV0;}5N5aVd=9vA$Zd-kLtw(XNWPNh_paU2x2SFd_e-6C~%gr>8*SJe4r z{fX3duN9bP%w8uj&HTMN&M6RVcqfm1v4SaBGg5Y{Y=R3~DDiymIT3-1zO27!mlIw+VF^@biWGeGjzUEZYu^DY7hZoSA7xKkII{ZQ!T%Z>qv_z#N+ksO% zD0<4@7YhK>YoANK6U~851EOBMF9tw{_9ZFHpcS@Y@qMz-0&?o=zGQVdq_Vi+O?V71 zUDgB66uszFS0Xb-i%!d3hq-;vi_MjL0xBsaUn=%hbl^odz|EN#lR-%Zy_BY`QAx~2 zu*6^Rk)m>@1R{2-dnpzu=bo1`)%C~(&j|8);5#AEF>wD)l3!s1oq5SEXv53-%6%&T zJW@EqHFa8#@i)@=m)!tAOI~)uO}g!67u=*rUd|8?&_(1tM8^Gg1f*r`&lH-bex)N|)Ad)f)g5R{ z3-XJG-vMC*y?isg0ov>-8uDtQ`ZUTB$^u7=u70=p3_bX&O?ei|Vz#j9fm$@aVkdp| zYNFV+;XnqERptRVBG-xzB#FILbs!TE>Y)Qx`}1f@;}ZjRNsHpZZpJ6O{sMh?AQjPS z{~XAMKQ!&NH1QG@zm_4HtJhiqJMDVS3heaWYc};&w30;8$Ky#Hj0JHOe=t#f4S4~= zXYfI@I7rhE<|>C(iUPm7=b%j-p<@T#;&r+L(KjHPMb}E4yfYj8K&L}t;!Wy%$SK~U z@Tx9V0+a8Z!wKpMB;ibjmZpCWM~ahVIO0}MAv2|Z zVMH1VDtrOB_W_MNlAwI3Qr;M>{v%Q1Biec-1A%Ps9wvLf%SJFQPoa2z7re9zIG~rqBRx{h8*zWmm7D907v}95HwroM2b!&|9rR zWI>i9-VOm^ihDar{T-44QqC~6=g6V5gMX;xN{^%QUxel~goOPGDT(h!K=1l$5l`}e z9RGi5&s#bPTjV`iBIGt8|2G|d+YL7B^4k{mUq}UFu+!d&P;Vdw_ES?D5#lC|d&dQ2 zwdfs}(kz6wy<-QmI{1!FDD>q!$s%aO|5_vmWACGZ+9pQ~91>Hi;eJ5hnyDyu6WkP3 z@xSIuNC-^IeT z;oUg50V%ogH0ozS&mlt!diR{rqqtDYhoLN+yABuG4Pn3G$k8+cA`Eo;hB+KT_r2>< zBT<&fuC~HuZ0t-_h~_RePWPg@X3>za@}8~2=E~Pxbs>yD<-H%Bu@DyVIpA`lRpAlUAi=!VWm=F#D=I#2QCmYImXCY@BfR9ePH7Xu zm19II?KvK=wv}C!B!i1C9@newkaTMEA@W2Ns4Uls7HS9N+2ul}suM=hkrtfDRy!dt z5J?_TU0XFi5^{A?-bx zZ0mt+ZJ%2|S^5qfUfj2^ryQ!@bnRrS+6MvwN;;xoSdYHNvZOEaGB~ObaC6;N5!)E` z3L5K_9pP?kPPJ4^AOmcy@x1ZMpb$RyBtCS+2chap+ zWHLhJWt4VebOm1rB+Ugv@rOEPOo)VX#=@y!1@WwA;{tO!bh=-r#?#RcEdYJrf9O<8 zQ8|{jzZg%hk5sT(sUIbaiPZlin_4CxLfg9_PVl2}fWFlq*#Y{V`N#$8>L`9rrJp}? zi*kzmI8B)rLVG%btNAzvxNg$NF0}%c(?MZc=#h`()fuuWEl9L+{mrB^AGZToGkxMv zYC|+EB~MJygirKJT}Y#SH|A?z%2{Y2PMcm$Tlv|@a|WF8$3BS`bLi|RZV*)BQ=Bl6 z;;^YPG~iRcbv{xOqe@mipjbwD=V`;TfM$N$LS2aRc${ z5I6H@*$8nfJ!wlDfuQBaZRZ`Rqwxg+60^9!9M?OMnceisw|!<+??RSM2JV@X;cKo! zyubF~WyqEr%tB3P4ydasFOv=2P5*wDp)N;ZuAIY^dp3+pK92;+CB8DV?W{0_0nnFC z?W^IqRkY^wEFi*HK2HTAJpZ{vtl98|TV0Fl2{`;=qRw9!)OAQD^2rw1*7&}NQr9Dy z#KqquE_U-5q3~Tk{zbaDkB;N#Ci?S>ER`W(M*y$2$;91HMPH@@{?&Y$1NgW7ODEvp zkuQ@$YkiOWEfjt_4dhnq(>cmEe7HSMLwmV;wxb~zEl#k|6Q?6Uce3c5C>%vzyfHCzJOxhKN}5nR&};z$}7l}#x<~k*XT@eOO?Lv{z;mf{Z*9XK+mRFI(=5B zJ0Me#rcPrl%4;E7EV$!bb6~gpb185^jyRW!lLU*-wO5ZoGO*(~c`h6v?#wv{9FI57 zrK)eDB$dYZO`!qjb?RG4SvcxmY-X#@8`%cysE=;)v^T#vvz+0YLmk^(WdY22<{pe^6$gAY6TeU@@DgirPs zR^y1NNJeZe+btbRQY4FdQ*E)gD>kp-n?7#qr^}rt1&{G-Ez6gXbvk4+7j2| zKeU2Cb^u~Z7J5kClqtR%?c7H9!QEvo1?7RAdC^a?0x?8CB`d+9TJwm6;=^t0cm5%? z`=?awPd@p{3IF9EKRFWhs44f0^|74r%_4qLo`{mYF`}?JO_&j<%7;Wy$;CDzik4q= z;ncy7i!DWSI(^Zl#Dwzt2S6LdTxzbwhSHbcB}EhfcWP574lOvqrN+>7l*WhhQa4u5 zxO^jRxujD~D76NVc!TjZhteQUpdT;AD%Q|I)JgN7V^kX?b3lWeId?96t0g~20IN;- zIYo7#AWhr1ZT;D7av~)^e-qs&JMN<6Kc`~T`uopGfNqw{E^J6T;AaYrxoibIntj== zrlDr4<}}}PIROmY`YZC2 z8R;u~;X$c%xHX*C()cG?kQ<84p@Uw%5(Tt(^ok8=@5d{tVCSN)Iz&s#y=qljg$BTI zg?3n|HCh6-JrYoE?bT?IcH6Jo;FCOfwTtl@N2fx zFO+h>Nu=GsM!`9G_*aSQ&iras283#WWY6cAGF3%-WnicbudhFrf_S&z^lC94kHbhf zWK_B`R3oWMkmJ%mga4&irOphN8KVF=YHb4k*t3d$KwbqFMZ<0QmR) zZbG!$!rwF0(ej08b3Zp7{oRNYsh|CBQ^z7NQ#zm04O4L_RohUFqpUyD)$u5?1P-_P z|Ih=>&HcmSEJbF3jnmG&_NwsKOfA;fI4?>9;V;G_zkhn*80kbh{YQG|G89P@5O6fz zw!{OV#)o2UonoV0iO4CB96}kRCfDf{D)=)WNU-M5Bp^ZlQyyd3_osAQe)VS?r6QE_ zin0SIVGlef^ax*@@K>TziNz=hF@)t~gP_u`zrx_peD$v^_e?xX+t^7%TjZVSt7!67 zR--JLmUcFi^Y0h{$CiJmsI|xo99wH#A9Zx{dMs`FJ5rs6LKj`{YmWUtp)#{k&`~?2 zOSk^ED04ys!Pc$+iBjf;YN0nY_8&ctJxu;5NnHS8Sm5Or?Heyd$|iTmQS#hcz1u}D zrN#8oKQ46%iWBL^j@!H@ODXB!B;}4!dRXV8ssF~p$GPxd52(Rs|8=O#AfMWBA~l$d z9Rk5)cVn`Dj%}d*dbC(hx!0Yb2#c?K;PG5^-KpGzD3F(9DEz5d!%#m?EBkw;nw6+I*1i69DmSJ%5uz@|~8$3pQMoD0a=wefG^R(GSWcJ|fGZ3S}oa33L(#B*FBM7r{PsPxWQc(=g3 zeu4K3VHf-OQz0_Mi!2n8EMDSNMWm=NqZyZWl%4&G(5d@nmt-(kxE8Zo?=X0Uw!aVeV3O8i&W)3P3arj$j|sbYQ)J?jeIs(=)_UJAP?^yM{b%t7{P8; znA8(UYL^c1Fjd4jP9k|*Ku8m{a0&&9l=p2sKMXnX0q;>o2k{|aRE1l7%;6!zBR=6y zA;PJAs=Y!CSA__(@|m{U_~{T4D?aB#A@Fs6fu=N1KvT%?mmC%R@vYDCnotbW*Ss?n!}Luk%~%flF;ql~Z#i6tX1_zT*)sIZ#p877;`clg z+2RM@tV8t+d_*T)>W|uMls=fSNspR8ag<)Tm5ZVBU?%s|qt+!JuNOGZz{~W)DK7Kl zdepjtTJak5!)NqDuUykm6<^omrGDXP118$9+|eLx>Ti%tqAUH}ywD)@mfw+-drJuo zhgD9m#1V1%N`Hj%)z3gHykZd1;!g&dWL5u?&yaxup~V^r`ZpVl7>j>24Z~fH;GO;r z<-H%n@IJJ~$V-gEs9X=#I1XJs-*$uHEXy(9tbb@dnrm3IxA+$$7FRPJXM_oxRUo=V z+NXv)1;AL=Un!t)X_!b6L40?Z0D{!9`;xHeyZZtNM&;vSB1a8D^)3O$E#n$PxmUQz zPSzn;E|ULj5;WwbnM*y2Q}}4Da7Xnh2SHY?sR09W(|G(5VPoutnhPWU5sozd@@=@D``5=qA9Fvj=wW?fgmHOJWyqU z8yK>o@ z9NFMts_ezm=(Ar1i*>8b9_3~m1=0q7kWD)sd5+AdOT;byz7W8`xrzVIjTRCdT z#ajZOgs-y9=kZrI98HsAdUec zqSBUl7i!9xrMX!&)~9fA&w`;nHN3V=Yc_DdL^v*O5W&jbI)qEXh4D)$KjXlcS!h!+`=9NJ#NDD6?oskodS07ISSt$At!tCa&YZoIqIXA!OtAK?qCe>=NNB zAswe3{%z3P8@a+I($!5Ua0YJI8P`THm=C*PAnr$QzQVM&;xPIAM9iGW@KlG4MvLLCiK4msxa=z}iZL;qIFaHB{wfhq zeNrbWL!5{nY2*ZihpRgv)?PAn={z(EIO!=JZSSt#S;6<>NTT|*)(o5(T>JqRo*dI> z_(&2a=Cgc034PtkhGZ=HU64!D=zQ*;EaKJONLx8NyFMhetbTK_mzN}qq?G4SDk-EP zQ@yyDMGKS;td)8@xew)mJCo!E4%(GT%8OVl^4t$NBtzp__LpQQV!0$m#H#yINxS2N z7p4Huyuxc!M4Ixdj(6eAGM`GpEI+8zj^Oa$Qs6KfQ=uM?aOYI0hc|des>oK}L?nH> z<@Q4dZ}DLmTi{~QwTa>#4oU;W{2#YS6K&OZ@kkqAog=I{4e_(@)xVmyCkh0@d3xcp zf`-l1`zY7k7G`bo9z!xshV$?*X@GslIV2sQ`~+vG<71q}>cLSv?S%L#o}P}m`XS^^ zeDXu6);;MkIUn=>bgZOLkd2u8`(q=9RZ1^hJsSUXQwA)>XY9@ZCjVTAy8*JeHbX=y zUtqbfK^qTeU>bcX@r;EJ$-htYyBX-fS9~P{sQe6?)xwk6k%>ukR?fGil=H}yU#}O= zj@MQD0HNeDq)DD)f8bcm*C;2;dWvuO5!4dj@!OdqMfqMQNtbjlN!P#j6lx&vjHf7LvEsmoWpXkHTx4u zGZn8kaUPQ5FFE&d2}2Gb+uta{)j%#`4{!MR|7cC--DP0}Tt=(ck;JLk2V?oY9IUk) zNCx6E{>{O+zR8gu%)eV);1SL+siiIGl|+-2{f|Wz$jEGP`Gf&F)gPWfaFJBUCq3Ax z1o6)vOv+%6%Ec&!a9*xRRweZ$uNI1BoRN$WdR~wVwPWD>Q3z1`8h%;BAQM2{xO7TR z7!M*}wC@ql*KuKg$GhfM*S7@*yA9gNI&)Xgs*4v}!<9T2{)Q5>@BmPjBne(CX68Ob@k)+u58lAD& z9}|h;sJ~Orfu{tBk(3r#8!kQNCBz$sRZjG3dl@%RXdzmPM5Y$Pqb5T*jZTiT^7$45 zE^#C+yyY{@_{f$}W2s2TODhuIa0Wk3wyv=PJh~-5PC8e%#2aQXwG?i9CQ2m;XbPuj zy6Y#4PqhS)%GNhTJ%;NgRRw9po7h`n>*CRCz&bmSnTxihTL^xRrYnym|JuDi%qR~6 z88WZ|ciVig=bf#DLCM$Cx;B$pkiyT%Z@BC_j)vdWl zYfv3+&abq_f^N_6wZ>}iz*k$tymdrjnxxaXbsM1M zPF&PRq$GAmuI%q^S4GGWuBHg^E=+AizSO+&&V0BtKuV9~Z`)%iN3o#; zevRh54x)uJCh+BTle|)7tX?}Q!-&j}5#xAQ2cXRHe6j=hm{PQ!p_zdbDz;mB9ifW7 z+@T}ja2bknIFT--U3a9e) zQq@S1w}vAN@b%Vmrvf1Qb$CDvoDIrm$1fr@baJ^Iy!E`TKy(%x_)Gyde8h(Cc**!L%2#ouAO?P0G2l%z_Kn@S0UVW5fJx}ux zhZUkDo4I`Lrg;=(a@QFgGf=Bs#nR<-ld*J%b$I+6L!@Eg^ z9`L}*CqKbn6p9_Zw1>#IKLr{2iR)=XExOMW@E$y^mw_m`C3O{nz=vlbDiut?+0b}B zR1sb+aMpDf1QO`%J0|w@6b9>VBsJSrK1nhj1O0MgYoon~hxCL>d`{0xnk%WixhJN; z^SrC4$O9dFwkJmWCDheU4P`Y=f|t2VFHC~{dais~IKpm=$$y2{_kuY(pw|v29q%RL zm4kXZ`m~MmF6hD=b}EO^rkT9MVmYff$gsou4fh3tfRkzhjF84Iy$-4W(B3WOpuNd+ zdINR71(Ufno{E1B3BUaq+S`1hH#+?eswPV>5GVA(vUnFsCzXcUjDbV-a!$R+C4FE` z-{-mbr5=TZ1Gg#JnqKl4A4Q3B9Mj`swn3u`WIX`Qz8Ia8JgzUk{V8737kkYQG^an2al5_e)L7bKkpk2==7#fJ^uV6{BN0E1qn8g|1-yfFj z9HinTzSYai2xU*s^Ns$Pr(d(9NVHMEK{>8OXl)HEgoCR-bmm)LQiS>a9q%l{*nH2Q z6oD1KpqJ!jJi_#K95+Bj+I~b;Ia8Y)t3yDhYv1fA?lwSl6c>5H0N9~R{KNpD%b)r9 z0AW!tqne9u9&pL1S=pg00bOsLteJzWC{B~dDoyO#E5do~Kw;2bLuL|0>Du3E>aR%1 zyOZ47!2ZsM2cnaI@Q(wr7XM^pvB*~cf{464$ZWt`*Jk)XdfNKEix(9G%l?Z=lW*cD zi$#Rx1|;R4vr$FWhq~S5Zq0#1?HyE=q#vp@YVhX(o?3{&AipGT;%ZsJ~f>mVz+U^-F;*>Z8 zFYODIcy=&0Zt;9=u*kv4I){jy)@D3K5(Sds02-{oDG~&xWeQR-N zrWRC{z)Ob!-GPM}A{?FU5S2PUfP^)t(QUW2I_ev0AgD+9CRH|Gd+XdZ6wt)QZHB_= zyScJl)L-b8h+2UQ;rM}}!e~!IIzS`UU!6M@uG@N|JDHCR1qMiwRS-R3ZzP&i*)~Jh`pns;syp@>7UbB0lPSDGjYhu&0mei*bL&!qcMdBbIce($04#%yYQ_s z!gnao7y}zVjGw_(qUvx6WXaPrd~OULGGfzM4EspV9EyIu z%Wpw&&MFVYH2L_qanPlcQQg8o+PPtSmQU%)?>LZL6@ zXfI&wB1oiAKYcQHStfKn79%Np{~zF2P%+y(S5w4GP%O6tvbdMeH)$d^Z-|8|E2|H2 zUyAZL1eTdK?S2Qp=>?{|lmGU@+TO*P6Y*`A@xY1L$KB1-CgKw>=hYK2`B(6>6Y(AI z;iD6=eO|>sOvH}G`JtcP#1x2{4nd=IeOC-RaWgm65XzWv$*IBE*LjrWl}#I-)ai-+ZSn~Z^c zx$rjg5g*Xy7QW^a8R}NF+Ix(6k^XIS+wtTs{?>q&=`! zMKDuqrowbRXP`y>9lSM635jUjvObS?a3?O*=ucCj(f7d+#wLUf_Tq|8E#%_G`ZmYo zYGv+Hj&J@F_b$h7^kr#d9AZDOMoN7J&3NeWFcY7Uxv%o&a^S@S$hA_XH^I=me!Ke` zF8b|ZX$Gw4k&oi5slx0t5` z_`i*YGv#%#{K<5@_&Ww#m#+CQLk%M_sLlR|^1vY=&aQyUd>83dzUER)Tv7p|=zXnz zRH2FQsKD$#%9|^&4vz7W3ei$MjzV+8aRD$|Glb4`0(tlktE>zcdNr^cCpmY9hE}Cn zikR$`kNyB+(%iGF2UNy~ymkg)#z%Z)24K&}2EJ7X$hT&tPMboXa8xBM!58TMF{_N> zQ?=|bc}yj|vZoF5Zde(K#G5Oz+5U=mR%$@>ZBzmUdJ#hEIXuoT<3`!xhcP(Mxqje) zZ`kLD%(r}xADiv(_(?xT`FnoHk8g8MuYv};h(@#d zU=eI0 zV&P(6*{>izEK7s=r)qRvHS&otpsplX4q(OhHCQ1!qjfZN-Amh>Sc6ki$KX3@wx7I-wTKJhdOlw^FUI$QN<&&rJMOV&6z1F;WE?R4YqCAdXi1GV&E*{d3gXZBQbl|Lc z2-@g~QfYc|FfNhFfBXt@_B$7T_NYuZWiFoV2u;}b{@V$0Y}fr zT4kHUjS`c%;y$hdtGAGZc&qwKzhzxh&LaECZTM=r|`Ii zAcuw^oz3g|W1iraON$uFTNgr;4nsDMC?fXi{6fUo4Cg-nurEl-FAV;(Z%Rt8GnyD>Lir8HG`D21h=dDj9L&I7cIfUpUmTy zh~(5M5YY(S`j3SOcWtlRXpG7sVB?uD<6fTz6+0bSIOvlY8(!kCscrDyRq)j%81@+) zwG`I4Qj^*JQCwJYS*;&;X3CfJ^Z2DADXFUdnT@Bz3jG!S>f3fzGtp5{ane_bQ@l&D zKdI*9O957DP}8hg#;7|)n7I~7{8w)QwD35oU+TEk9hgY7*n0;$G@F;+fv+_Of=(X$ zkTA#mmkytcf-IhJ9?SoiJ79V@ve^YF2;7IuW9|eDU1;RBX-Wb= z^&ODJBHnN(=ILTSa;NAEAGz@^e9fiCfbo}xI=tcb?mN(oMf)c*G{bTyFTM-Cyo&Eu*40hE^S}oRA1S2dEZZocP;|E%QUu;P>7REov@IX+>N^c z?&D>5L(6UCr|w4MoA{%)aVvKD|Td^uLogPgh?EBzrJxEvdshfy78e*jcgF2~k; zb3oSx81}9FDkRly5c$v5mr((J2|a4Iot-OSSROIbxCc!Uf%SRstD6!+lpmym&J{=?i?vJs6A^`H6e5@w#>o zVyZRG`ZDTj7cqtd!OBysEoANe>|7;57YaQZt)=|~O8f7NsQ11|$EB2em6xo-_dCd2 zRsq)>(!{09<=0gh-oqSrFBZ=cEA%MD-ip#`d(<`|5w&^ zz}I-a|GbBrc^8p&vu>6o5{cNOR!LDKQKP%0m7+!veqFRWew}77zDli9RMqITMXPp& z)~*qBpai8;@&7*Oz4s>mzt4xy&3n#s-uKMsdCoJpV!;F>Pkj?ca_&Oq1fs5O1W7Zc z0cjI?Q{0Z`6S+`3SWMZ=+%&!AcH*sx#NxYHs8cUs&qVU2yTd#q8%N^8r=-8PCX%V# zgP=*=RNtcBB!0Y{(8AotWAG%d^*%g5i4(pb^CwY-_nqFa)f{5J$K^>}oda-A<~cYR z2K!yaradMb5%GukA`y1@xomBe++Lf9AC|4wfFi=xlX;OmiW8G56gb8PW*Qy_I-qkl z+D+l+Jb@uo2y+scLbP})j8czw5TkKR1>qT4Pb@a#r;@ImM#fa`*)u4dN)_|jFo{)) z$y1Gpwm%Y5u5o@s++HGLWw&P!;>R%8u_BoSjNCat@*IkOrPdruKAq<7aPOn!$>scAfkw_!}Dpf13Qtm#~A1Kp-mhN`S6vXa#-%uyB{5V{5hK2e@WuDY;lx>3_o zlaKVTiiyE@)5$AZaBe!^6^PIo{0Tz#44%1Q6!OOsLeNytiS*bAE`dJ|gk~XGL(8Eb zs|m5K*gJzF1FERyMRw48A=_}ED>#!*3pof+zj zW#P8^Xu3n!Tax%*?LwQZLz^Y@Q4T~0eUGV%Q7j)z!IXE25K;-^rBO%UrOG7(SKg&~ zydI0|n;xx~Cfd+r7EgQ@ie{0JWMk|sE=GMTH%*jBEV_gt&4bp+YBKFpX7eaE#)8?L-6q&Lo8M|` z)xvXJpG~`tX0X0T!qgm{-ZK*7TJRetLVkjQxjGGgvPw(V5-+`H+^t$!MQMQJ@6nR8 zwNH(fd(Yh{BT$PD{EjKCHPyN%W1Zub zcXwp1Fs9nDsC)77F*JxZg+2L*o69R~Cjw}ykntc5iOp+H7nTYA^q+|yCI8WJUZihb zF@CPmTy^7?AHw~#cP=+ZcU+mvo!0~L^Nbi(U^Qb3^&Z8jSLR{riAU!VpcmenXC$dU z+#S5DXk+-k*6EdGC@#(8>fDbTj3HoofS*tF&}hU#VpBXo_LS`Z2d$Wr#)W)%J{R>N z44Kbu{V*oYC)4+c3_{C9+pvlB@==z^xI0pQP%=dMN|>4iW9pA&Vmjeo1G*`!pfI+DF zKKcE@1gwkAuk+0O`7#Y)p5n7NW`$2Ovz*jk0QFw{annT`7T+wMQg2w>JW3 zETRx%G|MPqXM~OE8;Ess7mv+ujfY|3H z7N?>|kV?j-4@4iWzd*e{oQr9%_X-~)D73DYbmld4WL+w`3rZFnfs_&cXEAThZ(#mn zQl&SseKF7ETRckZNqKKAHi9e@_?Cv+iwtQ?jD*;Ue3pHoeL@G7Jgp<}>D$O8Jhp@f zdkUUg!ckAf>?K_9cd&j52k5~mDV#QADbdVy#4csk476IxGT@P=yaLU%@(L7*`Adlh z-o=`w#2&M7l0tp*jsGqsd;6YMbm6uRJY-{r7U`?O929;?27fNQL`&vRj8I1yCj0>_DE0$5tvji2( z*zKjL`4Q>wGIKi@d}M?+|HwQ3YUiTRj77DaHFD^=Zjz_2cz|RM;uS>)^!ON4KjJ1> zp}Ruk$XFcvh!*lI`Q}=2R)1qaoHy<{v#9Zs?N{2ZXD!oi zkfV=c$QYdmuIGI|naKuLMrn~P_I_*xCvW7l46}MjTz@o+O{|RZlvl>-O}-g1E7*rJ zv{*q@vqf-R9gJ8(mh&sZrFmYu5rOwtQ0)4(ZbnT(h{QjTY1oQWD~!5v->^bxfc{vo z{2m?i@9XzqK_7wGhNP8TsqN^sl6Yc=eqn6SILuhdCEkT4E2&`K&C)m#FNXM>z4xGU zrIF$Ow)%U0aeec3K#p=&C8Aa!Un-yZ4v(&4=fB7JRdne(KuSgzU*ry?5@+)&GQ0<| zV-As~KfH_fwLOUkFp>sX>LHFM-lIs|2CLQgZvr z=Lsa+pkSz^h?VPZwY&HQRwjEERCiIl2;(#IPnF2#*(4X+?KAH3D{@jZ$g?i~jNAJf z_DJ1zT$H-sg~n3`{y8smf1v;8R3QI}IiHhH{!1Unu!eqV$v>$4oQl00{Az;OH#(}W zZvV3>iY1@^g2K&PEY)J=$Y8J8&u#4eLfBFp{`!K{ss>zN8tDl&$=J#u zP41@8@KQ5|sG0hMkrTfpXdqttl3k>Zn=Mp`P5UM{)BGm>`jT6R5=+8i_(&tre_n0q zx`u7-7`BF!;=s%`M88gKUc)!l!sRtYd$nO(OY{_umTQTgBGG59kx>L7VH

``3&3DB}P%liD%C>lS6Fc1w z>o!sLdN(RJaY{PCvYB|gBSB3A`Y2vSB(5%NoF#FR2J3q4txp*1as%P7{n&t^uSt`=IOmkhi!1(gqNA*Jd=_!uqv!u&0K zd0##^)$!M`YYSg{KYrc9P4EChzaj~KkhQTQ_x0?n2=p)5LwMvXBQxb;RtoVkowdB) zg8mFKkFmDOwWnsFX5;!{$5$L>f7T^PmIPS7Hk{c-d=&Ymc+U9SKh8qAaLEOsN+$jU z+JDU@7{JO*6gFe1(uxNxc>8Pa^J11I>1mo_K4=effw((C-`aRwG%KX1X}M@(sH(%BBsmmw&^rm15^Nyj_eYNV>L!4%|j|b`0XS z@dW<|?YD8(pO$xOVe%W>IIw3l?CQZjPoCY|cvzpqKikN{jJ1i0oW!ymS|S4+hxXgK zD_&$1PR$>6oSKgtR5Fy&45fZNrf%o*zJyiVi8x-y>Fs>iD{$`Mq`t~VrU0P(4%$us z*Jc_idZ~c4e$8fH#)b`-r#I!~M9>XB!Y>VeOLtXbanbG#K|3i*nqam;&Q9{B6VYTR zx9}wN*~uxKjPW~-x zRj=`&&+8$GX4>=x{n9QY z;;vb&68zGBG<}5z4dXRNUlb)dwY+>bs|7RjvNN>Uv`O?|l;1;}-8^k`2x8tz@Y-%- zkhz$%n}=*3HtpuUU_NV8bd;mvj|bxBZn_FAV38Y}Hc`l!wZ{mFUdU&`sa^)Jhu4Jc z19aPCWVjZymj8HVGm{wm-5Hl)(jKnphpeOl;HbDTGOq(mG|l)3C-)dBNh??-GgsaF zq&EXI_`FY6A^BUeS3KUTaS}_xqCOlQBM5633=rtVw>@3xsjPrMo=N`UZZi{EB}pQ3l_0O;#WQx z--h$0SYW$=uWgbD7dOiJp{??2a)tF&E#&N@QPVeUnW^KsqyIjViEVglA8FQhOxj1a z!cNw@Jk)dG+kG6sEg-5qc4qwCRbmgy*usJEZ{VGr8xH{9-TSt=Xt4oiR0Hs)!m z$6ma&pKNP6p_((qQ#8u&+Z|wOmbTF;_>T1c5T5#u^0330 z`5n>B5p4X9MuSHQ6QP~N{pa@w7J2t;COwBlzWP09`UFOPZzLz2WUb7t@3b*`Kbb@C zmOO>k-%}}GVKW`4D!%8f{xlny9H;#NbuZuA=23Zs_08{}83n*KDThY|bH``Rg`+s1XSvN4E60LuAqZ zMB-s1+5I- zR$|~Vz9irlY)8lp-bU*q6iEcw(U$?LDJ~s*guJ1`EM|%%m%8x?=b|PqAK~Z&5r34l zD9A2>k#HZw%2bJHf+W*GDtSUN!Pucyv~>H{agCt zM8{*a601ch?cQXSx`Af4x^PT8Ms}?Z>zLH8eY7?Pim-b|ZeXUeH!T03u0%ooK-pw8 z!5MVn)g%=DK;|Nbk5SUkuwJ7XT1lUM7smd;F~(xv4?Mi_*z$vs7L!20VD`v#J~b`K z+$_tiO0Ny~af-K+(BL?iCK-<&r*TCJK^p6MV4B=?m1-B4L{U*Y$;F;N&MQa;LQilQ z^$2L@fI!z1ynkn*_yn(2*>=sx~PV$sAM4ywCjy1Mp&wrWCp%Ebhnqb*Uu39s@i8yD|O+l+@o3m+>>0!>0 ze07W#$U8+N!j^WEZ|js_(5*{f?Xl1b<4Q})N&=Dgm$Ymb?AhO3ZrpqXTC~y zO7+`+hk_ox+jrHCVtxc`&riq%=gLFbH2_iJn`yX_8o*Hyf{bf(PLvHBcwr`=TmLVLiP7@#qKhEgqf6mI{IDUp`U^OT;NU?Kmo)oyM)q4!mmX7v+d~LkSOfIUrEQ_W1DF0{#<3EI|q|~tJSg^F?xA0QW_1zW34LBKOTgyI;c;l&6ie7Gcgs>XSbZauOHr6SVqS z)x|^<)X~kjL`wLf9WM+pV*Rn6mLc~N(Ixfkm&kxDXJ1prTpDj*B8mIhy9&dG$da$% zcjg7pW>@ltn_nv>!f}OF<(^rGM=$f^>+#xU&dLUSc$t&9 z5#L^>d~y@vwZDsmVI#}vykexrm9bD5Sua~d$7287Y(e1_UZ=h$M3rw^H2K00uaMe( z!(s-NDmTJ&?ta!M=-b9Z+1p+g$8`VeFs9U-GIKktQ~mM*ns=|oReTl5gd zU!#S?QC3AtCPv#!rw_4&SAvw zyy2ZEJhzb<0~ecrCq1};oxhWKU1UuHV;#hI_9dOZ#1he1c^BWbPaBZKs4-8_SX(|+ zNr?a9dOLdccbC!g4{o+Ac|o?p;IqA4V&6-7f5= zmfebNiTcZqEjKw<3Gl$Ij)8doPu{Zr##?`qGyF$Rf10{s7jLr0UXL38{=CT#%4YL1 zc;ac6L*l}e!}8r*tk#LMQu8#AbDPiJ8>>$}r_)plY=Faix7X$l244KjsIQbm`#T2d zn2a?X8ns^gi`1Yd4-DDwKjV=3w-J+S;iL4!>qC&!p=89fUV|8Ubs(!5N4PW5*mHlA zAr8Wnzd38cSo=4pB@{>h<`E6U&A+(|t#JQC*#IS}{}>sucD5vEZK81T^Bd|7r0Q@W zFV_gKMNghPq_<9d@{f^gsl|3~x%txhPAfj78?_yR8pWdn88^sIgyTvLmFSN#!$`9? z$P7fVX<9XhtQ9wCC=uz91PYL#j;LUPC5lkA++u9?JKQ*<9cJ(;pI#ycdH+(n7)$6B zty+{052a&+pH#-d^Dl{QJl6k9-E{)4{7Z!EM(9oAog_Ak_e{PWjUG42v?Sx8#yY^;kh*@ zRlHq-PdAMD9?CJ$E?ic?H7q?`B2rcHPCB8VIe zpXN_=?L(!$H}YyS=uaQkCy3oS(=!HRY)utHw)wT1Duoi>Wi?f-|Pz{lMXSkNeI>4 z%|HUuyr+;p#x#odW`Y~UDQ4Da3b#x%i@}%>sM6F^4)ad5BTz*cLvS*XpB*|QNM)&E zY;Y|c?SeQ@CAc?8H8DnDe2~ha@xaO;<)YE)t{|02@$H2mZjvz$lo#+0n;OhaTTinG zZtX}?N9@?{FB&!6+tFuOL-PwEWaEOB)$%N#>&cZiMPip$QPby87R(dzJWd6xCYG_f zm1K?ZBpwK~jN@a9mccU-3my$oHd>Yr2~kP%Ucj11+_-opG)Zp#T+8_J2Fh*NyBOk%@ih9*zbC}Xnp zMLv!;Val$iICNALEz6(EDlPFyPnUi74j+Y(_I|pg*XZIAq9o7JM*9AJ;K9}~<+e;C zV4Mz~;K#f(VY8}i+6T0>a%avW0HuNqim5dYa&eiB@mAG<4neD}D%CQF04XrK5glB% zawX@&VpADplyhvH#rf!N<2GM_kv7%HvXHRJD9hoct<0us(=6b78_~`O4osd;wCFSM zT8w17N>@u9+C+ply74p;7;9H9^`XPGKVD&HBDH0F8{>zZCc2)I#z=!+HuNK0wyR9b za@NLZO&dMH&HLfUXyf3Lu3$|xgKfrIWHc)=)4>T}g-s6Srik?vL1I54h(=6Q5HVP` zWD@RfV(HJ2>*Tb2L4YXFzRq>3YgUGl*7G=&zga#Zq_*ZS&6U3js|STfLbb}c^RQZ3}ObV>RwbjL}Sb?ES7`K z(`n|`W2{^qRgium()ufGt;KPEjSIC@eKO6_wK?2x(4sb1X&WA(=RGB-FVi63ec_wQmAN$1_9Cq87kn?;GHXJ@x?Rf|@skAQNp#s*b8_Il_h!I{h+M)nUt{SVxyh zbxh-FyGU0``+7Yif0z-$i9XH-(dhq`H~z;7+#A6moy6b>p2}009>F!Kz?uk^q)t0% z{23MDMSFv3w>4a*<_zBu$FMUrOO51#J}cWK8XY3J?|wv4B&ozt4hDn}6Hl8jw%E^D z9jVfze_>NujH-BN`Z%7$l}M7D^Q?{1F$U^IsZjF0O`oU@fxYt0`e@6Me}4`$H-_-?e73% z?ofuhMt=Un(P$M%X7&$0sT(q;DCEZQDE-T~=J+(q@iZeH7o*ZGw^$67 zPFWtq({Idhag`ORf?FRl=5MG?S!p5TW5(8Gsr1pO0qRA^eDm~J@S=;e8i+Y;O$KF) zOEs_r6Fk{m@sL;*X@tNXOZpJ%)Si-$Vc_KX$5A+SEFDnj=hS8E1nY{gLd&;Y8QsYlU~K* zwRqAiIwwOo917Hw9X zUt4Y7TZTUSDcGMtl%0xO3B;ReP96B7Z6fC~9eoqoj|{w&s5((+v@?_;?b0R6gC7n*}EZuYSO2D=H8hbe9qry4rV5V76_YmKni&53P{OKw%)(uD0}C9O=Y z2boHscof&Ty|#gD>J)=3G`Q-;yUj2pNu?UiF(pamSz54}88qi~66r-t{F%g~*~;nJ zvX0pxnK?$}siEkWtb)~DPQjYm7>3SCFD9#G)yC!Fwv6I7c`8+flc{_mRW(ZLP5{kLiQ9Y!$*0jVzgvFqd@-OB z>e2(>rE>lYaFegI6cRcd!yh*y^{(p4$8;SYACIT;_}qsvX*^WDSR5mXHOKsKGWZi9)-&oQsEWZ(Ws6Thmc>iA5h_WxUpa*mYbC>C2-m zOJu0mgwT$>yh+JpPAzQ;?c1fJX_wUx;pyx_e}TjcTbWPLC)X-sksH+DxW$`G8b6Ln z>D(z#;B#p*fc15-=~Wt5^&SPSNz4GBP zh^?nGX%>)QkDq>8ss(99hBfc(3+Vq0Ce-5sJ&O|9U zy@JuIB|F8CWi{g{f3!qObOcj^BL0??b}+_sX&Acaahq9jqX{vA4fZA~#v-F+ti}c^ zDpXrz%Nn||pgB#ZujFz{xh{=3mRh)-qez_sJY~~k;tF)=R>90d1+}ij8+W2t9gN8# zy`t*2fl7=JMpl+jbg*Qf^(dk+KU+l++g9XpVq%cdgg-94*@QRRSe(pKF$vxd$FZgK z&!<+_feK6G1;$Nkd4G1aj?#uI z*_GjKS{*{$4`yO{Qx$Ki$ND6M#v3lC4PykF4njDyFgur1l+CLmFQoMelFArnlxW5@ zBD%}L%tpkmxd9%dVR(=Z<=?9TS~paQ(Rl>bXOf4v$lPXKMi&ojIHNIFv=RC@Rq5Rt z6Gj%1t7BT_3gQw4h+Jatm_WVlnzB@o<{dTOui-$yA=ThsfwM79`IeVd15W{!PXc-ue;bbtd=G5_tF>3u5EzU=02E9^4~6i z3Wjh`gBQbEwI{5cpz8B1{HLVLiQ#{*l+p~8J|M@t5!w$d=@6h*!0whRB3`=K(fcB; zd@`p{uU9_CHBzqVdsr^24IW0bo4$Jch^x3o^|~Jin-Ez& zfOi`Z^g*;}tlX}LyxsA;nCUNZ${rT1Bc4ft)D{vcCDO^ZD4Q7OF?`&TKmG7VQ*w;` z(XTmQTBPw7CgrI>m*khdbA;Z7cml4bs&1^vUjJts>dzKqe+zOCPZGckf8f67{*Jxm zswL-7u#FFIdfzw*ds?dWgu$#8ra%st_Sx_%-1K343YR!grcEhyMWZ}R*`wt4CHTU> zVEPU-Owe#b%y3rRvG%4Ra7ln^xFNwQg1u4YMhc-1?o5d2Sb~X);x{MW-76T_`k_m{mW6cheaf*85@RYWWGBF z4PpKcx*~|P>~jHHtHp&UtDdKVW1lDR|IG1&lxmlbMS6Y8IL6_27HQ`TnA2Ff{tu>M Bo@4+3 delta 41987 zcmZ5p1$Y7Uq(T+=e{=69;r;u2FUicDnS1ZZneTk(%<$Mv!>_*^#LfM}FNNBsB#F*6 zCM8*Pp~Wd#q8sf^v5W3>CM8?+Ad#9NdQwuVUF{`WwTk5Kix^~qz*ull|pjE9VKzz|vj=NePL<`d_VlZt<%TWpiI@?jY7drGLZI^8#>6oUT9A68lIatw1FA4G%zbgor=sPK4KH*kb8lBEcRHsAKLF;=)QLw`zswmr$C8}w>BT03m#7gI9MbQ>Vkf^0Sj#yDg z?>ek%JxZea#t$OGueYnp)u4Sw0|jI!h(^lIPElt>K(UMt<)$n53+}N_L?;cKQ|l^m z*4Nj%>$Exa0Avm54mlnp-F4Gt*Q}z{HWqcY_9&;Sgz=)I!ppa$&OLjMEM7xZZR}zl zt!a}X*3)Zk5(UxuHZkHs`m0S_v5_2kNeT;cu8*YYc|qb~x+gDDJVM*@(!`_mUS5KD zjIQQoh)opRwvE_Kg>4;T3(ae5Qnm`tenLdj-nJ33+wk-NJgi`{+~wWu(swXyOX#2CM4rnjuaJk3Knl+XA%q(d z^0YL(ro!zQ?3&!*X;PM*rJAm(;v8{Tn{r-oh_47^+xNoHw{)trPMa|o=wjD4wu@*Z z6!Kbj-^wc2u*zD;u*!xiP3CJs`#&^MQ8yp)4V0#Z8oGswZ)tfqv-%w>rqlL#j71mp zi5VB;|sS%q&NO*^#ca8QCPk6Wa1Lpx@U?Xsjz#zxJJ7*y z@R1*dneOQkAbz10J(9(*w68~^`8O2FelBgOET8VGD{+=jca*wnDv;Icce>HTuHJ-1 z6z@;NP^S0vQ~!|9r8Ak)A#zAcUF8jx?iwlmr=YFIDBAXmPk^q@Dj?bFZ}jR-R9*L~ z4?Wv6Q2hs)S#s^!>8qY$;$OPn)1=-;W()h4yc?yJm@w;SrY5$4&gL@4xl(}BWwbG2wqQm;t zxf^RS0~+d)-AYA%1f6tY^5lC7ANoB%Ni`tP#`f>9pSJB4su&fr{T@way@JvGGkT?~ z{#tqdLSdyty$ni#!WX}i%M1d6bfZ^-2%_2%G2R{JbAzdEK}Qin)dhK2dD{!1QRrxa zT@6PY@x17euu(v7qZ)x^B;~FOr|jNF=&(+`?Pzgq?*uG{g}w8!zK--x5^;2KSlGr6 z!pGPjYDd1lnSA?XU1NM+GhgPAh=MTtx*=ohbMAukFuHj)mosf1=t+K7hy9iWuLf9k8>)&ea&}oB;uV zV%-O%*t9VA$M2>FN-OCD565rttjQ+QEP+jev7fXebIY zXmOB@{u~slmP#?+|1ESt=HLKz7?L4WHa%S1;f7-puLI&7^qWzPkkgD_8XP1>(mR7w zlu-%=eHG_df>t%`Gg_gAtu3^rqaSrI^anm0RG6ZUMRO6fxLufEbH9&M_?bi{oemWm zl<{ce&FH`aXZcj^)h0kZmYg3(`j@&In$~j}g%qW!P86AGfBWzdsaQ$@jLI8anmU?9 z6-726xTQrlr9$DJFJO%vEQ)LILJdEBZ-KkI+Fj!)bnBXXGP0%49_ef-pXz9axlUb4 zR#I@W4d5-e*rZHXc>Ryi{0$F^aBWM_XaMPCJcp$bT#a)#d3ZDtVO1n_3@`XFX zKAkgR2gcwn9@YjVQ3u!5CA3=doJuOj=u#C1%kZB^{L6iUhqB zIK*3-gK1$4`YN4XsR7jm zo{!Xe7K*!WW@WicZcy427t-k=$?77=L}@03RhFQkR*R7(wWL(3{pU=otJFI9UdkDo z1sFJCXq>W4q3xTk^w>~eWw}B<7TDg6+>dK23 z92DWaWu@@zyb+lpc*)`QuDSs=lidz&_wD7@02iZBE>d034lEhF<{cQ?H#th}j?ey*B6^V$G?e&Ei#BHaf%n8p>sF z%lXn93ekxjI)9dPj_mCNbaHf(`Z^@yb@&=MCQNxl>)oUZZMGdmnOun_F3&)gIBQ%Z z+?c7zY;}mr#zZNH6<)hR#Q96b-`6=?7964NW75Q%^!^wJVCmmu+KRU+du)pG4yNXj z2&x_%EdEOi#-^)B(SD5F-HpR*he>;@)iF9b)-K+q>tij-dl<%I5!<4e-dE^Gc?yji z=PQm=?xZljc3b%Pdr+aQeS%hxi?*Efe6zOd(CH10^?hn8bX9Z;i?f}H&W#Her|H_b zc=Zf~6Qr*7E2#ut)t1u-ls`U6`B0HoW+at88bA+>4-+5J*6}IgV>&wCrhKB%nvKz1 z*hUyNHTX2w8bxR6C3b;&OtguMR5sBnzNSSJ69G=2nwS~;Ekt$W$l0K6ZbMy8?R~$a%MIOyS(51|WCo&tv^7`IKY!T7!F~D;lRb8sHkT!vub^Dc zlHs)#&IXr5|AkEnS*?Di3uW!ZRf=?4)L$T%BX=w+{@zIAongSDGn_W{cjQNL&uPFr z`HfFgJ>0 zj|)HAG$~NIqtJ7cqSaQdCBT%L+StT@2>NMKvS>{q9Z!3+PD(bFbE{lf^8;hbOnoW zT2~W8TV3A3DNnl+Fq__UC1Urx<}%|=0w(7HC+1I1MZZm(9FHlmdU71l;?BunF6jNq z3D~!;O-@#+AJb zN@>o=_AS9-gIn8PQjxDsk_ZZz8mOir8KvR%cq)w6Q7!D z7g=<4szY(K*7x3$BoUM<2_nsE$Uz0EG32tVcZ>jYRbK+*#9gmxYoNx;EYXJCl_sTa zYnm}4+NX`2h3zn!FNM*;%1E_68pxpiAII?7|B8@ix}yX6PfGz7Y&$JobfSsVQo+I9 zKh2_aY0aQgqUrE7Khc$rPfJm{wdTdJ2FWlz*4z_~$$4GiZk*&8=Bxz-Ep<2QHc~$I zm>vhPH*R{G(z~^UfDyE5daT+9byC>!6Gr2c>0wIW*1DCaSq1$lxGG8Q4++>L1s0<; zq|kh;0pzU85`$=MRVLWC*Q*?&kSE7xjwG>5(a;2E*z3MfXx908rFk`H4qnJQxZW~Cqf%sWQ)7>em z6S6r}cFn?B_lsa(ZL-K#C($X$l+$&02I#lA+9azBl5&itG3G&m^^W3(sXEG>Ol7rc z%9PfW+a-*))P@_TLOcTEwEIYmsHBf-Y`v^u-b2m&Ej zG$X}c4S6|^BVCh9UCuh7!U5GlwOXgupvvJ;#EpDXlMh(rMQHuhd9lJ6kP@RF4 zjq{~l9arb8)*%_s^KW9z`_=_2^{sj9dQ7UCx(KxaMRq=aT*L)P0&NzMB3`6bBkiwC zik^u=AEe~&ivP=kS;$J{A^p+M!SzOvezEmw>Re>T@~u3ySypdU??Ez(*Dn=e@ql$r z2Jk%OO54nXhTW58a|>JR@ayIJFm*8m;%LT{Sl?cA@^vu0gnp?{1Pds&OiqKha$jq{ z@DEh%x>~57vIc{)v^ABjG5HO3)w{G6xU4maE@s-@5F(b-p$0R6;n@b0x&lona?d0v zBF9SxvNjskmB>nB+aBnn0gb`x14x>9+fyPus28Y)DX_-%b+n2WH|B`d@)i2JwEb@l zM8om!THp7nsBCc8Ig0Blr&QKBweoc+4?}tL-07P?WMZ$zh6a5GY@m>tNeX$?@SvID zpcu<$CW(i%C9r3vueuQpWYGGJ5wz$jBYg=8rt32^!8w{|wF7)Cos|sEaqcX0>|>DB zwoKi^D5!H`f0O;XiT2M*0}c7*tOP*BJF}A2?GUxl#s7p;_t_zUg(b7&O-~|E?wieT z+RTPNMXP690TOr5Zm&KAsR$}s7rkMQ7qFr_CtlrwEVBevCg1!?9?o?a4VjY(%(!4q zqO!X+o%fEW*XKmW?SZIf1W6OCWgFTnTcFdQMubbKSK2sf8q6uFEBB!w4)$LJWzG#$ z_ahZWhpQr5H1`WMVQ!M;WfVvZu5I~+eM(F7`}LVvQapIDY~w$)eXcF`Rfxz5r}1m@ z2mWsL8Zu3^=6IY>agj_PpxbkkVqZt@UH#a?dLN{2_aulz=_&ImvXEMJL19dcd_o9fcp-M6%d=7&bm<$D6uw~>kmk!_~fdH!H8Q|6_B zy)2%WsJz=+Hy&5bi&Nff%|jj)(d_*?cGbtG8kOU%S=dC3kG4Kfw5EZ-o5(WXAWl-s ze6xBAjb_lrFcX~$4KYlfEW6=MYhHI!M1&UCx@x2RxF85vFlIrb_=LJI$W}h}th`P+0;mQ5eMZ|*_&L3^APeN? zuM1KE{^Ay+kRxCT`GSw_jQ?9h;ll{=adl!dVe}=rA zQXasq&sAyP$d(G;f5VP^N5P+*b z_XaC}LGP`N4Uq`>ZcF}eT5@l?@=t5NG!3nchIn%_hyM0uKiLN3}CXPNGn==U!J0PamfyN6pCvAEj&88HJ!UJMpeBe zM+YApMJx?dy^#u&&WAASxztDXK{A{j9YvHz#u<@}B-=vx6qXu6R<2x{3>3V7X@csH z60@f1t}YD%9KF5N4mfIC79SIYk|xO4#F5C?3Z}8k5V{se~1L5_a|V>TYrB#=*rjcPZWuC@%|(=2`xlp%L*gQ z3V)GI87pE%3iVx)1`j~(3J0jktt+zP(jg^P;4pN*KCANNr(_^IODDe6l~E#_%quOR zAG@wJgMJ*d(yF$BK(cN-J+d-X%|kL4&@no&naXO5EE_EdGvDQ?YfraVCRjS4L{8== zdZF18kWcPNJsya+c7lk+IU4h<^BAs{wc42$JrE1x@v#T&K%Q?rkZkGZY4R?+voCbF z4#m5ZSd}4qP}Zt!&~@Wi#e;oZv?^UG@Z!UPN~GjtR64pUaCC3aQ*|s4#a~_7FtnLE z@8cS^Ae7bx?`P|{udab?72*}Gp z(V0IGMj*|=S?H|ENKfIgS?U^XUV=<1+b={`IPX6z zB7JhCT3qC%0h_ZAMvBGs+k*+p5-%R|tFWdNxN9r*m2fYr$Vn3<%|R_^!Goss`M6f9Pd|Hc%t5}G%RYIX+F@QtD30h+ooQLLiX8F`x>`5F&fdR6eqxf!^7-rAm?G~`Ea88D9WQW7&-r8U--Q5 zf7qgKLY@g)D9V3CrBlv$*;8BS8IIBT2xVeIH2y6jG)|e(Xsf3R<9zZ*(@6I;Mo8VP}Zh6^$jVgZFzpp&h~?z z!Cbg0SRA2so6ZgQ{7Txk5ZQGo#yzkY-O}C)oYD=E@kb<|iQ$L1SioPLD*%~4~r8!%3f$(;1 zwJ2YB(Z$^nbYW{WVBTL_?dn&MjhCAdbpR+iO9Qs$DCfL*ounDoZHpD>Y1g(a0K3n( zC4lO?wM|le=I!x7YdyE;fy-;yo-BT#$F^sROLT0zRrwLS_+||3t?g#zCohEd=)`1? z$Bpne4|v?B{)`7E@}V|hlophRs#lS;@R=CJTf8Kwwko{HO{d=0s``zUB|zpSZiP*>g}q*8gEg` zH);J7cJ&X)#PH%65y|_$7COcGCw=xrrs;3bVwcI6Iq){-z9G&7i9dNL@X6^i6LH1FW>rZg0|tK8bgB2a3h{j(Fa2H?$lDhJ$Q z&!>`AFXW_otVk0!-%U@YD&8uUJrr$kD;KB_$|Wi((N=mv6?R#qT1h>r5A6IZSjtZu zRU>kmm3biWTk+E=z;CmjP7?mK`DrU~+Z#{EseuqPQ*mKzP)q*>Aum$X7N%#6YA{mL zMoFN-&jcwUs^%pRENrZ=EN>zSLTS-6nE-aXpJ}T~msd0oNd}U=^^CzBfuyEaH9v%g zXY*_8bT>gH#Xp;@%1%t=+}VKXQ=bi1O|m}amq+*&NRv#n&EshEvni?>CCPl}1!3ba zrilR6g0zLOg|w_IE7^BAKt-0|XFM(3ktmYr$sO^)ct>~Gf$@IakqLAcxzi%jsol;b zkwIg3rh`CSwiAwK`C!RWhx;S4ttlA8K__-5DcLID`2#RBcvmn`o_$xMISFXg)<68!6Onw~x|GmByyAS5>1+zElBC+npqO)4JWMY9C1IHZh&v9Rz>!h20K- zu%JB_c#$1@?4S!v_9Q5UDq9AKRCa_Y0iuX@?MV>DbZUmMC7kZO5QX1x z56jp0)BUlf$Vp_U7skN7*QgFdGD2tn*C9C^$t=xce06V(Is&N#xY$kM2orJD^@nYw zgRhY&@X*1geSzvIB;m*%9+6(qSXT!#z6qp_MuBub>Np);ohx5wjBHkF#RyumF9JyG z;e8fmoXQv5qPI@%gAZBNDO7D$O`zNRtja_cfj2RM{i;Bz$u`Q+26Tk9k4Eng=;lOH z4taqm3{2BWB~A_FmZMB#mzsQ1I&(DG<(%n~O;ykn`?JJkIc6&ax%QOh+y5nwFb3YGco{m!a8cn-A>{_5voq4OGZO_})YDgq=ZeL-F zDss(q)oH%Fk(CXaJJ^jvm_(qd0$vDLYmrLSfLB0M1j7tu#nSoCKvysLi#nS9f-R;V zdAePvS;Wn&qk;CnU{hzJ)U2U(y8ePMT+;u%&=%o^IWHzDb5t#gr{={_#27Aqu`S{Y zUw$!HorfB68n+*$ubV<=jnYCA52`)>PK1M@cO;jbl&vZ`e~oLw`P<0yS`>g?``5CS$5rY%HHsFz7N$OdN7!gjrNs}MRAa4d z_erb;PZ)u(_MoRAlS8-1Bym=f@NJ$gPb1qd1F+2g2-s~}yU);&18D$<_Z)~ENPfd@h33l?0ww+(`wAkXa99TS{s84VCWv`-4 zewohambejJ(L(LMMnMN1h^*{>FdmVW&V#w?8xV(*)On0(idw>_ogN~_5__g+(kW!{5UPh zx6NI_d8ec_+G#;I8m&IKa#EeMP8-S7kO0$!7__P*(Q#*xlAg_em6Jgb;Aef`CZ_%a z+IA#a{SX2c&A)XQC-M>9I1&dwGw{uL@R_-9#w(wyG$b~Ps@@D0pV7iMlYw)e#?LS4 z#G4(}FVRMU7P7`)T9gp#{Z_DYPUUN(f$`2a2>)ic-FaI4R=j!v;?X*mKlGMCxv1*y zm5Xmh0QCOxmQDQz0($sZA;6aGwr{EX+sW#8$WH}$Gt;uSL)Gt*%Fs8reQ#TVj!(ax zs$N27T9b!T4+8p;9PcD3KLJQcl5g5OkwD0c-?54-wEZ13JlTidNl~w%S~|^uS$zk2 z*X54tGf4|h{Dr#xHvt5r^S_De?~sb+ZcapFBI7|SJ;EcLIG!C6Q^D81_P|V{;mxqz z>|~hkltU8i&E1WPEnf53hM;;g{n*=8-W2*4ihMmNS!1+<`_womc^I$=6s2iV#_aBh zm3QbpA5$dqWEV+YTL9YEkzeJi(-0hN==b8VgWP`4qQrRX@%~-kk5*$*Bas68B+$I~ z4Zw*@-?yt~XRBvtN zXV8Nu;+0Hqo=_u9E#WFz-g*S>jS~?dFCk6YCsj2^Yk&XGkyL!r4-j|kNs}oLd9oWu zdNg%k#C7Rvx-G3gX%+2g|H*EmJzYDQB|4D#RJz&`HBxkQy}Q3Z)t>TIJ0Z)=XL3YL z@K9H^d#1i?bw;jT+yCi}Q(@pM&zwq$>*{&lT})*!r^ZTj!-zj(l@vO_Z|~C*{7yM- zQ+j&S`L?D|&5hWEUh>h1Nd|)$;lGoe(+l7G8E}HOi51Z8)3J!6j5(7G)Z6n+ywcyB z{%&KV`_6mQKp#wk5 zsOY0aixaYPedMRsTN?VGopBmNKNTt!~UGY@>X&{{06F#*8T`v4I2I%sUPuqxjbo^60&ahnl zG+kW)S(C=~=X@4~<10Ns%TyL=^M+P@77)7_#Tr$lyJCw6$-Z5J%uFp7o)5<<0qiZ5 zK=oc^#?gY}D7y2Rf82dYNi)2_DgC3GF)V8?MYg4huL{6%m%`6Gt1FNxJ%{16?ehp_ zr8gISB;tZ3{{iq1>?12aKwp2J49sc#!UC^#>KAr(4Qj>GI$M-qi($T&YQM-r2;`P8 z9AX2V_##yyZz`J>PJUm80a9AO%uqL?8Up*mO)c&QMwW?cCdV3^JYWygV_#;$8U5~; zR*-=|ewl~^Fo9nstD7MiryEU0Uj+g~j{ho4+3KwuN}c39+D7}o$^d{o`&GPne8bsP z^$AqbKQ8}l1PH>BXD#Z}+B+N>1xS207_o_4&svpT9<}q~*$DMH?S-6W(RY2?ZVEmZ zC-zX*xkP2JH|E=d8eRht9>TFG9+yQA+_D z>e7jpm*gCZpv`|8DC4}p`Z9!4XvpU&hF*Hu=6`7V`Ap>%Z@vQ$srJMJ=YtWYc>KH- zhheUqw*j&RT(AMMIWDB*FwE!+N#Yp_?@y2q=-lY_aYo@rtNXg+ig;EPYXBTE;6Z$(%j&D+wGtgo) z02t?d6O1!4E5EUTEZp&pMfu2EdIRX%H~v6W|9)cyT^RRm2jw$w-mahns=xJDKF3JO zgDdVZ#V4q0a(~2Ux^+zVg*RV+3OoFPZ==*N@nk)6E zGML1P-$@toLi~M^p8hUd{TelFwEgLDE_qHE0^GH8ngW%+@uuP{2`%Q-x0LgJuKFG1 z(|{o3=%8N!t^M9d`QBTLVLtG^ulfTDlPTogDBe~qy!m)r0Ep|~`>2=XLwL^&;hF!A znK|gDRzG>ug##w)`GZlt3<*hRh0~-TEI?n2f5?gc8F@|d%hK&Wphi}@>dnE=V23{U zg8{tc4?oz!OByfbs=q=ykwf}nvo5>j3s5%wQarrAYc92e*Z1v9cI8if{@%G1BmSb8 zA5+!8Q6p0`$jSL*G-3( zRPtu6T6xp$pR9mjmdh4Eux^**AT{Q)Sqbowq)%o`s8tZ{y=+6E;pxkHIC|oB#Rim= zbR`u=ZPAr1Y?Sk^q@k0ZMouK1x&q$MNB2|&{2Z;s`sjf|oqrAky;t;eM_{AnKPMr; zY4^`Tj5vo;tEeU!9uLgpXf8wP)Re0-80sp>&bvr9j{x|HYf?^Au*nlfO$R=$@*1k2g}-`ES)C2Vxs4-M*>{Edp%C+ z;G-Rmz%c>xy%7qE(0n6F>Fgt86caUl+y#|1^-$$*tSH4om1l38QF&Kdbi*NV7Wjrk z>F(p9=Y8nk8$oIhRE(zFKO+2U3g?W}xBH%y^GlkVkCOP7GiEb?2~m3aXi%3+?iE44 zn&Vl1W&s`kB?pY+jbGw$b~y0Y6s4~ZAF319mMPee%6?5&`=dp>?g85RYq&DNN7qfC z{u&I-b?H~LWe^1Z$4)P8tZh0JIvCHEE{347;qp9*Qs~oibYf4w@Mp($pok(``&)uq zjCO3gEw*>D?_Ik~37!8fId&+D?{XvShe7ZmtxC!Idm1p?fZr2wN~Pxa_F@#@!5L|~ zkf+k&-vbf8cTPHH*!3MKhg`y~gEK2*MRjXW@Gh0U#Uui4;WB{y#5u0Gs7qU%1~!QzKd>C zUpXcsG|e%K^8e0M=J;sgNL;oI44QoUTw3#Yf_e`sMCxbnnu9OrArGg`5X5%n?;x>& z{{7nqBxe363kQh@{gWUT^L}qE`E~zQTr2SC5{`8Nc>YvjLHb-8RzJ1f26-!Q}!KK-v%S%Cq(!p~_)B0O6>N=#XO%TtUPTVqp z>igtY8+8K;Z1PlO9Hrg%1KZc`w&eLn;^#)1b30CD2q3)Sc(kvk$mGKwrPptpl*fFi zXRejzc^fv|F({jSXu^lFzKBZGt@$nFxRZ`>z|nVXQQOeO|8U)HWGmZg-JN*#3GKxu z+`=|~>P{e_*tt6<92@!jj$J(c5CXW>XCM$oXTG>AD(~5c#)%}`4ito;o%{w|2r#u8 z+LS45C_4kb8>Dnzi@&2}N|${rtD(9XmY zW!7G<6(T|G=LdyIRi5{ej-!~Cv%4?wMIp@MMY+<_l$U&@nP&EBr%lVNP| zn-&2ZfM63>U#NNcLa*>PS^6qUt+f5w=pe*oG`OpqLh)bY8;Zyf2iV+NSj0i@+FB%w zLtNfk#ET=m48PPjQ8i8aLHV85B3gONhivHs3ymlDekZ#XMIf>Z)e z*eBxCn;`wi$O?y8Q{)gVMtLG;uyc~`Li@z??&cqbF<1+5nCh#v>q8JYk< z!{OpP-Xcu>97z~|Q^Eo@0~>9(`T|)Y>|EtJ*Y+h3@ewxVthS5!%&e3m=Xiq;2K_w0 z?1Nsshzgl>>eX2O)knmLuQ|XVQp7iMfZ~ER%CNq9v-*~u2GK$N4pnS4BNZ1u-~g}k zJ>FX=(R|K;z>gnL1~-33*hZr;s+W)g1VUf|#~ZQH{>UAT!mj?LH6TAjo{{F6MoiSp zyv&Gkxx%}R!YY2|6Gn{7RlW*&ab3csRB?kl0T@_*L2ZrY0(B<$()^mr78Ud>FY*Ns z`y21|6_LvCK6J>}m19?@Th*g77*T(yHi`Z$>G;E$x!N`}re0Rt}9i#|ID{Spp|bWjnAJP(nON`!$ggeuW~IB(}!Tammc z2va7C&jvvU#PB~sPztuB2#TAKS3VK_A7KxLO7u8%=T;#7a$S2 zI2`JsBhLyK>2aMPC_7)ObhJlkg&-h*w}~)oTO`h|E|cF`x$L+ z9VNPPZiGk^-Fa*TUa1E!h!E)_pLaxHi|EB4M+jSd0pwelGaSpQX{ehciC_7w-Y7JY zGdUW8^DrIyaOX%Ym%cnQ60P>*#gWi}{S6Y4>vt{;;3JU;%^Qenpz^2KIUovq;b68z zLGu)H_bBv85l@l7ig{fW=1__Dgd?LYTI|{oq++F|mp;r{HGMF)J&hn5ifkPsm)9YX z1OW#vFu#;7(IUY*3?kANkhFCv)E98mUF_a)E{hiSo+BV6r~Ln{i8{9oT+|rHktmma zhbL$kWoX`kmPd`^Bhi@0qxpQaNJ<#%c_N@1+|2bFRCDy2)8NuL$8jk2_;mDB#%Q+H z1TKuh_BWB|$A~n08AO^@Wz%^8kE3uB%96S4BG$qW1tLf-M>?_THkxp?0!cHDh{rW! z>d9Obi$R^rb7P?tDp3xH*3EF<9gE33%^*1?2KyT$rt?p+!lYDVIRLAydjY#d;1|N6 z;mR6R(}LB_{M--`&^)ExJk2CbqL!DLFhytZ9+T*z)ERU@u<(Wmx5}@pM{P+}Ngv5* zcVm8?tG}yGn??Y{-?&Y}phd;bgS32S8IcOlu^x{)ADIXmdlRZ=pIL+{3k_+r`sacY9+GGEzGyp-wz-!Pv0@#wL(X&Ht@xt zaDJ>AxUAV|L%*$Mn@yyv>mVH`gBQYJyiKk|@9I}XZ9skmPYiWPhf$tLUy8#Gt6pb`jO(5mc6wP&zZgii0)B+Je%NJ@qKcm|ulM)b$`i;^E0A^|Dtz-Rsw*|vx`PiUpj&pb6ATXDO2F2# z3$2)Gf`4?{usR&2^1zGdkSqJ9u<00iae0H=bC1VvE=t6%vxgTa0$c6lXA?EFe>_oG zl@|?El9`FCL&9aaK%nxHK_h}B8HLM-xFQMt^$M>}5^3tIcm$kt$3%?3ghRT6=ruzV zl=0!elSHWUhJl))j7{e) zWb4Ie>o!sJM~c>lOj5ZW4s{+L;EhjmLja`d#E45 zntP%d3?Ii{AFNoY_^7Y%aGWZtl4Ef~4t_+2c881yip#M$iTWDz&=jy(*r+p3r|_M) zuE)2Xtb7_$R*k&$*IYe1cliMyOvUSc#1~WHNBS5tvC@|2*fbF!KH=0f^h51#!Xo-{~M&7(`P1E zrwe~^f#;^97cQcjP98j;j=uex-@~~I@hx9X7fH%@sEbe&X*6nWea~Gouv1*((HW@v zBdVI|(59H+5ta3oaK6f3`3adgdh(=hJ6+}@8R+pV{Gw>P(TS+%WK(FSOVQJ?i!szL*Ix@hb;q;nz*>mW7x6L(X)o_>&iB zL0kRByRw8s{RfT5Ht|ww^SRl7H#$Un^%e?~Ill~0tHc3I?KaY$m~ze6e8<2m9U?(# zW#o%vut%M6z$6exO_lPW4(LvWBeK!wt+^x4rl=~^U5vE8{Q+iXIrRgZ-aJ2BB%9^d zBUhQew6#^4GWkJLZZIupPO)2R{q4_*IiedN@}wMeUm&l{ z5gE}z5ZByPx_e8Wk(3=D%qMaHGDG-wj>t2IdY;~*|0<*s)R0y<7v-Y42%edX6&uM2 zEw*BJI+P1V7sKar(E)KrJ;bT@T41<#pg=+g{mK|KT27YgTHZ+ztyqne6C26%aX*1# zGxEgCz^^;o03F%+KpTul0>o3aOCQ(^r&57u&3V8_Nyv`WBGzoxUicer%62s_f^v$y zc|{)PXbNwHFrpO?<1X+LsF|o6Llb*P^2D~nSIIJJ z6l{$)Asr}-*eFDJKvPd;BL}C^?(#E)i5$Mr7E3CZMLRsA4V&9xl=HY}JAjY2TqRTO zcx^k83qX6M9s0Q=|I!XSLMM)Hk525&`Rzp;wF_E~)#8kJU3+MuuKZ|wwAzgiv`5YE z{BwJJO%D$3Aad1w$R^UocWnW(Z*hN_?1WxM?J%>W-rv}CA6)@&?f`Aq8{+YrHsDJg zM3BI@TTjMn{z3a6|#7IR&mI(oA+Hi>ckNoQ=?f-0X1fI5pAty z@_iuR62ekZp+|PfRwnVHE~2ASZsfAHn6an3fEuXa@4Em&xr}@$74tT;t1u{&TLgmj zIEpEr)jP8*P|?)8iuHhsNHl2;#BoB)>YPzp6G+;nYxf>g; z=Ao-*XE%|h)S|O?B>3fNz(T&|3_jQm^R$jHbOR8qM}0Vm_G8LBx?{u|jlBIj;+!WU z0kG)qE@G8g=qfLhUr})rmoSI-cNaAGxL6gTiS1)`$k4@hQ~y zJdW;x&sbmtSqu`X2cYXBNXZWU9~?itrd9_mi+OzysNy9M!T|>mGsk;~VC6oe3`*DU zC0ok>_7H8wGS2O(VZpII!7SWw^vlu8XK<7`VS=eit&KWeA8!P`={<1eldxufd z(j43elWZr)_JL~H&0YFnC-;R`e}&h;^boJ|t9_xz4;bYkDZbek``8;s8Sif9 zjDDDm2aWP<92etn(5MspiS(!=c-;T+(0S<7R&VjPe(0XJ`9wbe*mp3&4wzajivO~? zzsOdOp*7s9ft#DSx<5F*chM9`kBuOmnhp5(czb_P#_tGLWVP#B{0Cs) zIKk!t*s4#;kJnuPTt5J(iB9p-0U};GZRBf1MRX*tE^tYG-fT;sfxJFr=qcZz|Idbg z$RPuvwLapG1ED8BhO9h*AHxd=Vwd@ZR}I8O_>}hz6rI)2P^caGm-E!X{)0q>^0`sM zLhT$3_Z=hx)h{5F2}3m1A36cBPus1(Nuz4`f6kU)>?J7a;jNMl zVoaDnxU3la{9mZv?9-1_|3*@aFyK?gpt}C$bHyS`xn<;BgJR;)5-i!<+Fa7E*t{E6 z2`(uS2{tdx&@jBb$94lUt;A)7&67!GD#1H=^Ggs`eIT4mXWq2%KPBiDBa#TAmkPQ2 z5Mhk*MOsJ9i0UoHeF3=KQVx_Kmkohk8i3*yJ|Yjbfi(a##|MW%>j(Mr){n9AYIbwz zP?+PvzI6BljdSqlqM?8zA*gBAP7Ak8|4?2$6ayOOON)9-zAcbHA1b6tb5&+X_|iQ% z?AWeUgs73I9nS#=0Hmr*g->)8(o)+=O2BiLRla33uPVjZ#_*0(Z0;sLSqeQF$3K?> zpqtrm7`8hLUMwP8kEXZsgkeDRHeadXb<@O-hAkT6^3xeZ*=#(Y7$!_=0?N{~5ODS# z4t1T#7F-*tCLueH548vOl^QphYln+WCB;{FUn0!e46t@-IA%i{hl~J_&+ygQ6v8bl zk>IYhzR3=M9Mb#d^f5zv9zd}ss!Nsg}`*%)ey05~&@gobOwIU_N_ z@_776z`(Y?8s9p#QNDaT-ZBy+*8%OCw4k@ZQdcc*g!LG=9r?Pf*@excuxEDVcB4c` zfU}xW7=iA-`cAQXl!ygHJ2ncuc2Bfp=j;?=@z?JQkk82XrLnJA0zgT)XL%w~dU4Ou zFiQ%!X0*sqd!v>fV%&5twhtec<$d`o%E2$jjzQ1#_m#o;8m~Wk3^eip{X@z%RWgWI zjKRt(lrJ2^$H!m>Tv{fSQs4CGuN_^Nq1kHX}H7oJflw3E5@`MxSc;w94MD`trKU zTIsEo!##@Y$KeA;^VV_L)W-0cad_}p{(T(O+Bj5BZ91kLF2?iV@z~xbaP@f9n8=Te z$CN39OfH{3Bid>ku#<0&$CRumGU%EJ!U?52>Z>By1M?9CU-f#n(IZqj-3vAEG;*`IuV0d%RfxSB%HxPWl#onzVhZ*9#JNOqZ?3F zv&%quIOH)!{n%F{FDS!&p2geCuuIS812Q#-&y@*F#9UN?392KxKDu>w4~IBKiZaia zwm%=i#ZG+Pe267^Ldb*RP8JJzl@qVDkas!Jt&30$58A45T>4t0Z8eMeiWAsv3EL;Z zRJoUjP7(?B`yeI_QazRwTyYJqDE3@WycA_oT$}`;{@f&C7`qHGjiBj5FuQyJzA0H%wl;!1>oz37CjWI-47{< zpQ^yq9)w&vExKaoYmfthm|F+UdwsX?_A7E%*1P13v9Er=*XdLrZP*{?t&_3#Cb^(0 z9^ttzJoHiCIXD}KpWOf#yD(~ zE#`>rd>S(1asGR4J?@!xF_8;bE@5qnkIM}Hwx#5^H=+XU(-R4XL#Ba z&~eZD(!#M3ylo07vYqlZc=0dzsuNR0l)4LP{hFyT>0~dG7vgFL=5r`WqMvsp`pQ9( zi+Z;&&sYQVf810c)IGjBrT4&8Xq>&gbt){+{ivc{9?O@fg0g=e$yhBOCkRW*Ls`lW ze39*ySk5nbn$YgZ##wxg@OasmkGulLVQD3X=|9>Y#Ct1+3b^`GC4kwh{8gpsq`oHG zrm?qUj1Dleve5(Fbs8|$>nOmzakwIw=TCz}{|#O?4P9`sX*V_U$!SxEATS#Y+{T~}YHysA_+k9v`P}Dnoema!sf8}dv zk^Jnaf+c)ZR@TmVHkoP1czhL9;CsBb3i9uxJepU+m!Qp@M0&sE%B?a^yQ|5qT%XCTHEs0My>6Sxnm8s z`_FlNjYx|70)=v&mFWL;gQFBwDh}evj{B0g)QI-6UqM2Tb<^+ZXg(Nnman3rxO1Ks zbfqBYM6*sf&ki>L`vqSb@15C9L4M7v-6GNQ4eCh)_3jnkT=QE#)a=(k>ezky7Kl12Wtf!y&o?6jCx$Mj9iVzKkJ5#lPL;+lgHubOK8EL$*7S2z3 z*(-R$s2SL>uXD)^tmzxFR36*ojWaM=f8m`oz}@`H7iNe&%Wt07yUWRof0)1nJ8sJ5 zpJ4hEG8ztU`WFB+l_>k}A9mMah5pNr)S<6$@j;nV_!534w}y(Bn`ARjQ2_e4DIqI+ zK|s3E!+B6W#@(Bp^{@^R@lcPQ*2u@|F$;YCw2N}IXdDFi;jSv}N<%+Xm7DedSpCh{ zB>8i01KuNm$2MTa1o4sv7>>dGYy-MFgpV~~R|@6p4Z!7LY;DBm8_qo&u^=Pxu+1Ww zS2sdmMdA?-t=C?|O_yL@KZFR>++U4Y=_V9L)9Gp9+7Y3a)c<@rhbFN$~0ff>;jQWmzg#xu^&!DMd7*XD>W-~}`0iWEyH zl(zVt<%td12>gap*LLRGxlmJGc;#G7tggIwE|61q)NpX8Q6l3m3#$kF-y<^Pd!kIv z(PmdobC^UvN@7qV|2YJ+Qs75LZR7Z%dqjw(&;PuEba_kf7tV}8x>a9(`yQZ+etz;S zs!oCRXa9My`UdDDI#n})2J)zRm`{Uv(L4|lgVCZ{-sc}6^?6f-cOhS#hfyzL!+gx0 zV#uU(051OG(7B-2OOTG1WJ_d=4K$S3&W9VOl#kBGyd367)=U!{7r+b}&Xxr*Bu4m2 zMvdJIu$7MFxeG+9Wt8V@npB*Ae$%7mM)TnXfR|(V$^wzBjKxh>Htm+|AWz8IIPSI( zWXO1)x)A+6fmbhtBAV!@`H5PB)|`BDq39tdao{58m2y1L&imiPmRPh1!&|{+GTVi0 z+;>qN-E62#=ADb+rkRR@IL(E+KCNCqF{1$^_n9k9Q0oAIIYnHJd2;p9g zsR<@=G4O7UpB6{Q+ZKZva`Vo`c+FZroj5JNE>!+uF-V6QsBG2FQ{HVD*Rg#GII(&Z z;(u7I(*2{k8{~{@;BiY}@-*^_B~TMHdB+kg_gQ>u3A$xA|Gfk{X)fp9i_nsLFeS!E z1>XhvQN7hXrh75S^ZB)VLFO;O6Fi|nk@vy)T*!I%q2m`}$>HX1&1Mg1x?6oQWMed6 zzHDa+QsKM}V9F+w_aZ4bu0bxuWK>r>YbqRlD|P&PAAfxxK-N+}d4HH+hh}nh8TVWY z-L{`T%nF6ga1n|D4;89kh#caM%DROY-o_xeA4D&e{#KAI_bqz{W$xXqB0xM$=#Nsql3^Z^MP~)8yFroKx>`Ls%`?+K#X2|o} z9;E;4GWurz0`FY;e`S3KbQIP5cILvSZVTy~ULmAF=pZ0niV&&@iV*1#2@+6L6#Utx zv%*7fDk4Gvk={W>da=-(f}m1GQIYb0-aEUS@O|fmv&`HwGxxsjzLnC^Y8?EKM0*W) z`=vzK#!^kZR{!69rhR~aHQC5@cw#I;a6N{MrTo7Ei^ozqznKrM$ zxpZ@kM=VPhS+?>r9%mTg@59z@=rNAmXFEoZBlzqHLDi#1)ResPSU-+J?M@EJfVdjt z*Kzb%_&P+~*yN6_ma^kR7+*w;>+Hcc=>5)N~K zY?;m|klVY6MkA)jF;yu?1YI&=pGYIf(GZkmQc})k_G`;`92D#Bh1%jg`O?I^97(3E9kz%Ayn`D$%$B7~{Nv1+<6g4s@kw%|D!%37sPGP_# z;=pORCz14?!PZHHxwAMw$!Kjk$2nres%Pyq!j}&2JlantFS&q`lL@3hVeVw2@y|Fg znX=(UT$P_+5HiKcNV?47`qW8|X*zB6;ph1%z!h|u!p^^9=oIRie#e9<)H7Yh+9{N% zt`UoNL$pFK=7k%ak!k{BP<^)%oN$wuvVxBYSRTibTOsbpx3B_NU4M~z z{Qh9qIudhATZaoqwynNy8Q z%^tFYs52;UmwIJsf!iyXi7HdDwKUmTt0A2S3@oO$aeaNR=j75Hiua0~>q zFsSLIG2t8+C&h4LLd-aC89?pGbR#t?nr#&2OLN84kj5B%FrCkJ;fv{nx>y{U&a+Is zRXd~yR@1T&Q=5{-SZn$KEYa!{AUs`?tnMn`$N1}nbIF)JgE*6dbu$Qeskku1sHG}e z%Q$2)$c(R~)bE)Qd75%8*E!7L(Lb?lkN_pE_S?4oK~O+RCL zm_=D?@yQf}H}WLjb~ab1Hi~8wqv~M7Yznq@*;-rFb9IBYcwLXzVkQYk`8lMC^{pby zqv{;;(*|sc)IeeGLF=h@e;f>fKld4^O$2cELW9cq4O`A)2X#(q9 zBffr9-W1tZXR^`330?<n^dBk@?46EEira3xp!-;4wGTU z8OM_a!}|Bt>Pva8Hn=dC`}CyM)I%>n6^aJ)jDXm-o~JkUp8kA=F502zJd%#~?2s(s z1T~n)rhs|;`g_@JN45x_czi452uvlVe1TWp(b=j!fKX&p7E2d)k7ps9s4Vfv6vy-4 z@?uZ%w$H@t@hI<@-=&>SJJJ=6=2O4*H2cI!;IEH&bc1_7&kWt!5F-kvQajo+ycH`7 z*c2j`Jm6X0ko7Hd2IetDT6!XG0evNVS>1WRR79@@JXsZJTnMS*1JdU)X8|FkH?}Sy zp!LDI1;oaF2wupW{gJ(pC^`W73wf>@h&LBfh8<+p#s*!W__6x}Um`y{tANzP%WNCv4O1zUkHY&voM#E_os8wdFJsjwWM3n3<`XLEUtxC& zEr+75I)6bEot2T2@TW#<{A+9zB1ILH>@7u~QUlW{y!a`l)7P!qk&opoBh_dt^7D*X zYt#I8of|jR5dmXx<5Rxcn@C(l9{E4CSw!@FM?NDQV-}Hly^FbvXik04s?$P?mNy{S z2Y~P6#v-oy2XK5w|&xb6XS^ z6c6w?C4M9@5}DORvaHHVPxZWqMqh819&ctV=`am%FQyOztXxb{U^>n(HqsMkaFmEc zUR{bV>7YHDWynmVeNF(Jh5XN{&6~}>iFjyJ2{x|=dk$|kF?~)Cf6mpOi(BkTovUjJ zw_pKUEa8$aM873QcHGD8t7)@0#I*5nffYF~eS(rD6y`r=4>4P&G!VYmMW<0$#d>wkgSUr^JxlpPY>4>!4-WzwuK@HvtmRhI`AoE_=(^MheQbs2A!f2bqLu{5YJ^|O7TI12ZenT))@U=$JzhNe z5+5%mgpjDRZ?*T>frJL|@8Bd0r5m!QXwFQk!xb9m~P{IY<<{`pc2HL52_vZWE zj+G@0i`c=bSipn^o(Clqe|92ZIi>!uk-MDQqFqFknp7|iTFyiBH+XG1$y>oJTbGh9L3@l zoZ&m{UO|ZY9yeDIettmcN-ZJhtfb@7G2wmD7`@W)ryTt5N(wH{`={(;1l4qL>9MZrC%DNgS z#pdhms4iM@YbVbGxvRJim+<&1qlWs$iXl$A%FSLy8TGQ&Oz(Gi6?gXv&aNVF{MG87 z|3RdiM-U`_#UsJ*oIg=#Tg@{AqMG`AS+223KuF{>GibgW&*ptc@>(lpqO*ZhVc zS7NX)YyB-8{K`nT{^1!d;OEEJ~$B_~L3K(()JY z<(09*EnRIyC*9#qS+pnfn>K#3r#FV6Mb~DXWJCYfc!!WR)Z_olo=Lb?NC~eUg-y#{ zUMGmy9%2$XcBeYGa1Ev0dziO|mdE?-A&RQ2h+5Bs zY^crW5ob&D(!vUSfTqj|S#*tDL8g=qFq_oeum zwt?sugP;w>-&o{s;3~wS{RR^3c)Y%W`nv?I-oQ0U#F-5wt;q=5NSjNlO%f|aB7Y-Y z7ScE&4=g;b=yH3_Xlj&YNXL+koQ+4f_x{U!7 zF?f12?d&ydB9w$-)MlbkO^n~njj4sDn>l%H9NbJAQkTd}q8UtS<;IB`(Zc+&(qTPY(owP7WF|J{ui1z_k_ zio(q>YO7IIwcw{SYGuz>TE|-2wBjqzCyBL!Z5y|&HS)I6{@eyVw{Z{J0o$m2%;)3c z(BXR{!eQo}5mk;Xb$guOMwNO8wwoHHobA*gb@YB&Cdec!=-B&CHtk_SZfaOdj~kt_ zbUQz;3yy3z8mB$QabYs6R7~yIylty?&6;=Y*|}BcC!5Q|y0SSDD^jT;Z@Ys_{IpFc zxd_w#&c40q#$E~TjZ@2{cI}Rm9R%VYButDzGSxlL;pPsK*PgmJ3w0o8r{T=*#Y;gj z`be88BjmXSyeTI?$v|i7rsVGPa2{u|+yV0c-k7kHhVVYvxs&kQ7dLlOcYYck!fM>vc@n0S!5vHokSvj$_&*VM)q+I*=Y-1YZawfD;laP2ZG zrw-v*Ay#^Enzn4r*w80S%gPq9HHngXlGl1W6ccxmguaMv@-qy#c9HTIBlH`dnufD8 zojZ0AkDmL6)O>`^op30|{q%9GCN3}Oxg;I+if{O8FJqew8p*qE@Ogg2(h0mujKK42t?Li z?%5R7-^-J&TW_PgUba>1;6B0!dx<7fv1~67CDU+jFEJW0_EG4cfh-<2Xuog0kK}F^ zr{uZzbOc84<8-qzX&+%^4tDJ`k`m^!QG|b==L3uSc{5qgv+2aVQaUb@l4ah0BP(tp z`~Mbb$l!hYt&1!ylP>glu*+t*w*91K~kj+Huv^F!r(eYxos0_AL6=g zM&4nuQ83L6UOvRU%v(4G`D%7F%a;@k>+6+xwqiL)S+=n?(p_*`(mwn7ZO3()Y6n6N z^E-CRR9O_{dK@PA-Nl|v(8%H`Saz5k^c!BgBxScGf@Tg&oaPwI9^TE?>CchMC@Zzs zrZX&}BQGrb*cc%o9PU%@?#G8mxW5PR`4K|VLF_+bG^Og)d6YK~qsmb}|2sT$l*W!9 zFy$zz=#SWTlxn48oGMv|0O8(IdRQKpsohEY=}F@WLOUtIk?0opGb%p6BgUS_jPLl6 zGuZT<5f^`!Bg|uw_z>y}kWEGuYoCX6HbysvfrZOM)p;8lN)n0FN6XOI3uya24R1f$ z-1F+ue^0bBOTH(S{+V-TNRlM{$g!4-ymY!ldxhy0x`gsSP=>h7n@p9~)`iuDh9mU~ zFSWp=3l4b5fKP4rD_avK841S!Kw$h0bAO=0=XX+Fi9o;c12sd}*u^Eu*pT=m0rNU? zel%*>Z^~V6i&-TDiEq+md<*aYNY?uYmeXND-M0BMmoPS8a=-lr*D=!CJ9y$4m+2o2 zI!40sFDFXSwarQu7I%3sO{77|YT10G_)B@Rg8WBf`!V0_?lCF{?g=?hQ};^=FghPM zoUR8PPT8$gm+HxH_t1tnjx&x`BmzyA`xXr?>}yso(Pc_BLpInNh2-jd%IV{jx0Ky| z;EQyGoFFkPXO|oRsD6UyAPbtGAo=&Vo2KYjPf!safQcuJ>MGD)n#6|kfF+1idTa=h zCpk12l}?geTG93-!O(%ilO%0Uj6X^Fr2;mcB$|cctlVUBhLb#+L~??7ksT`t^!fN^ z6mO^a$^tp5uYdCtAs|M+zr`n-6ZO(e7Gws?(z4#0b-<2``41p%gu0yNyguZ8E{~6M= z9Ngs3W4WA81Pz~tV)(EkCYSXd6|1mWh^^1@zpZxsugcpxog@04C1uXT>u1RVs$=0DHRp(^sl5y{r)Udam1Z&x4f1AtcmfSB5U5(>*$brat=KCG*X=4k zgzU%Tl-e50FHmpP2G=f-xIW1)IS75nNDHl=E5YPUy2VqUe1BUs`-uWqK6|8qHR}`b z;ZLMO?Rm|>UQaOvyU_t#e?W zQj?qrT}|0z{ge%ViY;a~6qIlv?fhGQCZTu+7k(z$=mGmho^GB)!3`rkoGBNW@zv+Q z+ml1hglO(_;Szhtbnd)G{!xXrbN)rz*$c4jB8l|#ID64ZjqA-;0cKNI(rm;~dW-W! zBm?^({u1G?9~xic3ifA5A`?~JV=htd8epe6G7R%BF~Du0-92Oqy-wdEk`2O{OEiNI zX75;R3dtT?{bqOd`X>8~n=C^#>R#S07^1uT<}jwTmQ@fyE=3 zUar^l@|5%LO7ldxe&aJH@fi_}Q8Aqh1cEi8`y#AXJ6#Wr<2&QXkqg4Gm6?1>% zYfQuD-v~3n`QL~#)7h6gpOP}cCNq%xJHcosp8K7ic(X9&ckcCUtdXBNILRM1*DmZi zjJ)Sjx8QkpT?_;Du96SV$BWm@*9xMmg5IPB7<`pWu+Z+c6-Br{<_nM;dAHgOzLf?3 z1ZS^O+V~XKYm|f*quMowdw$N|{L^M!Rx_nJ?v?x-GMt)&=cAS%To}B+bh?Cc!=ST70ngq`%TGn!|7myH2S25)-Zy&Q@Xh zbuyZ-*f~>b`QX8I$^)z6xWTtviv~BiJnIDYQZ4J*hv-iS-C$o)oee0t!DZhldzI?i z#2)h1CQNng+kZr%S+`^}>^Dg*x3E3N2ckAA0ejq}$hr+9ZxS$fVE#=a>P{TF$=Cmy zeIqGehJ`fo`4{a%+%1X@->`|Rv6Y0T=Ph#Q-F690jlx^E$WZoR&Mi7%?v*~0x+aw8 zz~RhEOkWZ+mSZ2v{lO*O&kiZtzF(n>L?3h=*kYh8ki1xh4oj=Imk09_iSK}zMZj;S_hxWI*wBNH+vQ$aO+}jj} ze!$|}r0vIX=r#%d3Ea9(s62(_KRMzwTKvhIXE5MTb~%fQa`PO%`jcevJTCl6l>7+~ zcvD@pi~CsyTK~oGzhp<W5F28F#q1iXF^$s;Mw{YwZ zmBN3pYgKHQz!*Bt`y=6R9`0_F{7DMCUJNm#3H*(}iFg0t%fG3#{8wWduKvwMyNd^Z z6V~n_`ycM@ea>XYU;Are-~k5zL&MZV{Z*L%54Ej+`0O7#+8YjuTM5wl5tYLvE(~x8 z329N#yKgJ4A1jBvf9W7n9)tho)E3fx?zmI|U-+-~!(8_-wYy9N_b=&C5RAKAs$h1C zGF|x^+$En6LCd>5k6BTCmwj!ReU}2S9jothXB;?rml|&;ha_o97M1_wc7!^F4(KqB z_WzNcRY0%*Na4cR%_UTnE_2KyFl2;gI^ih!k3b)RbN`XdPs1pg7FW@cB`_7F0F<04|yoebGQ?`Moo37 zU`sW&BujmwFewaEzdA3?GyL;S_(m)>RmwqXuua&qX_A+7Y~MajO9QZLPW_+CRJ9!X zXf$=Fin7$^fLw1xNW7&EFSRunRSjh`>Y|~c(k+kiZj$75iVrDGe%1h!43$a+;W?*D zWHDHOoRA@naM@5S%7|dapQgxBDu&YE6H3La77mH=j16X1^}-@qfhRCldbLD}QZ+2C z_?R3M^U9Y~QL44W-99eLw`Fb6pqyf%AM`Az@)$fcxf~zgj$Rll1_#S2o62{H@D^ZB z-5&SKsaVQ&1lYtN(e}#&JEBo}6-^(_Zsk>FOJ_bXL5`xOw4@74%B$3br`RHE{D>2z3hNm`8XX3+rxt>0vS1a@A7m*$DYTGn=E2fa z!c5#Zw3I6|4q+=Z|A>d@hXE>{w(Z3MDmQ*8Z}abw6isARGU7!CeQ_gL*xnP1Gt4u; zCr+optQ_c7NDN2SK$S~R&YpoPi_+lOK$W3JI&{7Y$r8$>dWyxsaV1bCs8=2CiB}?# z5Tp_)2{s5)8J1C;T`DVvV^oler2fwx#Cb+zYY<;{49)}*+TNTN%t_xO$(;}ztP9S{ zuD*@7!CcFC@p3Tt<9*BsR=KVZIGqRq;>0GYa&x`!ITja!Rk~}Or(Fz6PZkxFx)O~? zQi#f-;;&r@pEc2;3;zUbrZ$OVv|<1>6PcRN$-Kpb*5L3`IGlp3Au5RxJ~peWXaPGU zBlwV!nBiN<>AdFyQICg32Tzf%8F<4=M4#!9I)2z~RiTs;PgoVRrsIK?3p@uoHdRT@ z)qF=gaxjc%giWQY`3|Pr)*89emsyAdHh#^=_|HZ-`-BhH-Wkkr$IbW@t?A6J7CCfI z4ecd6r9nul$4%oicIIDM$6YTXEXG#5s%(6Y-|Q+|Ephm=K8XNth75dx#txNcS;`qI zi+qzABu7ozu4S0*Ao`bJn?t1sE@uZh1!E|yHmDU2%)Le9PO6inXC)f&CwUcn$ZFAM zGqk9ILkc+P`eJIM z14aGFaC(F)2X%@sgc1(7U|guG6up(BMZhE+He*Cv67p9n%9obu!_Z zVK+~@yfc^_K}0-@%@M@Fb2uNNlGSx$$zT|ibOA^j%~t?celgGHhvRkY=2 zUTP0V>r<_oHP6=u(u)ozUC??7?29DFxr7rONiR#rT1PS-CpwA+G6^l?l`l#YOY=ZXk!*U>Kd#Hd@7~ zKOFQeO2E6(s)D-haNk@Q&oY;Kra!SYnw$3*&dbl=AUMWRQcQ^9)m=Ouqp~djaq3*3 zWiS$RVpIVAAwP}bM?AoR7*)ygkXOKUTGAp0m9WYHid-s?%jOAT zF%6OJie#(GVZ4iQUml;i$Z{>ztuhk=U3tpmj7x=B{5d9FVw_Xph^255!0Qy9BO@crI;A4`T6jK#71mJsZUCD2)MJ(lllMbS(3G#Ss=F*c>YQYJd5zD5rbyvKTxY zuR>I`Q%4W56ktf2mn6rqH0#|aWyJrqYiAr0*kRTY)NJz<`-DTz$MTao?ho8AzdhY97M@@I_stwi#&EH-7D zB4gbo#YB{7n?z*I!HY@!m@1f@M8vC#bxA5tJvIBMLRh)^bV_Ym_9bAWLly$}ms0lDZY&Cv)5C$cvDv z#!BKa3C@rTeeykZk(feUV|t(z^_Y6hNzxdHnJLOj>+xqPB%%#C(kxjTQY!8@#EldZ zw#Q*lRn;jkHc4gAChSRF%8hU>pfu%G0v6OZ$`pcY1{ROZU^YuuoMGN}r{pO}!nS7( ztGgvlmQQeq%YFD*1XH~61zO^nG@@K5q;uUnVtYCnXlMMAu5uE($op~$c>XE%SQhh> ztV>tqWl;8f8f`OFn(F3sx8EFz4>I_e?wFauk9Y>#Gl=HTa*{-EO`#xID=HRwbefLL zy=p28&xcGu=|saDOt_~RzeoGo6Fn=EQupHcBr~*f8OKsRxTYd!e;#Kl@`ZbY9#-Pq zm|RI^M)zf3;Yc2*g}xpoSwB2qiFiyAvXXLH2C!3gaYD?>qIXsAzNHD52eL)5OFohM zZ%K9U^=BP~hm{BggOQv`A)yfYndAgRFd~x+Uxay?DvDv{Ycu&`FXC(_iSjVIJ`-k( zon}SqMlnHNE#q*LTDV_-F96R~Cf6OoY;K(UB}}ZW(h^?gOUR;YsoW#-_yPz=;z(sK z`m4BBndI*^1Y{8{M{z_HJ`AG&FUR@4j+R-ZVQ-*s7C(A4#%J*)F$P<+RI0m^D+2rK z5a(slV=y^ev8a%l{zUOk3OdwLv5AtzvD3g8XmcsYo7zG{*{^x$#x09R3@a{=&#S3a zT{%^p3!naj9OuI|#fe~~{{*Hnq4ndw-IBw7i`6oGvP7Uar_O-vdxv0iFcuqztU zN0Kd-etB7sA-HRIQj2LUvkfuf(On)4!8UDraXin_Cd`&x+c%*oM{hxW;zO zsz=u5@H6c`?N3YO+~H)Lt*TODQrPa>M$fCJ@?H`q z*QF`L1fn$F(6QGRasNukxGFrIW}szV(yof2A40lC3{fUH26})Y6HnJt@llo8AloU2 z4+5a)5m`9PG|h3{D7s~PI(V}8_3b08S)AjiRl6V5;|}FwU|mv*DoD;Dzpcvt=GJOY z?M`{Jr!m#USD;vqE}~d?ej3efrujI3 zNFg0MYvV#)<-&?QWr?c8q4F8NYzvYQySOf%;Ubc?G~m}Tr1Vs66=SK-ZW)j=f_S^8 za#|YjI!)sx+T@YwH^fvT7CB3U8Y-biBev>|E3-iY&5e0qKE*Wq`r?yhADiImJe5+V zDO&}5dMvoye_h#hV}T<7SGn;N44Xe%$jx0h)xt3$mgY;zjggIGd-~S4NPqsz zFZ615idj#WZrm&}sv~bY!l+IC`}aQ^dHXtY~It_Mgu^S&%WS=jY7b>VIKc4^|L znjrlYs?{PA^07 z3f?(o7oOv_2DU^KihA-|c8f=$-h+j;sI~uK+`_ z{(ynJ_sDL0jlYA4J`||8Rae3O#bU5X&;S@<;&UMyWs~2%;2s(kj(}Rqp@#V3{9q%V zv^30BZ-{4FY%ViX~aP7D=OsWG-7v=eSQRMO}ahOPl^W0ds+Q;_gAn#TgAt|%I*SxkARIP o0k2_fb(K_i6dPq_{=bL4&YSWsWxr0Ju?a?u3wZ-=>!^zV2i|QI?EnA( diff --git a/submodules/WalletUI/Resources/WalletStrings.mapping b/submodules/WalletUI/Resources/WalletStrings.mapping index 589c6fe85e4fa03a50b6adefffe67915bd39bf1c..9f7c34892095545bdfb3f1e1871a24394137ff12 100644 GIT binary patch delta 17 YcmX@$c))Q(i^Al^3bKrhlN%M}070t;9smFU delta 40 vcmX@$c))Q(i-L?e0|P^NVopwKiC$ String { + public func Wallet_Updated_MinutesAgo(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = walletStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[0 * 6 + Int(form.rawValue)]!, stringValue) } - public func Wallet_Updated_MinutesAgo(_ value: Int32) -> String { + public func Wallet_Updated_HoursAgo(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = walletStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[1 * 6 + Int(form.rawValue)]!, stringValue) From 974c2d8e17a18d0364e7b6386d0df77feed1b932 Mon Sep 17 00:00:00 2001 From: Ali <> Date: Sun, 1 Mar 2020 01:44:25 +0400 Subject: [PATCH 3/6] Improve tab switching --- .../Sources/ChatListControllerNode.swift | 16 ++++-- ...teractiveTransitionGestureRecognizer.swift | 51 ++++++++++++++----- .../Sources/Items/ItemListEditableItem.swift | 10 ++++ 3 files changed, 59 insertions(+), 18 deletions(-) diff --git a/submodules/ChatListUI/Sources/ChatListControllerNode.swift b/submodules/ChatListUI/Sources/ChatListControllerNode.swift index 6a67317762..6a5ed75585 100644 --- a/submodules/ChatListUI/Sources/ChatListControllerNode.swift +++ b/submodules/ChatListUI/Sources/ChatListControllerNode.swift @@ -267,13 +267,13 @@ final class ChatListContainerNode: ASDisplayNode, UIGestureRecognizerDelegate { guard let strongSelf = self, let index = strongSelf.availableFilters.index(where: { $0.id == strongSelf.selectedId }) else { return [] } - var directions: InteractiveTransitionGestureRecognizerDirections = [.left, .right] + var directions: InteractiveTransitionGestureRecognizerDirections = [.leftCenter, .rightCenter] if strongSelf.availableFilters.count > 1 { if index == 0 { - directions.remove(.right) + directions.remove(.rightCenter) } if index == strongSelf.availableFilters.count - 1 { - directions.remove(.left) + directions.remove(.leftCenter) } } else { directions = [] @@ -358,7 +358,7 @@ final class ChatListContainerNode: ASDisplayNode, UIGestureRecognizerDelegate { self.disableItemNodeOperationsWhileAnimating = true self.update(layout: layout, navigationBarHeight: navigationBarHeight, visualNavigationHeight: visualNavigationHeight, cleanNavigationBarHeight: cleanNavigationBarHeight, transition: transition) self.currentItemFilterUpdated?(self.currentItemFilter, self.transitionFraction, transition) - transition.updateBounds(node: self, bounds: self.bounds, force: true, completion: { [weak self] _ in + /*transition.updateBounds(node: self, bounds: self.bounds, force: true, completion: { [weak self] _ in guard let strongSelf = self else { return } @@ -366,7 +366,13 @@ final class ChatListContainerNode: ASDisplayNode, UIGestureRecognizerDelegate { if let (layout, navigationBarHeight, visualNavigationHeight, cleanNavigationBarHeight) = strongSelf.validLayout { strongSelf.update(layout: layout, navigationBarHeight: navigationBarHeight, visualNavigationHeight: visualNavigationHeight, cleanNavigationBarHeight: cleanNavigationBarHeight, transition: .immediate) } - }) + })*/ + DispatchQueue.main.async { + self.disableItemNodeOperationsWhileAnimating = false + if let (layout, navigationBarHeight, visualNavigationHeight, cleanNavigationBarHeight) = self.validLayout { + self.update(layout: layout, navigationBarHeight: navigationBarHeight, visualNavigationHeight: visualNavigationHeight, cleanNavigationBarHeight: cleanNavigationBarHeight, transition: .immediate) + } + } } default: break diff --git a/submodules/Display/Display/InteractiveTransitionGestureRecognizer.swift b/submodules/Display/Display/InteractiveTransitionGestureRecognizer.swift index c129c90f15..ae8af03902 100644 --- a/submodules/Display/Display/InteractiveTransitionGestureRecognizer.swift +++ b/submodules/Display/Display/InteractiveTransitionGestureRecognizer.swift @@ -1,16 +1,23 @@ import Foundation import UIKit -private func hasHorizontalGestures(_ view: UIView, point: CGPoint?) -> Bool { - if view.disablesInteractiveTransitionGestureRecognizer { - return true - } +private enum HorizontalGestures { + case none + case some + case strict +} + +private func hasHorizontalGestures(_ view: UIView, point: CGPoint?) -> HorizontalGestures { if let disablesInteractiveTransitionGestureRecognizerNow = view.disablesInteractiveTransitionGestureRecognizerNow, disablesInteractiveTransitionGestureRecognizerNow() { - return true + return .strict + } + + if view.disablesInteractiveTransitionGestureRecognizer { + return .some } if let point = point, let test = view.interactiveTransitionGestureRecognizerTest, test(point) { - return true + return .some } if let view = view as? ListViewBackingView { @@ -20,14 +27,14 @@ private func hasHorizontalGestures(_ view: UIView, point: CGPoint?) -> Bool { let term2: Double = abs(angle + Double.pi / 2.0) let term3: Double = abs(angle - Double.pi * 3.0 / 2.0) if term1 < 0.001 || term2 < 0.001 || term3 < 0.001 { - return true + return .some } } if let superview = view.superview { return hasHorizontalGestures(superview, point: point != nil ? view.convert(point!, to: superview) : nil) } else { - return false + return .none } } @@ -84,9 +91,17 @@ public class InteractiveTransitionGestureRecognizer: UIPanGestureRecognizer { self.firstLocation = point if let target = self.view?.hitTest(self.firstLocation, with: event) { - if hasHorizontalGestures(target, point: self.view?.convert(self.firstLocation, to: target)) { - allowedDirections.remove(.leftCenter) - allowedDirections.remove(.rightCenter) + let horizontalGestures = hasHorizontalGestures(target, point: self.view?.convert(self.firstLocation, to: target)) + switch horizontalGestures { + case .some, .strict: + if case .strict = horizontalGestures { + allowedDirections = [] + } else if allowedDirections.contains(.leftEdge) || allowedDirections.contains(.rightEdge) { + allowedDirections.remove(.leftCenter) + allowedDirections.remove(.rightCenter) + } + case .none: + break } } @@ -105,11 +120,21 @@ public class InteractiveTransitionGestureRecognizer: UIPanGestureRecognizer { let absTranslationY: CGFloat = abs(translation.y) let size = self.view?.bounds.size ?? CGSize() + let edgeWidth: CGFloat = 20.0 if !self.validatedGesture { - if self.currentAllowedDirections.contains(.rightEdge) && self.firstLocation.x < 16.0 { + if self.firstLocation.x < edgeWidth && !self.currentAllowedDirections.contains(.rightEdge) { + self.state = .failed + return + } + if self.firstLocation.x > size.width - edgeWidth && !self.currentAllowedDirections.contains(.leftEdge) { + self.state = .failed + return + } + + if self.currentAllowedDirections.contains(.rightEdge) && self.firstLocation.x < edgeWidth { self.validatedGesture = true - } else if self.currentAllowedDirections.contains(.leftEdge) && self.firstLocation.x > size.width - 16.0 { + } else if self.currentAllowedDirections.contains(.leftEdge) && self.firstLocation.x > size.width - edgeWidth { self.validatedGesture = true } else if !self.currentAllowedDirections.contains(.leftCenter) && translation.x < 0.0 { self.state = .failed diff --git a/submodules/ItemListUI/Sources/Items/ItemListEditableItem.swift b/submodules/ItemListUI/Sources/Items/ItemListEditableItem.swift index 5a2c91dd52..b95d244833 100644 --- a/submodules/ItemListUI/Sources/Items/ItemListEditableItem.swift +++ b/submodules/ItemListUI/Sources/Items/ItemListEditableItem.swift @@ -101,6 +101,16 @@ open class ItemListRevealOptionsItemNode: ListViewItemNode, UIGestureRecognizerD self.view.addGestureRecognizer(tapRecognizer) self.view.disablesInteractiveTransitionGestureRecognizer = self.allowAnyDirection + + self.view.disablesInteractiveTransitionGestureRecognizerNow = { [weak self] in + guard let strongSelf = self else { + return false + } + if !strongSelf.revealOffset.isZero { + return true + } + return false + } } open func setRevealOptions(_ options: (left: [ItemListRevealOption], right: [ItemListRevealOption])) { From 5ad48b0af823c0b6290ec7ef77c79b56fe9e8066 Mon Sep 17 00:00:00 2001 From: Ali <> Date: Sun, 1 Mar 2020 01:57:56 +0400 Subject: [PATCH 4/6] Use symmetric chat list loading --- .../Sources/ChatListController.swift | 2 +- .../Postbox/Sources/ChatListTable.swift | 38 ++----------------- 2 files changed, 5 insertions(+), 35 deletions(-) diff --git a/submodules/ChatListUI/Sources/ChatListController.swift b/submodules/ChatListUI/Sources/ChatListController.swift index 8e41b09f4c..de0e664510 100644 --- a/submodules/ChatListUI/Sources/ChatListController.swift +++ b/submodules/ChatListUI/Sources/ChatListController.swift @@ -433,7 +433,7 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, } let (totalCount, items) = countAndFilterItems var filterItems: [ChatListFilterTabEntry] = [] - filterItems.append(.all(unreadCount: totalCount)) + filterItems.append(.all(unreadCount: 0)) for (filter, unreadCount) in items { filterItems.append(.filter(id: filter.id, text: filter.title, unreadCount: unreadCount)) } diff --git a/submodules/Postbox/Sources/ChatListTable.swift b/submodules/Postbox/Sources/ChatListTable.swift index d205921714..2e4a9794a9 100644 --- a/submodules/Postbox/Sources/ChatListTable.swift +++ b/submodules/Postbox/Sources/ChatListTable.swift @@ -421,8 +421,8 @@ final class ChatListTable: Table { lowerEntries.append(entry) return .accept } - }, limit: count / 2 + 1) - if lowerEntries.count >= count / 2 + 1 { + }, limit: count + 1) + if lowerEntries.count >= count + 1 { lower = lowerEntries.last lowerEntries.removeLast() } @@ -440,42 +440,12 @@ final class ChatListTable: Table { upperEntries.append(entry) return .accept } - }, limit: count - lowerEntries.count + 1) - if upperEntries.count >= count - lowerEntries.count + 1 { + }, limit: count + 1) + if upperEntries.count >= count + 1 { upper = upperEntries.last upperEntries.removeLast() } - if lowerEntries.count != 0 && lowerEntries.count + upperEntries.count < count { - var additionalLowerEntries: [ChatListIntermediateEntry] = [] - let startEntryType: ChatListEntryType - switch lowerEntries.last! { - case .message: - startEntryType = .message - case .hole: - startEntryType = .hole - } - self.valueBox.filteredRange(self.table, start: self.key(groupId: groupId, index: lowerEntries.last!.index, type: startEntryType), end: self.lowerBound(groupId: groupId), values: { key, value in - let entry = readEntry(groupId: groupId, messageHistoryTable: messageHistoryTable, peerChatInterfaceStateTable: peerChatInterfaceStateTable, key: key, value: value) - if let predicate = predicate { - if predicate(entry) { - additionalLowerEntries.append(entry) - return .accept - } else { - return .skip - } - } else { - additionalLowerEntries.append(entry) - return .accept - } - }, limit: count - lowerEntries.count - upperEntries.count + 1) - if additionalLowerEntries.count >= count - lowerEntries.count + upperEntries.count + 1 { - lower = additionalLowerEntries.last - additionalLowerEntries.removeLast() - } - lowerEntries.append(contentsOf: additionalLowerEntries) - } - var entries: [ChatListIntermediateEntry] = [] entries.append(contentsOf: lowerEntries.reversed()) entries.append(contentsOf: upperEntries) From 789438a27450dcbdee6065ebf096198ed3b90fec Mon Sep 17 00:00:00 2001 From: Ali <> Date: Sun, 1 Mar 2020 13:59:30 +0400 Subject: [PATCH 5/6] Rename directories [skip ci] --- .../{Display => Sources}/ASTransformLayerNode.swift | 0 .../{Display => Sources}/Accessibility.swift | 0 .../AccessibilityAreaNode.swift | 0 .../ActionSheetButtonItem.swift | 0 .../ActionSheetCheckboxItem.swift | 0 .../ActionSheetController.swift | 0 .../ActionSheetControllerNode.swift | 0 .../{Display => Sources}/ActionSheetItem.swift | 0 .../{Display => Sources}/ActionSheetItemGroup.swift | 0 .../ActionSheetItemGroupNode.swift | 0 .../ActionSheetItemGroupsContainerNode.swift | 0 .../{Display => Sources}/ActionSheetItemNode.swift | 0 .../ActionSheetSwitchItem.swift | 0 .../{Display => Sources}/ActionSheetTextItem.swift | 0 .../{Display => Sources}/ActionSheetTheme.swift | 0 .../{Display => Sources}/AlertContentNode.swift | 0 .../{Display => Sources}/AlertController.swift | 0 .../{Display => Sources}/AlertControllerNode.swift | 0 .../{Display => Sources}/CAAnimationUtils.swift | 0 .../{Display => Sources}/CASeeThroughTracingLayer.h | 0 .../{Display => Sources}/CASeeThroughTracingLayer.m | 0 .../Display/{Display => Sources}/CATracingLayer.h | 0 .../Display/{Display => Sources}/CATracingLayer.m | 0 .../{Display => Sources}/ChildWindowHostView.swift | 0 .../{Display => Sources}/CollectionIndexNode.swift | 0 .../ContainableController.swift | 0 .../ContainedViewLayoutTransition.swift | 0 .../{Display => Sources}/ContainerViewLayout.swift | 0 .../ContextContentContainerNode.swift | 0 .../ContextContentSourceNode.swift | 0 .../ContextControllerSourceNode.swift | 0 .../{Display => Sources}/ContextGesture.swift | 0 .../{Display => Sources}/ContextMenuAction.swift | 0 .../ContextMenuActionNode.swift | 0 .../ContextMenuContainerNode.swift | 0 .../ContextMenuController.swift | 0 .../{Display => Sources}/ContextMenuNode.swift | 0 .../{Display => Sources}/DeviceMetrics.swift | 0 submodules/Display/{Display => Sources}/Display.h | 0 .../{Display => Sources}/DisplayLinkAnimator.swift | 0 .../DisplayLinkDispatcher.swift | 0 .../{Display => Sources}/EditableTextNode.swift | 0 submodules/Display/{Display => Sources}/Font.swift | 0 .../{Display => Sources}/GenerateImage.swift | 0 .../GlobalOverlayPresentationContext.swift | 0 .../Display/{Display => Sources}/GridItem.swift | 0 .../Display/{Display => Sources}/GridItemNode.swift | 0 .../Display/{Display => Sources}/GridNode.swift | 0 .../{Display => Sources}/GridNodeScroller.swift | 0 .../{Display => Sources}/HapticFeedback.swift | 0 .../HighlightTrackingButton.swift | 0 .../{Display => Sources}/HighlightableButton.swift | 0 .../Display/{Display => Sources}/ImageCorners.swift | 0 .../Display/{Display => Sources}/ImageNode.swift | 0 .../{Display => Sources}/ImmediateTextNode.swift | 0 submodules/Display/{Display => Sources}/Info.plist | 0 .../InteractiveTransitionGestureRecognizer.swift | 0 .../Display/{Display => Sources}/KeyShortcut.swift | 0 .../KeyShortcutsController.swift | 0 .../Display/{Display => Sources}/Keyboard.swift | 0 .../{Display => Sources}/KeyboardManager.swift | 0 .../Display/{Display => Sources}/LayoutSizes.swift | 0 .../LegacyPresentedController.swift | 0 .../LegacyPresentedControllerNode.swift | 0 .../{Display => Sources}/LinkHighlightingNode.swift | 0 .../Display/{Display => Sources}/ListView.swift | 0 .../ListViewAccessoryItem.swift | 0 .../ListViewAccessoryItemNode.swift | 0 .../{Display => Sources}/ListViewAnimation.swift | 0 .../ListViewFloatingHeaderNode.swift | 0 .../ListViewIntermediateState.swift | 0 .../Display/{Display => Sources}/ListViewItem.swift | 0 .../{Display => Sources}/ListViewItemHeader.swift | 0 .../{Display => Sources}/ListViewItemNode.swift | 0 .../ListViewOverscrollBackgroundNode.swift | 0 .../ListViewReorderingGestureRecognizer.swift | 0 .../ListViewReorderingItemNode.swift | 0 .../{Display => Sources}/ListViewScroller.swift | 0 .../ListViewTapGestureRecognizer.swift | 0 .../{Display => Sources}/ListViewTempItemNode.swift | 0 .../ListViewTransactionQueue.swift | 0 .../MinimizeKeyboardGestureRecognizer.swift | 0 submodules/Display/{Display => Sources}/NSBag.h | 0 submodules/Display/{Display => Sources}/NSBag.m | 0 .../Display/{Display => Sources}/NSWeakReference.h | 0 .../Display/{Display => Sources}/NSWeakReference.m | 0 .../{Display => Sources}/NativeWindowHostView.swift | 0 .../Navigation/NavigationContainer.swift | 0 .../Navigation/NavigationController.swift | 0 .../Navigation/NavigationLayout.swift | 0 .../Navigation/NavigationModalContainer.swift | 0 .../Navigation/NavigationModalFrame.swift | 0 .../Navigation/NavigationOverlayContainer.swift | 0 .../Navigation/NavigationSplitContainer.swift | 0 .../NavigationBackButtonNode.swift | 0 .../{Display => Sources}/NavigationBar.swift | 0 .../{Display => Sources}/NavigationBarBadge.swift | 0 .../NavigationBarContentNode.swift | 0 .../{Display => Sources}/NavigationBarProxy.h | 0 .../{Display => Sources}/NavigationBarProxy.m | 0 .../NavigationBarTitleTransitionNode.swift | 0 .../NavigationBarTitleView.swift | 0 .../NavigationBarTransitionContainer.swift | 0 .../NavigationBarTransitionState.swift | 0 .../{Display => Sources}/NavigationButtonNode.swift | 0 .../NavigationControllerProxy.h | 0 .../NavigationControllerProxy.m | 0 .../{Display => Sources}/NavigationTitleNode.swift | 0 .../NavigationTransitionCoordinator.swift | 0 .../{Display => Sources}/NotificationCenterUtils.h | 0 .../{Display => Sources}/NotificationCenterUtils.m | 0 .../{Display => Sources}/PageControlNode.swift | 0 .../{Display => Sources}/PeekController.swift | 0 .../PeekControllerContent.swift | 0 .../PeekControllerGestureRecognizer.swift | 0 .../PeekControllerMenuItemNode.swift | 0 .../PeekControllerMenuNode.swift | 0 .../{Display => Sources}/PeekControllerNode.swift | 0 .../{Display => Sources}/PresentationContext.swift | 0 .../Display/{Display => Sources}/RuntimeUtils.h | 0 .../Display/{Display => Sources}/RuntimeUtils.m | 0 .../Display/{Display => Sources}/RuntimeUtils.swift | 0 .../{Display => Sources}/ScrollToTopProxyView.swift | 0 .../{Display => Sources}/ShakeAnimation.swift | 0 .../Display/{Display => Sources}/Spring.swift | 0 .../Display/{Display => Sources}/StatusBar.swift | 0 .../{Display => Sources}/StatusBarHost.swift | 0 .../{Display => Sources}/StatusBarProxyNode.swift | 0 .../{Display => Sources}/SubstringSearch.swift | 0 .../Display/{Display => Sources}/SwitchNode.swift | 0 .../{Display => Sources}/TabBarContollerNode.swift | 0 .../{Display => Sources}/TabBarController.swift | 0 .../Display/{Display => Sources}/TabBarNode.swift | 0 .../{Display => Sources}/TabBarTapRecognizer.swift | 0 .../TapLongTapOrDoubleTapGestureRecognizer.swift | 0 .../{Display => Sources}/TextAlertController.swift | 0 .../{Display => Sources}/TextFieldNode.swift | 0 .../Display/{Display => Sources}/TextNode.swift | 0 .../Display/{Display => Sources}/Toolbar.swift | 0 .../Display/{Display => Sources}/ToolbarNode.swift | 0 .../{Display => Sources}/TooltipController.swift | 0 .../TooltipControllerNode.swift | 0 .../TransformImageArguments.swift | 0 .../{Display => Sources}/TransformImageNode.swift | 0 .../{Display => Sources}/UIBarButtonItem+Proxy.h | 0 .../{Display => Sources}/UIBarButtonItem+Proxy.m | 0 .../Display/{Display => Sources}/UIKitUtils.h | 0 .../Display/{Display => Sources}/UIKitUtils.m | 0 .../Display/{Display => Sources}/UIKitUtils.swift | 0 .../Display/{Display => Sources}/UIMenuItem+Icons.h | 0 .../Display/{Display => Sources}/UIMenuItem+Icons.m | 0 .../{Display => Sources}/UINavigationItem+Proxy.h | 0 .../{Display => Sources}/UINavigationItem+Proxy.m | 0 .../{Display => Sources}/UITracingLayerView.swift | 0 .../UIViewController+Navigation.h | 0 .../UIViewController+Navigation.m | 0 .../UIWindow+OrientationChange.h | 0 .../UIWindow+OrientationChange.m | 0 .../UniversalMasterController.swift | 0 .../UniversalTapRecognizer.swift | 0 .../{Display => Sources}/ViewController.swift | 0 .../ViewControllerPreviewing.swift | 0 .../ViewControllerTracingNode.swift | 0 .../VolumeControlStatusBar.swift | 0 .../WallpaperBackgroundNode.swift | 0 .../{Display => Sources}/WindowContent.swift | 0 .../{Display => Sources}/WindowCoveringView.swift | 0 .../WindowInputAccessoryHeightProvider.swift | 0 .../{Display => Sources}/WindowPanRecognizer.swift | 0 .../AccessoryPanelNode.swift | 0 .../{TelegramUI => Sources}/AccountContext.swift | 0 .../{TelegramUI => Sources}/AppDelegate.swift | 0 .../ApplicationContext.swift | 0 .../ApplicationShortcutItem.swift | 0 .../AudioRecordningToneData.swift | 0 .../{TelegramUI => Sources}/AudioWaveform.swift | 0 .../{TelegramUI => Sources}/AudioWaveformNode.swift | 0 ...tionSequenceAwaitingAccountResetController.swift | 0 ...SequenceAwaitingAccountResetControllerNode.swift | 0 .../AuthorizationSequenceCodeEntryController.swift | 0 ...thorizationSequenceCodeEntryControllerNode.swift | 0 .../AuthorizationSequenceController.swift | 0 ...thorizationSequencePasswordEntryController.swift | 0 ...izationSequencePasswordEntryControllerNode.swift | 0 ...rizationSequencePasswordRecoveryController.swift | 0 ...tionSequencePasswordRecoveryControllerNode.swift | 0 .../AuthorizationSequencePhoneEntryController.swift | 0 ...horizationSequencePhoneEntryControllerNode.swift | 0 .../AuthorizationSequenceSignUpController.swift | 0 .../AuthorizationSequenceSignUpControllerNode.swift | 0 .../AuthorizationSequenceSplashController.swift | 0 .../AuthorizationSequenceSplashControllerNode.swift | 0 .../ChatAvatarNavigationNode.swift | 0 .../{TelegramUI => Sources}/ChatBotInfoItem.swift | 0 .../ChatBotStartInputPanelNode.swift | 0 .../ChatButtonKeyboardInputNode.swift | 0 .../ChatChannelSubscriberInputPanelNode.swift | 0 .../ChatContextResultPeekContentNode.swift | 0 .../{TelegramUI => Sources}/ChatController.swift | 0 .../ChatControllerInteraction.swift | 0 .../ChatControllerNode.swift | 0 .../ChatControllerTitlePanelNodeContainer.swift | 0 .../ChatDateSelectionSheet.swift | 0 .../ChatEditInterfaceMessageState.swift | 0 .../ChatEditMessageMediaContext.swift | 0 .../{TelegramUI => Sources}/ChatEmptyNode.swift | 0 .../ChatFeedNavigationInputPanelNode.swift | 0 .../ChatHistoryEntriesForView.swift | 0 .../{TelegramUI => Sources}/ChatHistoryEntry.swift | 0 .../ChatHistoryGridNode.swift | 0 .../ChatHistoryListNode.swift | 0 .../ChatHistoryLocation.swift | 0 .../ChatHistoryNavigationButtonNode.swift | 0 .../ChatHistoryNavigationButtons.swift | 0 .../ChatHistoryNavigationStack.swift | 0 .../{TelegramUI => Sources}/ChatHistoryNode.swift | 0 .../ChatHistorySearchContainerNode.swift | 0 .../ChatHistoryViewForLocation.swift | 0 .../{TelegramUI => Sources}/ChatHoleItem.swift | 0 .../{TelegramUI => Sources}/ChatInfo.swift | 0 .../ChatInfoTitlePanelNode.swift | 0 .../ChatInputContextPanelNode.swift | 0 .../{TelegramUI => Sources}/ChatInputNode.swift | 0 .../ChatInputPanelNode.swift | 0 .../ChatInstantVideoMessageDurationNode.swift | 0 .../ChatInterfaceInputContextPanels.swift | 0 .../ChatInterfaceInputContexts.swift | 0 .../ChatInterfaceInputNodes.swift | 0 .../ChatInterfaceState.swift | 0 .../ChatInterfaceStateAccessoryPanels.swift | 0 .../ChatInterfaceStateContextMenus.swift | 0 .../ChatInterfaceStateContextQueries.swift | 0 .../ChatInterfaceStateInputPanels.swift | 0 .../ChatInterfaceStateNavigationButtons.swift | 0 .../ChatInterfaceTitlePanelNodes.swift | 0 .../{TelegramUI => Sources}/ChatLinkPreview.swift | 0 .../{TelegramUI => Sources}/ChatLoadingNode.swift | 0 .../ChatMediaInputGifPane.swift | 0 .../ChatMediaInputGridEntries.swift | 0 .../ChatMediaInputMetaSectionItemNode.swift | 0 .../ChatMediaInputNode.swift | 0 .../ChatMediaInputPane.swift | 0 .../ChatMediaInputPanelEntries.swift | 0 .../ChatMediaInputPeerSpecificItem.swift | 0 .../ChatMediaInputRecentGifsItem.swift | 0 .../ChatMediaInputSettingsItem.swift | 0 .../ChatMediaInputStickerGridItem.swift | 0 .../ChatMediaInputStickerPackItem.swift | 0 .../ChatMediaInputStickerPane.swift | 0 .../ChatMediaInputTrendingItem.swift | 0 .../ChatMediaInputTrendingPane.swift | 0 .../ChatMessageActionButtonsNode.swift | 0 .../ChatMessageActionItemNode.swift | 0 .../ChatMessageActionSheetController.swift | 0 .../ChatMessageActionSheetControllerNode.swift | 0 .../ChatMessageActionUrlAuthController.swift | 0 .../ChatMessageAnimatedStickerItemNode.swift | 0 .../ChatMessageAttachedContentNode.swift | 0 .../ChatMessageAvatarAccessoryItem.swift | 0 .../ChatMessageBackground.swift | 0 .../ChatMessageBubbleBackdrop.swift | 0 ...MessageBubbleContentCalclulateImageCorners.swift | 0 .../ChatMessageBubbleContentNode.swift | 0 .../ChatMessageBubbleItemNode.swift | 0 .../ChatMessageCallBubbleContentNode.swift | 0 .../ChatMessageContactBubbleContentNode.swift | 0 .../ChatMessageContextControllerContentSource.swift | 0 .../ChatMessageDateAndStatusNode.swift | 0 .../ChatMessageDateHeader.swift | 0 .../ChatMessageDeliveryFailedNode.swift | 0 ...sageEventLogPreviousDescriptionContentNode.swift | 0 ...ChatMessageEventLogPreviousLinkContentNode.swift | 0 ...tMessageEventLogPreviousMessageContentNode.swift | 0 .../ChatMessageFileBubbleContentNode.swift | 0 .../ChatMessageForwardInfoNode.swift | 0 .../ChatMessageGameBubbleContentNode.swift | 0 .../ChatMessageInstantVideoItemNode.swift | 0 .../ChatMessageInteractiveFileNode.swift | 0 .../ChatMessageInteractiveInstantVideoNode.swift | 0 .../ChatMessageInteractiveMediaBadge.swift | 0 .../ChatMessageInteractiveMediaNode.swift | 0 .../ChatMessageInvoiceBubbleContentNode.swift | 0 .../{TelegramUI => Sources}/ChatMessageItem.swift | 0 .../ChatMessageItemView.swift | 0 .../ChatMessageLiveLocationTextNode.swift | 0 .../ChatMessageMapBubbleContentNode.swift | 0 .../ChatMessageMediaBubbleContentNode.swift | 0 .../ChatMessageNotificationItem.swift | 0 .../ChatMessagePollBubbleContentNode.swift | 0 .../ChatMessageReplyInfoNode.swift | 0 .../ChatMessageRestrictedBubbleContentNode.swift | 0 .../ChatMessageSelectionInputPanelNode.swift | 0 .../ChatMessageSelectionNode.swift | 0 .../ChatMessageStickerItemNode.swift | 0 .../ChatMessageSwipeToReplyNode.swift | 0 .../ChatMessageTextBubbleContentNode.swift | 0 .../ChatMessageThrottledProcessingManager.swift | 0 .../ChatMessageUnsupportedBubbleContentNode.swift | 0 .../ChatMessageWebpageBubbleContentNode.swift | 0 .../ChatOverlayNavigationBar.swift | 0 .../ChatPanelInterfaceInteraction.swift | 0 .../ChatPinnedMessageTitlePanelNode.swift | 0 .../ChatPresentationData.swift | 0 .../ChatPresentationInterfaceState.swift | 0 .../ChatRecentActionsController.swift | 0 .../ChatRecentActionsControllerNode.swift | 0 .../ChatRecentActionsControllerState.swift | 0 .../ChatRecentActionsEmptyNode.swift | 0 .../ChatRecentActionsFilterController.swift | 0 .../ChatRecentActionsHistoryTransition.swift | 0 .../ChatRecentActionsInteraction.swift | 0 ...atRecentActionsSearchNavigationContentNode.swift | 0 .../ChatRecentActionsTitleView.swift | 0 .../ChatRecordingPreviewInputPanelNode.swift | 0 .../ChatReportPeerTitlePanelNode.swift | 0 .../ChatRequestInProgressTitlePanelNode.swift | 0 .../ChatRestrictedInputPanelNode.swift | 0 .../ChatRestrictedNode.swift | 0 .../ChatScheduleTimeController.swift | 0 .../ChatScheduleTimeControllerNode.swift | 0 .../ChatSearchInputPanelNode.swift | 0 .../ChatSearchNavigationContentNode.swift | 0 .../ChatSearchResultsContollerNode.swift | 0 .../ChatSearchResultsController.swift | 0 .../{TelegramUI => Sources}/ChatSearchState.swift | 0 .../ChatSecretAutoremoveTimerActionSheet.swift | 0 .../ChatSendButtonRadialStatusNode.swift | 0 .../ChatSendMessageActionSheetController.swift | 0 .../ChatSendMessageActionSheetControllerNode.swift | 0 .../ChatSlowmodeHintController.swift | 0 .../ChatSwipeToReplyRecognizer.swift | 0 .../{TelegramUI => Sources}/ChatTextFormat.swift | 0 .../ChatTextInputAccessoryItem.swift | 0 .../ChatTextInputActionButtonsNode.swift | 0 ...ChatTextInputAudioRecordingCancelIndicator.swift | 0 .../ChatTextInputAudioRecordingOverlayButton.swift | 0 .../ChatTextInputAudioRecordingTimeNode.swift | 0 .../ChatTextInputMediaRecordingButton.swift | 0 .../{TelegramUI => Sources}/ChatTextInputMenu.swift | 0 .../ChatTextInputPanelNode.swift | 0 .../ChatTextInputPanelState.swift | 0 .../ChatTextInputSlowmodePlaceholderNode.swift | 0 .../ChatTextLinkEditController.swift | 0 .../ChatTitleAccessoryPanelNode.swift | 0 .../{TelegramUI => Sources}/ChatTitleView.swift | 0 .../ChatToastAlertPanelNode.swift | 0 .../ChatUnblockInputPanelNode.swift | 0 .../{TelegramUI => Sources}/ChatUnreadItem.swift | 0 .../{TelegramUI => Sources}/CheckDiskSpace.swift | 0 .../ClearNotificationsManager.swift | 0 .../CommandChatInputContextPanelNode.swift | 0 .../CommandChatInputPanelItem.swift | 0 .../{TelegramUI => Sources}/ComposeController.swift | 0 .../ComposeControllerNode.swift | 0 .../{TelegramUI => Sources}/ConfettiView.swift | 0 .../ContactMultiselectionController.swift | 0 .../ContactMultiselectionControllerNode.swift | 0 .../ContactSelectionController.swift | 0 .../ContactSelectionControllerNode.swift | 0 .../{TelegramUI => Sources}/ConvertToWebP.swift | 0 .../CreateChannelController.swift | 0 .../CreateGroupController.swift | 0 .../{TelegramUI => Sources}/DeclareEncodables.swift | 0 .../DeleteChatInputPanelNode.swift | 0 .../DeviceContactDataManager.swift | 0 ...ledContextResultsChatInputContextPanelNode.swift | 0 .../DocumentPreviewController.swift | 0 .../EditAccessoryPanelNode.swift | 0 .../EditableTokenListNode.swift | 0 .../{TelegramUI => Sources}/EmojiResources.swift | 0 .../EmojisChatInputContextPanelNode.swift | 0 .../EmojisChatInputPanelItem.swift | 0 .../FetchCachedRepresentations.swift | 0 .../{TelegramUI => Sources}/FetchManager.swift | 0 .../FetchManagerLocation.swift | 0 .../{TelegramUI => Sources}/FetchResource.swift | 0 .../FetchVideoMediaResource.swift | 0 .../FileMediaResourceStatus.swift | 0 .../ForwardAccessoryPanelNode.swift | 0 .../GalleryHiddenMediaManager.swift | 0 .../GifPaneSearchContentNode.swift | 0 .../GlobalExperimentalSettings.swift | 0 .../{TelegramUI => Sources}/GridHoleItem.swift | 0 .../{TelegramUI => Sources}/GridMessageItem.swift | 0 .../HashtagChatInputContextPanelNode.swift | 0 .../HashtagChatInputPanelItem.swift | 0 ...istContextResultsChatInputContextPanelNode.swift | 0 ...zontalListContextResultsChatInputPanelItem.swift | 0 .../HorizontalStickerGridItem.swift | 0 .../HorizontalStickersChatContextPanelNode.swift | 0 .../{TelegramUI => Sources}/ICloudResources.swift | 0 .../{TelegramUI => Sources}/ID3ArtworkReader.swift | 0 .../{TelegramUI => Sources}/IconButtonNode.swift | 0 .../InChatPrefetchManager.swift | 0 .../TelegramUI/{TelegramUI => Sources}/Info.plist | 0 .../InstantVideoRadialStatusNode.swift | 0 .../{TelegramUI => Sources}/LegacyCache.swift | 0 .../{TelegramUI => Sources}/LegacyCamera.swift | 0 .../LegacyInstantVideoController.swift | 0 .../LegacyLiveUploadInterface.swift | 0 .../LinkHighlightingNode.swift | 0 .../ListMessageDateHeader.swift | 0 .../ListMessageFileItemNode.swift | 0 .../ListMessageHoleItem.swift | 0 .../{TelegramUI => Sources}/ListMessageItem.swift | 0 .../{TelegramUI => Sources}/ListMessageNode.swift | 0 .../ListMessagePlaybackOverlayNode.swift | 0 .../ListMessageSnippetItemNode.swift | 0 .../LockedWindowCoveringView.swift | 0 .../ManageSharedAccountInfo.swift | 0 .../ManagedAudioRecorder.swift | 0 .../MediaInputPaneTrendingItem.swift | 0 .../{TelegramUI => Sources}/MediaManager.swift | 0 .../MediaPlaybackStoredState.swift | 0 .../MentionChatInputContextPanelNode.swift | 0 .../MentionChatInputPanelItem.swift | 0 .../MultiScaleTextNode.swift | 0 .../MultiplexedSoftwareVideoNode.swift | 0 .../MultiplexedSoftwareVideoSourceManager.swift | 0 .../MultiplexedVideoNode.swift | 0 .../NavigateToChatController.swift | 0 .../NotificationContainerController.swift | 0 .../NotificationContainerControllerNode.swift | 0 .../NotificationContentContext.swift | 0 .../{TelegramUI => Sources}/NotificationItem.swift | 0 .../NotificationItemContainerNode.swift | 0 .../{TelegramUI => Sources}/OpenAddContact.swift | 0 .../{TelegramUI => Sources}/OpenChatMessage.swift | 0 .../{TelegramUI => Sources}/OpenResolvedUrl.swift | 0 .../{TelegramUI => Sources}/OpenUrl.swift | 0 .../OverlayAudioPlayerController.swift | 0 .../OverlayInstantVideoDecoration.swift | 0 .../OverlayInstantVideoNode.swift | 0 .../OverlayMediaController.swift | 0 .../OverlayMediaControllerNode.swift | 0 .../OverlayPlayerControllerNode.swift | 0 .../OverlayPlayerControlsNode.swift | 0 .../{TelegramUI => Sources}/PaneSearchBarNode.swift | 0 .../PaneSearchBarPlaceholderItem.swift | 0 .../PaneSearchContainerNode.swift | 0 .../{TelegramUI => Sources}/Pasteboard.swift | 0 .../ListItems/PeerInfoScreenActionItem.swift | 0 .../ListItems/PeerInfoScreenAddressItem.swift | 0 .../ListItems/PeerInfoScreenCallListItem.swift | 0 .../ListItems/PeerInfoScreenCommentItem.swift | 0 .../PeerInfoScreenDisclosureEncryptionKeyItem.swift | 0 .../ListItems/PeerInfoScreenDisclosureItem.swift | 0 .../ListItems/PeerInfoScreenHeaderItem.swift | 0 .../ListItems/PeerInfoScreenLabeledValueItem.swift | 0 .../ListItems/PeerInfoScreenMemberItem.swift | 0 .../PeerInfoScreenSelectableBackgroundNode.swift | 0 .../ListItems/PeerInfoScreenSwitchItem.swift | 0 .../Panes/PeerInfoGroupsInCommonPaneNode.swift | 0 .../PeerInfo/Panes/PeerInfoListPaneNode.swift | 0 .../PeerInfo/Panes/PeerInfoMembersPane.swift | 0 .../Panes/PeerInfoVisualMediaPaneNode.swift | 0 .../PeerInfo/PeerInfoData.swift | 0 .../PeerInfo/PeerInfoHeaderNode.swift | 0 .../PeerInfo/PeerInfoMembers.swift | 0 .../PeerInfo/PeerInfoPaneContainerNode.swift | 0 .../PeerInfo/PeerInfoScreen.swift | 0 .../PeerMediaCollectionController.swift | 0 .../PeerMediaCollectionControllerNode.swift | 0 .../PeerMediaCollectionEmptyNode.swift | 0 .../PeerMediaCollectionInterfaceState.swift | 0 .../PeerMediaCollectionInterfaceStateButtons.swift | 0 .../PeerMediaCollectionSectionsNode.swift | 0 .../PeerMessagesMediaPlaylist.swift | 0 .../PeerSelectionController.swift | 0 .../PeerSelectionControllerNode.swift | 0 .../PeersNearbyManager.swift | 0 .../PollResultsController.swift | 0 .../{TelegramUI => Sources}/PrefetchManager.swift | 0 .../PrepareSecretThumbnailData.swift | 0 .../PreparedChatHistoryViewTransition.swift | 0 .../ProcessedPeerRestrictionText.swift | 0 .../RadialProgressNode.swift | 0 .../{TelegramUI => Sources}/RadialTimeoutNode.swift | 0 .../ReplyAccessoryPanelNode.swift | 0 .../Resources/Animations/ChatListEmpty.tgs | Bin .../Resources/Animations/ChatListFilterEmpty.tgs | Bin .../Resources/Animations/anim_archive.json | 0 .../Resources/Animations/anim_archiveAvatar.json | 0 .../Resources/Animations/anim_archiveswipe.json | 0 .../Resources/Animations/anim_delete.json | 0 .../Resources/Animations/anim_group.json | 0 .../Resources/Animations/anim_hide.json | 0 .../Resources/Animations/anim_infotip.json | 0 .../Resources/Animations/anim_mute.json | 0 .../Resources/Animations/anim_pin.json | 0 .../Resources/Animations/anim_qr.json | 0 .../Resources/Animations/anim_read.json | 0 .../Resources/Animations/anim_success.json | 0 .../Resources/Animations/anim_swipereply.json | 0 .../Resources/Animations/anim_unarchive.json | 0 .../Resources/Animations/anim_ungroup.json | 0 .../Resources/Animations/anim_unmute.json | 0 .../Resources/Animations/anim_unpin.json | 0 .../Resources/Animations/anim_unread.json | 0 .../Resources/BuiltinReactions/celebrate.tgs | Bin .../Resources/BuiltinReactions/cry.tgs | Bin .../Resources/BuiltinReactions/heart.tgs | Bin .../Resources/BuiltinReactions/lol.tgs | Bin .../Resources/BuiltinReactions/meh.tgs | Bin .../Resources/BuiltinReactions/ok.tgs | Bin .../Resources/BuiltinReactions/poker.tgs | Bin .../Resources/BuiltinReactions/poop.tgs | Bin .../Resources/BuiltinReactions/sad.tgs | Bin .../Resources/BuiltinReactions/smile.tgs | Bin .../Resources/BuiltinReactions/surprised.tgs | Bin .../Resources/BuiltinReactions/thumbsup.tgs | Bin .../Resources/ChatWallpaperBuiltin0.jpg | Bin .../{TelegramUI => Sources}/Resources/Emoji.mapping | Bin .../Resources/Fonts/SFCompactRounded-Semibold.otf | Bin .../Resources/PhoneCountries.txt | 0 .../Resources/PresentationStrings.mapping | Bin .../StillReactions/simplereaction_10@2x.png | Bin .../StillReactions/simplereaction_10@3x.png | Bin .../StillReactions/simplereaction_11@2x.png | Bin .../StillReactions/simplereaction_11@3x.png | Bin .../StillReactions/simplereaction_12@2x.png | Bin .../StillReactions/simplereaction_12@3x.png | Bin .../StillReactions/simplereaction_13@2x.png | Bin .../StillReactions/simplereaction_13@3x.png | Bin .../StillReactions/simplereaction_14@2x.png | Bin .../StillReactions/simplereaction_14@3x.png | Bin .../StillReactions/simplereaction_15@2x.png | Bin .../StillReactions/simplereaction_15@3x.png | Bin .../StillReactions/simplereaction_16@2x.png | Bin .../StillReactions/simplereaction_16@3x.png | Bin .../StillReactions/simplereaction_17@2x.png | Bin .../StillReactions/simplereaction_17@3x.png | Bin .../StillReactions/simplereaction_18@2x.png | Bin .../StillReactions/simplereaction_18@3x.png | Bin .../StillReactions/simplereaction_19@2x.png | Bin .../StillReactions/simplereaction_19@3x.png | Bin .../StillReactions/simplereaction_1@2x.png | Bin .../StillReactions/simplereaction_1@3x.png | Bin .../StillReactions/simplereaction_20@2x.png | Bin .../StillReactions/simplereaction_20@3x.png | Bin .../StillReactions/simplereaction_2@2x.png | Bin .../StillReactions/simplereaction_2@3x.png | Bin .../StillReactions/simplereaction_3@2x.png | Bin .../StillReactions/simplereaction_3@3x.png | Bin .../StillReactions/simplereaction_4@2x.png | Bin .../StillReactions/simplereaction_4@3x.png | Bin .../StillReactions/simplereaction_5@2x.png | Bin .../StillReactions/simplereaction_5@3x.png | Bin .../StillReactions/simplereaction_6@2x.png | Bin .../StillReactions/simplereaction_6@3x.png | Bin .../StillReactions/simplereaction_7@2x.png | Bin .../StillReactions/simplereaction_7@3x.png | Bin .../StillReactions/simplereaction_8@2x.png | Bin .../StillReactions/simplereaction_8@3x.png | Bin .../StillReactions/simplereaction_9@2x.png | Bin .../StillReactions/simplereaction_9@3x.png | Bin .../Resources/Stripe/stp_card_amex@2x.png | Bin .../Resources/Stripe/stp_card_amex@3x.png | Bin .../Resources/Stripe/stp_card_amex_template@2x.png | Bin .../Resources/Stripe/stp_card_amex_template@3x.png | Bin .../Resources/Stripe/stp_card_applepay@2x.png | Bin .../Resources/Stripe/stp_card_applepay@3x.png | Bin .../Stripe/stp_card_applepay_template@2x.png | Bin .../Stripe/stp_card_applepay_template@3x.png | Bin .../Resources/Stripe/stp_card_cvc@2x.png | Bin .../Resources/Stripe/stp_card_cvc@3x.png | Bin .../Resources/Stripe/stp_card_cvc_amex@2x.png | Bin .../Resources/Stripe/stp_card_cvc_amex@3x.png | Bin .../Resources/Stripe/stp_card_diners@2x.png | Bin .../Resources/Stripe/stp_card_diners@3x.png | Bin .../Stripe/stp_card_diners_template@2x.png | Bin .../Stripe/stp_card_diners_template@3x.png | Bin .../Resources/Stripe/stp_card_discover@2x.png | Bin .../Resources/Stripe/stp_card_discover@3x.png | Bin .../Stripe/stp_card_discover_template@2x.png | Bin .../Stripe/stp_card_discover_template@3x.png | Bin .../Resources/Stripe/stp_card_form_applepay@2x.png | Bin .../Resources/Stripe/stp_card_form_applepay@3x.png | Bin .../Resources/Stripe/stp_card_form_back@2x.png | Bin .../Resources/Stripe/stp_card_form_back@3x.png | Bin .../Resources/Stripe/stp_card_form_front@2x.png | Bin .../Resources/Stripe/stp_card_form_front@3x.png | Bin .../Resources/Stripe/stp_card_jcb@2x.png | Bin .../Resources/Stripe/stp_card_jcb@3x.png | Bin .../Resources/Stripe/stp_card_jcb_template@2x.png | Bin .../Resources/Stripe/stp_card_jcb_template@3x.png | Bin .../Resources/Stripe/stp_card_mastercard@2x.png | Bin .../Resources/Stripe/stp_card_mastercard@3x.png | Bin .../Stripe/stp_card_mastercard_template@2x.png | Bin .../Stripe/stp_card_mastercard_template@3x.png | Bin .../Stripe/stp_card_placeholder_template@2x.png | Bin .../Stripe/stp_card_placeholder_template@3x.png | Bin .../Resources/Stripe/stp_card_visa@2x.png | Bin .../Resources/Stripe/stp_card_visa@3x.png | Bin .../Resources/Stripe/stp_card_visa_template@2x.png | Bin .../Resources/Stripe/stp_card_visa_template@3x.png | Bin .../Resources/WebEmbed/Generic.html | 0 .../Resources/WebEmbed/GenericUserScript.js | 0 .../Resources/WebEmbed/Instagram.html | 0 .../Resources/WebEmbed/Twitch.html | 0 .../Resources/WebEmbed/TwitchUserScript.js | 0 .../Resources/WebEmbed/Vimeo.html | 0 .../Resources/WebEmbed/VimeoUserScript.js | 0 .../Resources/WebEmbed/Youtube.html | 0 .../Resources/WebEmbed/YoutubeUserScript.js | 0 .../Resources/currencies.json | 0 .../{TelegramUI => Sources}/SampleBufferPool.swift | 0 .../SecretChatHandshakeStatusInputPanelNode.swift | 0 .../ServiceSoundManager.swift | 0 .../ShareExtensionContext.swift | 0 .../SharedAccountContext.swift | 0 .../{TelegramUI => Sources}/SharedMediaPlayer.swift | 0 .../SharedNotificationManager.swift | 0 .../SharedVideoContextManager.swift | 0 .../SharedWakeupManager.swift | 0 .../SoftwareVideoLayerFrameManager.swift | 0 .../SoftwareVideoThumbnailLayer.swift | 0 .../{TelegramUI => Sources}/Sounds/MessageSent.caf | Bin .../{TelegramUI => Sources}/Sounds/notification.caf | Bin .../{TelegramUI => Sources}/SpotlightContacts.swift | 0 .../StickerPanePeerSpecificSetupGridItem.swift | 0 .../StickerPaneSearchContentNode.swift | 0 .../StickerPaneSearchGlobaltem.swift | 0 .../StickerPaneSearchStickerItem.swift | 0 .../StickersChatInputContextPanelItem.swift | 0 .../StickersChatInputContextPanelNode.swift | 0 .../StoreDownloadedMedia.swift | 0 .../StringForMessageTimestampStatus.swift | 0 .../SuppressContactsWarning.swift | 0 .../TelegramAccountAuxiliaryMethods.swift | 0 .../TelegramRootController.swift | 0 .../TelegramUI/{TelegramUI => Sources}/TelegramUI.h | 0 .../{TelegramUI => Sources}/TextLinkHandling.swift | 0 .../ThemeUpdateManager.swift | 0 .../TimeBasedVideoPreload.swift | 0 .../{TelegramUI => Sources}/TonePlayer.swift | 0 .../TransformOutgoingMessageMedia.swift | 0 .../{TelegramUI => Sources}/UpgradedAccounts.swift | 0 ...istContextResultsChatInputContextPanelNode.swift | 0 ...ListContextResultsChatInputPanelButtonItem.swift | 0 ...rticalListContextResultsChatInputPanelItem.swift | 0 .../{TelegramUI => Sources}/VolumeButtons.swift | 0 .../{TelegramUI => Sources}/WalletContextImpl.swift | 0 .../WallpaperPreviewMedia.swift | 0 .../WallpaperUploadManager.swift | 0 .../{TelegramUI => Sources}/WatchManager.swift | 0 .../TelegramUI/{TelegramUI => Sources}/Weak.swift | 0 .../WebpagePreviewAccessoryPanelNode.swift | 0 .../{TelegramUI => Sources}/WidgetDataContext.swift | 0 .../module.private.modulemap | 0 650 files changed, 0 insertions(+), 0 deletions(-) rename submodules/Display/{Display => Sources}/ASTransformLayerNode.swift (100%) rename submodules/Display/{Display => Sources}/Accessibility.swift (100%) rename submodules/Display/{Display => Sources}/AccessibilityAreaNode.swift (100%) rename submodules/Display/{Display => Sources}/ActionSheetButtonItem.swift (100%) rename submodules/Display/{Display => Sources}/ActionSheetCheckboxItem.swift (100%) rename submodules/Display/{Display => Sources}/ActionSheetController.swift (100%) rename submodules/Display/{Display => Sources}/ActionSheetControllerNode.swift (100%) rename submodules/Display/{Display => Sources}/ActionSheetItem.swift (100%) rename submodules/Display/{Display => Sources}/ActionSheetItemGroup.swift (100%) rename submodules/Display/{Display => Sources}/ActionSheetItemGroupNode.swift (100%) rename submodules/Display/{Display => Sources}/ActionSheetItemGroupsContainerNode.swift (100%) rename submodules/Display/{Display => Sources}/ActionSheetItemNode.swift (100%) rename submodules/Display/{Display => Sources}/ActionSheetSwitchItem.swift (100%) rename submodules/Display/{Display => Sources}/ActionSheetTextItem.swift (100%) rename submodules/Display/{Display => Sources}/ActionSheetTheme.swift (100%) rename submodules/Display/{Display => Sources}/AlertContentNode.swift (100%) rename submodules/Display/{Display => Sources}/AlertController.swift (100%) rename submodules/Display/{Display => Sources}/AlertControllerNode.swift (100%) rename submodules/Display/{Display => Sources}/CAAnimationUtils.swift (100%) rename submodules/Display/{Display => Sources}/CASeeThroughTracingLayer.h (100%) rename submodules/Display/{Display => Sources}/CASeeThroughTracingLayer.m (100%) rename submodules/Display/{Display => Sources}/CATracingLayer.h (100%) rename submodules/Display/{Display => Sources}/CATracingLayer.m (100%) rename submodules/Display/{Display => Sources}/ChildWindowHostView.swift (100%) rename submodules/Display/{Display => Sources}/CollectionIndexNode.swift (100%) rename submodules/Display/{Display => Sources}/ContainableController.swift (100%) rename submodules/Display/{Display => Sources}/ContainedViewLayoutTransition.swift (100%) rename submodules/Display/{Display => Sources}/ContainerViewLayout.swift (100%) rename submodules/Display/{Display => Sources}/ContextContentContainerNode.swift (100%) rename submodules/Display/{Display => Sources}/ContextContentSourceNode.swift (100%) rename submodules/Display/{Display => Sources}/ContextControllerSourceNode.swift (100%) rename submodules/Display/{Display => Sources}/ContextGesture.swift (100%) rename submodules/Display/{Display => Sources}/ContextMenuAction.swift (100%) rename submodules/Display/{Display => Sources}/ContextMenuActionNode.swift (100%) rename submodules/Display/{Display => Sources}/ContextMenuContainerNode.swift (100%) rename submodules/Display/{Display => Sources}/ContextMenuController.swift (100%) rename submodules/Display/{Display => Sources}/ContextMenuNode.swift (100%) rename submodules/Display/{Display => Sources}/DeviceMetrics.swift (100%) rename submodules/Display/{Display => Sources}/Display.h (100%) rename submodules/Display/{Display => Sources}/DisplayLinkAnimator.swift (100%) rename submodules/Display/{Display => Sources}/DisplayLinkDispatcher.swift (100%) rename submodules/Display/{Display => Sources}/EditableTextNode.swift (100%) rename submodules/Display/{Display => Sources}/Font.swift (100%) rename submodules/Display/{Display => Sources}/GenerateImage.swift (100%) rename submodules/Display/{Display => Sources}/GlobalOverlayPresentationContext.swift (100%) rename submodules/Display/{Display => Sources}/GridItem.swift (100%) rename submodules/Display/{Display => Sources}/GridItemNode.swift (100%) rename submodules/Display/{Display => Sources}/GridNode.swift (100%) rename submodules/Display/{Display => Sources}/GridNodeScroller.swift (100%) rename submodules/Display/{Display => Sources}/HapticFeedback.swift (100%) rename submodules/Display/{Display => Sources}/HighlightTrackingButton.swift (100%) rename submodules/Display/{Display => Sources}/HighlightableButton.swift (100%) rename submodules/Display/{Display => Sources}/ImageCorners.swift (100%) rename submodules/Display/{Display => Sources}/ImageNode.swift (100%) rename submodules/Display/{Display => Sources}/ImmediateTextNode.swift (100%) rename submodules/Display/{Display => Sources}/Info.plist (100%) rename submodules/Display/{Display => Sources}/InteractiveTransitionGestureRecognizer.swift (100%) rename submodules/Display/{Display => Sources}/KeyShortcut.swift (100%) rename submodules/Display/{Display => Sources}/KeyShortcutsController.swift (100%) rename submodules/Display/{Display => Sources}/Keyboard.swift (100%) rename submodules/Display/{Display => Sources}/KeyboardManager.swift (100%) rename submodules/Display/{Display => Sources}/LayoutSizes.swift (100%) rename submodules/Display/{Display => Sources}/LegacyPresentedController.swift (100%) rename submodules/Display/{Display => Sources}/LegacyPresentedControllerNode.swift (100%) rename submodules/Display/{Display => Sources}/LinkHighlightingNode.swift (100%) rename submodules/Display/{Display => Sources}/ListView.swift (100%) rename submodules/Display/{Display => Sources}/ListViewAccessoryItem.swift (100%) rename submodules/Display/{Display => Sources}/ListViewAccessoryItemNode.swift (100%) rename submodules/Display/{Display => Sources}/ListViewAnimation.swift (100%) rename submodules/Display/{Display => Sources}/ListViewFloatingHeaderNode.swift (100%) rename submodules/Display/{Display => Sources}/ListViewIntermediateState.swift (100%) rename submodules/Display/{Display => Sources}/ListViewItem.swift (100%) rename submodules/Display/{Display => Sources}/ListViewItemHeader.swift (100%) rename submodules/Display/{Display => Sources}/ListViewItemNode.swift (100%) rename submodules/Display/{Display => Sources}/ListViewOverscrollBackgroundNode.swift (100%) rename submodules/Display/{Display => Sources}/ListViewReorderingGestureRecognizer.swift (100%) rename submodules/Display/{Display => Sources}/ListViewReorderingItemNode.swift (100%) rename submodules/Display/{Display => Sources}/ListViewScroller.swift (100%) rename submodules/Display/{Display => Sources}/ListViewTapGestureRecognizer.swift (100%) rename submodules/Display/{Display => Sources}/ListViewTempItemNode.swift (100%) rename submodules/Display/{Display => Sources}/ListViewTransactionQueue.swift (100%) rename submodules/Display/{Display => Sources}/MinimizeKeyboardGestureRecognizer.swift (100%) rename submodules/Display/{Display => Sources}/NSBag.h (100%) rename submodules/Display/{Display => Sources}/NSBag.m (100%) rename submodules/Display/{Display => Sources}/NSWeakReference.h (100%) rename submodules/Display/{Display => Sources}/NSWeakReference.m (100%) rename submodules/Display/{Display => Sources}/NativeWindowHostView.swift (100%) rename submodules/Display/{Display => Sources}/Navigation/NavigationContainer.swift (100%) rename submodules/Display/{Display => Sources}/Navigation/NavigationController.swift (100%) rename submodules/Display/{Display => Sources}/Navigation/NavigationLayout.swift (100%) rename submodules/Display/{Display => Sources}/Navigation/NavigationModalContainer.swift (100%) rename submodules/Display/{Display => Sources}/Navigation/NavigationModalFrame.swift (100%) rename submodules/Display/{Display => Sources}/Navigation/NavigationOverlayContainer.swift (100%) rename submodules/Display/{Display => Sources}/Navigation/NavigationSplitContainer.swift (100%) rename submodules/Display/{Display => Sources}/NavigationBackButtonNode.swift (100%) rename submodules/Display/{Display => Sources}/NavigationBar.swift (100%) rename submodules/Display/{Display => Sources}/NavigationBarBadge.swift (100%) rename submodules/Display/{Display => Sources}/NavigationBarContentNode.swift (100%) rename submodules/Display/{Display => Sources}/NavigationBarProxy.h (100%) rename submodules/Display/{Display => Sources}/NavigationBarProxy.m (100%) rename submodules/Display/{Display => Sources}/NavigationBarTitleTransitionNode.swift (100%) rename submodules/Display/{Display => Sources}/NavigationBarTitleView.swift (100%) rename submodules/Display/{Display => Sources}/NavigationBarTransitionContainer.swift (100%) rename submodules/Display/{Display => Sources}/NavigationBarTransitionState.swift (100%) rename submodules/Display/{Display => Sources}/NavigationButtonNode.swift (100%) rename submodules/Display/{Display => Sources}/NavigationControllerProxy.h (100%) rename submodules/Display/{Display => Sources}/NavigationControllerProxy.m (100%) rename submodules/Display/{Display => Sources}/NavigationTitleNode.swift (100%) rename submodules/Display/{Display => Sources}/NavigationTransitionCoordinator.swift (100%) rename submodules/Display/{Display => Sources}/NotificationCenterUtils.h (100%) rename submodules/Display/{Display => Sources}/NotificationCenterUtils.m (100%) rename submodules/Display/{Display => Sources}/PageControlNode.swift (100%) rename submodules/Display/{Display => Sources}/PeekController.swift (100%) rename submodules/Display/{Display => Sources}/PeekControllerContent.swift (100%) rename submodules/Display/{Display => Sources}/PeekControllerGestureRecognizer.swift (100%) rename submodules/Display/{Display => Sources}/PeekControllerMenuItemNode.swift (100%) rename submodules/Display/{Display => Sources}/PeekControllerMenuNode.swift (100%) rename submodules/Display/{Display => Sources}/PeekControllerNode.swift (100%) rename submodules/Display/{Display => Sources}/PresentationContext.swift (100%) rename submodules/Display/{Display => Sources}/RuntimeUtils.h (100%) rename submodules/Display/{Display => Sources}/RuntimeUtils.m (100%) rename submodules/Display/{Display => Sources}/RuntimeUtils.swift (100%) rename submodules/Display/{Display => Sources}/ScrollToTopProxyView.swift (100%) rename submodules/Display/{Display => Sources}/ShakeAnimation.swift (100%) rename submodules/Display/{Display => Sources}/Spring.swift (100%) rename submodules/Display/{Display => Sources}/StatusBar.swift (100%) rename submodules/Display/{Display => Sources}/StatusBarHost.swift (100%) rename submodules/Display/{Display => Sources}/StatusBarProxyNode.swift (100%) rename submodules/Display/{Display => Sources}/SubstringSearch.swift (100%) rename submodules/Display/{Display => Sources}/SwitchNode.swift (100%) rename submodules/Display/{Display => Sources}/TabBarContollerNode.swift (100%) rename submodules/Display/{Display => Sources}/TabBarController.swift (100%) rename submodules/Display/{Display => Sources}/TabBarNode.swift (100%) rename submodules/Display/{Display => Sources}/TabBarTapRecognizer.swift (100%) rename submodules/Display/{Display => Sources}/TapLongTapOrDoubleTapGestureRecognizer.swift (100%) rename submodules/Display/{Display => Sources}/TextAlertController.swift (100%) rename submodules/Display/{Display => Sources}/TextFieldNode.swift (100%) rename submodules/Display/{Display => Sources}/TextNode.swift (100%) rename submodules/Display/{Display => Sources}/Toolbar.swift (100%) rename submodules/Display/{Display => Sources}/ToolbarNode.swift (100%) rename submodules/Display/{Display => Sources}/TooltipController.swift (100%) rename submodules/Display/{Display => Sources}/TooltipControllerNode.swift (100%) rename submodules/Display/{Display => Sources}/TransformImageArguments.swift (100%) rename submodules/Display/{Display => Sources}/TransformImageNode.swift (100%) rename submodules/Display/{Display => Sources}/UIBarButtonItem+Proxy.h (100%) rename submodules/Display/{Display => Sources}/UIBarButtonItem+Proxy.m (100%) rename submodules/Display/{Display => Sources}/UIKitUtils.h (100%) rename submodules/Display/{Display => Sources}/UIKitUtils.m (100%) rename submodules/Display/{Display => Sources}/UIKitUtils.swift (100%) rename submodules/Display/{Display => Sources}/UIMenuItem+Icons.h (100%) rename submodules/Display/{Display => Sources}/UIMenuItem+Icons.m (100%) rename submodules/Display/{Display => Sources}/UINavigationItem+Proxy.h (100%) rename submodules/Display/{Display => Sources}/UINavigationItem+Proxy.m (100%) rename submodules/Display/{Display => Sources}/UITracingLayerView.swift (100%) rename submodules/Display/{Display => Sources}/UIViewController+Navigation.h (100%) rename submodules/Display/{Display => Sources}/UIViewController+Navigation.m (100%) rename submodules/Display/{Display => Sources}/UIWindow+OrientationChange.h (100%) rename submodules/Display/{Display => Sources}/UIWindow+OrientationChange.m (100%) rename submodules/Display/{Display => Sources}/UniversalMasterController.swift (100%) rename submodules/Display/{Display => Sources}/UniversalTapRecognizer.swift (100%) rename submodules/Display/{Display => Sources}/ViewController.swift (100%) rename submodules/Display/{Display => Sources}/ViewControllerPreviewing.swift (100%) rename submodules/Display/{Display => Sources}/ViewControllerTracingNode.swift (100%) rename submodules/Display/{Display => Sources}/VolumeControlStatusBar.swift (100%) rename submodules/Display/{Display => Sources}/WallpaperBackgroundNode.swift (100%) rename submodules/Display/{Display => Sources}/WindowContent.swift (100%) rename submodules/Display/{Display => Sources}/WindowCoveringView.swift (100%) rename submodules/Display/{Display => Sources}/WindowInputAccessoryHeightProvider.swift (100%) rename submodules/Display/{Display => Sources}/WindowPanRecognizer.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/AccessoryPanelNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/AccountContext.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/AppDelegate.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ApplicationContext.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ApplicationShortcutItem.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/AudioRecordningToneData.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/AudioWaveform.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/AudioWaveformNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/AuthorizationSequenceAwaitingAccountResetController.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/AuthorizationSequenceAwaitingAccountResetControllerNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/AuthorizationSequenceCodeEntryController.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/AuthorizationSequenceCodeEntryControllerNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/AuthorizationSequenceController.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/AuthorizationSequencePasswordEntryController.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/AuthorizationSequencePasswordEntryControllerNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/AuthorizationSequencePasswordRecoveryController.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/AuthorizationSequencePasswordRecoveryControllerNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/AuthorizationSequencePhoneEntryController.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/AuthorizationSequencePhoneEntryControllerNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/AuthorizationSequenceSignUpController.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/AuthorizationSequenceSignUpControllerNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/AuthorizationSequenceSplashController.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/AuthorizationSequenceSplashControllerNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatAvatarNavigationNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatBotInfoItem.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatBotStartInputPanelNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatButtonKeyboardInputNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatChannelSubscriberInputPanelNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatContextResultPeekContentNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatController.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatControllerInteraction.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatControllerNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatControllerTitlePanelNodeContainer.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatDateSelectionSheet.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatEditInterfaceMessageState.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatEditMessageMediaContext.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatEmptyNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatFeedNavigationInputPanelNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatHistoryEntriesForView.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatHistoryEntry.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatHistoryGridNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatHistoryListNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatHistoryLocation.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatHistoryNavigationButtonNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatHistoryNavigationButtons.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatHistoryNavigationStack.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatHistoryNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatHistorySearchContainerNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatHistoryViewForLocation.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatHoleItem.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatInfo.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatInfoTitlePanelNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatInputContextPanelNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatInputNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatInputPanelNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatInstantVideoMessageDurationNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatInterfaceInputContextPanels.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatInterfaceInputContexts.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatInterfaceInputNodes.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatInterfaceState.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatInterfaceStateAccessoryPanels.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatInterfaceStateContextMenus.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatInterfaceStateContextQueries.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatInterfaceStateInputPanels.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatInterfaceStateNavigationButtons.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatInterfaceTitlePanelNodes.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatLinkPreview.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatLoadingNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatMediaInputGifPane.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatMediaInputGridEntries.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatMediaInputMetaSectionItemNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatMediaInputNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatMediaInputPane.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatMediaInputPanelEntries.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatMediaInputPeerSpecificItem.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatMediaInputRecentGifsItem.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatMediaInputSettingsItem.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatMediaInputStickerGridItem.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatMediaInputStickerPackItem.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatMediaInputStickerPane.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatMediaInputTrendingItem.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatMediaInputTrendingPane.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatMessageActionButtonsNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatMessageActionItemNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatMessageActionSheetController.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatMessageActionSheetControllerNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatMessageActionUrlAuthController.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatMessageAnimatedStickerItemNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatMessageAttachedContentNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatMessageAvatarAccessoryItem.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatMessageBackground.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatMessageBubbleBackdrop.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatMessageBubbleContentCalclulateImageCorners.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatMessageBubbleContentNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatMessageBubbleItemNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatMessageCallBubbleContentNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatMessageContactBubbleContentNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatMessageContextControllerContentSource.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatMessageDateAndStatusNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatMessageDateHeader.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatMessageDeliveryFailedNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatMessageEventLogPreviousDescriptionContentNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatMessageEventLogPreviousLinkContentNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatMessageEventLogPreviousMessageContentNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatMessageFileBubbleContentNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatMessageForwardInfoNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatMessageGameBubbleContentNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatMessageInstantVideoItemNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatMessageInteractiveFileNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatMessageInteractiveInstantVideoNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatMessageInteractiveMediaBadge.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatMessageInteractiveMediaNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatMessageInvoiceBubbleContentNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatMessageItem.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatMessageItemView.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatMessageLiveLocationTextNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatMessageMapBubbleContentNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatMessageMediaBubbleContentNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatMessageNotificationItem.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatMessagePollBubbleContentNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatMessageReplyInfoNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatMessageRestrictedBubbleContentNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatMessageSelectionInputPanelNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatMessageSelectionNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatMessageStickerItemNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatMessageSwipeToReplyNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatMessageTextBubbleContentNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatMessageThrottledProcessingManager.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatMessageUnsupportedBubbleContentNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatMessageWebpageBubbleContentNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatOverlayNavigationBar.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatPanelInterfaceInteraction.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatPinnedMessageTitlePanelNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatPresentationData.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatPresentationInterfaceState.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatRecentActionsController.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatRecentActionsControllerNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatRecentActionsControllerState.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatRecentActionsEmptyNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatRecentActionsFilterController.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatRecentActionsHistoryTransition.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatRecentActionsInteraction.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatRecentActionsSearchNavigationContentNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatRecentActionsTitleView.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatRecordingPreviewInputPanelNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatReportPeerTitlePanelNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatRequestInProgressTitlePanelNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatRestrictedInputPanelNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatRestrictedNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatScheduleTimeController.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatScheduleTimeControllerNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatSearchInputPanelNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatSearchNavigationContentNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatSearchResultsContollerNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatSearchResultsController.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatSearchState.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatSecretAutoremoveTimerActionSheet.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatSendButtonRadialStatusNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatSendMessageActionSheetController.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatSendMessageActionSheetControllerNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatSlowmodeHintController.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatSwipeToReplyRecognizer.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatTextFormat.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatTextInputAccessoryItem.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatTextInputActionButtonsNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatTextInputAudioRecordingCancelIndicator.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatTextInputAudioRecordingOverlayButton.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatTextInputAudioRecordingTimeNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatTextInputMediaRecordingButton.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatTextInputMenu.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatTextInputPanelNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatTextInputPanelState.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatTextInputSlowmodePlaceholderNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatTextLinkEditController.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatTitleAccessoryPanelNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatTitleView.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatToastAlertPanelNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatUnblockInputPanelNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ChatUnreadItem.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/CheckDiskSpace.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ClearNotificationsManager.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/CommandChatInputContextPanelNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/CommandChatInputPanelItem.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ComposeController.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ComposeControllerNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ConfettiView.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ContactMultiselectionController.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ContactMultiselectionControllerNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ContactSelectionController.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ContactSelectionControllerNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ConvertToWebP.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/CreateChannelController.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/CreateGroupController.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/DeclareEncodables.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/DeleteChatInputPanelNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/DeviceContactDataManager.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/DisabledContextResultsChatInputContextPanelNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/DocumentPreviewController.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/EditAccessoryPanelNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/EditableTokenListNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/EmojiResources.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/EmojisChatInputContextPanelNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/EmojisChatInputPanelItem.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/FetchCachedRepresentations.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/FetchManager.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/FetchManagerLocation.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/FetchResource.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/FetchVideoMediaResource.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/FileMediaResourceStatus.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ForwardAccessoryPanelNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/GalleryHiddenMediaManager.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/GifPaneSearchContentNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/GlobalExperimentalSettings.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/GridHoleItem.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/GridMessageItem.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/HashtagChatInputContextPanelNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/HashtagChatInputPanelItem.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/HorizontalListContextResultsChatInputContextPanelNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/HorizontalListContextResultsChatInputPanelItem.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/HorizontalStickerGridItem.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/HorizontalStickersChatContextPanelNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ICloudResources.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ID3ArtworkReader.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/IconButtonNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/InChatPrefetchManager.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Info.plist (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/InstantVideoRadialStatusNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/LegacyCache.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/LegacyCamera.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/LegacyInstantVideoController.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/LegacyLiveUploadInterface.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/LinkHighlightingNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ListMessageDateHeader.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ListMessageFileItemNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ListMessageHoleItem.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ListMessageItem.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ListMessageNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ListMessagePlaybackOverlayNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ListMessageSnippetItemNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/LockedWindowCoveringView.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ManageSharedAccountInfo.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ManagedAudioRecorder.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/MediaInputPaneTrendingItem.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/MediaManager.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/MediaPlaybackStoredState.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/MentionChatInputContextPanelNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/MentionChatInputPanelItem.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/MultiScaleTextNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/MultiplexedSoftwareVideoNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/MultiplexedSoftwareVideoSourceManager.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/MultiplexedVideoNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/NavigateToChatController.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/NotificationContainerController.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/NotificationContainerControllerNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/NotificationContentContext.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/NotificationItem.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/NotificationItemContainerNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/OpenAddContact.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/OpenChatMessage.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/OpenResolvedUrl.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/OpenUrl.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/OverlayAudioPlayerController.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/OverlayInstantVideoDecoration.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/OverlayInstantVideoNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/OverlayMediaController.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/OverlayMediaControllerNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/OverlayPlayerControllerNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/OverlayPlayerControlsNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/PaneSearchBarNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/PaneSearchBarPlaceholderItem.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/PaneSearchContainerNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Pasteboard.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/PeerInfo/ListItems/PeerInfoScreenActionItem.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/PeerInfo/ListItems/PeerInfoScreenAddressItem.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/PeerInfo/ListItems/PeerInfoScreenCallListItem.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/PeerInfo/ListItems/PeerInfoScreenCommentItem.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/PeerInfo/ListItems/PeerInfoScreenDisclosureEncryptionKeyItem.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/PeerInfo/ListItems/PeerInfoScreenDisclosureItem.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/PeerInfo/ListItems/PeerInfoScreenHeaderItem.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/PeerInfo/ListItems/PeerInfoScreenLabeledValueItem.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/PeerInfo/ListItems/PeerInfoScreenMemberItem.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/PeerInfo/ListItems/PeerInfoScreenSelectableBackgroundNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/PeerInfo/ListItems/PeerInfoScreenSwitchItem.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/PeerInfo/Panes/PeerInfoGroupsInCommonPaneNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/PeerInfo/Panes/PeerInfoListPaneNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/PeerInfo/Panes/PeerInfoMembersPane.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/PeerInfo/Panes/PeerInfoVisualMediaPaneNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/PeerInfo/PeerInfoData.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/PeerInfo/PeerInfoHeaderNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/PeerInfo/PeerInfoMembers.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/PeerInfo/PeerInfoPaneContainerNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/PeerInfo/PeerInfoScreen.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/PeerMediaCollectionController.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/PeerMediaCollectionControllerNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/PeerMediaCollectionEmptyNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/PeerMediaCollectionInterfaceState.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/PeerMediaCollectionInterfaceStateButtons.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/PeerMediaCollectionSectionsNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/PeerMessagesMediaPlaylist.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/PeerSelectionController.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/PeerSelectionControllerNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/PeersNearbyManager.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/PollResultsController.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/PrefetchManager.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/PrepareSecretThumbnailData.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/PreparedChatHistoryViewTransition.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ProcessedPeerRestrictionText.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/RadialProgressNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/RadialTimeoutNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ReplyAccessoryPanelNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/Animations/ChatListEmpty.tgs (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/Animations/ChatListFilterEmpty.tgs (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/Animations/anim_archive.json (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/Animations/anim_archiveAvatar.json (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/Animations/anim_archiveswipe.json (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/Animations/anim_delete.json (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/Animations/anim_group.json (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/Animations/anim_hide.json (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/Animations/anim_infotip.json (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/Animations/anim_mute.json (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/Animations/anim_pin.json (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/Animations/anim_qr.json (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/Animations/anim_read.json (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/Animations/anim_success.json (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/Animations/anim_swipereply.json (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/Animations/anim_unarchive.json (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/Animations/anim_ungroup.json (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/Animations/anim_unmute.json (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/Animations/anim_unpin.json (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/Animations/anim_unread.json (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/BuiltinReactions/celebrate.tgs (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/BuiltinReactions/cry.tgs (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/BuiltinReactions/heart.tgs (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/BuiltinReactions/lol.tgs (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/BuiltinReactions/meh.tgs (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/BuiltinReactions/ok.tgs (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/BuiltinReactions/poker.tgs (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/BuiltinReactions/poop.tgs (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/BuiltinReactions/sad.tgs (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/BuiltinReactions/smile.tgs (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/BuiltinReactions/surprised.tgs (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/BuiltinReactions/thumbsup.tgs (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/ChatWallpaperBuiltin0.jpg (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/Emoji.mapping (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/Fonts/SFCompactRounded-Semibold.otf (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/PhoneCountries.txt (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/PresentationStrings.mapping (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/StillReactions/simplereaction_10@2x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/StillReactions/simplereaction_10@3x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/StillReactions/simplereaction_11@2x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/StillReactions/simplereaction_11@3x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/StillReactions/simplereaction_12@2x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/StillReactions/simplereaction_12@3x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/StillReactions/simplereaction_13@2x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/StillReactions/simplereaction_13@3x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/StillReactions/simplereaction_14@2x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/StillReactions/simplereaction_14@3x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/StillReactions/simplereaction_15@2x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/StillReactions/simplereaction_15@3x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/StillReactions/simplereaction_16@2x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/StillReactions/simplereaction_16@3x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/StillReactions/simplereaction_17@2x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/StillReactions/simplereaction_17@3x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/StillReactions/simplereaction_18@2x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/StillReactions/simplereaction_18@3x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/StillReactions/simplereaction_19@2x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/StillReactions/simplereaction_19@3x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/StillReactions/simplereaction_1@2x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/StillReactions/simplereaction_1@3x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/StillReactions/simplereaction_20@2x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/StillReactions/simplereaction_20@3x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/StillReactions/simplereaction_2@2x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/StillReactions/simplereaction_2@3x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/StillReactions/simplereaction_3@2x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/StillReactions/simplereaction_3@3x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/StillReactions/simplereaction_4@2x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/StillReactions/simplereaction_4@3x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/StillReactions/simplereaction_5@2x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/StillReactions/simplereaction_5@3x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/StillReactions/simplereaction_6@2x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/StillReactions/simplereaction_6@3x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/StillReactions/simplereaction_7@2x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/StillReactions/simplereaction_7@3x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/StillReactions/simplereaction_8@2x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/StillReactions/simplereaction_8@3x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/StillReactions/simplereaction_9@2x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/StillReactions/simplereaction_9@3x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/Stripe/stp_card_amex@2x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/Stripe/stp_card_amex@3x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/Stripe/stp_card_amex_template@2x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/Stripe/stp_card_amex_template@3x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/Stripe/stp_card_applepay@2x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/Stripe/stp_card_applepay@3x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/Stripe/stp_card_applepay_template@2x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/Stripe/stp_card_applepay_template@3x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/Stripe/stp_card_cvc@2x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/Stripe/stp_card_cvc@3x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/Stripe/stp_card_cvc_amex@2x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/Stripe/stp_card_cvc_amex@3x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/Stripe/stp_card_diners@2x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/Stripe/stp_card_diners@3x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/Stripe/stp_card_diners_template@2x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/Stripe/stp_card_diners_template@3x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/Stripe/stp_card_discover@2x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/Stripe/stp_card_discover@3x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/Stripe/stp_card_discover_template@2x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/Stripe/stp_card_discover_template@3x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/Stripe/stp_card_form_applepay@2x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/Stripe/stp_card_form_applepay@3x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/Stripe/stp_card_form_back@2x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/Stripe/stp_card_form_back@3x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/Stripe/stp_card_form_front@2x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/Stripe/stp_card_form_front@3x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/Stripe/stp_card_jcb@2x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/Stripe/stp_card_jcb@3x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/Stripe/stp_card_jcb_template@2x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/Stripe/stp_card_jcb_template@3x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/Stripe/stp_card_mastercard@2x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/Stripe/stp_card_mastercard@3x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/Stripe/stp_card_mastercard_template@2x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/Stripe/stp_card_mastercard_template@3x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/Stripe/stp_card_placeholder_template@2x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/Stripe/stp_card_placeholder_template@3x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/Stripe/stp_card_visa@2x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/Stripe/stp_card_visa@3x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/Stripe/stp_card_visa_template@2x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/Stripe/stp_card_visa_template@3x.png (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/WebEmbed/Generic.html (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/WebEmbed/GenericUserScript.js (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/WebEmbed/Instagram.html (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/WebEmbed/Twitch.html (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/WebEmbed/TwitchUserScript.js (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/WebEmbed/Vimeo.html (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/WebEmbed/VimeoUserScript.js (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/WebEmbed/Youtube.html (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/WebEmbed/YoutubeUserScript.js (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Resources/currencies.json (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/SampleBufferPool.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/SecretChatHandshakeStatusInputPanelNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ServiceSoundManager.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ShareExtensionContext.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/SharedAccountContext.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/SharedMediaPlayer.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/SharedNotificationManager.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/SharedVideoContextManager.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/SharedWakeupManager.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/SoftwareVideoLayerFrameManager.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/SoftwareVideoThumbnailLayer.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Sounds/MessageSent.caf (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Sounds/notification.caf (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/SpotlightContacts.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/StickerPanePeerSpecificSetupGridItem.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/StickerPaneSearchContentNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/StickerPaneSearchGlobaltem.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/StickerPaneSearchStickerItem.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/StickersChatInputContextPanelItem.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/StickersChatInputContextPanelNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/StoreDownloadedMedia.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/StringForMessageTimestampStatus.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/SuppressContactsWarning.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/TelegramAccountAuxiliaryMethods.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/TelegramRootController.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/TelegramUI.h (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/TextLinkHandling.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/ThemeUpdateManager.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/TimeBasedVideoPreload.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/TonePlayer.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/TransformOutgoingMessageMedia.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/UpgradedAccounts.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/VerticalListContextResultsChatInputContextPanelNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/VerticalListContextResultsChatInputPanelButtonItem.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/VerticalListContextResultsChatInputPanelItem.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/VolumeButtons.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/WalletContextImpl.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/WallpaperPreviewMedia.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/WallpaperUploadManager.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/WatchManager.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/Weak.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/WebpagePreviewAccessoryPanelNode.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/WidgetDataContext.swift (100%) rename submodules/TelegramUI/{TelegramUI => Sources}/module.private.modulemap (100%) diff --git a/submodules/Display/Display/ASTransformLayerNode.swift b/submodules/Display/Sources/ASTransformLayerNode.swift similarity index 100% rename from submodules/Display/Display/ASTransformLayerNode.swift rename to submodules/Display/Sources/ASTransformLayerNode.swift diff --git a/submodules/Display/Display/Accessibility.swift b/submodules/Display/Sources/Accessibility.swift similarity index 100% rename from submodules/Display/Display/Accessibility.swift rename to submodules/Display/Sources/Accessibility.swift diff --git a/submodules/Display/Display/AccessibilityAreaNode.swift b/submodules/Display/Sources/AccessibilityAreaNode.swift similarity index 100% rename from submodules/Display/Display/AccessibilityAreaNode.swift rename to submodules/Display/Sources/AccessibilityAreaNode.swift diff --git a/submodules/Display/Display/ActionSheetButtonItem.swift b/submodules/Display/Sources/ActionSheetButtonItem.swift similarity index 100% rename from submodules/Display/Display/ActionSheetButtonItem.swift rename to submodules/Display/Sources/ActionSheetButtonItem.swift diff --git a/submodules/Display/Display/ActionSheetCheckboxItem.swift b/submodules/Display/Sources/ActionSheetCheckboxItem.swift similarity index 100% rename from submodules/Display/Display/ActionSheetCheckboxItem.swift rename to submodules/Display/Sources/ActionSheetCheckboxItem.swift diff --git a/submodules/Display/Display/ActionSheetController.swift b/submodules/Display/Sources/ActionSheetController.swift similarity index 100% rename from submodules/Display/Display/ActionSheetController.swift rename to submodules/Display/Sources/ActionSheetController.swift diff --git a/submodules/Display/Display/ActionSheetControllerNode.swift b/submodules/Display/Sources/ActionSheetControllerNode.swift similarity index 100% rename from submodules/Display/Display/ActionSheetControllerNode.swift rename to submodules/Display/Sources/ActionSheetControllerNode.swift diff --git a/submodules/Display/Display/ActionSheetItem.swift b/submodules/Display/Sources/ActionSheetItem.swift similarity index 100% rename from submodules/Display/Display/ActionSheetItem.swift rename to submodules/Display/Sources/ActionSheetItem.swift diff --git a/submodules/Display/Display/ActionSheetItemGroup.swift b/submodules/Display/Sources/ActionSheetItemGroup.swift similarity index 100% rename from submodules/Display/Display/ActionSheetItemGroup.swift rename to submodules/Display/Sources/ActionSheetItemGroup.swift diff --git a/submodules/Display/Display/ActionSheetItemGroupNode.swift b/submodules/Display/Sources/ActionSheetItemGroupNode.swift similarity index 100% rename from submodules/Display/Display/ActionSheetItemGroupNode.swift rename to submodules/Display/Sources/ActionSheetItemGroupNode.swift diff --git a/submodules/Display/Display/ActionSheetItemGroupsContainerNode.swift b/submodules/Display/Sources/ActionSheetItemGroupsContainerNode.swift similarity index 100% rename from submodules/Display/Display/ActionSheetItemGroupsContainerNode.swift rename to submodules/Display/Sources/ActionSheetItemGroupsContainerNode.swift diff --git a/submodules/Display/Display/ActionSheetItemNode.swift b/submodules/Display/Sources/ActionSheetItemNode.swift similarity index 100% rename from submodules/Display/Display/ActionSheetItemNode.swift rename to submodules/Display/Sources/ActionSheetItemNode.swift diff --git a/submodules/Display/Display/ActionSheetSwitchItem.swift b/submodules/Display/Sources/ActionSheetSwitchItem.swift similarity index 100% rename from submodules/Display/Display/ActionSheetSwitchItem.swift rename to submodules/Display/Sources/ActionSheetSwitchItem.swift diff --git a/submodules/Display/Display/ActionSheetTextItem.swift b/submodules/Display/Sources/ActionSheetTextItem.swift similarity index 100% rename from submodules/Display/Display/ActionSheetTextItem.swift rename to submodules/Display/Sources/ActionSheetTextItem.swift diff --git a/submodules/Display/Display/ActionSheetTheme.swift b/submodules/Display/Sources/ActionSheetTheme.swift similarity index 100% rename from submodules/Display/Display/ActionSheetTheme.swift rename to submodules/Display/Sources/ActionSheetTheme.swift diff --git a/submodules/Display/Display/AlertContentNode.swift b/submodules/Display/Sources/AlertContentNode.swift similarity index 100% rename from submodules/Display/Display/AlertContentNode.swift rename to submodules/Display/Sources/AlertContentNode.swift diff --git a/submodules/Display/Display/AlertController.swift b/submodules/Display/Sources/AlertController.swift similarity index 100% rename from submodules/Display/Display/AlertController.swift rename to submodules/Display/Sources/AlertController.swift diff --git a/submodules/Display/Display/AlertControllerNode.swift b/submodules/Display/Sources/AlertControllerNode.swift similarity index 100% rename from submodules/Display/Display/AlertControllerNode.swift rename to submodules/Display/Sources/AlertControllerNode.swift diff --git a/submodules/Display/Display/CAAnimationUtils.swift b/submodules/Display/Sources/CAAnimationUtils.swift similarity index 100% rename from submodules/Display/Display/CAAnimationUtils.swift rename to submodules/Display/Sources/CAAnimationUtils.swift diff --git a/submodules/Display/Display/CASeeThroughTracingLayer.h b/submodules/Display/Sources/CASeeThroughTracingLayer.h similarity index 100% rename from submodules/Display/Display/CASeeThroughTracingLayer.h rename to submodules/Display/Sources/CASeeThroughTracingLayer.h diff --git a/submodules/Display/Display/CASeeThroughTracingLayer.m b/submodules/Display/Sources/CASeeThroughTracingLayer.m similarity index 100% rename from submodules/Display/Display/CASeeThroughTracingLayer.m rename to submodules/Display/Sources/CASeeThroughTracingLayer.m diff --git a/submodules/Display/Display/CATracingLayer.h b/submodules/Display/Sources/CATracingLayer.h similarity index 100% rename from submodules/Display/Display/CATracingLayer.h rename to submodules/Display/Sources/CATracingLayer.h diff --git a/submodules/Display/Display/CATracingLayer.m b/submodules/Display/Sources/CATracingLayer.m similarity index 100% rename from submodules/Display/Display/CATracingLayer.m rename to submodules/Display/Sources/CATracingLayer.m diff --git a/submodules/Display/Display/ChildWindowHostView.swift b/submodules/Display/Sources/ChildWindowHostView.swift similarity index 100% rename from submodules/Display/Display/ChildWindowHostView.swift rename to submodules/Display/Sources/ChildWindowHostView.swift diff --git a/submodules/Display/Display/CollectionIndexNode.swift b/submodules/Display/Sources/CollectionIndexNode.swift similarity index 100% rename from submodules/Display/Display/CollectionIndexNode.swift rename to submodules/Display/Sources/CollectionIndexNode.swift diff --git a/submodules/Display/Display/ContainableController.swift b/submodules/Display/Sources/ContainableController.swift similarity index 100% rename from submodules/Display/Display/ContainableController.swift rename to submodules/Display/Sources/ContainableController.swift diff --git a/submodules/Display/Display/ContainedViewLayoutTransition.swift b/submodules/Display/Sources/ContainedViewLayoutTransition.swift similarity index 100% rename from submodules/Display/Display/ContainedViewLayoutTransition.swift rename to submodules/Display/Sources/ContainedViewLayoutTransition.swift diff --git a/submodules/Display/Display/ContainerViewLayout.swift b/submodules/Display/Sources/ContainerViewLayout.swift similarity index 100% rename from submodules/Display/Display/ContainerViewLayout.swift rename to submodules/Display/Sources/ContainerViewLayout.swift diff --git a/submodules/Display/Display/ContextContentContainerNode.swift b/submodules/Display/Sources/ContextContentContainerNode.swift similarity index 100% rename from submodules/Display/Display/ContextContentContainerNode.swift rename to submodules/Display/Sources/ContextContentContainerNode.swift diff --git a/submodules/Display/Display/ContextContentSourceNode.swift b/submodules/Display/Sources/ContextContentSourceNode.swift similarity index 100% rename from submodules/Display/Display/ContextContentSourceNode.swift rename to submodules/Display/Sources/ContextContentSourceNode.swift diff --git a/submodules/Display/Display/ContextControllerSourceNode.swift b/submodules/Display/Sources/ContextControllerSourceNode.swift similarity index 100% rename from submodules/Display/Display/ContextControllerSourceNode.swift rename to submodules/Display/Sources/ContextControllerSourceNode.swift diff --git a/submodules/Display/Display/ContextGesture.swift b/submodules/Display/Sources/ContextGesture.swift similarity index 100% rename from submodules/Display/Display/ContextGesture.swift rename to submodules/Display/Sources/ContextGesture.swift diff --git a/submodules/Display/Display/ContextMenuAction.swift b/submodules/Display/Sources/ContextMenuAction.swift similarity index 100% rename from submodules/Display/Display/ContextMenuAction.swift rename to submodules/Display/Sources/ContextMenuAction.swift diff --git a/submodules/Display/Display/ContextMenuActionNode.swift b/submodules/Display/Sources/ContextMenuActionNode.swift similarity index 100% rename from submodules/Display/Display/ContextMenuActionNode.swift rename to submodules/Display/Sources/ContextMenuActionNode.swift diff --git a/submodules/Display/Display/ContextMenuContainerNode.swift b/submodules/Display/Sources/ContextMenuContainerNode.swift similarity index 100% rename from submodules/Display/Display/ContextMenuContainerNode.swift rename to submodules/Display/Sources/ContextMenuContainerNode.swift diff --git a/submodules/Display/Display/ContextMenuController.swift b/submodules/Display/Sources/ContextMenuController.swift similarity index 100% rename from submodules/Display/Display/ContextMenuController.swift rename to submodules/Display/Sources/ContextMenuController.swift diff --git a/submodules/Display/Display/ContextMenuNode.swift b/submodules/Display/Sources/ContextMenuNode.swift similarity index 100% rename from submodules/Display/Display/ContextMenuNode.swift rename to submodules/Display/Sources/ContextMenuNode.swift diff --git a/submodules/Display/Display/DeviceMetrics.swift b/submodules/Display/Sources/DeviceMetrics.swift similarity index 100% rename from submodules/Display/Display/DeviceMetrics.swift rename to submodules/Display/Sources/DeviceMetrics.swift diff --git a/submodules/Display/Display/Display.h b/submodules/Display/Sources/Display.h similarity index 100% rename from submodules/Display/Display/Display.h rename to submodules/Display/Sources/Display.h diff --git a/submodules/Display/Display/DisplayLinkAnimator.swift b/submodules/Display/Sources/DisplayLinkAnimator.swift similarity index 100% rename from submodules/Display/Display/DisplayLinkAnimator.swift rename to submodules/Display/Sources/DisplayLinkAnimator.swift diff --git a/submodules/Display/Display/DisplayLinkDispatcher.swift b/submodules/Display/Sources/DisplayLinkDispatcher.swift similarity index 100% rename from submodules/Display/Display/DisplayLinkDispatcher.swift rename to submodules/Display/Sources/DisplayLinkDispatcher.swift diff --git a/submodules/Display/Display/EditableTextNode.swift b/submodules/Display/Sources/EditableTextNode.swift similarity index 100% rename from submodules/Display/Display/EditableTextNode.swift rename to submodules/Display/Sources/EditableTextNode.swift diff --git a/submodules/Display/Display/Font.swift b/submodules/Display/Sources/Font.swift similarity index 100% rename from submodules/Display/Display/Font.swift rename to submodules/Display/Sources/Font.swift diff --git a/submodules/Display/Display/GenerateImage.swift b/submodules/Display/Sources/GenerateImage.swift similarity index 100% rename from submodules/Display/Display/GenerateImage.swift rename to submodules/Display/Sources/GenerateImage.swift diff --git a/submodules/Display/Display/GlobalOverlayPresentationContext.swift b/submodules/Display/Sources/GlobalOverlayPresentationContext.swift similarity index 100% rename from submodules/Display/Display/GlobalOverlayPresentationContext.swift rename to submodules/Display/Sources/GlobalOverlayPresentationContext.swift diff --git a/submodules/Display/Display/GridItem.swift b/submodules/Display/Sources/GridItem.swift similarity index 100% rename from submodules/Display/Display/GridItem.swift rename to submodules/Display/Sources/GridItem.swift diff --git a/submodules/Display/Display/GridItemNode.swift b/submodules/Display/Sources/GridItemNode.swift similarity index 100% rename from submodules/Display/Display/GridItemNode.swift rename to submodules/Display/Sources/GridItemNode.swift diff --git a/submodules/Display/Display/GridNode.swift b/submodules/Display/Sources/GridNode.swift similarity index 100% rename from submodules/Display/Display/GridNode.swift rename to submodules/Display/Sources/GridNode.swift diff --git a/submodules/Display/Display/GridNodeScroller.swift b/submodules/Display/Sources/GridNodeScroller.swift similarity index 100% rename from submodules/Display/Display/GridNodeScroller.swift rename to submodules/Display/Sources/GridNodeScroller.swift diff --git a/submodules/Display/Display/HapticFeedback.swift b/submodules/Display/Sources/HapticFeedback.swift similarity index 100% rename from submodules/Display/Display/HapticFeedback.swift rename to submodules/Display/Sources/HapticFeedback.swift diff --git a/submodules/Display/Display/HighlightTrackingButton.swift b/submodules/Display/Sources/HighlightTrackingButton.swift similarity index 100% rename from submodules/Display/Display/HighlightTrackingButton.swift rename to submodules/Display/Sources/HighlightTrackingButton.swift diff --git a/submodules/Display/Display/HighlightableButton.swift b/submodules/Display/Sources/HighlightableButton.swift similarity index 100% rename from submodules/Display/Display/HighlightableButton.swift rename to submodules/Display/Sources/HighlightableButton.swift diff --git a/submodules/Display/Display/ImageCorners.swift b/submodules/Display/Sources/ImageCorners.swift similarity index 100% rename from submodules/Display/Display/ImageCorners.swift rename to submodules/Display/Sources/ImageCorners.swift diff --git a/submodules/Display/Display/ImageNode.swift b/submodules/Display/Sources/ImageNode.swift similarity index 100% rename from submodules/Display/Display/ImageNode.swift rename to submodules/Display/Sources/ImageNode.swift diff --git a/submodules/Display/Display/ImmediateTextNode.swift b/submodules/Display/Sources/ImmediateTextNode.swift similarity index 100% rename from submodules/Display/Display/ImmediateTextNode.swift rename to submodules/Display/Sources/ImmediateTextNode.swift diff --git a/submodules/Display/Display/Info.plist b/submodules/Display/Sources/Info.plist similarity index 100% rename from submodules/Display/Display/Info.plist rename to submodules/Display/Sources/Info.plist diff --git a/submodules/Display/Display/InteractiveTransitionGestureRecognizer.swift b/submodules/Display/Sources/InteractiveTransitionGestureRecognizer.swift similarity index 100% rename from submodules/Display/Display/InteractiveTransitionGestureRecognizer.swift rename to submodules/Display/Sources/InteractiveTransitionGestureRecognizer.swift diff --git a/submodules/Display/Display/KeyShortcut.swift b/submodules/Display/Sources/KeyShortcut.swift similarity index 100% rename from submodules/Display/Display/KeyShortcut.swift rename to submodules/Display/Sources/KeyShortcut.swift diff --git a/submodules/Display/Display/KeyShortcutsController.swift b/submodules/Display/Sources/KeyShortcutsController.swift similarity index 100% rename from submodules/Display/Display/KeyShortcutsController.swift rename to submodules/Display/Sources/KeyShortcutsController.swift diff --git a/submodules/Display/Display/Keyboard.swift b/submodules/Display/Sources/Keyboard.swift similarity index 100% rename from submodules/Display/Display/Keyboard.swift rename to submodules/Display/Sources/Keyboard.swift diff --git a/submodules/Display/Display/KeyboardManager.swift b/submodules/Display/Sources/KeyboardManager.swift similarity index 100% rename from submodules/Display/Display/KeyboardManager.swift rename to submodules/Display/Sources/KeyboardManager.swift diff --git a/submodules/Display/Display/LayoutSizes.swift b/submodules/Display/Sources/LayoutSizes.swift similarity index 100% rename from submodules/Display/Display/LayoutSizes.swift rename to submodules/Display/Sources/LayoutSizes.swift diff --git a/submodules/Display/Display/LegacyPresentedController.swift b/submodules/Display/Sources/LegacyPresentedController.swift similarity index 100% rename from submodules/Display/Display/LegacyPresentedController.swift rename to submodules/Display/Sources/LegacyPresentedController.swift diff --git a/submodules/Display/Display/LegacyPresentedControllerNode.swift b/submodules/Display/Sources/LegacyPresentedControllerNode.swift similarity index 100% rename from submodules/Display/Display/LegacyPresentedControllerNode.swift rename to submodules/Display/Sources/LegacyPresentedControllerNode.swift diff --git a/submodules/Display/Display/LinkHighlightingNode.swift b/submodules/Display/Sources/LinkHighlightingNode.swift similarity index 100% rename from submodules/Display/Display/LinkHighlightingNode.swift rename to submodules/Display/Sources/LinkHighlightingNode.swift diff --git a/submodules/Display/Display/ListView.swift b/submodules/Display/Sources/ListView.swift similarity index 100% rename from submodules/Display/Display/ListView.swift rename to submodules/Display/Sources/ListView.swift diff --git a/submodules/Display/Display/ListViewAccessoryItem.swift b/submodules/Display/Sources/ListViewAccessoryItem.swift similarity index 100% rename from submodules/Display/Display/ListViewAccessoryItem.swift rename to submodules/Display/Sources/ListViewAccessoryItem.swift diff --git a/submodules/Display/Display/ListViewAccessoryItemNode.swift b/submodules/Display/Sources/ListViewAccessoryItemNode.swift similarity index 100% rename from submodules/Display/Display/ListViewAccessoryItemNode.swift rename to submodules/Display/Sources/ListViewAccessoryItemNode.swift diff --git a/submodules/Display/Display/ListViewAnimation.swift b/submodules/Display/Sources/ListViewAnimation.swift similarity index 100% rename from submodules/Display/Display/ListViewAnimation.swift rename to submodules/Display/Sources/ListViewAnimation.swift diff --git a/submodules/Display/Display/ListViewFloatingHeaderNode.swift b/submodules/Display/Sources/ListViewFloatingHeaderNode.swift similarity index 100% rename from submodules/Display/Display/ListViewFloatingHeaderNode.swift rename to submodules/Display/Sources/ListViewFloatingHeaderNode.swift diff --git a/submodules/Display/Display/ListViewIntermediateState.swift b/submodules/Display/Sources/ListViewIntermediateState.swift similarity index 100% rename from submodules/Display/Display/ListViewIntermediateState.swift rename to submodules/Display/Sources/ListViewIntermediateState.swift diff --git a/submodules/Display/Display/ListViewItem.swift b/submodules/Display/Sources/ListViewItem.swift similarity index 100% rename from submodules/Display/Display/ListViewItem.swift rename to submodules/Display/Sources/ListViewItem.swift diff --git a/submodules/Display/Display/ListViewItemHeader.swift b/submodules/Display/Sources/ListViewItemHeader.swift similarity index 100% rename from submodules/Display/Display/ListViewItemHeader.swift rename to submodules/Display/Sources/ListViewItemHeader.swift diff --git a/submodules/Display/Display/ListViewItemNode.swift b/submodules/Display/Sources/ListViewItemNode.swift similarity index 100% rename from submodules/Display/Display/ListViewItemNode.swift rename to submodules/Display/Sources/ListViewItemNode.swift diff --git a/submodules/Display/Display/ListViewOverscrollBackgroundNode.swift b/submodules/Display/Sources/ListViewOverscrollBackgroundNode.swift similarity index 100% rename from submodules/Display/Display/ListViewOverscrollBackgroundNode.swift rename to submodules/Display/Sources/ListViewOverscrollBackgroundNode.swift diff --git a/submodules/Display/Display/ListViewReorderingGestureRecognizer.swift b/submodules/Display/Sources/ListViewReorderingGestureRecognizer.swift similarity index 100% rename from submodules/Display/Display/ListViewReorderingGestureRecognizer.swift rename to submodules/Display/Sources/ListViewReorderingGestureRecognizer.swift diff --git a/submodules/Display/Display/ListViewReorderingItemNode.swift b/submodules/Display/Sources/ListViewReorderingItemNode.swift similarity index 100% rename from submodules/Display/Display/ListViewReorderingItemNode.swift rename to submodules/Display/Sources/ListViewReorderingItemNode.swift diff --git a/submodules/Display/Display/ListViewScroller.swift b/submodules/Display/Sources/ListViewScroller.swift similarity index 100% rename from submodules/Display/Display/ListViewScroller.swift rename to submodules/Display/Sources/ListViewScroller.swift diff --git a/submodules/Display/Display/ListViewTapGestureRecognizer.swift b/submodules/Display/Sources/ListViewTapGestureRecognizer.swift similarity index 100% rename from submodules/Display/Display/ListViewTapGestureRecognizer.swift rename to submodules/Display/Sources/ListViewTapGestureRecognizer.swift diff --git a/submodules/Display/Display/ListViewTempItemNode.swift b/submodules/Display/Sources/ListViewTempItemNode.swift similarity index 100% rename from submodules/Display/Display/ListViewTempItemNode.swift rename to submodules/Display/Sources/ListViewTempItemNode.swift diff --git a/submodules/Display/Display/ListViewTransactionQueue.swift b/submodules/Display/Sources/ListViewTransactionQueue.swift similarity index 100% rename from submodules/Display/Display/ListViewTransactionQueue.swift rename to submodules/Display/Sources/ListViewTransactionQueue.swift diff --git a/submodules/Display/Display/MinimizeKeyboardGestureRecognizer.swift b/submodules/Display/Sources/MinimizeKeyboardGestureRecognizer.swift similarity index 100% rename from submodules/Display/Display/MinimizeKeyboardGestureRecognizer.swift rename to submodules/Display/Sources/MinimizeKeyboardGestureRecognizer.swift diff --git a/submodules/Display/Display/NSBag.h b/submodules/Display/Sources/NSBag.h similarity index 100% rename from submodules/Display/Display/NSBag.h rename to submodules/Display/Sources/NSBag.h diff --git a/submodules/Display/Display/NSBag.m b/submodules/Display/Sources/NSBag.m similarity index 100% rename from submodules/Display/Display/NSBag.m rename to submodules/Display/Sources/NSBag.m diff --git a/submodules/Display/Display/NSWeakReference.h b/submodules/Display/Sources/NSWeakReference.h similarity index 100% rename from submodules/Display/Display/NSWeakReference.h rename to submodules/Display/Sources/NSWeakReference.h diff --git a/submodules/Display/Display/NSWeakReference.m b/submodules/Display/Sources/NSWeakReference.m similarity index 100% rename from submodules/Display/Display/NSWeakReference.m rename to submodules/Display/Sources/NSWeakReference.m diff --git a/submodules/Display/Display/NativeWindowHostView.swift b/submodules/Display/Sources/NativeWindowHostView.swift similarity index 100% rename from submodules/Display/Display/NativeWindowHostView.swift rename to submodules/Display/Sources/NativeWindowHostView.swift diff --git a/submodules/Display/Display/Navigation/NavigationContainer.swift b/submodules/Display/Sources/Navigation/NavigationContainer.swift similarity index 100% rename from submodules/Display/Display/Navigation/NavigationContainer.swift rename to submodules/Display/Sources/Navigation/NavigationContainer.swift diff --git a/submodules/Display/Display/Navigation/NavigationController.swift b/submodules/Display/Sources/Navigation/NavigationController.swift similarity index 100% rename from submodules/Display/Display/Navigation/NavigationController.swift rename to submodules/Display/Sources/Navigation/NavigationController.swift diff --git a/submodules/Display/Display/Navigation/NavigationLayout.swift b/submodules/Display/Sources/Navigation/NavigationLayout.swift similarity index 100% rename from submodules/Display/Display/Navigation/NavigationLayout.swift rename to submodules/Display/Sources/Navigation/NavigationLayout.swift diff --git a/submodules/Display/Display/Navigation/NavigationModalContainer.swift b/submodules/Display/Sources/Navigation/NavigationModalContainer.swift similarity index 100% rename from submodules/Display/Display/Navigation/NavigationModalContainer.swift rename to submodules/Display/Sources/Navigation/NavigationModalContainer.swift diff --git a/submodules/Display/Display/Navigation/NavigationModalFrame.swift b/submodules/Display/Sources/Navigation/NavigationModalFrame.swift similarity index 100% rename from submodules/Display/Display/Navigation/NavigationModalFrame.swift rename to submodules/Display/Sources/Navigation/NavigationModalFrame.swift diff --git a/submodules/Display/Display/Navigation/NavigationOverlayContainer.swift b/submodules/Display/Sources/Navigation/NavigationOverlayContainer.swift similarity index 100% rename from submodules/Display/Display/Navigation/NavigationOverlayContainer.swift rename to submodules/Display/Sources/Navigation/NavigationOverlayContainer.swift diff --git a/submodules/Display/Display/Navigation/NavigationSplitContainer.swift b/submodules/Display/Sources/Navigation/NavigationSplitContainer.swift similarity index 100% rename from submodules/Display/Display/Navigation/NavigationSplitContainer.swift rename to submodules/Display/Sources/Navigation/NavigationSplitContainer.swift diff --git a/submodules/Display/Display/NavigationBackButtonNode.swift b/submodules/Display/Sources/NavigationBackButtonNode.swift similarity index 100% rename from submodules/Display/Display/NavigationBackButtonNode.swift rename to submodules/Display/Sources/NavigationBackButtonNode.swift diff --git a/submodules/Display/Display/NavigationBar.swift b/submodules/Display/Sources/NavigationBar.swift similarity index 100% rename from submodules/Display/Display/NavigationBar.swift rename to submodules/Display/Sources/NavigationBar.swift diff --git a/submodules/Display/Display/NavigationBarBadge.swift b/submodules/Display/Sources/NavigationBarBadge.swift similarity index 100% rename from submodules/Display/Display/NavigationBarBadge.swift rename to submodules/Display/Sources/NavigationBarBadge.swift diff --git a/submodules/Display/Display/NavigationBarContentNode.swift b/submodules/Display/Sources/NavigationBarContentNode.swift similarity index 100% rename from submodules/Display/Display/NavigationBarContentNode.swift rename to submodules/Display/Sources/NavigationBarContentNode.swift diff --git a/submodules/Display/Display/NavigationBarProxy.h b/submodules/Display/Sources/NavigationBarProxy.h similarity index 100% rename from submodules/Display/Display/NavigationBarProxy.h rename to submodules/Display/Sources/NavigationBarProxy.h diff --git a/submodules/Display/Display/NavigationBarProxy.m b/submodules/Display/Sources/NavigationBarProxy.m similarity index 100% rename from submodules/Display/Display/NavigationBarProxy.m rename to submodules/Display/Sources/NavigationBarProxy.m diff --git a/submodules/Display/Display/NavigationBarTitleTransitionNode.swift b/submodules/Display/Sources/NavigationBarTitleTransitionNode.swift similarity index 100% rename from submodules/Display/Display/NavigationBarTitleTransitionNode.swift rename to submodules/Display/Sources/NavigationBarTitleTransitionNode.swift diff --git a/submodules/Display/Display/NavigationBarTitleView.swift b/submodules/Display/Sources/NavigationBarTitleView.swift similarity index 100% rename from submodules/Display/Display/NavigationBarTitleView.swift rename to submodules/Display/Sources/NavigationBarTitleView.swift diff --git a/submodules/Display/Display/NavigationBarTransitionContainer.swift b/submodules/Display/Sources/NavigationBarTransitionContainer.swift similarity index 100% rename from submodules/Display/Display/NavigationBarTransitionContainer.swift rename to submodules/Display/Sources/NavigationBarTransitionContainer.swift diff --git a/submodules/Display/Display/NavigationBarTransitionState.swift b/submodules/Display/Sources/NavigationBarTransitionState.swift similarity index 100% rename from submodules/Display/Display/NavigationBarTransitionState.swift rename to submodules/Display/Sources/NavigationBarTransitionState.swift diff --git a/submodules/Display/Display/NavigationButtonNode.swift b/submodules/Display/Sources/NavigationButtonNode.swift similarity index 100% rename from submodules/Display/Display/NavigationButtonNode.swift rename to submodules/Display/Sources/NavigationButtonNode.swift diff --git a/submodules/Display/Display/NavigationControllerProxy.h b/submodules/Display/Sources/NavigationControllerProxy.h similarity index 100% rename from submodules/Display/Display/NavigationControllerProxy.h rename to submodules/Display/Sources/NavigationControllerProxy.h diff --git a/submodules/Display/Display/NavigationControllerProxy.m b/submodules/Display/Sources/NavigationControllerProxy.m similarity index 100% rename from submodules/Display/Display/NavigationControllerProxy.m rename to submodules/Display/Sources/NavigationControllerProxy.m diff --git a/submodules/Display/Display/NavigationTitleNode.swift b/submodules/Display/Sources/NavigationTitleNode.swift similarity index 100% rename from submodules/Display/Display/NavigationTitleNode.swift rename to submodules/Display/Sources/NavigationTitleNode.swift diff --git a/submodules/Display/Display/NavigationTransitionCoordinator.swift b/submodules/Display/Sources/NavigationTransitionCoordinator.swift similarity index 100% rename from submodules/Display/Display/NavigationTransitionCoordinator.swift rename to submodules/Display/Sources/NavigationTransitionCoordinator.swift diff --git a/submodules/Display/Display/NotificationCenterUtils.h b/submodules/Display/Sources/NotificationCenterUtils.h similarity index 100% rename from submodules/Display/Display/NotificationCenterUtils.h rename to submodules/Display/Sources/NotificationCenterUtils.h diff --git a/submodules/Display/Display/NotificationCenterUtils.m b/submodules/Display/Sources/NotificationCenterUtils.m similarity index 100% rename from submodules/Display/Display/NotificationCenterUtils.m rename to submodules/Display/Sources/NotificationCenterUtils.m diff --git a/submodules/Display/Display/PageControlNode.swift b/submodules/Display/Sources/PageControlNode.swift similarity index 100% rename from submodules/Display/Display/PageControlNode.swift rename to submodules/Display/Sources/PageControlNode.swift diff --git a/submodules/Display/Display/PeekController.swift b/submodules/Display/Sources/PeekController.swift similarity index 100% rename from submodules/Display/Display/PeekController.swift rename to submodules/Display/Sources/PeekController.swift diff --git a/submodules/Display/Display/PeekControllerContent.swift b/submodules/Display/Sources/PeekControllerContent.swift similarity index 100% rename from submodules/Display/Display/PeekControllerContent.swift rename to submodules/Display/Sources/PeekControllerContent.swift diff --git a/submodules/Display/Display/PeekControllerGestureRecognizer.swift b/submodules/Display/Sources/PeekControllerGestureRecognizer.swift similarity index 100% rename from submodules/Display/Display/PeekControllerGestureRecognizer.swift rename to submodules/Display/Sources/PeekControllerGestureRecognizer.swift diff --git a/submodules/Display/Display/PeekControllerMenuItemNode.swift b/submodules/Display/Sources/PeekControllerMenuItemNode.swift similarity index 100% rename from submodules/Display/Display/PeekControllerMenuItemNode.swift rename to submodules/Display/Sources/PeekControllerMenuItemNode.swift diff --git a/submodules/Display/Display/PeekControllerMenuNode.swift b/submodules/Display/Sources/PeekControllerMenuNode.swift similarity index 100% rename from submodules/Display/Display/PeekControllerMenuNode.swift rename to submodules/Display/Sources/PeekControllerMenuNode.swift diff --git a/submodules/Display/Display/PeekControllerNode.swift b/submodules/Display/Sources/PeekControllerNode.swift similarity index 100% rename from submodules/Display/Display/PeekControllerNode.swift rename to submodules/Display/Sources/PeekControllerNode.swift diff --git a/submodules/Display/Display/PresentationContext.swift b/submodules/Display/Sources/PresentationContext.swift similarity index 100% rename from submodules/Display/Display/PresentationContext.swift rename to submodules/Display/Sources/PresentationContext.swift diff --git a/submodules/Display/Display/RuntimeUtils.h b/submodules/Display/Sources/RuntimeUtils.h similarity index 100% rename from submodules/Display/Display/RuntimeUtils.h rename to submodules/Display/Sources/RuntimeUtils.h diff --git a/submodules/Display/Display/RuntimeUtils.m b/submodules/Display/Sources/RuntimeUtils.m similarity index 100% rename from submodules/Display/Display/RuntimeUtils.m rename to submodules/Display/Sources/RuntimeUtils.m diff --git a/submodules/Display/Display/RuntimeUtils.swift b/submodules/Display/Sources/RuntimeUtils.swift similarity index 100% rename from submodules/Display/Display/RuntimeUtils.swift rename to submodules/Display/Sources/RuntimeUtils.swift diff --git a/submodules/Display/Display/ScrollToTopProxyView.swift b/submodules/Display/Sources/ScrollToTopProxyView.swift similarity index 100% rename from submodules/Display/Display/ScrollToTopProxyView.swift rename to submodules/Display/Sources/ScrollToTopProxyView.swift diff --git a/submodules/Display/Display/ShakeAnimation.swift b/submodules/Display/Sources/ShakeAnimation.swift similarity index 100% rename from submodules/Display/Display/ShakeAnimation.swift rename to submodules/Display/Sources/ShakeAnimation.swift diff --git a/submodules/Display/Display/Spring.swift b/submodules/Display/Sources/Spring.swift similarity index 100% rename from submodules/Display/Display/Spring.swift rename to submodules/Display/Sources/Spring.swift diff --git a/submodules/Display/Display/StatusBar.swift b/submodules/Display/Sources/StatusBar.swift similarity index 100% rename from submodules/Display/Display/StatusBar.swift rename to submodules/Display/Sources/StatusBar.swift diff --git a/submodules/Display/Display/StatusBarHost.swift b/submodules/Display/Sources/StatusBarHost.swift similarity index 100% rename from submodules/Display/Display/StatusBarHost.swift rename to submodules/Display/Sources/StatusBarHost.swift diff --git a/submodules/Display/Display/StatusBarProxyNode.swift b/submodules/Display/Sources/StatusBarProxyNode.swift similarity index 100% rename from submodules/Display/Display/StatusBarProxyNode.swift rename to submodules/Display/Sources/StatusBarProxyNode.swift diff --git a/submodules/Display/Display/SubstringSearch.swift b/submodules/Display/Sources/SubstringSearch.swift similarity index 100% rename from submodules/Display/Display/SubstringSearch.swift rename to submodules/Display/Sources/SubstringSearch.swift diff --git a/submodules/Display/Display/SwitchNode.swift b/submodules/Display/Sources/SwitchNode.swift similarity index 100% rename from submodules/Display/Display/SwitchNode.swift rename to submodules/Display/Sources/SwitchNode.swift diff --git a/submodules/Display/Display/TabBarContollerNode.swift b/submodules/Display/Sources/TabBarContollerNode.swift similarity index 100% rename from submodules/Display/Display/TabBarContollerNode.swift rename to submodules/Display/Sources/TabBarContollerNode.swift diff --git a/submodules/Display/Display/TabBarController.swift b/submodules/Display/Sources/TabBarController.swift similarity index 100% rename from submodules/Display/Display/TabBarController.swift rename to submodules/Display/Sources/TabBarController.swift diff --git a/submodules/Display/Display/TabBarNode.swift b/submodules/Display/Sources/TabBarNode.swift similarity index 100% rename from submodules/Display/Display/TabBarNode.swift rename to submodules/Display/Sources/TabBarNode.swift diff --git a/submodules/Display/Display/TabBarTapRecognizer.swift b/submodules/Display/Sources/TabBarTapRecognizer.swift similarity index 100% rename from submodules/Display/Display/TabBarTapRecognizer.swift rename to submodules/Display/Sources/TabBarTapRecognizer.swift diff --git a/submodules/Display/Display/TapLongTapOrDoubleTapGestureRecognizer.swift b/submodules/Display/Sources/TapLongTapOrDoubleTapGestureRecognizer.swift similarity index 100% rename from submodules/Display/Display/TapLongTapOrDoubleTapGestureRecognizer.swift rename to submodules/Display/Sources/TapLongTapOrDoubleTapGestureRecognizer.swift diff --git a/submodules/Display/Display/TextAlertController.swift b/submodules/Display/Sources/TextAlertController.swift similarity index 100% rename from submodules/Display/Display/TextAlertController.swift rename to submodules/Display/Sources/TextAlertController.swift diff --git a/submodules/Display/Display/TextFieldNode.swift b/submodules/Display/Sources/TextFieldNode.swift similarity index 100% rename from submodules/Display/Display/TextFieldNode.swift rename to submodules/Display/Sources/TextFieldNode.swift diff --git a/submodules/Display/Display/TextNode.swift b/submodules/Display/Sources/TextNode.swift similarity index 100% rename from submodules/Display/Display/TextNode.swift rename to submodules/Display/Sources/TextNode.swift diff --git a/submodules/Display/Display/Toolbar.swift b/submodules/Display/Sources/Toolbar.swift similarity index 100% rename from submodules/Display/Display/Toolbar.swift rename to submodules/Display/Sources/Toolbar.swift diff --git a/submodules/Display/Display/ToolbarNode.swift b/submodules/Display/Sources/ToolbarNode.swift similarity index 100% rename from submodules/Display/Display/ToolbarNode.swift rename to submodules/Display/Sources/ToolbarNode.swift diff --git a/submodules/Display/Display/TooltipController.swift b/submodules/Display/Sources/TooltipController.swift similarity index 100% rename from submodules/Display/Display/TooltipController.swift rename to submodules/Display/Sources/TooltipController.swift diff --git a/submodules/Display/Display/TooltipControllerNode.swift b/submodules/Display/Sources/TooltipControllerNode.swift similarity index 100% rename from submodules/Display/Display/TooltipControllerNode.swift rename to submodules/Display/Sources/TooltipControllerNode.swift diff --git a/submodules/Display/Display/TransformImageArguments.swift b/submodules/Display/Sources/TransformImageArguments.swift similarity index 100% rename from submodules/Display/Display/TransformImageArguments.swift rename to submodules/Display/Sources/TransformImageArguments.swift diff --git a/submodules/Display/Display/TransformImageNode.swift b/submodules/Display/Sources/TransformImageNode.swift similarity index 100% rename from submodules/Display/Display/TransformImageNode.swift rename to submodules/Display/Sources/TransformImageNode.swift diff --git a/submodules/Display/Display/UIBarButtonItem+Proxy.h b/submodules/Display/Sources/UIBarButtonItem+Proxy.h similarity index 100% rename from submodules/Display/Display/UIBarButtonItem+Proxy.h rename to submodules/Display/Sources/UIBarButtonItem+Proxy.h diff --git a/submodules/Display/Display/UIBarButtonItem+Proxy.m b/submodules/Display/Sources/UIBarButtonItem+Proxy.m similarity index 100% rename from submodules/Display/Display/UIBarButtonItem+Proxy.m rename to submodules/Display/Sources/UIBarButtonItem+Proxy.m diff --git a/submodules/Display/Display/UIKitUtils.h b/submodules/Display/Sources/UIKitUtils.h similarity index 100% rename from submodules/Display/Display/UIKitUtils.h rename to submodules/Display/Sources/UIKitUtils.h diff --git a/submodules/Display/Display/UIKitUtils.m b/submodules/Display/Sources/UIKitUtils.m similarity index 100% rename from submodules/Display/Display/UIKitUtils.m rename to submodules/Display/Sources/UIKitUtils.m diff --git a/submodules/Display/Display/UIKitUtils.swift b/submodules/Display/Sources/UIKitUtils.swift similarity index 100% rename from submodules/Display/Display/UIKitUtils.swift rename to submodules/Display/Sources/UIKitUtils.swift diff --git a/submodules/Display/Display/UIMenuItem+Icons.h b/submodules/Display/Sources/UIMenuItem+Icons.h similarity index 100% rename from submodules/Display/Display/UIMenuItem+Icons.h rename to submodules/Display/Sources/UIMenuItem+Icons.h diff --git a/submodules/Display/Display/UIMenuItem+Icons.m b/submodules/Display/Sources/UIMenuItem+Icons.m similarity index 100% rename from submodules/Display/Display/UIMenuItem+Icons.m rename to submodules/Display/Sources/UIMenuItem+Icons.m diff --git a/submodules/Display/Display/UINavigationItem+Proxy.h b/submodules/Display/Sources/UINavigationItem+Proxy.h similarity index 100% rename from submodules/Display/Display/UINavigationItem+Proxy.h rename to submodules/Display/Sources/UINavigationItem+Proxy.h diff --git a/submodules/Display/Display/UINavigationItem+Proxy.m b/submodules/Display/Sources/UINavigationItem+Proxy.m similarity index 100% rename from submodules/Display/Display/UINavigationItem+Proxy.m rename to submodules/Display/Sources/UINavigationItem+Proxy.m diff --git a/submodules/Display/Display/UITracingLayerView.swift b/submodules/Display/Sources/UITracingLayerView.swift similarity index 100% rename from submodules/Display/Display/UITracingLayerView.swift rename to submodules/Display/Sources/UITracingLayerView.swift diff --git a/submodules/Display/Display/UIViewController+Navigation.h b/submodules/Display/Sources/UIViewController+Navigation.h similarity index 100% rename from submodules/Display/Display/UIViewController+Navigation.h rename to submodules/Display/Sources/UIViewController+Navigation.h diff --git a/submodules/Display/Display/UIViewController+Navigation.m b/submodules/Display/Sources/UIViewController+Navigation.m similarity index 100% rename from submodules/Display/Display/UIViewController+Navigation.m rename to submodules/Display/Sources/UIViewController+Navigation.m diff --git a/submodules/Display/Display/UIWindow+OrientationChange.h b/submodules/Display/Sources/UIWindow+OrientationChange.h similarity index 100% rename from submodules/Display/Display/UIWindow+OrientationChange.h rename to submodules/Display/Sources/UIWindow+OrientationChange.h diff --git a/submodules/Display/Display/UIWindow+OrientationChange.m b/submodules/Display/Sources/UIWindow+OrientationChange.m similarity index 100% rename from submodules/Display/Display/UIWindow+OrientationChange.m rename to submodules/Display/Sources/UIWindow+OrientationChange.m diff --git a/submodules/Display/Display/UniversalMasterController.swift b/submodules/Display/Sources/UniversalMasterController.swift similarity index 100% rename from submodules/Display/Display/UniversalMasterController.swift rename to submodules/Display/Sources/UniversalMasterController.swift diff --git a/submodules/Display/Display/UniversalTapRecognizer.swift b/submodules/Display/Sources/UniversalTapRecognizer.swift similarity index 100% rename from submodules/Display/Display/UniversalTapRecognizer.swift rename to submodules/Display/Sources/UniversalTapRecognizer.swift diff --git a/submodules/Display/Display/ViewController.swift b/submodules/Display/Sources/ViewController.swift similarity index 100% rename from submodules/Display/Display/ViewController.swift rename to submodules/Display/Sources/ViewController.swift diff --git a/submodules/Display/Display/ViewControllerPreviewing.swift b/submodules/Display/Sources/ViewControllerPreviewing.swift similarity index 100% rename from submodules/Display/Display/ViewControllerPreviewing.swift rename to submodules/Display/Sources/ViewControllerPreviewing.swift diff --git a/submodules/Display/Display/ViewControllerTracingNode.swift b/submodules/Display/Sources/ViewControllerTracingNode.swift similarity index 100% rename from submodules/Display/Display/ViewControllerTracingNode.swift rename to submodules/Display/Sources/ViewControllerTracingNode.swift diff --git a/submodules/Display/Display/VolumeControlStatusBar.swift b/submodules/Display/Sources/VolumeControlStatusBar.swift similarity index 100% rename from submodules/Display/Display/VolumeControlStatusBar.swift rename to submodules/Display/Sources/VolumeControlStatusBar.swift diff --git a/submodules/Display/Display/WallpaperBackgroundNode.swift b/submodules/Display/Sources/WallpaperBackgroundNode.swift similarity index 100% rename from submodules/Display/Display/WallpaperBackgroundNode.swift rename to submodules/Display/Sources/WallpaperBackgroundNode.swift diff --git a/submodules/Display/Display/WindowContent.swift b/submodules/Display/Sources/WindowContent.swift similarity index 100% rename from submodules/Display/Display/WindowContent.swift rename to submodules/Display/Sources/WindowContent.swift diff --git a/submodules/Display/Display/WindowCoveringView.swift b/submodules/Display/Sources/WindowCoveringView.swift similarity index 100% rename from submodules/Display/Display/WindowCoveringView.swift rename to submodules/Display/Sources/WindowCoveringView.swift diff --git a/submodules/Display/Display/WindowInputAccessoryHeightProvider.swift b/submodules/Display/Sources/WindowInputAccessoryHeightProvider.swift similarity index 100% rename from submodules/Display/Display/WindowInputAccessoryHeightProvider.swift rename to submodules/Display/Sources/WindowInputAccessoryHeightProvider.swift diff --git a/submodules/Display/Display/WindowPanRecognizer.swift b/submodules/Display/Sources/WindowPanRecognizer.swift similarity index 100% rename from submodules/Display/Display/WindowPanRecognizer.swift rename to submodules/Display/Sources/WindowPanRecognizer.swift diff --git a/submodules/TelegramUI/TelegramUI/AccessoryPanelNode.swift b/submodules/TelegramUI/Sources/AccessoryPanelNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/AccessoryPanelNode.swift rename to submodules/TelegramUI/Sources/AccessoryPanelNode.swift diff --git a/submodules/TelegramUI/TelegramUI/AccountContext.swift b/submodules/TelegramUI/Sources/AccountContext.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/AccountContext.swift rename to submodules/TelegramUI/Sources/AccountContext.swift diff --git a/submodules/TelegramUI/TelegramUI/AppDelegate.swift b/submodules/TelegramUI/Sources/AppDelegate.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/AppDelegate.swift rename to submodules/TelegramUI/Sources/AppDelegate.swift diff --git a/submodules/TelegramUI/TelegramUI/ApplicationContext.swift b/submodules/TelegramUI/Sources/ApplicationContext.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ApplicationContext.swift rename to submodules/TelegramUI/Sources/ApplicationContext.swift diff --git a/submodules/TelegramUI/TelegramUI/ApplicationShortcutItem.swift b/submodules/TelegramUI/Sources/ApplicationShortcutItem.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ApplicationShortcutItem.swift rename to submodules/TelegramUI/Sources/ApplicationShortcutItem.swift diff --git a/submodules/TelegramUI/TelegramUI/AudioRecordningToneData.swift b/submodules/TelegramUI/Sources/AudioRecordningToneData.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/AudioRecordningToneData.swift rename to submodules/TelegramUI/Sources/AudioRecordningToneData.swift diff --git a/submodules/TelegramUI/TelegramUI/AudioWaveform.swift b/submodules/TelegramUI/Sources/AudioWaveform.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/AudioWaveform.swift rename to submodules/TelegramUI/Sources/AudioWaveform.swift diff --git a/submodules/TelegramUI/TelegramUI/AudioWaveformNode.swift b/submodules/TelegramUI/Sources/AudioWaveformNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/AudioWaveformNode.swift rename to submodules/TelegramUI/Sources/AudioWaveformNode.swift diff --git a/submodules/TelegramUI/TelegramUI/AuthorizationSequenceAwaitingAccountResetController.swift b/submodules/TelegramUI/Sources/AuthorizationSequenceAwaitingAccountResetController.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/AuthorizationSequenceAwaitingAccountResetController.swift rename to submodules/TelegramUI/Sources/AuthorizationSequenceAwaitingAccountResetController.swift diff --git a/submodules/TelegramUI/TelegramUI/AuthorizationSequenceAwaitingAccountResetControllerNode.swift b/submodules/TelegramUI/Sources/AuthorizationSequenceAwaitingAccountResetControllerNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/AuthorizationSequenceAwaitingAccountResetControllerNode.swift rename to submodules/TelegramUI/Sources/AuthorizationSequenceAwaitingAccountResetControllerNode.swift diff --git a/submodules/TelegramUI/TelegramUI/AuthorizationSequenceCodeEntryController.swift b/submodules/TelegramUI/Sources/AuthorizationSequenceCodeEntryController.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/AuthorizationSequenceCodeEntryController.swift rename to submodules/TelegramUI/Sources/AuthorizationSequenceCodeEntryController.swift diff --git a/submodules/TelegramUI/TelegramUI/AuthorizationSequenceCodeEntryControllerNode.swift b/submodules/TelegramUI/Sources/AuthorizationSequenceCodeEntryControllerNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/AuthorizationSequenceCodeEntryControllerNode.swift rename to submodules/TelegramUI/Sources/AuthorizationSequenceCodeEntryControllerNode.swift diff --git a/submodules/TelegramUI/TelegramUI/AuthorizationSequenceController.swift b/submodules/TelegramUI/Sources/AuthorizationSequenceController.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/AuthorizationSequenceController.swift rename to submodules/TelegramUI/Sources/AuthorizationSequenceController.swift diff --git a/submodules/TelegramUI/TelegramUI/AuthorizationSequencePasswordEntryController.swift b/submodules/TelegramUI/Sources/AuthorizationSequencePasswordEntryController.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/AuthorizationSequencePasswordEntryController.swift rename to submodules/TelegramUI/Sources/AuthorizationSequencePasswordEntryController.swift diff --git a/submodules/TelegramUI/TelegramUI/AuthorizationSequencePasswordEntryControllerNode.swift b/submodules/TelegramUI/Sources/AuthorizationSequencePasswordEntryControllerNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/AuthorizationSequencePasswordEntryControllerNode.swift rename to submodules/TelegramUI/Sources/AuthorizationSequencePasswordEntryControllerNode.swift diff --git a/submodules/TelegramUI/TelegramUI/AuthorizationSequencePasswordRecoveryController.swift b/submodules/TelegramUI/Sources/AuthorizationSequencePasswordRecoveryController.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/AuthorizationSequencePasswordRecoveryController.swift rename to submodules/TelegramUI/Sources/AuthorizationSequencePasswordRecoveryController.swift diff --git a/submodules/TelegramUI/TelegramUI/AuthorizationSequencePasswordRecoveryControllerNode.swift b/submodules/TelegramUI/Sources/AuthorizationSequencePasswordRecoveryControllerNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/AuthorizationSequencePasswordRecoveryControllerNode.swift rename to submodules/TelegramUI/Sources/AuthorizationSequencePasswordRecoveryControllerNode.swift diff --git a/submodules/TelegramUI/TelegramUI/AuthorizationSequencePhoneEntryController.swift b/submodules/TelegramUI/Sources/AuthorizationSequencePhoneEntryController.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/AuthorizationSequencePhoneEntryController.swift rename to submodules/TelegramUI/Sources/AuthorizationSequencePhoneEntryController.swift diff --git a/submodules/TelegramUI/TelegramUI/AuthorizationSequencePhoneEntryControllerNode.swift b/submodules/TelegramUI/Sources/AuthorizationSequencePhoneEntryControllerNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/AuthorizationSequencePhoneEntryControllerNode.swift rename to submodules/TelegramUI/Sources/AuthorizationSequencePhoneEntryControllerNode.swift diff --git a/submodules/TelegramUI/TelegramUI/AuthorizationSequenceSignUpController.swift b/submodules/TelegramUI/Sources/AuthorizationSequenceSignUpController.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/AuthorizationSequenceSignUpController.swift rename to submodules/TelegramUI/Sources/AuthorizationSequenceSignUpController.swift diff --git a/submodules/TelegramUI/TelegramUI/AuthorizationSequenceSignUpControllerNode.swift b/submodules/TelegramUI/Sources/AuthorizationSequenceSignUpControllerNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/AuthorizationSequenceSignUpControllerNode.swift rename to submodules/TelegramUI/Sources/AuthorizationSequenceSignUpControllerNode.swift diff --git a/submodules/TelegramUI/TelegramUI/AuthorizationSequenceSplashController.swift b/submodules/TelegramUI/Sources/AuthorizationSequenceSplashController.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/AuthorizationSequenceSplashController.swift rename to submodules/TelegramUI/Sources/AuthorizationSequenceSplashController.swift diff --git a/submodules/TelegramUI/TelegramUI/AuthorizationSequenceSplashControllerNode.swift b/submodules/TelegramUI/Sources/AuthorizationSequenceSplashControllerNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/AuthorizationSequenceSplashControllerNode.swift rename to submodules/TelegramUI/Sources/AuthorizationSequenceSplashControllerNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatAvatarNavigationNode.swift b/submodules/TelegramUI/Sources/ChatAvatarNavigationNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatAvatarNavigationNode.swift rename to submodules/TelegramUI/Sources/ChatAvatarNavigationNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatBotInfoItem.swift b/submodules/TelegramUI/Sources/ChatBotInfoItem.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatBotInfoItem.swift rename to submodules/TelegramUI/Sources/ChatBotInfoItem.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatBotStartInputPanelNode.swift b/submodules/TelegramUI/Sources/ChatBotStartInputPanelNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatBotStartInputPanelNode.swift rename to submodules/TelegramUI/Sources/ChatBotStartInputPanelNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatButtonKeyboardInputNode.swift b/submodules/TelegramUI/Sources/ChatButtonKeyboardInputNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatButtonKeyboardInputNode.swift rename to submodules/TelegramUI/Sources/ChatButtonKeyboardInputNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatChannelSubscriberInputPanelNode.swift b/submodules/TelegramUI/Sources/ChatChannelSubscriberInputPanelNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatChannelSubscriberInputPanelNode.swift rename to submodules/TelegramUI/Sources/ChatChannelSubscriberInputPanelNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatContextResultPeekContentNode.swift b/submodules/TelegramUI/Sources/ChatContextResultPeekContentNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatContextResultPeekContentNode.swift rename to submodules/TelegramUI/Sources/ChatContextResultPeekContentNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatController.swift b/submodules/TelegramUI/Sources/ChatController.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatController.swift rename to submodules/TelegramUI/Sources/ChatController.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatControllerInteraction.swift b/submodules/TelegramUI/Sources/ChatControllerInteraction.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatControllerInteraction.swift rename to submodules/TelegramUI/Sources/ChatControllerInteraction.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatControllerNode.swift b/submodules/TelegramUI/Sources/ChatControllerNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatControllerNode.swift rename to submodules/TelegramUI/Sources/ChatControllerNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatControllerTitlePanelNodeContainer.swift b/submodules/TelegramUI/Sources/ChatControllerTitlePanelNodeContainer.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatControllerTitlePanelNodeContainer.swift rename to submodules/TelegramUI/Sources/ChatControllerTitlePanelNodeContainer.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatDateSelectionSheet.swift b/submodules/TelegramUI/Sources/ChatDateSelectionSheet.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatDateSelectionSheet.swift rename to submodules/TelegramUI/Sources/ChatDateSelectionSheet.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatEditInterfaceMessageState.swift b/submodules/TelegramUI/Sources/ChatEditInterfaceMessageState.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatEditInterfaceMessageState.swift rename to submodules/TelegramUI/Sources/ChatEditInterfaceMessageState.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatEditMessageMediaContext.swift b/submodules/TelegramUI/Sources/ChatEditMessageMediaContext.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatEditMessageMediaContext.swift rename to submodules/TelegramUI/Sources/ChatEditMessageMediaContext.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatEmptyNode.swift b/submodules/TelegramUI/Sources/ChatEmptyNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatEmptyNode.swift rename to submodules/TelegramUI/Sources/ChatEmptyNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatFeedNavigationInputPanelNode.swift b/submodules/TelegramUI/Sources/ChatFeedNavigationInputPanelNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatFeedNavigationInputPanelNode.swift rename to submodules/TelegramUI/Sources/ChatFeedNavigationInputPanelNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatHistoryEntriesForView.swift b/submodules/TelegramUI/Sources/ChatHistoryEntriesForView.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatHistoryEntriesForView.swift rename to submodules/TelegramUI/Sources/ChatHistoryEntriesForView.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatHistoryEntry.swift b/submodules/TelegramUI/Sources/ChatHistoryEntry.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatHistoryEntry.swift rename to submodules/TelegramUI/Sources/ChatHistoryEntry.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatHistoryGridNode.swift b/submodules/TelegramUI/Sources/ChatHistoryGridNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatHistoryGridNode.swift rename to submodules/TelegramUI/Sources/ChatHistoryGridNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatHistoryListNode.swift b/submodules/TelegramUI/Sources/ChatHistoryListNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatHistoryListNode.swift rename to submodules/TelegramUI/Sources/ChatHistoryListNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatHistoryLocation.swift b/submodules/TelegramUI/Sources/ChatHistoryLocation.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatHistoryLocation.swift rename to submodules/TelegramUI/Sources/ChatHistoryLocation.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatHistoryNavigationButtonNode.swift b/submodules/TelegramUI/Sources/ChatHistoryNavigationButtonNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatHistoryNavigationButtonNode.swift rename to submodules/TelegramUI/Sources/ChatHistoryNavigationButtonNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatHistoryNavigationButtons.swift b/submodules/TelegramUI/Sources/ChatHistoryNavigationButtons.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatHistoryNavigationButtons.swift rename to submodules/TelegramUI/Sources/ChatHistoryNavigationButtons.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatHistoryNavigationStack.swift b/submodules/TelegramUI/Sources/ChatHistoryNavigationStack.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatHistoryNavigationStack.swift rename to submodules/TelegramUI/Sources/ChatHistoryNavigationStack.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatHistoryNode.swift b/submodules/TelegramUI/Sources/ChatHistoryNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatHistoryNode.swift rename to submodules/TelegramUI/Sources/ChatHistoryNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatHistorySearchContainerNode.swift b/submodules/TelegramUI/Sources/ChatHistorySearchContainerNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatHistorySearchContainerNode.swift rename to submodules/TelegramUI/Sources/ChatHistorySearchContainerNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatHistoryViewForLocation.swift b/submodules/TelegramUI/Sources/ChatHistoryViewForLocation.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatHistoryViewForLocation.swift rename to submodules/TelegramUI/Sources/ChatHistoryViewForLocation.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatHoleItem.swift b/submodules/TelegramUI/Sources/ChatHoleItem.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatHoleItem.swift rename to submodules/TelegramUI/Sources/ChatHoleItem.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatInfo.swift b/submodules/TelegramUI/Sources/ChatInfo.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatInfo.swift rename to submodules/TelegramUI/Sources/ChatInfo.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatInfoTitlePanelNode.swift b/submodules/TelegramUI/Sources/ChatInfoTitlePanelNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatInfoTitlePanelNode.swift rename to submodules/TelegramUI/Sources/ChatInfoTitlePanelNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatInputContextPanelNode.swift b/submodules/TelegramUI/Sources/ChatInputContextPanelNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatInputContextPanelNode.swift rename to submodules/TelegramUI/Sources/ChatInputContextPanelNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatInputNode.swift b/submodules/TelegramUI/Sources/ChatInputNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatInputNode.swift rename to submodules/TelegramUI/Sources/ChatInputNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatInputPanelNode.swift b/submodules/TelegramUI/Sources/ChatInputPanelNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatInputPanelNode.swift rename to submodules/TelegramUI/Sources/ChatInputPanelNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatInstantVideoMessageDurationNode.swift b/submodules/TelegramUI/Sources/ChatInstantVideoMessageDurationNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatInstantVideoMessageDurationNode.swift rename to submodules/TelegramUI/Sources/ChatInstantVideoMessageDurationNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatInterfaceInputContextPanels.swift b/submodules/TelegramUI/Sources/ChatInterfaceInputContextPanels.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatInterfaceInputContextPanels.swift rename to submodules/TelegramUI/Sources/ChatInterfaceInputContextPanels.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatInterfaceInputContexts.swift b/submodules/TelegramUI/Sources/ChatInterfaceInputContexts.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatInterfaceInputContexts.swift rename to submodules/TelegramUI/Sources/ChatInterfaceInputContexts.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatInterfaceInputNodes.swift b/submodules/TelegramUI/Sources/ChatInterfaceInputNodes.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatInterfaceInputNodes.swift rename to submodules/TelegramUI/Sources/ChatInterfaceInputNodes.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatInterfaceState.swift b/submodules/TelegramUI/Sources/ChatInterfaceState.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatInterfaceState.swift rename to submodules/TelegramUI/Sources/ChatInterfaceState.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatInterfaceStateAccessoryPanels.swift b/submodules/TelegramUI/Sources/ChatInterfaceStateAccessoryPanels.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatInterfaceStateAccessoryPanels.swift rename to submodules/TelegramUI/Sources/ChatInterfaceStateAccessoryPanels.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatInterfaceStateContextMenus.swift b/submodules/TelegramUI/Sources/ChatInterfaceStateContextMenus.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatInterfaceStateContextMenus.swift rename to submodules/TelegramUI/Sources/ChatInterfaceStateContextMenus.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatInterfaceStateContextQueries.swift b/submodules/TelegramUI/Sources/ChatInterfaceStateContextQueries.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatInterfaceStateContextQueries.swift rename to submodules/TelegramUI/Sources/ChatInterfaceStateContextQueries.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatInterfaceStateInputPanels.swift b/submodules/TelegramUI/Sources/ChatInterfaceStateInputPanels.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatInterfaceStateInputPanels.swift rename to submodules/TelegramUI/Sources/ChatInterfaceStateInputPanels.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatInterfaceStateNavigationButtons.swift b/submodules/TelegramUI/Sources/ChatInterfaceStateNavigationButtons.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatInterfaceStateNavigationButtons.swift rename to submodules/TelegramUI/Sources/ChatInterfaceStateNavigationButtons.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatInterfaceTitlePanelNodes.swift b/submodules/TelegramUI/Sources/ChatInterfaceTitlePanelNodes.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatInterfaceTitlePanelNodes.swift rename to submodules/TelegramUI/Sources/ChatInterfaceTitlePanelNodes.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatLinkPreview.swift b/submodules/TelegramUI/Sources/ChatLinkPreview.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatLinkPreview.swift rename to submodules/TelegramUI/Sources/ChatLinkPreview.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatLoadingNode.swift b/submodules/TelegramUI/Sources/ChatLoadingNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatLoadingNode.swift rename to submodules/TelegramUI/Sources/ChatLoadingNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatMediaInputGifPane.swift b/submodules/TelegramUI/Sources/ChatMediaInputGifPane.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatMediaInputGifPane.swift rename to submodules/TelegramUI/Sources/ChatMediaInputGifPane.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatMediaInputGridEntries.swift b/submodules/TelegramUI/Sources/ChatMediaInputGridEntries.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatMediaInputGridEntries.swift rename to submodules/TelegramUI/Sources/ChatMediaInputGridEntries.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatMediaInputMetaSectionItemNode.swift b/submodules/TelegramUI/Sources/ChatMediaInputMetaSectionItemNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatMediaInputMetaSectionItemNode.swift rename to submodules/TelegramUI/Sources/ChatMediaInputMetaSectionItemNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatMediaInputNode.swift b/submodules/TelegramUI/Sources/ChatMediaInputNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatMediaInputNode.swift rename to submodules/TelegramUI/Sources/ChatMediaInputNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatMediaInputPane.swift b/submodules/TelegramUI/Sources/ChatMediaInputPane.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatMediaInputPane.swift rename to submodules/TelegramUI/Sources/ChatMediaInputPane.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatMediaInputPanelEntries.swift b/submodules/TelegramUI/Sources/ChatMediaInputPanelEntries.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatMediaInputPanelEntries.swift rename to submodules/TelegramUI/Sources/ChatMediaInputPanelEntries.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatMediaInputPeerSpecificItem.swift b/submodules/TelegramUI/Sources/ChatMediaInputPeerSpecificItem.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatMediaInputPeerSpecificItem.swift rename to submodules/TelegramUI/Sources/ChatMediaInputPeerSpecificItem.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatMediaInputRecentGifsItem.swift b/submodules/TelegramUI/Sources/ChatMediaInputRecentGifsItem.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatMediaInputRecentGifsItem.swift rename to submodules/TelegramUI/Sources/ChatMediaInputRecentGifsItem.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatMediaInputSettingsItem.swift b/submodules/TelegramUI/Sources/ChatMediaInputSettingsItem.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatMediaInputSettingsItem.swift rename to submodules/TelegramUI/Sources/ChatMediaInputSettingsItem.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatMediaInputStickerGridItem.swift b/submodules/TelegramUI/Sources/ChatMediaInputStickerGridItem.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatMediaInputStickerGridItem.swift rename to submodules/TelegramUI/Sources/ChatMediaInputStickerGridItem.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatMediaInputStickerPackItem.swift b/submodules/TelegramUI/Sources/ChatMediaInputStickerPackItem.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatMediaInputStickerPackItem.swift rename to submodules/TelegramUI/Sources/ChatMediaInputStickerPackItem.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatMediaInputStickerPane.swift b/submodules/TelegramUI/Sources/ChatMediaInputStickerPane.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatMediaInputStickerPane.swift rename to submodules/TelegramUI/Sources/ChatMediaInputStickerPane.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatMediaInputTrendingItem.swift b/submodules/TelegramUI/Sources/ChatMediaInputTrendingItem.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatMediaInputTrendingItem.swift rename to submodules/TelegramUI/Sources/ChatMediaInputTrendingItem.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatMediaInputTrendingPane.swift b/submodules/TelegramUI/Sources/ChatMediaInputTrendingPane.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatMediaInputTrendingPane.swift rename to submodules/TelegramUI/Sources/ChatMediaInputTrendingPane.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatMessageActionButtonsNode.swift b/submodules/TelegramUI/Sources/ChatMessageActionButtonsNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatMessageActionButtonsNode.swift rename to submodules/TelegramUI/Sources/ChatMessageActionButtonsNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatMessageActionItemNode.swift b/submodules/TelegramUI/Sources/ChatMessageActionItemNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatMessageActionItemNode.swift rename to submodules/TelegramUI/Sources/ChatMessageActionItemNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatMessageActionSheetController.swift b/submodules/TelegramUI/Sources/ChatMessageActionSheetController.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatMessageActionSheetController.swift rename to submodules/TelegramUI/Sources/ChatMessageActionSheetController.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatMessageActionSheetControllerNode.swift b/submodules/TelegramUI/Sources/ChatMessageActionSheetControllerNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatMessageActionSheetControllerNode.swift rename to submodules/TelegramUI/Sources/ChatMessageActionSheetControllerNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatMessageActionUrlAuthController.swift b/submodules/TelegramUI/Sources/ChatMessageActionUrlAuthController.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatMessageActionUrlAuthController.swift rename to submodules/TelegramUI/Sources/ChatMessageActionUrlAuthController.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatMessageAnimatedStickerItemNode.swift b/submodules/TelegramUI/Sources/ChatMessageAnimatedStickerItemNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatMessageAnimatedStickerItemNode.swift rename to submodules/TelegramUI/Sources/ChatMessageAnimatedStickerItemNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatMessageAttachedContentNode.swift b/submodules/TelegramUI/Sources/ChatMessageAttachedContentNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatMessageAttachedContentNode.swift rename to submodules/TelegramUI/Sources/ChatMessageAttachedContentNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatMessageAvatarAccessoryItem.swift b/submodules/TelegramUI/Sources/ChatMessageAvatarAccessoryItem.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatMessageAvatarAccessoryItem.swift rename to submodules/TelegramUI/Sources/ChatMessageAvatarAccessoryItem.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatMessageBackground.swift b/submodules/TelegramUI/Sources/ChatMessageBackground.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatMessageBackground.swift rename to submodules/TelegramUI/Sources/ChatMessageBackground.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatMessageBubbleBackdrop.swift b/submodules/TelegramUI/Sources/ChatMessageBubbleBackdrop.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatMessageBubbleBackdrop.swift rename to submodules/TelegramUI/Sources/ChatMessageBubbleBackdrop.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatMessageBubbleContentCalclulateImageCorners.swift b/submodules/TelegramUI/Sources/ChatMessageBubbleContentCalclulateImageCorners.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatMessageBubbleContentCalclulateImageCorners.swift rename to submodules/TelegramUI/Sources/ChatMessageBubbleContentCalclulateImageCorners.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatMessageBubbleContentNode.swift b/submodules/TelegramUI/Sources/ChatMessageBubbleContentNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatMessageBubbleContentNode.swift rename to submodules/TelegramUI/Sources/ChatMessageBubbleContentNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatMessageBubbleItemNode.swift b/submodules/TelegramUI/Sources/ChatMessageBubbleItemNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatMessageBubbleItemNode.swift rename to submodules/TelegramUI/Sources/ChatMessageBubbleItemNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatMessageCallBubbleContentNode.swift b/submodules/TelegramUI/Sources/ChatMessageCallBubbleContentNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatMessageCallBubbleContentNode.swift rename to submodules/TelegramUI/Sources/ChatMessageCallBubbleContentNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatMessageContactBubbleContentNode.swift b/submodules/TelegramUI/Sources/ChatMessageContactBubbleContentNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatMessageContactBubbleContentNode.swift rename to submodules/TelegramUI/Sources/ChatMessageContactBubbleContentNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatMessageContextControllerContentSource.swift b/submodules/TelegramUI/Sources/ChatMessageContextControllerContentSource.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatMessageContextControllerContentSource.swift rename to submodules/TelegramUI/Sources/ChatMessageContextControllerContentSource.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatMessageDateAndStatusNode.swift b/submodules/TelegramUI/Sources/ChatMessageDateAndStatusNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatMessageDateAndStatusNode.swift rename to submodules/TelegramUI/Sources/ChatMessageDateAndStatusNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatMessageDateHeader.swift b/submodules/TelegramUI/Sources/ChatMessageDateHeader.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatMessageDateHeader.swift rename to submodules/TelegramUI/Sources/ChatMessageDateHeader.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatMessageDeliveryFailedNode.swift b/submodules/TelegramUI/Sources/ChatMessageDeliveryFailedNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatMessageDeliveryFailedNode.swift rename to submodules/TelegramUI/Sources/ChatMessageDeliveryFailedNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatMessageEventLogPreviousDescriptionContentNode.swift b/submodules/TelegramUI/Sources/ChatMessageEventLogPreviousDescriptionContentNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatMessageEventLogPreviousDescriptionContentNode.swift rename to submodules/TelegramUI/Sources/ChatMessageEventLogPreviousDescriptionContentNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatMessageEventLogPreviousLinkContentNode.swift b/submodules/TelegramUI/Sources/ChatMessageEventLogPreviousLinkContentNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatMessageEventLogPreviousLinkContentNode.swift rename to submodules/TelegramUI/Sources/ChatMessageEventLogPreviousLinkContentNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatMessageEventLogPreviousMessageContentNode.swift b/submodules/TelegramUI/Sources/ChatMessageEventLogPreviousMessageContentNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatMessageEventLogPreviousMessageContentNode.swift rename to submodules/TelegramUI/Sources/ChatMessageEventLogPreviousMessageContentNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatMessageFileBubbleContentNode.swift b/submodules/TelegramUI/Sources/ChatMessageFileBubbleContentNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatMessageFileBubbleContentNode.swift rename to submodules/TelegramUI/Sources/ChatMessageFileBubbleContentNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatMessageForwardInfoNode.swift b/submodules/TelegramUI/Sources/ChatMessageForwardInfoNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatMessageForwardInfoNode.swift rename to submodules/TelegramUI/Sources/ChatMessageForwardInfoNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatMessageGameBubbleContentNode.swift b/submodules/TelegramUI/Sources/ChatMessageGameBubbleContentNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatMessageGameBubbleContentNode.swift rename to submodules/TelegramUI/Sources/ChatMessageGameBubbleContentNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatMessageInstantVideoItemNode.swift b/submodules/TelegramUI/Sources/ChatMessageInstantVideoItemNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatMessageInstantVideoItemNode.swift rename to submodules/TelegramUI/Sources/ChatMessageInstantVideoItemNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatMessageInteractiveFileNode.swift b/submodules/TelegramUI/Sources/ChatMessageInteractiveFileNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatMessageInteractiveFileNode.swift rename to submodules/TelegramUI/Sources/ChatMessageInteractiveFileNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatMessageInteractiveInstantVideoNode.swift b/submodules/TelegramUI/Sources/ChatMessageInteractiveInstantVideoNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatMessageInteractiveInstantVideoNode.swift rename to submodules/TelegramUI/Sources/ChatMessageInteractiveInstantVideoNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatMessageInteractiveMediaBadge.swift b/submodules/TelegramUI/Sources/ChatMessageInteractiveMediaBadge.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatMessageInteractiveMediaBadge.swift rename to submodules/TelegramUI/Sources/ChatMessageInteractiveMediaBadge.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatMessageInteractiveMediaNode.swift b/submodules/TelegramUI/Sources/ChatMessageInteractiveMediaNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatMessageInteractiveMediaNode.swift rename to submodules/TelegramUI/Sources/ChatMessageInteractiveMediaNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatMessageInvoiceBubbleContentNode.swift b/submodules/TelegramUI/Sources/ChatMessageInvoiceBubbleContentNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatMessageInvoiceBubbleContentNode.swift rename to submodules/TelegramUI/Sources/ChatMessageInvoiceBubbleContentNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatMessageItem.swift b/submodules/TelegramUI/Sources/ChatMessageItem.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatMessageItem.swift rename to submodules/TelegramUI/Sources/ChatMessageItem.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatMessageItemView.swift b/submodules/TelegramUI/Sources/ChatMessageItemView.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatMessageItemView.swift rename to submodules/TelegramUI/Sources/ChatMessageItemView.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatMessageLiveLocationTextNode.swift b/submodules/TelegramUI/Sources/ChatMessageLiveLocationTextNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatMessageLiveLocationTextNode.swift rename to submodules/TelegramUI/Sources/ChatMessageLiveLocationTextNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatMessageMapBubbleContentNode.swift b/submodules/TelegramUI/Sources/ChatMessageMapBubbleContentNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatMessageMapBubbleContentNode.swift rename to submodules/TelegramUI/Sources/ChatMessageMapBubbleContentNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatMessageMediaBubbleContentNode.swift b/submodules/TelegramUI/Sources/ChatMessageMediaBubbleContentNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatMessageMediaBubbleContentNode.swift rename to submodules/TelegramUI/Sources/ChatMessageMediaBubbleContentNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatMessageNotificationItem.swift b/submodules/TelegramUI/Sources/ChatMessageNotificationItem.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatMessageNotificationItem.swift rename to submodules/TelegramUI/Sources/ChatMessageNotificationItem.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatMessagePollBubbleContentNode.swift b/submodules/TelegramUI/Sources/ChatMessagePollBubbleContentNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatMessagePollBubbleContentNode.swift rename to submodules/TelegramUI/Sources/ChatMessagePollBubbleContentNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatMessageReplyInfoNode.swift b/submodules/TelegramUI/Sources/ChatMessageReplyInfoNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatMessageReplyInfoNode.swift rename to submodules/TelegramUI/Sources/ChatMessageReplyInfoNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatMessageRestrictedBubbleContentNode.swift b/submodules/TelegramUI/Sources/ChatMessageRestrictedBubbleContentNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatMessageRestrictedBubbleContentNode.swift rename to submodules/TelegramUI/Sources/ChatMessageRestrictedBubbleContentNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatMessageSelectionInputPanelNode.swift b/submodules/TelegramUI/Sources/ChatMessageSelectionInputPanelNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatMessageSelectionInputPanelNode.swift rename to submodules/TelegramUI/Sources/ChatMessageSelectionInputPanelNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatMessageSelectionNode.swift b/submodules/TelegramUI/Sources/ChatMessageSelectionNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatMessageSelectionNode.swift rename to submodules/TelegramUI/Sources/ChatMessageSelectionNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatMessageStickerItemNode.swift b/submodules/TelegramUI/Sources/ChatMessageStickerItemNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatMessageStickerItemNode.swift rename to submodules/TelegramUI/Sources/ChatMessageStickerItemNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatMessageSwipeToReplyNode.swift b/submodules/TelegramUI/Sources/ChatMessageSwipeToReplyNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatMessageSwipeToReplyNode.swift rename to submodules/TelegramUI/Sources/ChatMessageSwipeToReplyNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatMessageTextBubbleContentNode.swift b/submodules/TelegramUI/Sources/ChatMessageTextBubbleContentNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatMessageTextBubbleContentNode.swift rename to submodules/TelegramUI/Sources/ChatMessageTextBubbleContentNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatMessageThrottledProcessingManager.swift b/submodules/TelegramUI/Sources/ChatMessageThrottledProcessingManager.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatMessageThrottledProcessingManager.swift rename to submodules/TelegramUI/Sources/ChatMessageThrottledProcessingManager.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatMessageUnsupportedBubbleContentNode.swift b/submodules/TelegramUI/Sources/ChatMessageUnsupportedBubbleContentNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatMessageUnsupportedBubbleContentNode.swift rename to submodules/TelegramUI/Sources/ChatMessageUnsupportedBubbleContentNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatMessageWebpageBubbleContentNode.swift b/submodules/TelegramUI/Sources/ChatMessageWebpageBubbleContentNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatMessageWebpageBubbleContentNode.swift rename to submodules/TelegramUI/Sources/ChatMessageWebpageBubbleContentNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatOverlayNavigationBar.swift b/submodules/TelegramUI/Sources/ChatOverlayNavigationBar.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatOverlayNavigationBar.swift rename to submodules/TelegramUI/Sources/ChatOverlayNavigationBar.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatPanelInterfaceInteraction.swift b/submodules/TelegramUI/Sources/ChatPanelInterfaceInteraction.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatPanelInterfaceInteraction.swift rename to submodules/TelegramUI/Sources/ChatPanelInterfaceInteraction.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatPinnedMessageTitlePanelNode.swift b/submodules/TelegramUI/Sources/ChatPinnedMessageTitlePanelNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatPinnedMessageTitlePanelNode.swift rename to submodules/TelegramUI/Sources/ChatPinnedMessageTitlePanelNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatPresentationData.swift b/submodules/TelegramUI/Sources/ChatPresentationData.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatPresentationData.swift rename to submodules/TelegramUI/Sources/ChatPresentationData.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatPresentationInterfaceState.swift b/submodules/TelegramUI/Sources/ChatPresentationInterfaceState.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatPresentationInterfaceState.swift rename to submodules/TelegramUI/Sources/ChatPresentationInterfaceState.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatRecentActionsController.swift b/submodules/TelegramUI/Sources/ChatRecentActionsController.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatRecentActionsController.swift rename to submodules/TelegramUI/Sources/ChatRecentActionsController.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatRecentActionsControllerNode.swift b/submodules/TelegramUI/Sources/ChatRecentActionsControllerNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatRecentActionsControllerNode.swift rename to submodules/TelegramUI/Sources/ChatRecentActionsControllerNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatRecentActionsControllerState.swift b/submodules/TelegramUI/Sources/ChatRecentActionsControllerState.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatRecentActionsControllerState.swift rename to submodules/TelegramUI/Sources/ChatRecentActionsControllerState.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatRecentActionsEmptyNode.swift b/submodules/TelegramUI/Sources/ChatRecentActionsEmptyNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatRecentActionsEmptyNode.swift rename to submodules/TelegramUI/Sources/ChatRecentActionsEmptyNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatRecentActionsFilterController.swift b/submodules/TelegramUI/Sources/ChatRecentActionsFilterController.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatRecentActionsFilterController.swift rename to submodules/TelegramUI/Sources/ChatRecentActionsFilterController.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatRecentActionsHistoryTransition.swift b/submodules/TelegramUI/Sources/ChatRecentActionsHistoryTransition.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatRecentActionsHistoryTransition.swift rename to submodules/TelegramUI/Sources/ChatRecentActionsHistoryTransition.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatRecentActionsInteraction.swift b/submodules/TelegramUI/Sources/ChatRecentActionsInteraction.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatRecentActionsInteraction.swift rename to submodules/TelegramUI/Sources/ChatRecentActionsInteraction.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatRecentActionsSearchNavigationContentNode.swift b/submodules/TelegramUI/Sources/ChatRecentActionsSearchNavigationContentNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatRecentActionsSearchNavigationContentNode.swift rename to submodules/TelegramUI/Sources/ChatRecentActionsSearchNavigationContentNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatRecentActionsTitleView.swift b/submodules/TelegramUI/Sources/ChatRecentActionsTitleView.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatRecentActionsTitleView.swift rename to submodules/TelegramUI/Sources/ChatRecentActionsTitleView.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatRecordingPreviewInputPanelNode.swift b/submodules/TelegramUI/Sources/ChatRecordingPreviewInputPanelNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatRecordingPreviewInputPanelNode.swift rename to submodules/TelegramUI/Sources/ChatRecordingPreviewInputPanelNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatReportPeerTitlePanelNode.swift b/submodules/TelegramUI/Sources/ChatReportPeerTitlePanelNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatReportPeerTitlePanelNode.swift rename to submodules/TelegramUI/Sources/ChatReportPeerTitlePanelNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatRequestInProgressTitlePanelNode.swift b/submodules/TelegramUI/Sources/ChatRequestInProgressTitlePanelNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatRequestInProgressTitlePanelNode.swift rename to submodules/TelegramUI/Sources/ChatRequestInProgressTitlePanelNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatRestrictedInputPanelNode.swift b/submodules/TelegramUI/Sources/ChatRestrictedInputPanelNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatRestrictedInputPanelNode.swift rename to submodules/TelegramUI/Sources/ChatRestrictedInputPanelNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatRestrictedNode.swift b/submodules/TelegramUI/Sources/ChatRestrictedNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatRestrictedNode.swift rename to submodules/TelegramUI/Sources/ChatRestrictedNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatScheduleTimeController.swift b/submodules/TelegramUI/Sources/ChatScheduleTimeController.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatScheduleTimeController.swift rename to submodules/TelegramUI/Sources/ChatScheduleTimeController.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatScheduleTimeControllerNode.swift b/submodules/TelegramUI/Sources/ChatScheduleTimeControllerNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatScheduleTimeControllerNode.swift rename to submodules/TelegramUI/Sources/ChatScheduleTimeControllerNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatSearchInputPanelNode.swift b/submodules/TelegramUI/Sources/ChatSearchInputPanelNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatSearchInputPanelNode.swift rename to submodules/TelegramUI/Sources/ChatSearchInputPanelNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatSearchNavigationContentNode.swift b/submodules/TelegramUI/Sources/ChatSearchNavigationContentNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatSearchNavigationContentNode.swift rename to submodules/TelegramUI/Sources/ChatSearchNavigationContentNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatSearchResultsContollerNode.swift b/submodules/TelegramUI/Sources/ChatSearchResultsContollerNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatSearchResultsContollerNode.swift rename to submodules/TelegramUI/Sources/ChatSearchResultsContollerNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatSearchResultsController.swift b/submodules/TelegramUI/Sources/ChatSearchResultsController.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatSearchResultsController.swift rename to submodules/TelegramUI/Sources/ChatSearchResultsController.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatSearchState.swift b/submodules/TelegramUI/Sources/ChatSearchState.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatSearchState.swift rename to submodules/TelegramUI/Sources/ChatSearchState.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatSecretAutoremoveTimerActionSheet.swift b/submodules/TelegramUI/Sources/ChatSecretAutoremoveTimerActionSheet.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatSecretAutoremoveTimerActionSheet.swift rename to submodules/TelegramUI/Sources/ChatSecretAutoremoveTimerActionSheet.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatSendButtonRadialStatusNode.swift b/submodules/TelegramUI/Sources/ChatSendButtonRadialStatusNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatSendButtonRadialStatusNode.swift rename to submodules/TelegramUI/Sources/ChatSendButtonRadialStatusNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatSendMessageActionSheetController.swift b/submodules/TelegramUI/Sources/ChatSendMessageActionSheetController.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatSendMessageActionSheetController.swift rename to submodules/TelegramUI/Sources/ChatSendMessageActionSheetController.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatSendMessageActionSheetControllerNode.swift b/submodules/TelegramUI/Sources/ChatSendMessageActionSheetControllerNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatSendMessageActionSheetControllerNode.swift rename to submodules/TelegramUI/Sources/ChatSendMessageActionSheetControllerNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatSlowmodeHintController.swift b/submodules/TelegramUI/Sources/ChatSlowmodeHintController.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatSlowmodeHintController.swift rename to submodules/TelegramUI/Sources/ChatSlowmodeHintController.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatSwipeToReplyRecognizer.swift b/submodules/TelegramUI/Sources/ChatSwipeToReplyRecognizer.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatSwipeToReplyRecognizer.swift rename to submodules/TelegramUI/Sources/ChatSwipeToReplyRecognizer.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatTextFormat.swift b/submodules/TelegramUI/Sources/ChatTextFormat.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatTextFormat.swift rename to submodules/TelegramUI/Sources/ChatTextFormat.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatTextInputAccessoryItem.swift b/submodules/TelegramUI/Sources/ChatTextInputAccessoryItem.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatTextInputAccessoryItem.swift rename to submodules/TelegramUI/Sources/ChatTextInputAccessoryItem.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatTextInputActionButtonsNode.swift b/submodules/TelegramUI/Sources/ChatTextInputActionButtonsNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatTextInputActionButtonsNode.swift rename to submodules/TelegramUI/Sources/ChatTextInputActionButtonsNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatTextInputAudioRecordingCancelIndicator.swift b/submodules/TelegramUI/Sources/ChatTextInputAudioRecordingCancelIndicator.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatTextInputAudioRecordingCancelIndicator.swift rename to submodules/TelegramUI/Sources/ChatTextInputAudioRecordingCancelIndicator.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatTextInputAudioRecordingOverlayButton.swift b/submodules/TelegramUI/Sources/ChatTextInputAudioRecordingOverlayButton.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatTextInputAudioRecordingOverlayButton.swift rename to submodules/TelegramUI/Sources/ChatTextInputAudioRecordingOverlayButton.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatTextInputAudioRecordingTimeNode.swift b/submodules/TelegramUI/Sources/ChatTextInputAudioRecordingTimeNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatTextInputAudioRecordingTimeNode.swift rename to submodules/TelegramUI/Sources/ChatTextInputAudioRecordingTimeNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatTextInputMediaRecordingButton.swift b/submodules/TelegramUI/Sources/ChatTextInputMediaRecordingButton.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatTextInputMediaRecordingButton.swift rename to submodules/TelegramUI/Sources/ChatTextInputMediaRecordingButton.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatTextInputMenu.swift b/submodules/TelegramUI/Sources/ChatTextInputMenu.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatTextInputMenu.swift rename to submodules/TelegramUI/Sources/ChatTextInputMenu.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatTextInputPanelNode.swift b/submodules/TelegramUI/Sources/ChatTextInputPanelNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatTextInputPanelNode.swift rename to submodules/TelegramUI/Sources/ChatTextInputPanelNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatTextInputPanelState.swift b/submodules/TelegramUI/Sources/ChatTextInputPanelState.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatTextInputPanelState.swift rename to submodules/TelegramUI/Sources/ChatTextInputPanelState.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatTextInputSlowmodePlaceholderNode.swift b/submodules/TelegramUI/Sources/ChatTextInputSlowmodePlaceholderNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatTextInputSlowmodePlaceholderNode.swift rename to submodules/TelegramUI/Sources/ChatTextInputSlowmodePlaceholderNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatTextLinkEditController.swift b/submodules/TelegramUI/Sources/ChatTextLinkEditController.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatTextLinkEditController.swift rename to submodules/TelegramUI/Sources/ChatTextLinkEditController.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatTitleAccessoryPanelNode.swift b/submodules/TelegramUI/Sources/ChatTitleAccessoryPanelNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatTitleAccessoryPanelNode.swift rename to submodules/TelegramUI/Sources/ChatTitleAccessoryPanelNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatTitleView.swift b/submodules/TelegramUI/Sources/ChatTitleView.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatTitleView.swift rename to submodules/TelegramUI/Sources/ChatTitleView.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatToastAlertPanelNode.swift b/submodules/TelegramUI/Sources/ChatToastAlertPanelNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatToastAlertPanelNode.swift rename to submodules/TelegramUI/Sources/ChatToastAlertPanelNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatUnblockInputPanelNode.swift b/submodules/TelegramUI/Sources/ChatUnblockInputPanelNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatUnblockInputPanelNode.swift rename to submodules/TelegramUI/Sources/ChatUnblockInputPanelNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ChatUnreadItem.swift b/submodules/TelegramUI/Sources/ChatUnreadItem.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ChatUnreadItem.swift rename to submodules/TelegramUI/Sources/ChatUnreadItem.swift diff --git a/submodules/TelegramUI/TelegramUI/CheckDiskSpace.swift b/submodules/TelegramUI/Sources/CheckDiskSpace.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/CheckDiskSpace.swift rename to submodules/TelegramUI/Sources/CheckDiskSpace.swift diff --git a/submodules/TelegramUI/TelegramUI/ClearNotificationsManager.swift b/submodules/TelegramUI/Sources/ClearNotificationsManager.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ClearNotificationsManager.swift rename to submodules/TelegramUI/Sources/ClearNotificationsManager.swift diff --git a/submodules/TelegramUI/TelegramUI/CommandChatInputContextPanelNode.swift b/submodules/TelegramUI/Sources/CommandChatInputContextPanelNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/CommandChatInputContextPanelNode.swift rename to submodules/TelegramUI/Sources/CommandChatInputContextPanelNode.swift diff --git a/submodules/TelegramUI/TelegramUI/CommandChatInputPanelItem.swift b/submodules/TelegramUI/Sources/CommandChatInputPanelItem.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/CommandChatInputPanelItem.swift rename to submodules/TelegramUI/Sources/CommandChatInputPanelItem.swift diff --git a/submodules/TelegramUI/TelegramUI/ComposeController.swift b/submodules/TelegramUI/Sources/ComposeController.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ComposeController.swift rename to submodules/TelegramUI/Sources/ComposeController.swift diff --git a/submodules/TelegramUI/TelegramUI/ComposeControllerNode.swift b/submodules/TelegramUI/Sources/ComposeControllerNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ComposeControllerNode.swift rename to submodules/TelegramUI/Sources/ComposeControllerNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ConfettiView.swift b/submodules/TelegramUI/Sources/ConfettiView.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ConfettiView.swift rename to submodules/TelegramUI/Sources/ConfettiView.swift diff --git a/submodules/TelegramUI/TelegramUI/ContactMultiselectionController.swift b/submodules/TelegramUI/Sources/ContactMultiselectionController.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ContactMultiselectionController.swift rename to submodules/TelegramUI/Sources/ContactMultiselectionController.swift diff --git a/submodules/TelegramUI/TelegramUI/ContactMultiselectionControllerNode.swift b/submodules/TelegramUI/Sources/ContactMultiselectionControllerNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ContactMultiselectionControllerNode.swift rename to submodules/TelegramUI/Sources/ContactMultiselectionControllerNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ContactSelectionController.swift b/submodules/TelegramUI/Sources/ContactSelectionController.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ContactSelectionController.swift rename to submodules/TelegramUI/Sources/ContactSelectionController.swift diff --git a/submodules/TelegramUI/TelegramUI/ContactSelectionControllerNode.swift b/submodules/TelegramUI/Sources/ContactSelectionControllerNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ContactSelectionControllerNode.swift rename to submodules/TelegramUI/Sources/ContactSelectionControllerNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ConvertToWebP.swift b/submodules/TelegramUI/Sources/ConvertToWebP.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ConvertToWebP.swift rename to submodules/TelegramUI/Sources/ConvertToWebP.swift diff --git a/submodules/TelegramUI/TelegramUI/CreateChannelController.swift b/submodules/TelegramUI/Sources/CreateChannelController.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/CreateChannelController.swift rename to submodules/TelegramUI/Sources/CreateChannelController.swift diff --git a/submodules/TelegramUI/TelegramUI/CreateGroupController.swift b/submodules/TelegramUI/Sources/CreateGroupController.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/CreateGroupController.swift rename to submodules/TelegramUI/Sources/CreateGroupController.swift diff --git a/submodules/TelegramUI/TelegramUI/DeclareEncodables.swift b/submodules/TelegramUI/Sources/DeclareEncodables.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/DeclareEncodables.swift rename to submodules/TelegramUI/Sources/DeclareEncodables.swift diff --git a/submodules/TelegramUI/TelegramUI/DeleteChatInputPanelNode.swift b/submodules/TelegramUI/Sources/DeleteChatInputPanelNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/DeleteChatInputPanelNode.swift rename to submodules/TelegramUI/Sources/DeleteChatInputPanelNode.swift diff --git a/submodules/TelegramUI/TelegramUI/DeviceContactDataManager.swift b/submodules/TelegramUI/Sources/DeviceContactDataManager.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/DeviceContactDataManager.swift rename to submodules/TelegramUI/Sources/DeviceContactDataManager.swift diff --git a/submodules/TelegramUI/TelegramUI/DisabledContextResultsChatInputContextPanelNode.swift b/submodules/TelegramUI/Sources/DisabledContextResultsChatInputContextPanelNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/DisabledContextResultsChatInputContextPanelNode.swift rename to submodules/TelegramUI/Sources/DisabledContextResultsChatInputContextPanelNode.swift diff --git a/submodules/TelegramUI/TelegramUI/DocumentPreviewController.swift b/submodules/TelegramUI/Sources/DocumentPreviewController.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/DocumentPreviewController.swift rename to submodules/TelegramUI/Sources/DocumentPreviewController.swift diff --git a/submodules/TelegramUI/TelegramUI/EditAccessoryPanelNode.swift b/submodules/TelegramUI/Sources/EditAccessoryPanelNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/EditAccessoryPanelNode.swift rename to submodules/TelegramUI/Sources/EditAccessoryPanelNode.swift diff --git a/submodules/TelegramUI/TelegramUI/EditableTokenListNode.swift b/submodules/TelegramUI/Sources/EditableTokenListNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/EditableTokenListNode.swift rename to submodules/TelegramUI/Sources/EditableTokenListNode.swift diff --git a/submodules/TelegramUI/TelegramUI/EmojiResources.swift b/submodules/TelegramUI/Sources/EmojiResources.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/EmojiResources.swift rename to submodules/TelegramUI/Sources/EmojiResources.swift diff --git a/submodules/TelegramUI/TelegramUI/EmojisChatInputContextPanelNode.swift b/submodules/TelegramUI/Sources/EmojisChatInputContextPanelNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/EmojisChatInputContextPanelNode.swift rename to submodules/TelegramUI/Sources/EmojisChatInputContextPanelNode.swift diff --git a/submodules/TelegramUI/TelegramUI/EmojisChatInputPanelItem.swift b/submodules/TelegramUI/Sources/EmojisChatInputPanelItem.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/EmojisChatInputPanelItem.swift rename to submodules/TelegramUI/Sources/EmojisChatInputPanelItem.swift diff --git a/submodules/TelegramUI/TelegramUI/FetchCachedRepresentations.swift b/submodules/TelegramUI/Sources/FetchCachedRepresentations.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/FetchCachedRepresentations.swift rename to submodules/TelegramUI/Sources/FetchCachedRepresentations.swift diff --git a/submodules/TelegramUI/TelegramUI/FetchManager.swift b/submodules/TelegramUI/Sources/FetchManager.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/FetchManager.swift rename to submodules/TelegramUI/Sources/FetchManager.swift diff --git a/submodules/TelegramUI/TelegramUI/FetchManagerLocation.swift b/submodules/TelegramUI/Sources/FetchManagerLocation.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/FetchManagerLocation.swift rename to submodules/TelegramUI/Sources/FetchManagerLocation.swift diff --git a/submodules/TelegramUI/TelegramUI/FetchResource.swift b/submodules/TelegramUI/Sources/FetchResource.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/FetchResource.swift rename to submodules/TelegramUI/Sources/FetchResource.swift diff --git a/submodules/TelegramUI/TelegramUI/FetchVideoMediaResource.swift b/submodules/TelegramUI/Sources/FetchVideoMediaResource.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/FetchVideoMediaResource.swift rename to submodules/TelegramUI/Sources/FetchVideoMediaResource.swift diff --git a/submodules/TelegramUI/TelegramUI/FileMediaResourceStatus.swift b/submodules/TelegramUI/Sources/FileMediaResourceStatus.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/FileMediaResourceStatus.swift rename to submodules/TelegramUI/Sources/FileMediaResourceStatus.swift diff --git a/submodules/TelegramUI/TelegramUI/ForwardAccessoryPanelNode.swift b/submodules/TelegramUI/Sources/ForwardAccessoryPanelNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ForwardAccessoryPanelNode.swift rename to submodules/TelegramUI/Sources/ForwardAccessoryPanelNode.swift diff --git a/submodules/TelegramUI/TelegramUI/GalleryHiddenMediaManager.swift b/submodules/TelegramUI/Sources/GalleryHiddenMediaManager.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/GalleryHiddenMediaManager.swift rename to submodules/TelegramUI/Sources/GalleryHiddenMediaManager.swift diff --git a/submodules/TelegramUI/TelegramUI/GifPaneSearchContentNode.swift b/submodules/TelegramUI/Sources/GifPaneSearchContentNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/GifPaneSearchContentNode.swift rename to submodules/TelegramUI/Sources/GifPaneSearchContentNode.swift diff --git a/submodules/TelegramUI/TelegramUI/GlobalExperimentalSettings.swift b/submodules/TelegramUI/Sources/GlobalExperimentalSettings.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/GlobalExperimentalSettings.swift rename to submodules/TelegramUI/Sources/GlobalExperimentalSettings.swift diff --git a/submodules/TelegramUI/TelegramUI/GridHoleItem.swift b/submodules/TelegramUI/Sources/GridHoleItem.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/GridHoleItem.swift rename to submodules/TelegramUI/Sources/GridHoleItem.swift diff --git a/submodules/TelegramUI/TelegramUI/GridMessageItem.swift b/submodules/TelegramUI/Sources/GridMessageItem.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/GridMessageItem.swift rename to submodules/TelegramUI/Sources/GridMessageItem.swift diff --git a/submodules/TelegramUI/TelegramUI/HashtagChatInputContextPanelNode.swift b/submodules/TelegramUI/Sources/HashtagChatInputContextPanelNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/HashtagChatInputContextPanelNode.swift rename to submodules/TelegramUI/Sources/HashtagChatInputContextPanelNode.swift diff --git a/submodules/TelegramUI/TelegramUI/HashtagChatInputPanelItem.swift b/submodules/TelegramUI/Sources/HashtagChatInputPanelItem.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/HashtagChatInputPanelItem.swift rename to submodules/TelegramUI/Sources/HashtagChatInputPanelItem.swift diff --git a/submodules/TelegramUI/TelegramUI/HorizontalListContextResultsChatInputContextPanelNode.swift b/submodules/TelegramUI/Sources/HorizontalListContextResultsChatInputContextPanelNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/HorizontalListContextResultsChatInputContextPanelNode.swift rename to submodules/TelegramUI/Sources/HorizontalListContextResultsChatInputContextPanelNode.swift diff --git a/submodules/TelegramUI/TelegramUI/HorizontalListContextResultsChatInputPanelItem.swift b/submodules/TelegramUI/Sources/HorizontalListContextResultsChatInputPanelItem.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/HorizontalListContextResultsChatInputPanelItem.swift rename to submodules/TelegramUI/Sources/HorizontalListContextResultsChatInputPanelItem.swift diff --git a/submodules/TelegramUI/TelegramUI/HorizontalStickerGridItem.swift b/submodules/TelegramUI/Sources/HorizontalStickerGridItem.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/HorizontalStickerGridItem.swift rename to submodules/TelegramUI/Sources/HorizontalStickerGridItem.swift diff --git a/submodules/TelegramUI/TelegramUI/HorizontalStickersChatContextPanelNode.swift b/submodules/TelegramUI/Sources/HorizontalStickersChatContextPanelNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/HorizontalStickersChatContextPanelNode.swift rename to submodules/TelegramUI/Sources/HorizontalStickersChatContextPanelNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ICloudResources.swift b/submodules/TelegramUI/Sources/ICloudResources.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ICloudResources.swift rename to submodules/TelegramUI/Sources/ICloudResources.swift diff --git a/submodules/TelegramUI/TelegramUI/ID3ArtworkReader.swift b/submodules/TelegramUI/Sources/ID3ArtworkReader.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ID3ArtworkReader.swift rename to submodules/TelegramUI/Sources/ID3ArtworkReader.swift diff --git a/submodules/TelegramUI/TelegramUI/IconButtonNode.swift b/submodules/TelegramUI/Sources/IconButtonNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/IconButtonNode.swift rename to submodules/TelegramUI/Sources/IconButtonNode.swift diff --git a/submodules/TelegramUI/TelegramUI/InChatPrefetchManager.swift b/submodules/TelegramUI/Sources/InChatPrefetchManager.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/InChatPrefetchManager.swift rename to submodules/TelegramUI/Sources/InChatPrefetchManager.swift diff --git a/submodules/TelegramUI/TelegramUI/Info.plist b/submodules/TelegramUI/Sources/Info.plist similarity index 100% rename from submodules/TelegramUI/TelegramUI/Info.plist rename to submodules/TelegramUI/Sources/Info.plist diff --git a/submodules/TelegramUI/TelegramUI/InstantVideoRadialStatusNode.swift b/submodules/TelegramUI/Sources/InstantVideoRadialStatusNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/InstantVideoRadialStatusNode.swift rename to submodules/TelegramUI/Sources/InstantVideoRadialStatusNode.swift diff --git a/submodules/TelegramUI/TelegramUI/LegacyCache.swift b/submodules/TelegramUI/Sources/LegacyCache.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/LegacyCache.swift rename to submodules/TelegramUI/Sources/LegacyCache.swift diff --git a/submodules/TelegramUI/TelegramUI/LegacyCamera.swift b/submodules/TelegramUI/Sources/LegacyCamera.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/LegacyCamera.swift rename to submodules/TelegramUI/Sources/LegacyCamera.swift diff --git a/submodules/TelegramUI/TelegramUI/LegacyInstantVideoController.swift b/submodules/TelegramUI/Sources/LegacyInstantVideoController.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/LegacyInstantVideoController.swift rename to submodules/TelegramUI/Sources/LegacyInstantVideoController.swift diff --git a/submodules/TelegramUI/TelegramUI/LegacyLiveUploadInterface.swift b/submodules/TelegramUI/Sources/LegacyLiveUploadInterface.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/LegacyLiveUploadInterface.swift rename to submodules/TelegramUI/Sources/LegacyLiveUploadInterface.swift diff --git a/submodules/TelegramUI/TelegramUI/LinkHighlightingNode.swift b/submodules/TelegramUI/Sources/LinkHighlightingNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/LinkHighlightingNode.swift rename to submodules/TelegramUI/Sources/LinkHighlightingNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ListMessageDateHeader.swift b/submodules/TelegramUI/Sources/ListMessageDateHeader.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ListMessageDateHeader.swift rename to submodules/TelegramUI/Sources/ListMessageDateHeader.swift diff --git a/submodules/TelegramUI/TelegramUI/ListMessageFileItemNode.swift b/submodules/TelegramUI/Sources/ListMessageFileItemNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ListMessageFileItemNode.swift rename to submodules/TelegramUI/Sources/ListMessageFileItemNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ListMessageHoleItem.swift b/submodules/TelegramUI/Sources/ListMessageHoleItem.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ListMessageHoleItem.swift rename to submodules/TelegramUI/Sources/ListMessageHoleItem.swift diff --git a/submodules/TelegramUI/TelegramUI/ListMessageItem.swift b/submodules/TelegramUI/Sources/ListMessageItem.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ListMessageItem.swift rename to submodules/TelegramUI/Sources/ListMessageItem.swift diff --git a/submodules/TelegramUI/TelegramUI/ListMessageNode.swift b/submodules/TelegramUI/Sources/ListMessageNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ListMessageNode.swift rename to submodules/TelegramUI/Sources/ListMessageNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ListMessagePlaybackOverlayNode.swift b/submodules/TelegramUI/Sources/ListMessagePlaybackOverlayNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ListMessagePlaybackOverlayNode.swift rename to submodules/TelegramUI/Sources/ListMessagePlaybackOverlayNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ListMessageSnippetItemNode.swift b/submodules/TelegramUI/Sources/ListMessageSnippetItemNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ListMessageSnippetItemNode.swift rename to submodules/TelegramUI/Sources/ListMessageSnippetItemNode.swift diff --git a/submodules/TelegramUI/TelegramUI/LockedWindowCoveringView.swift b/submodules/TelegramUI/Sources/LockedWindowCoveringView.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/LockedWindowCoveringView.swift rename to submodules/TelegramUI/Sources/LockedWindowCoveringView.swift diff --git a/submodules/TelegramUI/TelegramUI/ManageSharedAccountInfo.swift b/submodules/TelegramUI/Sources/ManageSharedAccountInfo.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ManageSharedAccountInfo.swift rename to submodules/TelegramUI/Sources/ManageSharedAccountInfo.swift diff --git a/submodules/TelegramUI/TelegramUI/ManagedAudioRecorder.swift b/submodules/TelegramUI/Sources/ManagedAudioRecorder.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ManagedAudioRecorder.swift rename to submodules/TelegramUI/Sources/ManagedAudioRecorder.swift diff --git a/submodules/TelegramUI/TelegramUI/MediaInputPaneTrendingItem.swift b/submodules/TelegramUI/Sources/MediaInputPaneTrendingItem.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/MediaInputPaneTrendingItem.swift rename to submodules/TelegramUI/Sources/MediaInputPaneTrendingItem.swift diff --git a/submodules/TelegramUI/TelegramUI/MediaManager.swift b/submodules/TelegramUI/Sources/MediaManager.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/MediaManager.swift rename to submodules/TelegramUI/Sources/MediaManager.swift diff --git a/submodules/TelegramUI/TelegramUI/MediaPlaybackStoredState.swift b/submodules/TelegramUI/Sources/MediaPlaybackStoredState.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/MediaPlaybackStoredState.swift rename to submodules/TelegramUI/Sources/MediaPlaybackStoredState.swift diff --git a/submodules/TelegramUI/TelegramUI/MentionChatInputContextPanelNode.swift b/submodules/TelegramUI/Sources/MentionChatInputContextPanelNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/MentionChatInputContextPanelNode.swift rename to submodules/TelegramUI/Sources/MentionChatInputContextPanelNode.swift diff --git a/submodules/TelegramUI/TelegramUI/MentionChatInputPanelItem.swift b/submodules/TelegramUI/Sources/MentionChatInputPanelItem.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/MentionChatInputPanelItem.swift rename to submodules/TelegramUI/Sources/MentionChatInputPanelItem.swift diff --git a/submodules/TelegramUI/TelegramUI/MultiScaleTextNode.swift b/submodules/TelegramUI/Sources/MultiScaleTextNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/MultiScaleTextNode.swift rename to submodules/TelegramUI/Sources/MultiScaleTextNode.swift diff --git a/submodules/TelegramUI/TelegramUI/MultiplexedSoftwareVideoNode.swift b/submodules/TelegramUI/Sources/MultiplexedSoftwareVideoNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/MultiplexedSoftwareVideoNode.swift rename to submodules/TelegramUI/Sources/MultiplexedSoftwareVideoNode.swift diff --git a/submodules/TelegramUI/TelegramUI/MultiplexedSoftwareVideoSourceManager.swift b/submodules/TelegramUI/Sources/MultiplexedSoftwareVideoSourceManager.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/MultiplexedSoftwareVideoSourceManager.swift rename to submodules/TelegramUI/Sources/MultiplexedSoftwareVideoSourceManager.swift diff --git a/submodules/TelegramUI/TelegramUI/MultiplexedVideoNode.swift b/submodules/TelegramUI/Sources/MultiplexedVideoNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/MultiplexedVideoNode.swift rename to submodules/TelegramUI/Sources/MultiplexedVideoNode.swift diff --git a/submodules/TelegramUI/TelegramUI/NavigateToChatController.swift b/submodules/TelegramUI/Sources/NavigateToChatController.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/NavigateToChatController.swift rename to submodules/TelegramUI/Sources/NavigateToChatController.swift diff --git a/submodules/TelegramUI/TelegramUI/NotificationContainerController.swift b/submodules/TelegramUI/Sources/NotificationContainerController.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/NotificationContainerController.swift rename to submodules/TelegramUI/Sources/NotificationContainerController.swift diff --git a/submodules/TelegramUI/TelegramUI/NotificationContainerControllerNode.swift b/submodules/TelegramUI/Sources/NotificationContainerControllerNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/NotificationContainerControllerNode.swift rename to submodules/TelegramUI/Sources/NotificationContainerControllerNode.swift diff --git a/submodules/TelegramUI/TelegramUI/NotificationContentContext.swift b/submodules/TelegramUI/Sources/NotificationContentContext.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/NotificationContentContext.swift rename to submodules/TelegramUI/Sources/NotificationContentContext.swift diff --git a/submodules/TelegramUI/TelegramUI/NotificationItem.swift b/submodules/TelegramUI/Sources/NotificationItem.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/NotificationItem.swift rename to submodules/TelegramUI/Sources/NotificationItem.swift diff --git a/submodules/TelegramUI/TelegramUI/NotificationItemContainerNode.swift b/submodules/TelegramUI/Sources/NotificationItemContainerNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/NotificationItemContainerNode.swift rename to submodules/TelegramUI/Sources/NotificationItemContainerNode.swift diff --git a/submodules/TelegramUI/TelegramUI/OpenAddContact.swift b/submodules/TelegramUI/Sources/OpenAddContact.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/OpenAddContact.swift rename to submodules/TelegramUI/Sources/OpenAddContact.swift diff --git a/submodules/TelegramUI/TelegramUI/OpenChatMessage.swift b/submodules/TelegramUI/Sources/OpenChatMessage.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/OpenChatMessage.swift rename to submodules/TelegramUI/Sources/OpenChatMessage.swift diff --git a/submodules/TelegramUI/TelegramUI/OpenResolvedUrl.swift b/submodules/TelegramUI/Sources/OpenResolvedUrl.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/OpenResolvedUrl.swift rename to submodules/TelegramUI/Sources/OpenResolvedUrl.swift diff --git a/submodules/TelegramUI/TelegramUI/OpenUrl.swift b/submodules/TelegramUI/Sources/OpenUrl.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/OpenUrl.swift rename to submodules/TelegramUI/Sources/OpenUrl.swift diff --git a/submodules/TelegramUI/TelegramUI/OverlayAudioPlayerController.swift b/submodules/TelegramUI/Sources/OverlayAudioPlayerController.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/OverlayAudioPlayerController.swift rename to submodules/TelegramUI/Sources/OverlayAudioPlayerController.swift diff --git a/submodules/TelegramUI/TelegramUI/OverlayInstantVideoDecoration.swift b/submodules/TelegramUI/Sources/OverlayInstantVideoDecoration.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/OverlayInstantVideoDecoration.swift rename to submodules/TelegramUI/Sources/OverlayInstantVideoDecoration.swift diff --git a/submodules/TelegramUI/TelegramUI/OverlayInstantVideoNode.swift b/submodules/TelegramUI/Sources/OverlayInstantVideoNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/OverlayInstantVideoNode.swift rename to submodules/TelegramUI/Sources/OverlayInstantVideoNode.swift diff --git a/submodules/TelegramUI/TelegramUI/OverlayMediaController.swift b/submodules/TelegramUI/Sources/OverlayMediaController.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/OverlayMediaController.swift rename to submodules/TelegramUI/Sources/OverlayMediaController.swift diff --git a/submodules/TelegramUI/TelegramUI/OverlayMediaControllerNode.swift b/submodules/TelegramUI/Sources/OverlayMediaControllerNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/OverlayMediaControllerNode.swift rename to submodules/TelegramUI/Sources/OverlayMediaControllerNode.swift diff --git a/submodules/TelegramUI/TelegramUI/OverlayPlayerControllerNode.swift b/submodules/TelegramUI/Sources/OverlayPlayerControllerNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/OverlayPlayerControllerNode.swift rename to submodules/TelegramUI/Sources/OverlayPlayerControllerNode.swift diff --git a/submodules/TelegramUI/TelegramUI/OverlayPlayerControlsNode.swift b/submodules/TelegramUI/Sources/OverlayPlayerControlsNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/OverlayPlayerControlsNode.swift rename to submodules/TelegramUI/Sources/OverlayPlayerControlsNode.swift diff --git a/submodules/TelegramUI/TelegramUI/PaneSearchBarNode.swift b/submodules/TelegramUI/Sources/PaneSearchBarNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/PaneSearchBarNode.swift rename to submodules/TelegramUI/Sources/PaneSearchBarNode.swift diff --git a/submodules/TelegramUI/TelegramUI/PaneSearchBarPlaceholderItem.swift b/submodules/TelegramUI/Sources/PaneSearchBarPlaceholderItem.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/PaneSearchBarPlaceholderItem.swift rename to submodules/TelegramUI/Sources/PaneSearchBarPlaceholderItem.swift diff --git a/submodules/TelegramUI/TelegramUI/PaneSearchContainerNode.swift b/submodules/TelegramUI/Sources/PaneSearchContainerNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/PaneSearchContainerNode.swift rename to submodules/TelegramUI/Sources/PaneSearchContainerNode.swift diff --git a/submodules/TelegramUI/TelegramUI/Pasteboard.swift b/submodules/TelegramUI/Sources/Pasteboard.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/Pasteboard.swift rename to submodules/TelegramUI/Sources/Pasteboard.swift diff --git a/submodules/TelegramUI/TelegramUI/PeerInfo/ListItems/PeerInfoScreenActionItem.swift b/submodules/TelegramUI/Sources/PeerInfo/ListItems/PeerInfoScreenActionItem.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/PeerInfo/ListItems/PeerInfoScreenActionItem.swift rename to submodules/TelegramUI/Sources/PeerInfo/ListItems/PeerInfoScreenActionItem.swift diff --git a/submodules/TelegramUI/TelegramUI/PeerInfo/ListItems/PeerInfoScreenAddressItem.swift b/submodules/TelegramUI/Sources/PeerInfo/ListItems/PeerInfoScreenAddressItem.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/PeerInfo/ListItems/PeerInfoScreenAddressItem.swift rename to submodules/TelegramUI/Sources/PeerInfo/ListItems/PeerInfoScreenAddressItem.swift diff --git a/submodules/TelegramUI/TelegramUI/PeerInfo/ListItems/PeerInfoScreenCallListItem.swift b/submodules/TelegramUI/Sources/PeerInfo/ListItems/PeerInfoScreenCallListItem.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/PeerInfo/ListItems/PeerInfoScreenCallListItem.swift rename to submodules/TelegramUI/Sources/PeerInfo/ListItems/PeerInfoScreenCallListItem.swift diff --git a/submodules/TelegramUI/TelegramUI/PeerInfo/ListItems/PeerInfoScreenCommentItem.swift b/submodules/TelegramUI/Sources/PeerInfo/ListItems/PeerInfoScreenCommentItem.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/PeerInfo/ListItems/PeerInfoScreenCommentItem.swift rename to submodules/TelegramUI/Sources/PeerInfo/ListItems/PeerInfoScreenCommentItem.swift diff --git a/submodules/TelegramUI/TelegramUI/PeerInfo/ListItems/PeerInfoScreenDisclosureEncryptionKeyItem.swift b/submodules/TelegramUI/Sources/PeerInfo/ListItems/PeerInfoScreenDisclosureEncryptionKeyItem.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/PeerInfo/ListItems/PeerInfoScreenDisclosureEncryptionKeyItem.swift rename to submodules/TelegramUI/Sources/PeerInfo/ListItems/PeerInfoScreenDisclosureEncryptionKeyItem.swift diff --git a/submodules/TelegramUI/TelegramUI/PeerInfo/ListItems/PeerInfoScreenDisclosureItem.swift b/submodules/TelegramUI/Sources/PeerInfo/ListItems/PeerInfoScreenDisclosureItem.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/PeerInfo/ListItems/PeerInfoScreenDisclosureItem.swift rename to submodules/TelegramUI/Sources/PeerInfo/ListItems/PeerInfoScreenDisclosureItem.swift diff --git a/submodules/TelegramUI/TelegramUI/PeerInfo/ListItems/PeerInfoScreenHeaderItem.swift b/submodules/TelegramUI/Sources/PeerInfo/ListItems/PeerInfoScreenHeaderItem.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/PeerInfo/ListItems/PeerInfoScreenHeaderItem.swift rename to submodules/TelegramUI/Sources/PeerInfo/ListItems/PeerInfoScreenHeaderItem.swift diff --git a/submodules/TelegramUI/TelegramUI/PeerInfo/ListItems/PeerInfoScreenLabeledValueItem.swift b/submodules/TelegramUI/Sources/PeerInfo/ListItems/PeerInfoScreenLabeledValueItem.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/PeerInfo/ListItems/PeerInfoScreenLabeledValueItem.swift rename to submodules/TelegramUI/Sources/PeerInfo/ListItems/PeerInfoScreenLabeledValueItem.swift diff --git a/submodules/TelegramUI/TelegramUI/PeerInfo/ListItems/PeerInfoScreenMemberItem.swift b/submodules/TelegramUI/Sources/PeerInfo/ListItems/PeerInfoScreenMemberItem.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/PeerInfo/ListItems/PeerInfoScreenMemberItem.swift rename to submodules/TelegramUI/Sources/PeerInfo/ListItems/PeerInfoScreenMemberItem.swift diff --git a/submodules/TelegramUI/TelegramUI/PeerInfo/ListItems/PeerInfoScreenSelectableBackgroundNode.swift b/submodules/TelegramUI/Sources/PeerInfo/ListItems/PeerInfoScreenSelectableBackgroundNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/PeerInfo/ListItems/PeerInfoScreenSelectableBackgroundNode.swift rename to submodules/TelegramUI/Sources/PeerInfo/ListItems/PeerInfoScreenSelectableBackgroundNode.swift diff --git a/submodules/TelegramUI/TelegramUI/PeerInfo/ListItems/PeerInfoScreenSwitchItem.swift b/submodules/TelegramUI/Sources/PeerInfo/ListItems/PeerInfoScreenSwitchItem.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/PeerInfo/ListItems/PeerInfoScreenSwitchItem.swift rename to submodules/TelegramUI/Sources/PeerInfo/ListItems/PeerInfoScreenSwitchItem.swift diff --git a/submodules/TelegramUI/TelegramUI/PeerInfo/Panes/PeerInfoGroupsInCommonPaneNode.swift b/submodules/TelegramUI/Sources/PeerInfo/Panes/PeerInfoGroupsInCommonPaneNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/PeerInfo/Panes/PeerInfoGroupsInCommonPaneNode.swift rename to submodules/TelegramUI/Sources/PeerInfo/Panes/PeerInfoGroupsInCommonPaneNode.swift diff --git a/submodules/TelegramUI/TelegramUI/PeerInfo/Panes/PeerInfoListPaneNode.swift b/submodules/TelegramUI/Sources/PeerInfo/Panes/PeerInfoListPaneNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/PeerInfo/Panes/PeerInfoListPaneNode.swift rename to submodules/TelegramUI/Sources/PeerInfo/Panes/PeerInfoListPaneNode.swift diff --git a/submodules/TelegramUI/TelegramUI/PeerInfo/Panes/PeerInfoMembersPane.swift b/submodules/TelegramUI/Sources/PeerInfo/Panes/PeerInfoMembersPane.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/PeerInfo/Panes/PeerInfoMembersPane.swift rename to submodules/TelegramUI/Sources/PeerInfo/Panes/PeerInfoMembersPane.swift diff --git a/submodules/TelegramUI/TelegramUI/PeerInfo/Panes/PeerInfoVisualMediaPaneNode.swift b/submodules/TelegramUI/Sources/PeerInfo/Panes/PeerInfoVisualMediaPaneNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/PeerInfo/Panes/PeerInfoVisualMediaPaneNode.swift rename to submodules/TelegramUI/Sources/PeerInfo/Panes/PeerInfoVisualMediaPaneNode.swift diff --git a/submodules/TelegramUI/TelegramUI/PeerInfo/PeerInfoData.swift b/submodules/TelegramUI/Sources/PeerInfo/PeerInfoData.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/PeerInfo/PeerInfoData.swift rename to submodules/TelegramUI/Sources/PeerInfo/PeerInfoData.swift diff --git a/submodules/TelegramUI/TelegramUI/PeerInfo/PeerInfoHeaderNode.swift b/submodules/TelegramUI/Sources/PeerInfo/PeerInfoHeaderNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/PeerInfo/PeerInfoHeaderNode.swift rename to submodules/TelegramUI/Sources/PeerInfo/PeerInfoHeaderNode.swift diff --git a/submodules/TelegramUI/TelegramUI/PeerInfo/PeerInfoMembers.swift b/submodules/TelegramUI/Sources/PeerInfo/PeerInfoMembers.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/PeerInfo/PeerInfoMembers.swift rename to submodules/TelegramUI/Sources/PeerInfo/PeerInfoMembers.swift diff --git a/submodules/TelegramUI/TelegramUI/PeerInfo/PeerInfoPaneContainerNode.swift b/submodules/TelegramUI/Sources/PeerInfo/PeerInfoPaneContainerNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/PeerInfo/PeerInfoPaneContainerNode.swift rename to submodules/TelegramUI/Sources/PeerInfo/PeerInfoPaneContainerNode.swift diff --git a/submodules/TelegramUI/TelegramUI/PeerInfo/PeerInfoScreen.swift b/submodules/TelegramUI/Sources/PeerInfo/PeerInfoScreen.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/PeerInfo/PeerInfoScreen.swift rename to submodules/TelegramUI/Sources/PeerInfo/PeerInfoScreen.swift diff --git a/submodules/TelegramUI/TelegramUI/PeerMediaCollectionController.swift b/submodules/TelegramUI/Sources/PeerMediaCollectionController.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/PeerMediaCollectionController.swift rename to submodules/TelegramUI/Sources/PeerMediaCollectionController.swift diff --git a/submodules/TelegramUI/TelegramUI/PeerMediaCollectionControllerNode.swift b/submodules/TelegramUI/Sources/PeerMediaCollectionControllerNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/PeerMediaCollectionControllerNode.swift rename to submodules/TelegramUI/Sources/PeerMediaCollectionControllerNode.swift diff --git a/submodules/TelegramUI/TelegramUI/PeerMediaCollectionEmptyNode.swift b/submodules/TelegramUI/Sources/PeerMediaCollectionEmptyNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/PeerMediaCollectionEmptyNode.swift rename to submodules/TelegramUI/Sources/PeerMediaCollectionEmptyNode.swift diff --git a/submodules/TelegramUI/TelegramUI/PeerMediaCollectionInterfaceState.swift b/submodules/TelegramUI/Sources/PeerMediaCollectionInterfaceState.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/PeerMediaCollectionInterfaceState.swift rename to submodules/TelegramUI/Sources/PeerMediaCollectionInterfaceState.swift diff --git a/submodules/TelegramUI/TelegramUI/PeerMediaCollectionInterfaceStateButtons.swift b/submodules/TelegramUI/Sources/PeerMediaCollectionInterfaceStateButtons.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/PeerMediaCollectionInterfaceStateButtons.swift rename to submodules/TelegramUI/Sources/PeerMediaCollectionInterfaceStateButtons.swift diff --git a/submodules/TelegramUI/TelegramUI/PeerMediaCollectionSectionsNode.swift b/submodules/TelegramUI/Sources/PeerMediaCollectionSectionsNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/PeerMediaCollectionSectionsNode.swift rename to submodules/TelegramUI/Sources/PeerMediaCollectionSectionsNode.swift diff --git a/submodules/TelegramUI/TelegramUI/PeerMessagesMediaPlaylist.swift b/submodules/TelegramUI/Sources/PeerMessagesMediaPlaylist.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/PeerMessagesMediaPlaylist.swift rename to submodules/TelegramUI/Sources/PeerMessagesMediaPlaylist.swift diff --git a/submodules/TelegramUI/TelegramUI/PeerSelectionController.swift b/submodules/TelegramUI/Sources/PeerSelectionController.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/PeerSelectionController.swift rename to submodules/TelegramUI/Sources/PeerSelectionController.swift diff --git a/submodules/TelegramUI/TelegramUI/PeerSelectionControllerNode.swift b/submodules/TelegramUI/Sources/PeerSelectionControllerNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/PeerSelectionControllerNode.swift rename to submodules/TelegramUI/Sources/PeerSelectionControllerNode.swift diff --git a/submodules/TelegramUI/TelegramUI/PeersNearbyManager.swift b/submodules/TelegramUI/Sources/PeersNearbyManager.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/PeersNearbyManager.swift rename to submodules/TelegramUI/Sources/PeersNearbyManager.swift diff --git a/submodules/TelegramUI/TelegramUI/PollResultsController.swift b/submodules/TelegramUI/Sources/PollResultsController.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/PollResultsController.swift rename to submodules/TelegramUI/Sources/PollResultsController.swift diff --git a/submodules/TelegramUI/TelegramUI/PrefetchManager.swift b/submodules/TelegramUI/Sources/PrefetchManager.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/PrefetchManager.swift rename to submodules/TelegramUI/Sources/PrefetchManager.swift diff --git a/submodules/TelegramUI/TelegramUI/PrepareSecretThumbnailData.swift b/submodules/TelegramUI/Sources/PrepareSecretThumbnailData.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/PrepareSecretThumbnailData.swift rename to submodules/TelegramUI/Sources/PrepareSecretThumbnailData.swift diff --git a/submodules/TelegramUI/TelegramUI/PreparedChatHistoryViewTransition.swift b/submodules/TelegramUI/Sources/PreparedChatHistoryViewTransition.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/PreparedChatHistoryViewTransition.swift rename to submodules/TelegramUI/Sources/PreparedChatHistoryViewTransition.swift diff --git a/submodules/TelegramUI/TelegramUI/ProcessedPeerRestrictionText.swift b/submodules/TelegramUI/Sources/ProcessedPeerRestrictionText.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ProcessedPeerRestrictionText.swift rename to submodules/TelegramUI/Sources/ProcessedPeerRestrictionText.swift diff --git a/submodules/TelegramUI/TelegramUI/RadialProgressNode.swift b/submodules/TelegramUI/Sources/RadialProgressNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/RadialProgressNode.swift rename to submodules/TelegramUI/Sources/RadialProgressNode.swift diff --git a/submodules/TelegramUI/TelegramUI/RadialTimeoutNode.swift b/submodules/TelegramUI/Sources/RadialTimeoutNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/RadialTimeoutNode.swift rename to submodules/TelegramUI/Sources/RadialTimeoutNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ReplyAccessoryPanelNode.swift b/submodules/TelegramUI/Sources/ReplyAccessoryPanelNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ReplyAccessoryPanelNode.swift rename to submodules/TelegramUI/Sources/ReplyAccessoryPanelNode.swift diff --git a/submodules/TelegramUI/TelegramUI/Resources/Animations/ChatListEmpty.tgs b/submodules/TelegramUI/Sources/Resources/Animations/ChatListEmpty.tgs similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/Animations/ChatListEmpty.tgs rename to submodules/TelegramUI/Sources/Resources/Animations/ChatListEmpty.tgs diff --git a/submodules/TelegramUI/TelegramUI/Resources/Animations/ChatListFilterEmpty.tgs b/submodules/TelegramUI/Sources/Resources/Animations/ChatListFilterEmpty.tgs similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/Animations/ChatListFilterEmpty.tgs rename to submodules/TelegramUI/Sources/Resources/Animations/ChatListFilterEmpty.tgs diff --git a/submodules/TelegramUI/TelegramUI/Resources/Animations/anim_archive.json b/submodules/TelegramUI/Sources/Resources/Animations/anim_archive.json similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/Animations/anim_archive.json rename to submodules/TelegramUI/Sources/Resources/Animations/anim_archive.json diff --git a/submodules/TelegramUI/TelegramUI/Resources/Animations/anim_archiveAvatar.json b/submodules/TelegramUI/Sources/Resources/Animations/anim_archiveAvatar.json similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/Animations/anim_archiveAvatar.json rename to submodules/TelegramUI/Sources/Resources/Animations/anim_archiveAvatar.json diff --git a/submodules/TelegramUI/TelegramUI/Resources/Animations/anim_archiveswipe.json b/submodules/TelegramUI/Sources/Resources/Animations/anim_archiveswipe.json similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/Animations/anim_archiveswipe.json rename to submodules/TelegramUI/Sources/Resources/Animations/anim_archiveswipe.json diff --git a/submodules/TelegramUI/TelegramUI/Resources/Animations/anim_delete.json b/submodules/TelegramUI/Sources/Resources/Animations/anim_delete.json similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/Animations/anim_delete.json rename to submodules/TelegramUI/Sources/Resources/Animations/anim_delete.json diff --git a/submodules/TelegramUI/TelegramUI/Resources/Animations/anim_group.json b/submodules/TelegramUI/Sources/Resources/Animations/anim_group.json similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/Animations/anim_group.json rename to submodules/TelegramUI/Sources/Resources/Animations/anim_group.json diff --git a/submodules/TelegramUI/TelegramUI/Resources/Animations/anim_hide.json b/submodules/TelegramUI/Sources/Resources/Animations/anim_hide.json similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/Animations/anim_hide.json rename to submodules/TelegramUI/Sources/Resources/Animations/anim_hide.json diff --git a/submodules/TelegramUI/TelegramUI/Resources/Animations/anim_infotip.json b/submodules/TelegramUI/Sources/Resources/Animations/anim_infotip.json similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/Animations/anim_infotip.json rename to submodules/TelegramUI/Sources/Resources/Animations/anim_infotip.json diff --git a/submodules/TelegramUI/TelegramUI/Resources/Animations/anim_mute.json b/submodules/TelegramUI/Sources/Resources/Animations/anim_mute.json similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/Animations/anim_mute.json rename to submodules/TelegramUI/Sources/Resources/Animations/anim_mute.json diff --git a/submodules/TelegramUI/TelegramUI/Resources/Animations/anim_pin.json b/submodules/TelegramUI/Sources/Resources/Animations/anim_pin.json similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/Animations/anim_pin.json rename to submodules/TelegramUI/Sources/Resources/Animations/anim_pin.json diff --git a/submodules/TelegramUI/TelegramUI/Resources/Animations/anim_qr.json b/submodules/TelegramUI/Sources/Resources/Animations/anim_qr.json similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/Animations/anim_qr.json rename to submodules/TelegramUI/Sources/Resources/Animations/anim_qr.json diff --git a/submodules/TelegramUI/TelegramUI/Resources/Animations/anim_read.json b/submodules/TelegramUI/Sources/Resources/Animations/anim_read.json similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/Animations/anim_read.json rename to submodules/TelegramUI/Sources/Resources/Animations/anim_read.json diff --git a/submodules/TelegramUI/TelegramUI/Resources/Animations/anim_success.json b/submodules/TelegramUI/Sources/Resources/Animations/anim_success.json similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/Animations/anim_success.json rename to submodules/TelegramUI/Sources/Resources/Animations/anim_success.json diff --git a/submodules/TelegramUI/TelegramUI/Resources/Animations/anim_swipereply.json b/submodules/TelegramUI/Sources/Resources/Animations/anim_swipereply.json similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/Animations/anim_swipereply.json rename to submodules/TelegramUI/Sources/Resources/Animations/anim_swipereply.json diff --git a/submodules/TelegramUI/TelegramUI/Resources/Animations/anim_unarchive.json b/submodules/TelegramUI/Sources/Resources/Animations/anim_unarchive.json similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/Animations/anim_unarchive.json rename to submodules/TelegramUI/Sources/Resources/Animations/anim_unarchive.json diff --git a/submodules/TelegramUI/TelegramUI/Resources/Animations/anim_ungroup.json b/submodules/TelegramUI/Sources/Resources/Animations/anim_ungroup.json similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/Animations/anim_ungroup.json rename to submodules/TelegramUI/Sources/Resources/Animations/anim_ungroup.json diff --git a/submodules/TelegramUI/TelegramUI/Resources/Animations/anim_unmute.json b/submodules/TelegramUI/Sources/Resources/Animations/anim_unmute.json similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/Animations/anim_unmute.json rename to submodules/TelegramUI/Sources/Resources/Animations/anim_unmute.json diff --git a/submodules/TelegramUI/TelegramUI/Resources/Animations/anim_unpin.json b/submodules/TelegramUI/Sources/Resources/Animations/anim_unpin.json similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/Animations/anim_unpin.json rename to submodules/TelegramUI/Sources/Resources/Animations/anim_unpin.json diff --git a/submodules/TelegramUI/TelegramUI/Resources/Animations/anim_unread.json b/submodules/TelegramUI/Sources/Resources/Animations/anim_unread.json similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/Animations/anim_unread.json rename to submodules/TelegramUI/Sources/Resources/Animations/anim_unread.json diff --git a/submodules/TelegramUI/TelegramUI/Resources/BuiltinReactions/celebrate.tgs b/submodules/TelegramUI/Sources/Resources/BuiltinReactions/celebrate.tgs similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/BuiltinReactions/celebrate.tgs rename to submodules/TelegramUI/Sources/Resources/BuiltinReactions/celebrate.tgs diff --git a/submodules/TelegramUI/TelegramUI/Resources/BuiltinReactions/cry.tgs b/submodules/TelegramUI/Sources/Resources/BuiltinReactions/cry.tgs similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/BuiltinReactions/cry.tgs rename to submodules/TelegramUI/Sources/Resources/BuiltinReactions/cry.tgs diff --git a/submodules/TelegramUI/TelegramUI/Resources/BuiltinReactions/heart.tgs b/submodules/TelegramUI/Sources/Resources/BuiltinReactions/heart.tgs similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/BuiltinReactions/heart.tgs rename to submodules/TelegramUI/Sources/Resources/BuiltinReactions/heart.tgs diff --git a/submodules/TelegramUI/TelegramUI/Resources/BuiltinReactions/lol.tgs b/submodules/TelegramUI/Sources/Resources/BuiltinReactions/lol.tgs similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/BuiltinReactions/lol.tgs rename to submodules/TelegramUI/Sources/Resources/BuiltinReactions/lol.tgs diff --git a/submodules/TelegramUI/TelegramUI/Resources/BuiltinReactions/meh.tgs b/submodules/TelegramUI/Sources/Resources/BuiltinReactions/meh.tgs similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/BuiltinReactions/meh.tgs rename to submodules/TelegramUI/Sources/Resources/BuiltinReactions/meh.tgs diff --git a/submodules/TelegramUI/TelegramUI/Resources/BuiltinReactions/ok.tgs b/submodules/TelegramUI/Sources/Resources/BuiltinReactions/ok.tgs similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/BuiltinReactions/ok.tgs rename to submodules/TelegramUI/Sources/Resources/BuiltinReactions/ok.tgs diff --git a/submodules/TelegramUI/TelegramUI/Resources/BuiltinReactions/poker.tgs b/submodules/TelegramUI/Sources/Resources/BuiltinReactions/poker.tgs similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/BuiltinReactions/poker.tgs rename to submodules/TelegramUI/Sources/Resources/BuiltinReactions/poker.tgs diff --git a/submodules/TelegramUI/TelegramUI/Resources/BuiltinReactions/poop.tgs b/submodules/TelegramUI/Sources/Resources/BuiltinReactions/poop.tgs similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/BuiltinReactions/poop.tgs rename to submodules/TelegramUI/Sources/Resources/BuiltinReactions/poop.tgs diff --git a/submodules/TelegramUI/TelegramUI/Resources/BuiltinReactions/sad.tgs b/submodules/TelegramUI/Sources/Resources/BuiltinReactions/sad.tgs similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/BuiltinReactions/sad.tgs rename to submodules/TelegramUI/Sources/Resources/BuiltinReactions/sad.tgs diff --git a/submodules/TelegramUI/TelegramUI/Resources/BuiltinReactions/smile.tgs b/submodules/TelegramUI/Sources/Resources/BuiltinReactions/smile.tgs similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/BuiltinReactions/smile.tgs rename to submodules/TelegramUI/Sources/Resources/BuiltinReactions/smile.tgs diff --git a/submodules/TelegramUI/TelegramUI/Resources/BuiltinReactions/surprised.tgs b/submodules/TelegramUI/Sources/Resources/BuiltinReactions/surprised.tgs similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/BuiltinReactions/surprised.tgs rename to submodules/TelegramUI/Sources/Resources/BuiltinReactions/surprised.tgs diff --git a/submodules/TelegramUI/TelegramUI/Resources/BuiltinReactions/thumbsup.tgs b/submodules/TelegramUI/Sources/Resources/BuiltinReactions/thumbsup.tgs similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/BuiltinReactions/thumbsup.tgs rename to submodules/TelegramUI/Sources/Resources/BuiltinReactions/thumbsup.tgs diff --git a/submodules/TelegramUI/TelegramUI/Resources/ChatWallpaperBuiltin0.jpg b/submodules/TelegramUI/Sources/Resources/ChatWallpaperBuiltin0.jpg similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/ChatWallpaperBuiltin0.jpg rename to submodules/TelegramUI/Sources/Resources/ChatWallpaperBuiltin0.jpg diff --git a/submodules/TelegramUI/TelegramUI/Resources/Emoji.mapping b/submodules/TelegramUI/Sources/Resources/Emoji.mapping similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/Emoji.mapping rename to submodules/TelegramUI/Sources/Resources/Emoji.mapping diff --git a/submodules/TelegramUI/TelegramUI/Resources/Fonts/SFCompactRounded-Semibold.otf b/submodules/TelegramUI/Sources/Resources/Fonts/SFCompactRounded-Semibold.otf similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/Fonts/SFCompactRounded-Semibold.otf rename to submodules/TelegramUI/Sources/Resources/Fonts/SFCompactRounded-Semibold.otf diff --git a/submodules/TelegramUI/TelegramUI/Resources/PhoneCountries.txt b/submodules/TelegramUI/Sources/Resources/PhoneCountries.txt similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/PhoneCountries.txt rename to submodules/TelegramUI/Sources/Resources/PhoneCountries.txt diff --git a/submodules/TelegramUI/TelegramUI/Resources/PresentationStrings.mapping b/submodules/TelegramUI/Sources/Resources/PresentationStrings.mapping similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/PresentationStrings.mapping rename to submodules/TelegramUI/Sources/Resources/PresentationStrings.mapping diff --git a/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_10@2x.png b/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_10@2x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_10@2x.png rename to submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_10@2x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_10@3x.png b/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_10@3x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_10@3x.png rename to submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_10@3x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_11@2x.png b/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_11@2x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_11@2x.png rename to submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_11@2x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_11@3x.png b/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_11@3x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_11@3x.png rename to submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_11@3x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_12@2x.png b/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_12@2x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_12@2x.png rename to submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_12@2x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_12@3x.png b/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_12@3x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_12@3x.png rename to submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_12@3x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_13@2x.png b/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_13@2x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_13@2x.png rename to submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_13@2x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_13@3x.png b/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_13@3x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_13@3x.png rename to submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_13@3x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_14@2x.png b/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_14@2x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_14@2x.png rename to submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_14@2x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_14@3x.png b/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_14@3x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_14@3x.png rename to submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_14@3x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_15@2x.png b/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_15@2x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_15@2x.png rename to submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_15@2x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_15@3x.png b/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_15@3x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_15@3x.png rename to submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_15@3x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_16@2x.png b/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_16@2x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_16@2x.png rename to submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_16@2x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_16@3x.png b/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_16@3x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_16@3x.png rename to submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_16@3x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_17@2x.png b/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_17@2x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_17@2x.png rename to submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_17@2x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_17@3x.png b/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_17@3x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_17@3x.png rename to submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_17@3x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_18@2x.png b/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_18@2x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_18@2x.png rename to submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_18@2x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_18@3x.png b/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_18@3x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_18@3x.png rename to submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_18@3x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_19@2x.png b/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_19@2x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_19@2x.png rename to submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_19@2x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_19@3x.png b/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_19@3x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_19@3x.png rename to submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_19@3x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_1@2x.png b/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_1@2x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_1@2x.png rename to submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_1@2x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_1@3x.png b/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_1@3x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_1@3x.png rename to submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_1@3x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_20@2x.png b/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_20@2x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_20@2x.png rename to submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_20@2x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_20@3x.png b/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_20@3x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_20@3x.png rename to submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_20@3x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_2@2x.png b/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_2@2x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_2@2x.png rename to submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_2@2x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_2@3x.png b/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_2@3x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_2@3x.png rename to submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_2@3x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_3@2x.png b/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_3@2x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_3@2x.png rename to submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_3@2x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_3@3x.png b/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_3@3x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_3@3x.png rename to submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_3@3x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_4@2x.png b/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_4@2x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_4@2x.png rename to submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_4@2x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_4@3x.png b/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_4@3x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_4@3x.png rename to submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_4@3x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_5@2x.png b/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_5@2x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_5@2x.png rename to submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_5@2x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_5@3x.png b/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_5@3x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_5@3x.png rename to submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_5@3x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_6@2x.png b/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_6@2x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_6@2x.png rename to submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_6@2x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_6@3x.png b/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_6@3x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_6@3x.png rename to submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_6@3x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_7@2x.png b/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_7@2x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_7@2x.png rename to submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_7@2x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_7@3x.png b/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_7@3x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_7@3x.png rename to submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_7@3x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_8@2x.png b/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_8@2x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_8@2x.png rename to submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_8@2x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_8@3x.png b/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_8@3x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_8@3x.png rename to submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_8@3x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_9@2x.png b/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_9@2x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_9@2x.png rename to submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_9@2x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_9@3x.png b/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_9@3x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_9@3x.png rename to submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_9@3x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_amex@2x.png b/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_amex@2x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_amex@2x.png rename to submodules/TelegramUI/Sources/Resources/Stripe/stp_card_amex@2x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_amex@3x.png b/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_amex@3x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_amex@3x.png rename to submodules/TelegramUI/Sources/Resources/Stripe/stp_card_amex@3x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_amex_template@2x.png b/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_amex_template@2x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_amex_template@2x.png rename to submodules/TelegramUI/Sources/Resources/Stripe/stp_card_amex_template@2x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_amex_template@3x.png b/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_amex_template@3x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_amex_template@3x.png rename to submodules/TelegramUI/Sources/Resources/Stripe/stp_card_amex_template@3x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_applepay@2x.png b/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_applepay@2x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_applepay@2x.png rename to submodules/TelegramUI/Sources/Resources/Stripe/stp_card_applepay@2x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_applepay@3x.png b/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_applepay@3x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_applepay@3x.png rename to submodules/TelegramUI/Sources/Resources/Stripe/stp_card_applepay@3x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_applepay_template@2x.png b/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_applepay_template@2x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_applepay_template@2x.png rename to submodules/TelegramUI/Sources/Resources/Stripe/stp_card_applepay_template@2x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_applepay_template@3x.png b/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_applepay_template@3x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_applepay_template@3x.png rename to submodules/TelegramUI/Sources/Resources/Stripe/stp_card_applepay_template@3x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_cvc@2x.png b/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_cvc@2x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_cvc@2x.png rename to submodules/TelegramUI/Sources/Resources/Stripe/stp_card_cvc@2x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_cvc@3x.png b/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_cvc@3x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_cvc@3x.png rename to submodules/TelegramUI/Sources/Resources/Stripe/stp_card_cvc@3x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_cvc_amex@2x.png b/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_cvc_amex@2x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_cvc_amex@2x.png rename to submodules/TelegramUI/Sources/Resources/Stripe/stp_card_cvc_amex@2x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_cvc_amex@3x.png b/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_cvc_amex@3x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_cvc_amex@3x.png rename to submodules/TelegramUI/Sources/Resources/Stripe/stp_card_cvc_amex@3x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_diners@2x.png b/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_diners@2x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_diners@2x.png rename to submodules/TelegramUI/Sources/Resources/Stripe/stp_card_diners@2x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_diners@3x.png b/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_diners@3x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_diners@3x.png rename to submodules/TelegramUI/Sources/Resources/Stripe/stp_card_diners@3x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_diners_template@2x.png b/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_diners_template@2x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_diners_template@2x.png rename to submodules/TelegramUI/Sources/Resources/Stripe/stp_card_diners_template@2x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_diners_template@3x.png b/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_diners_template@3x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_diners_template@3x.png rename to submodules/TelegramUI/Sources/Resources/Stripe/stp_card_diners_template@3x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_discover@2x.png b/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_discover@2x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_discover@2x.png rename to submodules/TelegramUI/Sources/Resources/Stripe/stp_card_discover@2x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_discover@3x.png b/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_discover@3x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_discover@3x.png rename to submodules/TelegramUI/Sources/Resources/Stripe/stp_card_discover@3x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_discover_template@2x.png b/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_discover_template@2x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_discover_template@2x.png rename to submodules/TelegramUI/Sources/Resources/Stripe/stp_card_discover_template@2x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_discover_template@3x.png b/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_discover_template@3x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_discover_template@3x.png rename to submodules/TelegramUI/Sources/Resources/Stripe/stp_card_discover_template@3x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_form_applepay@2x.png b/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_form_applepay@2x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_form_applepay@2x.png rename to submodules/TelegramUI/Sources/Resources/Stripe/stp_card_form_applepay@2x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_form_applepay@3x.png b/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_form_applepay@3x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_form_applepay@3x.png rename to submodules/TelegramUI/Sources/Resources/Stripe/stp_card_form_applepay@3x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_form_back@2x.png b/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_form_back@2x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_form_back@2x.png rename to submodules/TelegramUI/Sources/Resources/Stripe/stp_card_form_back@2x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_form_back@3x.png b/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_form_back@3x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_form_back@3x.png rename to submodules/TelegramUI/Sources/Resources/Stripe/stp_card_form_back@3x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_form_front@2x.png b/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_form_front@2x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_form_front@2x.png rename to submodules/TelegramUI/Sources/Resources/Stripe/stp_card_form_front@2x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_form_front@3x.png b/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_form_front@3x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_form_front@3x.png rename to submodules/TelegramUI/Sources/Resources/Stripe/stp_card_form_front@3x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_jcb@2x.png b/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_jcb@2x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_jcb@2x.png rename to submodules/TelegramUI/Sources/Resources/Stripe/stp_card_jcb@2x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_jcb@3x.png b/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_jcb@3x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_jcb@3x.png rename to submodules/TelegramUI/Sources/Resources/Stripe/stp_card_jcb@3x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_jcb_template@2x.png b/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_jcb_template@2x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_jcb_template@2x.png rename to submodules/TelegramUI/Sources/Resources/Stripe/stp_card_jcb_template@2x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_jcb_template@3x.png b/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_jcb_template@3x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_jcb_template@3x.png rename to submodules/TelegramUI/Sources/Resources/Stripe/stp_card_jcb_template@3x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_mastercard@2x.png b/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_mastercard@2x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_mastercard@2x.png rename to submodules/TelegramUI/Sources/Resources/Stripe/stp_card_mastercard@2x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_mastercard@3x.png b/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_mastercard@3x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_mastercard@3x.png rename to submodules/TelegramUI/Sources/Resources/Stripe/stp_card_mastercard@3x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_mastercard_template@2x.png b/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_mastercard_template@2x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_mastercard_template@2x.png rename to submodules/TelegramUI/Sources/Resources/Stripe/stp_card_mastercard_template@2x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_mastercard_template@3x.png b/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_mastercard_template@3x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_mastercard_template@3x.png rename to submodules/TelegramUI/Sources/Resources/Stripe/stp_card_mastercard_template@3x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_placeholder_template@2x.png b/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_placeholder_template@2x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_placeholder_template@2x.png rename to submodules/TelegramUI/Sources/Resources/Stripe/stp_card_placeholder_template@2x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_placeholder_template@3x.png b/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_placeholder_template@3x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_placeholder_template@3x.png rename to submodules/TelegramUI/Sources/Resources/Stripe/stp_card_placeholder_template@3x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_visa@2x.png b/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_visa@2x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_visa@2x.png rename to submodules/TelegramUI/Sources/Resources/Stripe/stp_card_visa@2x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_visa@3x.png b/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_visa@3x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_visa@3x.png rename to submodules/TelegramUI/Sources/Resources/Stripe/stp_card_visa@3x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_visa_template@2x.png b/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_visa_template@2x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_visa_template@2x.png rename to submodules/TelegramUI/Sources/Resources/Stripe/stp_card_visa_template@2x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_visa_template@3x.png b/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_visa_template@3x.png similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_visa_template@3x.png rename to submodules/TelegramUI/Sources/Resources/Stripe/stp_card_visa_template@3x.png diff --git a/submodules/TelegramUI/TelegramUI/Resources/WebEmbed/Generic.html b/submodules/TelegramUI/Sources/Resources/WebEmbed/Generic.html similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/WebEmbed/Generic.html rename to submodules/TelegramUI/Sources/Resources/WebEmbed/Generic.html diff --git a/submodules/TelegramUI/TelegramUI/Resources/WebEmbed/GenericUserScript.js b/submodules/TelegramUI/Sources/Resources/WebEmbed/GenericUserScript.js similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/WebEmbed/GenericUserScript.js rename to submodules/TelegramUI/Sources/Resources/WebEmbed/GenericUserScript.js diff --git a/submodules/TelegramUI/TelegramUI/Resources/WebEmbed/Instagram.html b/submodules/TelegramUI/Sources/Resources/WebEmbed/Instagram.html similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/WebEmbed/Instagram.html rename to submodules/TelegramUI/Sources/Resources/WebEmbed/Instagram.html diff --git a/submodules/TelegramUI/TelegramUI/Resources/WebEmbed/Twitch.html b/submodules/TelegramUI/Sources/Resources/WebEmbed/Twitch.html similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/WebEmbed/Twitch.html rename to submodules/TelegramUI/Sources/Resources/WebEmbed/Twitch.html diff --git a/submodules/TelegramUI/TelegramUI/Resources/WebEmbed/TwitchUserScript.js b/submodules/TelegramUI/Sources/Resources/WebEmbed/TwitchUserScript.js similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/WebEmbed/TwitchUserScript.js rename to submodules/TelegramUI/Sources/Resources/WebEmbed/TwitchUserScript.js diff --git a/submodules/TelegramUI/TelegramUI/Resources/WebEmbed/Vimeo.html b/submodules/TelegramUI/Sources/Resources/WebEmbed/Vimeo.html similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/WebEmbed/Vimeo.html rename to submodules/TelegramUI/Sources/Resources/WebEmbed/Vimeo.html diff --git a/submodules/TelegramUI/TelegramUI/Resources/WebEmbed/VimeoUserScript.js b/submodules/TelegramUI/Sources/Resources/WebEmbed/VimeoUserScript.js similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/WebEmbed/VimeoUserScript.js rename to submodules/TelegramUI/Sources/Resources/WebEmbed/VimeoUserScript.js diff --git a/submodules/TelegramUI/TelegramUI/Resources/WebEmbed/Youtube.html b/submodules/TelegramUI/Sources/Resources/WebEmbed/Youtube.html similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/WebEmbed/Youtube.html rename to submodules/TelegramUI/Sources/Resources/WebEmbed/Youtube.html diff --git a/submodules/TelegramUI/TelegramUI/Resources/WebEmbed/YoutubeUserScript.js b/submodules/TelegramUI/Sources/Resources/WebEmbed/YoutubeUserScript.js similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/WebEmbed/YoutubeUserScript.js rename to submodules/TelegramUI/Sources/Resources/WebEmbed/YoutubeUserScript.js diff --git a/submodules/TelegramUI/TelegramUI/Resources/currencies.json b/submodules/TelegramUI/Sources/Resources/currencies.json similarity index 100% rename from submodules/TelegramUI/TelegramUI/Resources/currencies.json rename to submodules/TelegramUI/Sources/Resources/currencies.json diff --git a/submodules/TelegramUI/TelegramUI/SampleBufferPool.swift b/submodules/TelegramUI/Sources/SampleBufferPool.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/SampleBufferPool.swift rename to submodules/TelegramUI/Sources/SampleBufferPool.swift diff --git a/submodules/TelegramUI/TelegramUI/SecretChatHandshakeStatusInputPanelNode.swift b/submodules/TelegramUI/Sources/SecretChatHandshakeStatusInputPanelNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/SecretChatHandshakeStatusInputPanelNode.swift rename to submodules/TelegramUI/Sources/SecretChatHandshakeStatusInputPanelNode.swift diff --git a/submodules/TelegramUI/TelegramUI/ServiceSoundManager.swift b/submodules/TelegramUI/Sources/ServiceSoundManager.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ServiceSoundManager.swift rename to submodules/TelegramUI/Sources/ServiceSoundManager.swift diff --git a/submodules/TelegramUI/TelegramUI/ShareExtensionContext.swift b/submodules/TelegramUI/Sources/ShareExtensionContext.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ShareExtensionContext.swift rename to submodules/TelegramUI/Sources/ShareExtensionContext.swift diff --git a/submodules/TelegramUI/TelegramUI/SharedAccountContext.swift b/submodules/TelegramUI/Sources/SharedAccountContext.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/SharedAccountContext.swift rename to submodules/TelegramUI/Sources/SharedAccountContext.swift diff --git a/submodules/TelegramUI/TelegramUI/SharedMediaPlayer.swift b/submodules/TelegramUI/Sources/SharedMediaPlayer.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/SharedMediaPlayer.swift rename to submodules/TelegramUI/Sources/SharedMediaPlayer.swift diff --git a/submodules/TelegramUI/TelegramUI/SharedNotificationManager.swift b/submodules/TelegramUI/Sources/SharedNotificationManager.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/SharedNotificationManager.swift rename to submodules/TelegramUI/Sources/SharedNotificationManager.swift diff --git a/submodules/TelegramUI/TelegramUI/SharedVideoContextManager.swift b/submodules/TelegramUI/Sources/SharedVideoContextManager.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/SharedVideoContextManager.swift rename to submodules/TelegramUI/Sources/SharedVideoContextManager.swift diff --git a/submodules/TelegramUI/TelegramUI/SharedWakeupManager.swift b/submodules/TelegramUI/Sources/SharedWakeupManager.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/SharedWakeupManager.swift rename to submodules/TelegramUI/Sources/SharedWakeupManager.swift diff --git a/submodules/TelegramUI/TelegramUI/SoftwareVideoLayerFrameManager.swift b/submodules/TelegramUI/Sources/SoftwareVideoLayerFrameManager.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/SoftwareVideoLayerFrameManager.swift rename to submodules/TelegramUI/Sources/SoftwareVideoLayerFrameManager.swift diff --git a/submodules/TelegramUI/TelegramUI/SoftwareVideoThumbnailLayer.swift b/submodules/TelegramUI/Sources/SoftwareVideoThumbnailLayer.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/SoftwareVideoThumbnailLayer.swift rename to submodules/TelegramUI/Sources/SoftwareVideoThumbnailLayer.swift diff --git a/submodules/TelegramUI/TelegramUI/Sounds/MessageSent.caf b/submodules/TelegramUI/Sources/Sounds/MessageSent.caf similarity index 100% rename from submodules/TelegramUI/TelegramUI/Sounds/MessageSent.caf rename to submodules/TelegramUI/Sources/Sounds/MessageSent.caf diff --git a/submodules/TelegramUI/TelegramUI/Sounds/notification.caf b/submodules/TelegramUI/Sources/Sounds/notification.caf similarity index 100% rename from submodules/TelegramUI/TelegramUI/Sounds/notification.caf rename to submodules/TelegramUI/Sources/Sounds/notification.caf diff --git a/submodules/TelegramUI/TelegramUI/SpotlightContacts.swift b/submodules/TelegramUI/Sources/SpotlightContacts.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/SpotlightContacts.swift rename to submodules/TelegramUI/Sources/SpotlightContacts.swift diff --git a/submodules/TelegramUI/TelegramUI/StickerPanePeerSpecificSetupGridItem.swift b/submodules/TelegramUI/Sources/StickerPanePeerSpecificSetupGridItem.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/StickerPanePeerSpecificSetupGridItem.swift rename to submodules/TelegramUI/Sources/StickerPanePeerSpecificSetupGridItem.swift diff --git a/submodules/TelegramUI/TelegramUI/StickerPaneSearchContentNode.swift b/submodules/TelegramUI/Sources/StickerPaneSearchContentNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/StickerPaneSearchContentNode.swift rename to submodules/TelegramUI/Sources/StickerPaneSearchContentNode.swift diff --git a/submodules/TelegramUI/TelegramUI/StickerPaneSearchGlobaltem.swift b/submodules/TelegramUI/Sources/StickerPaneSearchGlobaltem.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/StickerPaneSearchGlobaltem.swift rename to submodules/TelegramUI/Sources/StickerPaneSearchGlobaltem.swift diff --git a/submodules/TelegramUI/TelegramUI/StickerPaneSearchStickerItem.swift b/submodules/TelegramUI/Sources/StickerPaneSearchStickerItem.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/StickerPaneSearchStickerItem.swift rename to submodules/TelegramUI/Sources/StickerPaneSearchStickerItem.swift diff --git a/submodules/TelegramUI/TelegramUI/StickersChatInputContextPanelItem.swift b/submodules/TelegramUI/Sources/StickersChatInputContextPanelItem.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/StickersChatInputContextPanelItem.swift rename to submodules/TelegramUI/Sources/StickersChatInputContextPanelItem.swift diff --git a/submodules/TelegramUI/TelegramUI/StickersChatInputContextPanelNode.swift b/submodules/TelegramUI/Sources/StickersChatInputContextPanelNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/StickersChatInputContextPanelNode.swift rename to submodules/TelegramUI/Sources/StickersChatInputContextPanelNode.swift diff --git a/submodules/TelegramUI/TelegramUI/StoreDownloadedMedia.swift b/submodules/TelegramUI/Sources/StoreDownloadedMedia.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/StoreDownloadedMedia.swift rename to submodules/TelegramUI/Sources/StoreDownloadedMedia.swift diff --git a/submodules/TelegramUI/TelegramUI/StringForMessageTimestampStatus.swift b/submodules/TelegramUI/Sources/StringForMessageTimestampStatus.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/StringForMessageTimestampStatus.swift rename to submodules/TelegramUI/Sources/StringForMessageTimestampStatus.swift diff --git a/submodules/TelegramUI/TelegramUI/SuppressContactsWarning.swift b/submodules/TelegramUI/Sources/SuppressContactsWarning.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/SuppressContactsWarning.swift rename to submodules/TelegramUI/Sources/SuppressContactsWarning.swift diff --git a/submodules/TelegramUI/TelegramUI/TelegramAccountAuxiliaryMethods.swift b/submodules/TelegramUI/Sources/TelegramAccountAuxiliaryMethods.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/TelegramAccountAuxiliaryMethods.swift rename to submodules/TelegramUI/Sources/TelegramAccountAuxiliaryMethods.swift diff --git a/submodules/TelegramUI/TelegramUI/TelegramRootController.swift b/submodules/TelegramUI/Sources/TelegramRootController.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/TelegramRootController.swift rename to submodules/TelegramUI/Sources/TelegramRootController.swift diff --git a/submodules/TelegramUI/TelegramUI/TelegramUI.h b/submodules/TelegramUI/Sources/TelegramUI.h similarity index 100% rename from submodules/TelegramUI/TelegramUI/TelegramUI.h rename to submodules/TelegramUI/Sources/TelegramUI.h diff --git a/submodules/TelegramUI/TelegramUI/TextLinkHandling.swift b/submodules/TelegramUI/Sources/TextLinkHandling.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/TextLinkHandling.swift rename to submodules/TelegramUI/Sources/TextLinkHandling.swift diff --git a/submodules/TelegramUI/TelegramUI/ThemeUpdateManager.swift b/submodules/TelegramUI/Sources/ThemeUpdateManager.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/ThemeUpdateManager.swift rename to submodules/TelegramUI/Sources/ThemeUpdateManager.swift diff --git a/submodules/TelegramUI/TelegramUI/TimeBasedVideoPreload.swift b/submodules/TelegramUI/Sources/TimeBasedVideoPreload.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/TimeBasedVideoPreload.swift rename to submodules/TelegramUI/Sources/TimeBasedVideoPreload.swift diff --git a/submodules/TelegramUI/TelegramUI/TonePlayer.swift b/submodules/TelegramUI/Sources/TonePlayer.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/TonePlayer.swift rename to submodules/TelegramUI/Sources/TonePlayer.swift diff --git a/submodules/TelegramUI/TelegramUI/TransformOutgoingMessageMedia.swift b/submodules/TelegramUI/Sources/TransformOutgoingMessageMedia.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/TransformOutgoingMessageMedia.swift rename to submodules/TelegramUI/Sources/TransformOutgoingMessageMedia.swift diff --git a/submodules/TelegramUI/TelegramUI/UpgradedAccounts.swift b/submodules/TelegramUI/Sources/UpgradedAccounts.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/UpgradedAccounts.swift rename to submodules/TelegramUI/Sources/UpgradedAccounts.swift diff --git a/submodules/TelegramUI/TelegramUI/VerticalListContextResultsChatInputContextPanelNode.swift b/submodules/TelegramUI/Sources/VerticalListContextResultsChatInputContextPanelNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/VerticalListContextResultsChatInputContextPanelNode.swift rename to submodules/TelegramUI/Sources/VerticalListContextResultsChatInputContextPanelNode.swift diff --git a/submodules/TelegramUI/TelegramUI/VerticalListContextResultsChatInputPanelButtonItem.swift b/submodules/TelegramUI/Sources/VerticalListContextResultsChatInputPanelButtonItem.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/VerticalListContextResultsChatInputPanelButtonItem.swift rename to submodules/TelegramUI/Sources/VerticalListContextResultsChatInputPanelButtonItem.swift diff --git a/submodules/TelegramUI/TelegramUI/VerticalListContextResultsChatInputPanelItem.swift b/submodules/TelegramUI/Sources/VerticalListContextResultsChatInputPanelItem.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/VerticalListContextResultsChatInputPanelItem.swift rename to submodules/TelegramUI/Sources/VerticalListContextResultsChatInputPanelItem.swift diff --git a/submodules/TelegramUI/TelegramUI/VolumeButtons.swift b/submodules/TelegramUI/Sources/VolumeButtons.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/VolumeButtons.swift rename to submodules/TelegramUI/Sources/VolumeButtons.swift diff --git a/submodules/TelegramUI/TelegramUI/WalletContextImpl.swift b/submodules/TelegramUI/Sources/WalletContextImpl.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/WalletContextImpl.swift rename to submodules/TelegramUI/Sources/WalletContextImpl.swift diff --git a/submodules/TelegramUI/TelegramUI/WallpaperPreviewMedia.swift b/submodules/TelegramUI/Sources/WallpaperPreviewMedia.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/WallpaperPreviewMedia.swift rename to submodules/TelegramUI/Sources/WallpaperPreviewMedia.swift diff --git a/submodules/TelegramUI/TelegramUI/WallpaperUploadManager.swift b/submodules/TelegramUI/Sources/WallpaperUploadManager.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/WallpaperUploadManager.swift rename to submodules/TelegramUI/Sources/WallpaperUploadManager.swift diff --git a/submodules/TelegramUI/TelegramUI/WatchManager.swift b/submodules/TelegramUI/Sources/WatchManager.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/WatchManager.swift rename to submodules/TelegramUI/Sources/WatchManager.swift diff --git a/submodules/TelegramUI/TelegramUI/Weak.swift b/submodules/TelegramUI/Sources/Weak.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/Weak.swift rename to submodules/TelegramUI/Sources/Weak.swift diff --git a/submodules/TelegramUI/TelegramUI/WebpagePreviewAccessoryPanelNode.swift b/submodules/TelegramUI/Sources/WebpagePreviewAccessoryPanelNode.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/WebpagePreviewAccessoryPanelNode.swift rename to submodules/TelegramUI/Sources/WebpagePreviewAccessoryPanelNode.swift diff --git a/submodules/TelegramUI/TelegramUI/WidgetDataContext.swift b/submodules/TelegramUI/Sources/WidgetDataContext.swift similarity index 100% rename from submodules/TelegramUI/TelegramUI/WidgetDataContext.swift rename to submodules/TelegramUI/Sources/WidgetDataContext.swift diff --git a/submodules/TelegramUI/TelegramUI/module.private.modulemap b/submodules/TelegramUI/Sources/module.private.modulemap similarity index 100% rename from submodules/TelegramUI/TelegramUI/module.private.modulemap rename to submodules/TelegramUI/Sources/module.private.modulemap From e9a4a9347a1000386e148a490a28d601c3bd0db3 Mon Sep 17 00:00:00 2001 From: Peter Iakovlev Date: Sun, 1 Mar 2020 10:06:51 +0000 Subject: [PATCH 6/6] Revert "Rename directories [skip ci]" This reverts commit 789438a27450dcbdee6065ebf096198ed3b90fec --- .../{Sources => Display}/ASTransformLayerNode.swift | 0 .../{Sources => Display}/Accessibility.swift | 0 .../AccessibilityAreaNode.swift | 0 .../ActionSheetButtonItem.swift | 0 .../ActionSheetCheckboxItem.swift | 0 .../ActionSheetController.swift | 0 .../ActionSheetControllerNode.swift | 0 .../{Sources => Display}/ActionSheetItem.swift | 0 .../{Sources => Display}/ActionSheetItemGroup.swift | 0 .../ActionSheetItemGroupNode.swift | 0 .../ActionSheetItemGroupsContainerNode.swift | 0 .../{Sources => Display}/ActionSheetItemNode.swift | 0 .../ActionSheetSwitchItem.swift | 0 .../{Sources => Display}/ActionSheetTextItem.swift | 0 .../{Sources => Display}/ActionSheetTheme.swift | 0 .../{Sources => Display}/AlertContentNode.swift | 0 .../{Sources => Display}/AlertController.swift | 0 .../{Sources => Display}/AlertControllerNode.swift | 0 .../{Sources => Display}/CAAnimationUtils.swift | 0 .../{Sources => Display}/CASeeThroughTracingLayer.h | 0 .../{Sources => Display}/CASeeThroughTracingLayer.m | 0 .../Display/{Sources => Display}/CATracingLayer.h | 0 .../Display/{Sources => Display}/CATracingLayer.m | 0 .../{Sources => Display}/ChildWindowHostView.swift | 0 .../{Sources => Display}/CollectionIndexNode.swift | 0 .../ContainableController.swift | 0 .../ContainedViewLayoutTransition.swift | 0 .../{Sources => Display}/ContainerViewLayout.swift | 0 .../ContextContentContainerNode.swift | 0 .../ContextContentSourceNode.swift | 0 .../ContextControllerSourceNode.swift | 0 .../{Sources => Display}/ContextGesture.swift | 0 .../{Sources => Display}/ContextMenuAction.swift | 0 .../ContextMenuActionNode.swift | 0 .../ContextMenuContainerNode.swift | 0 .../ContextMenuController.swift | 0 .../{Sources => Display}/ContextMenuNode.swift | 0 .../{Sources => Display}/DeviceMetrics.swift | 0 submodules/Display/{Sources => Display}/Display.h | 0 .../{Sources => Display}/DisplayLinkAnimator.swift | 0 .../DisplayLinkDispatcher.swift | 0 .../{Sources => Display}/EditableTextNode.swift | 0 submodules/Display/{Sources => Display}/Font.swift | 0 .../{Sources => Display}/GenerateImage.swift | 0 .../GlobalOverlayPresentationContext.swift | 0 .../Display/{Sources => Display}/GridItem.swift | 0 .../Display/{Sources => Display}/GridItemNode.swift | 0 .../Display/{Sources => Display}/GridNode.swift | 0 .../{Sources => Display}/GridNodeScroller.swift | 0 .../{Sources => Display}/HapticFeedback.swift | 0 .../HighlightTrackingButton.swift | 0 .../{Sources => Display}/HighlightableButton.swift | 0 .../Display/{Sources => Display}/ImageCorners.swift | 0 .../Display/{Sources => Display}/ImageNode.swift | 0 .../{Sources => Display}/ImmediateTextNode.swift | 0 submodules/Display/{Sources => Display}/Info.plist | 0 .../InteractiveTransitionGestureRecognizer.swift | 0 .../Display/{Sources => Display}/KeyShortcut.swift | 0 .../KeyShortcutsController.swift | 0 .../Display/{Sources => Display}/Keyboard.swift | 0 .../{Sources => Display}/KeyboardManager.swift | 0 .../Display/{Sources => Display}/LayoutSizes.swift | 0 .../LegacyPresentedController.swift | 0 .../LegacyPresentedControllerNode.swift | 0 .../{Sources => Display}/LinkHighlightingNode.swift | 0 .../Display/{Sources => Display}/ListView.swift | 0 .../ListViewAccessoryItem.swift | 0 .../ListViewAccessoryItemNode.swift | 0 .../{Sources => Display}/ListViewAnimation.swift | 0 .../ListViewFloatingHeaderNode.swift | 0 .../ListViewIntermediateState.swift | 0 .../Display/{Sources => Display}/ListViewItem.swift | 0 .../{Sources => Display}/ListViewItemHeader.swift | 0 .../{Sources => Display}/ListViewItemNode.swift | 0 .../ListViewOverscrollBackgroundNode.swift | 0 .../ListViewReorderingGestureRecognizer.swift | 0 .../ListViewReorderingItemNode.swift | 0 .../{Sources => Display}/ListViewScroller.swift | 0 .../ListViewTapGestureRecognizer.swift | 0 .../{Sources => Display}/ListViewTempItemNode.swift | 0 .../ListViewTransactionQueue.swift | 0 .../MinimizeKeyboardGestureRecognizer.swift | 0 submodules/Display/{Sources => Display}/NSBag.h | 0 submodules/Display/{Sources => Display}/NSBag.m | 0 .../Display/{Sources => Display}/NSWeakReference.h | 0 .../Display/{Sources => Display}/NSWeakReference.m | 0 .../{Sources => Display}/NativeWindowHostView.swift | 0 .../Navigation/NavigationContainer.swift | 0 .../Navigation/NavigationController.swift | 0 .../Navigation/NavigationLayout.swift | 0 .../Navigation/NavigationModalContainer.swift | 0 .../Navigation/NavigationModalFrame.swift | 0 .../Navigation/NavigationOverlayContainer.swift | 0 .../Navigation/NavigationSplitContainer.swift | 0 .../NavigationBackButtonNode.swift | 0 .../{Sources => Display}/NavigationBar.swift | 0 .../{Sources => Display}/NavigationBarBadge.swift | 0 .../NavigationBarContentNode.swift | 0 .../{Sources => Display}/NavigationBarProxy.h | 0 .../{Sources => Display}/NavigationBarProxy.m | 0 .../NavigationBarTitleTransitionNode.swift | 0 .../NavigationBarTitleView.swift | 0 .../NavigationBarTransitionContainer.swift | 0 .../NavigationBarTransitionState.swift | 0 .../{Sources => Display}/NavigationButtonNode.swift | 0 .../NavigationControllerProxy.h | 0 .../NavigationControllerProxy.m | 0 .../{Sources => Display}/NavigationTitleNode.swift | 0 .../NavigationTransitionCoordinator.swift | 0 .../{Sources => Display}/NotificationCenterUtils.h | 0 .../{Sources => Display}/NotificationCenterUtils.m | 0 .../{Sources => Display}/PageControlNode.swift | 0 .../{Sources => Display}/PeekController.swift | 0 .../PeekControllerContent.swift | 0 .../PeekControllerGestureRecognizer.swift | 0 .../PeekControllerMenuItemNode.swift | 0 .../PeekControllerMenuNode.swift | 0 .../{Sources => Display}/PeekControllerNode.swift | 0 .../{Sources => Display}/PresentationContext.swift | 0 .../Display/{Sources => Display}/RuntimeUtils.h | 0 .../Display/{Sources => Display}/RuntimeUtils.m | 0 .../Display/{Sources => Display}/RuntimeUtils.swift | 0 .../{Sources => Display}/ScrollToTopProxyView.swift | 0 .../{Sources => Display}/ShakeAnimation.swift | 0 .../Display/{Sources => Display}/Spring.swift | 0 .../Display/{Sources => Display}/StatusBar.swift | 0 .../{Sources => Display}/StatusBarHost.swift | 0 .../{Sources => Display}/StatusBarProxyNode.swift | 0 .../{Sources => Display}/SubstringSearch.swift | 0 .../Display/{Sources => Display}/SwitchNode.swift | 0 .../{Sources => Display}/TabBarContollerNode.swift | 0 .../{Sources => Display}/TabBarController.swift | 0 .../Display/{Sources => Display}/TabBarNode.swift | 0 .../{Sources => Display}/TabBarTapRecognizer.swift | 0 .../TapLongTapOrDoubleTapGestureRecognizer.swift | 0 .../{Sources => Display}/TextAlertController.swift | 0 .../{Sources => Display}/TextFieldNode.swift | 0 .../Display/{Sources => Display}/TextNode.swift | 0 .../Display/{Sources => Display}/Toolbar.swift | 0 .../Display/{Sources => Display}/ToolbarNode.swift | 0 .../{Sources => Display}/TooltipController.swift | 0 .../TooltipControllerNode.swift | 0 .../TransformImageArguments.swift | 0 .../{Sources => Display}/TransformImageNode.swift | 0 .../{Sources => Display}/UIBarButtonItem+Proxy.h | 0 .../{Sources => Display}/UIBarButtonItem+Proxy.m | 0 .../Display/{Sources => Display}/UIKitUtils.h | 0 .../Display/{Sources => Display}/UIKitUtils.m | 0 .../Display/{Sources => Display}/UIKitUtils.swift | 0 .../Display/{Sources => Display}/UIMenuItem+Icons.h | 0 .../Display/{Sources => Display}/UIMenuItem+Icons.m | 0 .../{Sources => Display}/UINavigationItem+Proxy.h | 0 .../{Sources => Display}/UINavigationItem+Proxy.m | 0 .../{Sources => Display}/UITracingLayerView.swift | 0 .../UIViewController+Navigation.h | 0 .../UIViewController+Navigation.m | 0 .../UIWindow+OrientationChange.h | 0 .../UIWindow+OrientationChange.m | 0 .../UniversalMasterController.swift | 0 .../UniversalTapRecognizer.swift | 0 .../{Sources => Display}/ViewController.swift | 0 .../ViewControllerPreviewing.swift | 0 .../ViewControllerTracingNode.swift | 0 .../VolumeControlStatusBar.swift | 0 .../WallpaperBackgroundNode.swift | 0 .../{Sources => Display}/WindowContent.swift | 0 .../{Sources => Display}/WindowCoveringView.swift | 0 .../WindowInputAccessoryHeightProvider.swift | 0 .../{Sources => Display}/WindowPanRecognizer.swift | 0 .../AccessoryPanelNode.swift | 0 .../{Sources => TelegramUI}/AccountContext.swift | 0 .../{Sources => TelegramUI}/AppDelegate.swift | 0 .../ApplicationContext.swift | 0 .../ApplicationShortcutItem.swift | 0 .../AudioRecordningToneData.swift | 0 .../{Sources => TelegramUI}/AudioWaveform.swift | 0 .../{Sources => TelegramUI}/AudioWaveformNode.swift | 0 ...tionSequenceAwaitingAccountResetController.swift | 0 ...SequenceAwaitingAccountResetControllerNode.swift | 0 .../AuthorizationSequenceCodeEntryController.swift | 0 ...thorizationSequenceCodeEntryControllerNode.swift | 0 .../AuthorizationSequenceController.swift | 0 ...thorizationSequencePasswordEntryController.swift | 0 ...izationSequencePasswordEntryControllerNode.swift | 0 ...rizationSequencePasswordRecoveryController.swift | 0 ...tionSequencePasswordRecoveryControllerNode.swift | 0 .../AuthorizationSequencePhoneEntryController.swift | 0 ...horizationSequencePhoneEntryControllerNode.swift | 0 .../AuthorizationSequenceSignUpController.swift | 0 .../AuthorizationSequenceSignUpControllerNode.swift | 0 .../AuthorizationSequenceSplashController.swift | 0 .../AuthorizationSequenceSplashControllerNode.swift | 0 .../ChatAvatarNavigationNode.swift | 0 .../{Sources => TelegramUI}/ChatBotInfoItem.swift | 0 .../ChatBotStartInputPanelNode.swift | 0 .../ChatButtonKeyboardInputNode.swift | 0 .../ChatChannelSubscriberInputPanelNode.swift | 0 .../ChatContextResultPeekContentNode.swift | 0 .../{Sources => TelegramUI}/ChatController.swift | 0 .../ChatControllerInteraction.swift | 0 .../ChatControllerNode.swift | 0 .../ChatControllerTitlePanelNodeContainer.swift | 0 .../ChatDateSelectionSheet.swift | 0 .../ChatEditInterfaceMessageState.swift | 0 .../ChatEditMessageMediaContext.swift | 0 .../{Sources => TelegramUI}/ChatEmptyNode.swift | 0 .../ChatFeedNavigationInputPanelNode.swift | 0 .../ChatHistoryEntriesForView.swift | 0 .../{Sources => TelegramUI}/ChatHistoryEntry.swift | 0 .../ChatHistoryGridNode.swift | 0 .../ChatHistoryListNode.swift | 0 .../ChatHistoryLocation.swift | 0 .../ChatHistoryNavigationButtonNode.swift | 0 .../ChatHistoryNavigationButtons.swift | 0 .../ChatHistoryNavigationStack.swift | 0 .../{Sources => TelegramUI}/ChatHistoryNode.swift | 0 .../ChatHistorySearchContainerNode.swift | 0 .../ChatHistoryViewForLocation.swift | 0 .../{Sources => TelegramUI}/ChatHoleItem.swift | 0 .../{Sources => TelegramUI}/ChatInfo.swift | 0 .../ChatInfoTitlePanelNode.swift | 0 .../ChatInputContextPanelNode.swift | 0 .../{Sources => TelegramUI}/ChatInputNode.swift | 0 .../ChatInputPanelNode.swift | 0 .../ChatInstantVideoMessageDurationNode.swift | 0 .../ChatInterfaceInputContextPanels.swift | 0 .../ChatInterfaceInputContexts.swift | 0 .../ChatInterfaceInputNodes.swift | 0 .../ChatInterfaceState.swift | 0 .../ChatInterfaceStateAccessoryPanels.swift | 0 .../ChatInterfaceStateContextMenus.swift | 0 .../ChatInterfaceStateContextQueries.swift | 0 .../ChatInterfaceStateInputPanels.swift | 0 .../ChatInterfaceStateNavigationButtons.swift | 0 .../ChatInterfaceTitlePanelNodes.swift | 0 .../{Sources => TelegramUI}/ChatLinkPreview.swift | 0 .../{Sources => TelegramUI}/ChatLoadingNode.swift | 0 .../ChatMediaInputGifPane.swift | 0 .../ChatMediaInputGridEntries.swift | 0 .../ChatMediaInputMetaSectionItemNode.swift | 0 .../ChatMediaInputNode.swift | 0 .../ChatMediaInputPane.swift | 0 .../ChatMediaInputPanelEntries.swift | 0 .../ChatMediaInputPeerSpecificItem.swift | 0 .../ChatMediaInputRecentGifsItem.swift | 0 .../ChatMediaInputSettingsItem.swift | 0 .../ChatMediaInputStickerGridItem.swift | 0 .../ChatMediaInputStickerPackItem.swift | 0 .../ChatMediaInputStickerPane.swift | 0 .../ChatMediaInputTrendingItem.swift | 0 .../ChatMediaInputTrendingPane.swift | 0 .../ChatMessageActionButtonsNode.swift | 0 .../ChatMessageActionItemNode.swift | 0 .../ChatMessageActionSheetController.swift | 0 .../ChatMessageActionSheetControllerNode.swift | 0 .../ChatMessageActionUrlAuthController.swift | 0 .../ChatMessageAnimatedStickerItemNode.swift | 0 .../ChatMessageAttachedContentNode.swift | 0 .../ChatMessageAvatarAccessoryItem.swift | 0 .../ChatMessageBackground.swift | 0 .../ChatMessageBubbleBackdrop.swift | 0 ...MessageBubbleContentCalclulateImageCorners.swift | 0 .../ChatMessageBubbleContentNode.swift | 0 .../ChatMessageBubbleItemNode.swift | 0 .../ChatMessageCallBubbleContentNode.swift | 0 .../ChatMessageContactBubbleContentNode.swift | 0 .../ChatMessageContextControllerContentSource.swift | 0 .../ChatMessageDateAndStatusNode.swift | 0 .../ChatMessageDateHeader.swift | 0 .../ChatMessageDeliveryFailedNode.swift | 0 ...sageEventLogPreviousDescriptionContentNode.swift | 0 ...ChatMessageEventLogPreviousLinkContentNode.swift | 0 ...tMessageEventLogPreviousMessageContentNode.swift | 0 .../ChatMessageFileBubbleContentNode.swift | 0 .../ChatMessageForwardInfoNode.swift | 0 .../ChatMessageGameBubbleContentNode.swift | 0 .../ChatMessageInstantVideoItemNode.swift | 0 .../ChatMessageInteractiveFileNode.swift | 0 .../ChatMessageInteractiveInstantVideoNode.swift | 0 .../ChatMessageInteractiveMediaBadge.swift | 0 .../ChatMessageInteractiveMediaNode.swift | 0 .../ChatMessageInvoiceBubbleContentNode.swift | 0 .../{Sources => TelegramUI}/ChatMessageItem.swift | 0 .../ChatMessageItemView.swift | 0 .../ChatMessageLiveLocationTextNode.swift | 0 .../ChatMessageMapBubbleContentNode.swift | 0 .../ChatMessageMediaBubbleContentNode.swift | 0 .../ChatMessageNotificationItem.swift | 0 .../ChatMessagePollBubbleContentNode.swift | 0 .../ChatMessageReplyInfoNode.swift | 0 .../ChatMessageRestrictedBubbleContentNode.swift | 0 .../ChatMessageSelectionInputPanelNode.swift | 0 .../ChatMessageSelectionNode.swift | 0 .../ChatMessageStickerItemNode.swift | 0 .../ChatMessageSwipeToReplyNode.swift | 0 .../ChatMessageTextBubbleContentNode.swift | 0 .../ChatMessageThrottledProcessingManager.swift | 0 .../ChatMessageUnsupportedBubbleContentNode.swift | 0 .../ChatMessageWebpageBubbleContentNode.swift | 0 .../ChatOverlayNavigationBar.swift | 0 .../ChatPanelInterfaceInteraction.swift | 0 .../ChatPinnedMessageTitlePanelNode.swift | 0 .../ChatPresentationData.swift | 0 .../ChatPresentationInterfaceState.swift | 0 .../ChatRecentActionsController.swift | 0 .../ChatRecentActionsControllerNode.swift | 0 .../ChatRecentActionsControllerState.swift | 0 .../ChatRecentActionsEmptyNode.swift | 0 .../ChatRecentActionsFilterController.swift | 0 .../ChatRecentActionsHistoryTransition.swift | 0 .../ChatRecentActionsInteraction.swift | 0 ...atRecentActionsSearchNavigationContentNode.swift | 0 .../ChatRecentActionsTitleView.swift | 0 .../ChatRecordingPreviewInputPanelNode.swift | 0 .../ChatReportPeerTitlePanelNode.swift | 0 .../ChatRequestInProgressTitlePanelNode.swift | 0 .../ChatRestrictedInputPanelNode.swift | 0 .../ChatRestrictedNode.swift | 0 .../ChatScheduleTimeController.swift | 0 .../ChatScheduleTimeControllerNode.swift | 0 .../ChatSearchInputPanelNode.swift | 0 .../ChatSearchNavigationContentNode.swift | 0 .../ChatSearchResultsContollerNode.swift | 0 .../ChatSearchResultsController.swift | 0 .../{Sources => TelegramUI}/ChatSearchState.swift | 0 .../ChatSecretAutoremoveTimerActionSheet.swift | 0 .../ChatSendButtonRadialStatusNode.swift | 0 .../ChatSendMessageActionSheetController.swift | 0 .../ChatSendMessageActionSheetControllerNode.swift | 0 .../ChatSlowmodeHintController.swift | 0 .../ChatSwipeToReplyRecognizer.swift | 0 .../{Sources => TelegramUI}/ChatTextFormat.swift | 0 .../ChatTextInputAccessoryItem.swift | 0 .../ChatTextInputActionButtonsNode.swift | 0 ...ChatTextInputAudioRecordingCancelIndicator.swift | 0 .../ChatTextInputAudioRecordingOverlayButton.swift | 0 .../ChatTextInputAudioRecordingTimeNode.swift | 0 .../ChatTextInputMediaRecordingButton.swift | 0 .../{Sources => TelegramUI}/ChatTextInputMenu.swift | 0 .../ChatTextInputPanelNode.swift | 0 .../ChatTextInputPanelState.swift | 0 .../ChatTextInputSlowmodePlaceholderNode.swift | 0 .../ChatTextLinkEditController.swift | 0 .../ChatTitleAccessoryPanelNode.swift | 0 .../{Sources => TelegramUI}/ChatTitleView.swift | 0 .../ChatToastAlertPanelNode.swift | 0 .../ChatUnblockInputPanelNode.swift | 0 .../{Sources => TelegramUI}/ChatUnreadItem.swift | 0 .../{Sources => TelegramUI}/CheckDiskSpace.swift | 0 .../ClearNotificationsManager.swift | 0 .../CommandChatInputContextPanelNode.swift | 0 .../CommandChatInputPanelItem.swift | 0 .../{Sources => TelegramUI}/ComposeController.swift | 0 .../ComposeControllerNode.swift | 0 .../{Sources => TelegramUI}/ConfettiView.swift | 0 .../ContactMultiselectionController.swift | 0 .../ContactMultiselectionControllerNode.swift | 0 .../ContactSelectionController.swift | 0 .../ContactSelectionControllerNode.swift | 0 .../{Sources => TelegramUI}/ConvertToWebP.swift | 0 .../CreateChannelController.swift | 0 .../CreateGroupController.swift | 0 .../{Sources => TelegramUI}/DeclareEncodables.swift | 0 .../DeleteChatInputPanelNode.swift | 0 .../DeviceContactDataManager.swift | 0 ...ledContextResultsChatInputContextPanelNode.swift | 0 .../DocumentPreviewController.swift | 0 .../EditAccessoryPanelNode.swift | 0 .../EditableTokenListNode.swift | 0 .../{Sources => TelegramUI}/EmojiResources.swift | 0 .../EmojisChatInputContextPanelNode.swift | 0 .../EmojisChatInputPanelItem.swift | 0 .../FetchCachedRepresentations.swift | 0 .../{Sources => TelegramUI}/FetchManager.swift | 0 .../FetchManagerLocation.swift | 0 .../{Sources => TelegramUI}/FetchResource.swift | 0 .../FetchVideoMediaResource.swift | 0 .../FileMediaResourceStatus.swift | 0 .../ForwardAccessoryPanelNode.swift | 0 .../GalleryHiddenMediaManager.swift | 0 .../GifPaneSearchContentNode.swift | 0 .../GlobalExperimentalSettings.swift | 0 .../{Sources => TelegramUI}/GridHoleItem.swift | 0 .../{Sources => TelegramUI}/GridMessageItem.swift | 0 .../HashtagChatInputContextPanelNode.swift | 0 .../HashtagChatInputPanelItem.swift | 0 ...istContextResultsChatInputContextPanelNode.swift | 0 ...zontalListContextResultsChatInputPanelItem.swift | 0 .../HorizontalStickerGridItem.swift | 0 .../HorizontalStickersChatContextPanelNode.swift | 0 .../{Sources => TelegramUI}/ICloudResources.swift | 0 .../{Sources => TelegramUI}/ID3ArtworkReader.swift | 0 .../{Sources => TelegramUI}/IconButtonNode.swift | 0 .../InChatPrefetchManager.swift | 0 .../TelegramUI/{Sources => TelegramUI}/Info.plist | 0 .../InstantVideoRadialStatusNode.swift | 0 .../{Sources => TelegramUI}/LegacyCache.swift | 0 .../{Sources => TelegramUI}/LegacyCamera.swift | 0 .../LegacyInstantVideoController.swift | 0 .../LegacyLiveUploadInterface.swift | 0 .../LinkHighlightingNode.swift | 0 .../ListMessageDateHeader.swift | 0 .../ListMessageFileItemNode.swift | 0 .../ListMessageHoleItem.swift | 0 .../{Sources => TelegramUI}/ListMessageItem.swift | 0 .../{Sources => TelegramUI}/ListMessageNode.swift | 0 .../ListMessagePlaybackOverlayNode.swift | 0 .../ListMessageSnippetItemNode.swift | 0 .../LockedWindowCoveringView.swift | 0 .../ManageSharedAccountInfo.swift | 0 .../ManagedAudioRecorder.swift | 0 .../MediaInputPaneTrendingItem.swift | 0 .../{Sources => TelegramUI}/MediaManager.swift | 0 .../MediaPlaybackStoredState.swift | 0 .../MentionChatInputContextPanelNode.swift | 0 .../MentionChatInputPanelItem.swift | 0 .../MultiScaleTextNode.swift | 0 .../MultiplexedSoftwareVideoNode.swift | 0 .../MultiplexedSoftwareVideoSourceManager.swift | 0 .../MultiplexedVideoNode.swift | 0 .../NavigateToChatController.swift | 0 .../NotificationContainerController.swift | 0 .../NotificationContainerControllerNode.swift | 0 .../NotificationContentContext.swift | 0 .../{Sources => TelegramUI}/NotificationItem.swift | 0 .../NotificationItemContainerNode.swift | 0 .../{Sources => TelegramUI}/OpenAddContact.swift | 0 .../{Sources => TelegramUI}/OpenChatMessage.swift | 0 .../{Sources => TelegramUI}/OpenResolvedUrl.swift | 0 .../{Sources => TelegramUI}/OpenUrl.swift | 0 .../OverlayAudioPlayerController.swift | 0 .../OverlayInstantVideoDecoration.swift | 0 .../OverlayInstantVideoNode.swift | 0 .../OverlayMediaController.swift | 0 .../OverlayMediaControllerNode.swift | 0 .../OverlayPlayerControllerNode.swift | 0 .../OverlayPlayerControlsNode.swift | 0 .../{Sources => TelegramUI}/PaneSearchBarNode.swift | 0 .../PaneSearchBarPlaceholderItem.swift | 0 .../PaneSearchContainerNode.swift | 0 .../{Sources => TelegramUI}/Pasteboard.swift | 0 .../ListItems/PeerInfoScreenActionItem.swift | 0 .../ListItems/PeerInfoScreenAddressItem.swift | 0 .../ListItems/PeerInfoScreenCallListItem.swift | 0 .../ListItems/PeerInfoScreenCommentItem.swift | 0 .../PeerInfoScreenDisclosureEncryptionKeyItem.swift | 0 .../ListItems/PeerInfoScreenDisclosureItem.swift | 0 .../ListItems/PeerInfoScreenHeaderItem.swift | 0 .../ListItems/PeerInfoScreenLabeledValueItem.swift | 0 .../ListItems/PeerInfoScreenMemberItem.swift | 0 .../PeerInfoScreenSelectableBackgroundNode.swift | 0 .../ListItems/PeerInfoScreenSwitchItem.swift | 0 .../Panes/PeerInfoGroupsInCommonPaneNode.swift | 0 .../PeerInfo/Panes/PeerInfoListPaneNode.swift | 0 .../PeerInfo/Panes/PeerInfoMembersPane.swift | 0 .../Panes/PeerInfoVisualMediaPaneNode.swift | 0 .../PeerInfo/PeerInfoData.swift | 0 .../PeerInfo/PeerInfoHeaderNode.swift | 0 .../PeerInfo/PeerInfoMembers.swift | 0 .../PeerInfo/PeerInfoPaneContainerNode.swift | 0 .../PeerInfo/PeerInfoScreen.swift | 0 .../PeerMediaCollectionController.swift | 0 .../PeerMediaCollectionControllerNode.swift | 0 .../PeerMediaCollectionEmptyNode.swift | 0 .../PeerMediaCollectionInterfaceState.swift | 0 .../PeerMediaCollectionInterfaceStateButtons.swift | 0 .../PeerMediaCollectionSectionsNode.swift | 0 .../PeerMessagesMediaPlaylist.swift | 0 .../PeerSelectionController.swift | 0 .../PeerSelectionControllerNode.swift | 0 .../PeersNearbyManager.swift | 0 .../PollResultsController.swift | 0 .../{Sources => TelegramUI}/PrefetchManager.swift | 0 .../PrepareSecretThumbnailData.swift | 0 .../PreparedChatHistoryViewTransition.swift | 0 .../ProcessedPeerRestrictionText.swift | 0 .../RadialProgressNode.swift | 0 .../{Sources => TelegramUI}/RadialTimeoutNode.swift | 0 .../ReplyAccessoryPanelNode.swift | 0 .../Resources/Animations/ChatListEmpty.tgs | Bin .../Resources/Animations/ChatListFilterEmpty.tgs | Bin .../Resources/Animations/anim_archive.json | 0 .../Resources/Animations/anim_archiveAvatar.json | 0 .../Resources/Animations/anim_archiveswipe.json | 0 .../Resources/Animations/anim_delete.json | 0 .../Resources/Animations/anim_group.json | 0 .../Resources/Animations/anim_hide.json | 0 .../Resources/Animations/anim_infotip.json | 0 .../Resources/Animations/anim_mute.json | 0 .../Resources/Animations/anim_pin.json | 0 .../Resources/Animations/anim_qr.json | 0 .../Resources/Animations/anim_read.json | 0 .../Resources/Animations/anim_success.json | 0 .../Resources/Animations/anim_swipereply.json | 0 .../Resources/Animations/anim_unarchive.json | 0 .../Resources/Animations/anim_ungroup.json | 0 .../Resources/Animations/anim_unmute.json | 0 .../Resources/Animations/anim_unpin.json | 0 .../Resources/Animations/anim_unread.json | 0 .../Resources/BuiltinReactions/celebrate.tgs | Bin .../Resources/BuiltinReactions/cry.tgs | Bin .../Resources/BuiltinReactions/heart.tgs | Bin .../Resources/BuiltinReactions/lol.tgs | Bin .../Resources/BuiltinReactions/meh.tgs | Bin .../Resources/BuiltinReactions/ok.tgs | Bin .../Resources/BuiltinReactions/poker.tgs | Bin .../Resources/BuiltinReactions/poop.tgs | Bin .../Resources/BuiltinReactions/sad.tgs | Bin .../Resources/BuiltinReactions/smile.tgs | Bin .../Resources/BuiltinReactions/surprised.tgs | Bin .../Resources/BuiltinReactions/thumbsup.tgs | Bin .../Resources/ChatWallpaperBuiltin0.jpg | Bin .../{Sources => TelegramUI}/Resources/Emoji.mapping | Bin .../Resources/Fonts/SFCompactRounded-Semibold.otf | Bin .../Resources/PhoneCountries.txt | 0 .../Resources/PresentationStrings.mapping | Bin .../StillReactions/simplereaction_10@2x.png | Bin .../StillReactions/simplereaction_10@3x.png | Bin .../StillReactions/simplereaction_11@2x.png | Bin .../StillReactions/simplereaction_11@3x.png | Bin .../StillReactions/simplereaction_12@2x.png | Bin .../StillReactions/simplereaction_12@3x.png | Bin .../StillReactions/simplereaction_13@2x.png | Bin .../StillReactions/simplereaction_13@3x.png | Bin .../StillReactions/simplereaction_14@2x.png | Bin .../StillReactions/simplereaction_14@3x.png | Bin .../StillReactions/simplereaction_15@2x.png | Bin .../StillReactions/simplereaction_15@3x.png | Bin .../StillReactions/simplereaction_16@2x.png | Bin .../StillReactions/simplereaction_16@3x.png | Bin .../StillReactions/simplereaction_17@2x.png | Bin .../StillReactions/simplereaction_17@3x.png | Bin .../StillReactions/simplereaction_18@2x.png | Bin .../StillReactions/simplereaction_18@3x.png | Bin .../StillReactions/simplereaction_19@2x.png | Bin .../StillReactions/simplereaction_19@3x.png | Bin .../StillReactions/simplereaction_1@2x.png | Bin .../StillReactions/simplereaction_1@3x.png | Bin .../StillReactions/simplereaction_20@2x.png | Bin .../StillReactions/simplereaction_20@3x.png | Bin .../StillReactions/simplereaction_2@2x.png | Bin .../StillReactions/simplereaction_2@3x.png | Bin .../StillReactions/simplereaction_3@2x.png | Bin .../StillReactions/simplereaction_3@3x.png | Bin .../StillReactions/simplereaction_4@2x.png | Bin .../StillReactions/simplereaction_4@3x.png | Bin .../StillReactions/simplereaction_5@2x.png | Bin .../StillReactions/simplereaction_5@3x.png | Bin .../StillReactions/simplereaction_6@2x.png | Bin .../StillReactions/simplereaction_6@3x.png | Bin .../StillReactions/simplereaction_7@2x.png | Bin .../StillReactions/simplereaction_7@3x.png | Bin .../StillReactions/simplereaction_8@2x.png | Bin .../StillReactions/simplereaction_8@3x.png | Bin .../StillReactions/simplereaction_9@2x.png | Bin .../StillReactions/simplereaction_9@3x.png | Bin .../Resources/Stripe/stp_card_amex@2x.png | Bin .../Resources/Stripe/stp_card_amex@3x.png | Bin .../Resources/Stripe/stp_card_amex_template@2x.png | Bin .../Resources/Stripe/stp_card_amex_template@3x.png | Bin .../Resources/Stripe/stp_card_applepay@2x.png | Bin .../Resources/Stripe/stp_card_applepay@3x.png | Bin .../Stripe/stp_card_applepay_template@2x.png | Bin .../Stripe/stp_card_applepay_template@3x.png | Bin .../Resources/Stripe/stp_card_cvc@2x.png | Bin .../Resources/Stripe/stp_card_cvc@3x.png | Bin .../Resources/Stripe/stp_card_cvc_amex@2x.png | Bin .../Resources/Stripe/stp_card_cvc_amex@3x.png | Bin .../Resources/Stripe/stp_card_diners@2x.png | Bin .../Resources/Stripe/stp_card_diners@3x.png | Bin .../Stripe/stp_card_diners_template@2x.png | Bin .../Stripe/stp_card_diners_template@3x.png | Bin .../Resources/Stripe/stp_card_discover@2x.png | Bin .../Resources/Stripe/stp_card_discover@3x.png | Bin .../Stripe/stp_card_discover_template@2x.png | Bin .../Stripe/stp_card_discover_template@3x.png | Bin .../Resources/Stripe/stp_card_form_applepay@2x.png | Bin .../Resources/Stripe/stp_card_form_applepay@3x.png | Bin .../Resources/Stripe/stp_card_form_back@2x.png | Bin .../Resources/Stripe/stp_card_form_back@3x.png | Bin .../Resources/Stripe/stp_card_form_front@2x.png | Bin .../Resources/Stripe/stp_card_form_front@3x.png | Bin .../Resources/Stripe/stp_card_jcb@2x.png | Bin .../Resources/Stripe/stp_card_jcb@3x.png | Bin .../Resources/Stripe/stp_card_jcb_template@2x.png | Bin .../Resources/Stripe/stp_card_jcb_template@3x.png | Bin .../Resources/Stripe/stp_card_mastercard@2x.png | Bin .../Resources/Stripe/stp_card_mastercard@3x.png | Bin .../Stripe/stp_card_mastercard_template@2x.png | Bin .../Stripe/stp_card_mastercard_template@3x.png | Bin .../Stripe/stp_card_placeholder_template@2x.png | Bin .../Stripe/stp_card_placeholder_template@3x.png | Bin .../Resources/Stripe/stp_card_visa@2x.png | Bin .../Resources/Stripe/stp_card_visa@3x.png | Bin .../Resources/Stripe/stp_card_visa_template@2x.png | Bin .../Resources/Stripe/stp_card_visa_template@3x.png | Bin .../Resources/WebEmbed/Generic.html | 0 .../Resources/WebEmbed/GenericUserScript.js | 0 .../Resources/WebEmbed/Instagram.html | 0 .../Resources/WebEmbed/Twitch.html | 0 .../Resources/WebEmbed/TwitchUserScript.js | 0 .../Resources/WebEmbed/Vimeo.html | 0 .../Resources/WebEmbed/VimeoUserScript.js | 0 .../Resources/WebEmbed/Youtube.html | 0 .../Resources/WebEmbed/YoutubeUserScript.js | 0 .../Resources/currencies.json | 0 .../{Sources => TelegramUI}/SampleBufferPool.swift | 0 .../SecretChatHandshakeStatusInputPanelNode.swift | 0 .../ServiceSoundManager.swift | 0 .../ShareExtensionContext.swift | 0 .../SharedAccountContext.swift | 0 .../{Sources => TelegramUI}/SharedMediaPlayer.swift | 0 .../SharedNotificationManager.swift | 0 .../SharedVideoContextManager.swift | 0 .../SharedWakeupManager.swift | 0 .../SoftwareVideoLayerFrameManager.swift | 0 .../SoftwareVideoThumbnailLayer.swift | 0 .../{Sources => TelegramUI}/Sounds/MessageSent.caf | Bin .../{Sources => TelegramUI}/Sounds/notification.caf | Bin .../{Sources => TelegramUI}/SpotlightContacts.swift | 0 .../StickerPanePeerSpecificSetupGridItem.swift | 0 .../StickerPaneSearchContentNode.swift | 0 .../StickerPaneSearchGlobaltem.swift | 0 .../StickerPaneSearchStickerItem.swift | 0 .../StickersChatInputContextPanelItem.swift | 0 .../StickersChatInputContextPanelNode.swift | 0 .../StoreDownloadedMedia.swift | 0 .../StringForMessageTimestampStatus.swift | 0 .../SuppressContactsWarning.swift | 0 .../TelegramAccountAuxiliaryMethods.swift | 0 .../TelegramRootController.swift | 0 .../TelegramUI/{Sources => TelegramUI}/TelegramUI.h | 0 .../{Sources => TelegramUI}/TextLinkHandling.swift | 0 .../ThemeUpdateManager.swift | 0 .../TimeBasedVideoPreload.swift | 0 .../{Sources => TelegramUI}/TonePlayer.swift | 0 .../TransformOutgoingMessageMedia.swift | 0 .../{Sources => TelegramUI}/UpgradedAccounts.swift | 0 ...istContextResultsChatInputContextPanelNode.swift | 0 ...ListContextResultsChatInputPanelButtonItem.swift | 0 ...rticalListContextResultsChatInputPanelItem.swift | 0 .../{Sources => TelegramUI}/VolumeButtons.swift | 0 .../{Sources => TelegramUI}/WalletContextImpl.swift | 0 .../WallpaperPreviewMedia.swift | 0 .../WallpaperUploadManager.swift | 0 .../{Sources => TelegramUI}/WatchManager.swift | 0 .../TelegramUI/{Sources => TelegramUI}/Weak.swift | 0 .../WebpagePreviewAccessoryPanelNode.swift | 0 .../{Sources => TelegramUI}/WidgetDataContext.swift | 0 .../module.private.modulemap | 0 650 files changed, 0 insertions(+), 0 deletions(-) rename submodules/Display/{Sources => Display}/ASTransformLayerNode.swift (100%) rename submodules/Display/{Sources => Display}/Accessibility.swift (100%) rename submodules/Display/{Sources => Display}/AccessibilityAreaNode.swift (100%) rename submodules/Display/{Sources => Display}/ActionSheetButtonItem.swift (100%) rename submodules/Display/{Sources => Display}/ActionSheetCheckboxItem.swift (100%) rename submodules/Display/{Sources => Display}/ActionSheetController.swift (100%) rename submodules/Display/{Sources => Display}/ActionSheetControllerNode.swift (100%) rename submodules/Display/{Sources => Display}/ActionSheetItem.swift (100%) rename submodules/Display/{Sources => Display}/ActionSheetItemGroup.swift (100%) rename submodules/Display/{Sources => Display}/ActionSheetItemGroupNode.swift (100%) rename submodules/Display/{Sources => Display}/ActionSheetItemGroupsContainerNode.swift (100%) rename submodules/Display/{Sources => Display}/ActionSheetItemNode.swift (100%) rename submodules/Display/{Sources => Display}/ActionSheetSwitchItem.swift (100%) rename submodules/Display/{Sources => Display}/ActionSheetTextItem.swift (100%) rename submodules/Display/{Sources => Display}/ActionSheetTheme.swift (100%) rename submodules/Display/{Sources => Display}/AlertContentNode.swift (100%) rename submodules/Display/{Sources => Display}/AlertController.swift (100%) rename submodules/Display/{Sources => Display}/AlertControllerNode.swift (100%) rename submodules/Display/{Sources => Display}/CAAnimationUtils.swift (100%) rename submodules/Display/{Sources => Display}/CASeeThroughTracingLayer.h (100%) rename submodules/Display/{Sources => Display}/CASeeThroughTracingLayer.m (100%) rename submodules/Display/{Sources => Display}/CATracingLayer.h (100%) rename submodules/Display/{Sources => Display}/CATracingLayer.m (100%) rename submodules/Display/{Sources => Display}/ChildWindowHostView.swift (100%) rename submodules/Display/{Sources => Display}/CollectionIndexNode.swift (100%) rename submodules/Display/{Sources => Display}/ContainableController.swift (100%) rename submodules/Display/{Sources => Display}/ContainedViewLayoutTransition.swift (100%) rename submodules/Display/{Sources => Display}/ContainerViewLayout.swift (100%) rename submodules/Display/{Sources => Display}/ContextContentContainerNode.swift (100%) rename submodules/Display/{Sources => Display}/ContextContentSourceNode.swift (100%) rename submodules/Display/{Sources => Display}/ContextControllerSourceNode.swift (100%) rename submodules/Display/{Sources => Display}/ContextGesture.swift (100%) rename submodules/Display/{Sources => Display}/ContextMenuAction.swift (100%) rename submodules/Display/{Sources => Display}/ContextMenuActionNode.swift (100%) rename submodules/Display/{Sources => Display}/ContextMenuContainerNode.swift (100%) rename submodules/Display/{Sources => Display}/ContextMenuController.swift (100%) rename submodules/Display/{Sources => Display}/ContextMenuNode.swift (100%) rename submodules/Display/{Sources => Display}/DeviceMetrics.swift (100%) rename submodules/Display/{Sources => Display}/Display.h (100%) rename submodules/Display/{Sources => Display}/DisplayLinkAnimator.swift (100%) rename submodules/Display/{Sources => Display}/DisplayLinkDispatcher.swift (100%) rename submodules/Display/{Sources => Display}/EditableTextNode.swift (100%) rename submodules/Display/{Sources => Display}/Font.swift (100%) rename submodules/Display/{Sources => Display}/GenerateImage.swift (100%) rename submodules/Display/{Sources => Display}/GlobalOverlayPresentationContext.swift (100%) rename submodules/Display/{Sources => Display}/GridItem.swift (100%) rename submodules/Display/{Sources => Display}/GridItemNode.swift (100%) rename submodules/Display/{Sources => Display}/GridNode.swift (100%) rename submodules/Display/{Sources => Display}/GridNodeScroller.swift (100%) rename submodules/Display/{Sources => Display}/HapticFeedback.swift (100%) rename submodules/Display/{Sources => Display}/HighlightTrackingButton.swift (100%) rename submodules/Display/{Sources => Display}/HighlightableButton.swift (100%) rename submodules/Display/{Sources => Display}/ImageCorners.swift (100%) rename submodules/Display/{Sources => Display}/ImageNode.swift (100%) rename submodules/Display/{Sources => Display}/ImmediateTextNode.swift (100%) rename submodules/Display/{Sources => Display}/Info.plist (100%) rename submodules/Display/{Sources => Display}/InteractiveTransitionGestureRecognizer.swift (100%) rename submodules/Display/{Sources => Display}/KeyShortcut.swift (100%) rename submodules/Display/{Sources => Display}/KeyShortcutsController.swift (100%) rename submodules/Display/{Sources => Display}/Keyboard.swift (100%) rename submodules/Display/{Sources => Display}/KeyboardManager.swift (100%) rename submodules/Display/{Sources => Display}/LayoutSizes.swift (100%) rename submodules/Display/{Sources => Display}/LegacyPresentedController.swift (100%) rename submodules/Display/{Sources => Display}/LegacyPresentedControllerNode.swift (100%) rename submodules/Display/{Sources => Display}/LinkHighlightingNode.swift (100%) rename submodules/Display/{Sources => Display}/ListView.swift (100%) rename submodules/Display/{Sources => Display}/ListViewAccessoryItem.swift (100%) rename submodules/Display/{Sources => Display}/ListViewAccessoryItemNode.swift (100%) rename submodules/Display/{Sources => Display}/ListViewAnimation.swift (100%) rename submodules/Display/{Sources => Display}/ListViewFloatingHeaderNode.swift (100%) rename submodules/Display/{Sources => Display}/ListViewIntermediateState.swift (100%) rename submodules/Display/{Sources => Display}/ListViewItem.swift (100%) rename submodules/Display/{Sources => Display}/ListViewItemHeader.swift (100%) rename submodules/Display/{Sources => Display}/ListViewItemNode.swift (100%) rename submodules/Display/{Sources => Display}/ListViewOverscrollBackgroundNode.swift (100%) rename submodules/Display/{Sources => Display}/ListViewReorderingGestureRecognizer.swift (100%) rename submodules/Display/{Sources => Display}/ListViewReorderingItemNode.swift (100%) rename submodules/Display/{Sources => Display}/ListViewScroller.swift (100%) rename submodules/Display/{Sources => Display}/ListViewTapGestureRecognizer.swift (100%) rename submodules/Display/{Sources => Display}/ListViewTempItemNode.swift (100%) rename submodules/Display/{Sources => Display}/ListViewTransactionQueue.swift (100%) rename submodules/Display/{Sources => Display}/MinimizeKeyboardGestureRecognizer.swift (100%) rename submodules/Display/{Sources => Display}/NSBag.h (100%) rename submodules/Display/{Sources => Display}/NSBag.m (100%) rename submodules/Display/{Sources => Display}/NSWeakReference.h (100%) rename submodules/Display/{Sources => Display}/NSWeakReference.m (100%) rename submodules/Display/{Sources => Display}/NativeWindowHostView.swift (100%) rename submodules/Display/{Sources => Display}/Navigation/NavigationContainer.swift (100%) rename submodules/Display/{Sources => Display}/Navigation/NavigationController.swift (100%) rename submodules/Display/{Sources => Display}/Navigation/NavigationLayout.swift (100%) rename submodules/Display/{Sources => Display}/Navigation/NavigationModalContainer.swift (100%) rename submodules/Display/{Sources => Display}/Navigation/NavigationModalFrame.swift (100%) rename submodules/Display/{Sources => Display}/Navigation/NavigationOverlayContainer.swift (100%) rename submodules/Display/{Sources => Display}/Navigation/NavigationSplitContainer.swift (100%) rename submodules/Display/{Sources => Display}/NavigationBackButtonNode.swift (100%) rename submodules/Display/{Sources => Display}/NavigationBar.swift (100%) rename submodules/Display/{Sources => Display}/NavigationBarBadge.swift (100%) rename submodules/Display/{Sources => Display}/NavigationBarContentNode.swift (100%) rename submodules/Display/{Sources => Display}/NavigationBarProxy.h (100%) rename submodules/Display/{Sources => Display}/NavigationBarProxy.m (100%) rename submodules/Display/{Sources => Display}/NavigationBarTitleTransitionNode.swift (100%) rename submodules/Display/{Sources => Display}/NavigationBarTitleView.swift (100%) rename submodules/Display/{Sources => Display}/NavigationBarTransitionContainer.swift (100%) rename submodules/Display/{Sources => Display}/NavigationBarTransitionState.swift (100%) rename submodules/Display/{Sources => Display}/NavigationButtonNode.swift (100%) rename submodules/Display/{Sources => Display}/NavigationControllerProxy.h (100%) rename submodules/Display/{Sources => Display}/NavigationControllerProxy.m (100%) rename submodules/Display/{Sources => Display}/NavigationTitleNode.swift (100%) rename submodules/Display/{Sources => Display}/NavigationTransitionCoordinator.swift (100%) rename submodules/Display/{Sources => Display}/NotificationCenterUtils.h (100%) rename submodules/Display/{Sources => Display}/NotificationCenterUtils.m (100%) rename submodules/Display/{Sources => Display}/PageControlNode.swift (100%) rename submodules/Display/{Sources => Display}/PeekController.swift (100%) rename submodules/Display/{Sources => Display}/PeekControllerContent.swift (100%) rename submodules/Display/{Sources => Display}/PeekControllerGestureRecognizer.swift (100%) rename submodules/Display/{Sources => Display}/PeekControllerMenuItemNode.swift (100%) rename submodules/Display/{Sources => Display}/PeekControllerMenuNode.swift (100%) rename submodules/Display/{Sources => Display}/PeekControllerNode.swift (100%) rename submodules/Display/{Sources => Display}/PresentationContext.swift (100%) rename submodules/Display/{Sources => Display}/RuntimeUtils.h (100%) rename submodules/Display/{Sources => Display}/RuntimeUtils.m (100%) rename submodules/Display/{Sources => Display}/RuntimeUtils.swift (100%) rename submodules/Display/{Sources => Display}/ScrollToTopProxyView.swift (100%) rename submodules/Display/{Sources => Display}/ShakeAnimation.swift (100%) rename submodules/Display/{Sources => Display}/Spring.swift (100%) rename submodules/Display/{Sources => Display}/StatusBar.swift (100%) rename submodules/Display/{Sources => Display}/StatusBarHost.swift (100%) rename submodules/Display/{Sources => Display}/StatusBarProxyNode.swift (100%) rename submodules/Display/{Sources => Display}/SubstringSearch.swift (100%) rename submodules/Display/{Sources => Display}/SwitchNode.swift (100%) rename submodules/Display/{Sources => Display}/TabBarContollerNode.swift (100%) rename submodules/Display/{Sources => Display}/TabBarController.swift (100%) rename submodules/Display/{Sources => Display}/TabBarNode.swift (100%) rename submodules/Display/{Sources => Display}/TabBarTapRecognizer.swift (100%) rename submodules/Display/{Sources => Display}/TapLongTapOrDoubleTapGestureRecognizer.swift (100%) rename submodules/Display/{Sources => Display}/TextAlertController.swift (100%) rename submodules/Display/{Sources => Display}/TextFieldNode.swift (100%) rename submodules/Display/{Sources => Display}/TextNode.swift (100%) rename submodules/Display/{Sources => Display}/Toolbar.swift (100%) rename submodules/Display/{Sources => Display}/ToolbarNode.swift (100%) rename submodules/Display/{Sources => Display}/TooltipController.swift (100%) rename submodules/Display/{Sources => Display}/TooltipControllerNode.swift (100%) rename submodules/Display/{Sources => Display}/TransformImageArguments.swift (100%) rename submodules/Display/{Sources => Display}/TransformImageNode.swift (100%) rename submodules/Display/{Sources => Display}/UIBarButtonItem+Proxy.h (100%) rename submodules/Display/{Sources => Display}/UIBarButtonItem+Proxy.m (100%) rename submodules/Display/{Sources => Display}/UIKitUtils.h (100%) rename submodules/Display/{Sources => Display}/UIKitUtils.m (100%) rename submodules/Display/{Sources => Display}/UIKitUtils.swift (100%) rename submodules/Display/{Sources => Display}/UIMenuItem+Icons.h (100%) rename submodules/Display/{Sources => Display}/UIMenuItem+Icons.m (100%) rename submodules/Display/{Sources => Display}/UINavigationItem+Proxy.h (100%) rename submodules/Display/{Sources => Display}/UINavigationItem+Proxy.m (100%) rename submodules/Display/{Sources => Display}/UITracingLayerView.swift (100%) rename submodules/Display/{Sources => Display}/UIViewController+Navigation.h (100%) rename submodules/Display/{Sources => Display}/UIViewController+Navigation.m (100%) rename submodules/Display/{Sources => Display}/UIWindow+OrientationChange.h (100%) rename submodules/Display/{Sources => Display}/UIWindow+OrientationChange.m (100%) rename submodules/Display/{Sources => Display}/UniversalMasterController.swift (100%) rename submodules/Display/{Sources => Display}/UniversalTapRecognizer.swift (100%) rename submodules/Display/{Sources => Display}/ViewController.swift (100%) rename submodules/Display/{Sources => Display}/ViewControllerPreviewing.swift (100%) rename submodules/Display/{Sources => Display}/ViewControllerTracingNode.swift (100%) rename submodules/Display/{Sources => Display}/VolumeControlStatusBar.swift (100%) rename submodules/Display/{Sources => Display}/WallpaperBackgroundNode.swift (100%) rename submodules/Display/{Sources => Display}/WindowContent.swift (100%) rename submodules/Display/{Sources => Display}/WindowCoveringView.swift (100%) rename submodules/Display/{Sources => Display}/WindowInputAccessoryHeightProvider.swift (100%) rename submodules/Display/{Sources => Display}/WindowPanRecognizer.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/AccessoryPanelNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/AccountContext.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/AppDelegate.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ApplicationContext.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ApplicationShortcutItem.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/AudioRecordningToneData.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/AudioWaveform.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/AudioWaveformNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/AuthorizationSequenceAwaitingAccountResetController.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/AuthorizationSequenceAwaitingAccountResetControllerNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/AuthorizationSequenceCodeEntryController.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/AuthorizationSequenceCodeEntryControllerNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/AuthorizationSequenceController.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/AuthorizationSequencePasswordEntryController.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/AuthorizationSequencePasswordEntryControllerNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/AuthorizationSequencePasswordRecoveryController.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/AuthorizationSequencePasswordRecoveryControllerNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/AuthorizationSequencePhoneEntryController.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/AuthorizationSequencePhoneEntryControllerNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/AuthorizationSequenceSignUpController.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/AuthorizationSequenceSignUpControllerNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/AuthorizationSequenceSplashController.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/AuthorizationSequenceSplashControllerNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatAvatarNavigationNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatBotInfoItem.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatBotStartInputPanelNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatButtonKeyboardInputNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatChannelSubscriberInputPanelNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatContextResultPeekContentNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatController.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatControllerInteraction.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatControllerNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatControllerTitlePanelNodeContainer.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatDateSelectionSheet.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatEditInterfaceMessageState.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatEditMessageMediaContext.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatEmptyNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatFeedNavigationInputPanelNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatHistoryEntriesForView.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatHistoryEntry.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatHistoryGridNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatHistoryListNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatHistoryLocation.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatHistoryNavigationButtonNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatHistoryNavigationButtons.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatHistoryNavigationStack.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatHistoryNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatHistorySearchContainerNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatHistoryViewForLocation.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatHoleItem.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatInfo.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatInfoTitlePanelNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatInputContextPanelNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatInputNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatInputPanelNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatInstantVideoMessageDurationNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatInterfaceInputContextPanels.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatInterfaceInputContexts.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatInterfaceInputNodes.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatInterfaceState.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatInterfaceStateAccessoryPanels.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatInterfaceStateContextMenus.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatInterfaceStateContextQueries.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatInterfaceStateInputPanels.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatInterfaceStateNavigationButtons.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatInterfaceTitlePanelNodes.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatLinkPreview.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatLoadingNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatMediaInputGifPane.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatMediaInputGridEntries.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatMediaInputMetaSectionItemNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatMediaInputNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatMediaInputPane.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatMediaInputPanelEntries.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatMediaInputPeerSpecificItem.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatMediaInputRecentGifsItem.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatMediaInputSettingsItem.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatMediaInputStickerGridItem.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatMediaInputStickerPackItem.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatMediaInputStickerPane.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatMediaInputTrendingItem.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatMediaInputTrendingPane.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatMessageActionButtonsNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatMessageActionItemNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatMessageActionSheetController.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatMessageActionSheetControllerNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatMessageActionUrlAuthController.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatMessageAnimatedStickerItemNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatMessageAttachedContentNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatMessageAvatarAccessoryItem.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatMessageBackground.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatMessageBubbleBackdrop.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatMessageBubbleContentCalclulateImageCorners.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatMessageBubbleContentNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatMessageBubbleItemNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatMessageCallBubbleContentNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatMessageContactBubbleContentNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatMessageContextControllerContentSource.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatMessageDateAndStatusNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatMessageDateHeader.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatMessageDeliveryFailedNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatMessageEventLogPreviousDescriptionContentNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatMessageEventLogPreviousLinkContentNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatMessageEventLogPreviousMessageContentNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatMessageFileBubbleContentNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatMessageForwardInfoNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatMessageGameBubbleContentNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatMessageInstantVideoItemNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatMessageInteractiveFileNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatMessageInteractiveInstantVideoNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatMessageInteractiveMediaBadge.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatMessageInteractiveMediaNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatMessageInvoiceBubbleContentNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatMessageItem.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatMessageItemView.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatMessageLiveLocationTextNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatMessageMapBubbleContentNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatMessageMediaBubbleContentNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatMessageNotificationItem.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatMessagePollBubbleContentNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatMessageReplyInfoNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatMessageRestrictedBubbleContentNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatMessageSelectionInputPanelNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatMessageSelectionNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatMessageStickerItemNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatMessageSwipeToReplyNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatMessageTextBubbleContentNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatMessageThrottledProcessingManager.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatMessageUnsupportedBubbleContentNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatMessageWebpageBubbleContentNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatOverlayNavigationBar.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatPanelInterfaceInteraction.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatPinnedMessageTitlePanelNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatPresentationData.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatPresentationInterfaceState.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatRecentActionsController.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatRecentActionsControllerNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatRecentActionsControllerState.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatRecentActionsEmptyNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatRecentActionsFilterController.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatRecentActionsHistoryTransition.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatRecentActionsInteraction.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatRecentActionsSearchNavigationContentNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatRecentActionsTitleView.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatRecordingPreviewInputPanelNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatReportPeerTitlePanelNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatRequestInProgressTitlePanelNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatRestrictedInputPanelNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatRestrictedNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatScheduleTimeController.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatScheduleTimeControllerNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatSearchInputPanelNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatSearchNavigationContentNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatSearchResultsContollerNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatSearchResultsController.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatSearchState.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatSecretAutoremoveTimerActionSheet.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatSendButtonRadialStatusNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatSendMessageActionSheetController.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatSendMessageActionSheetControllerNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatSlowmodeHintController.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatSwipeToReplyRecognizer.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatTextFormat.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatTextInputAccessoryItem.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatTextInputActionButtonsNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatTextInputAudioRecordingCancelIndicator.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatTextInputAudioRecordingOverlayButton.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatTextInputAudioRecordingTimeNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatTextInputMediaRecordingButton.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatTextInputMenu.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatTextInputPanelNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatTextInputPanelState.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatTextInputSlowmodePlaceholderNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatTextLinkEditController.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatTitleAccessoryPanelNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatTitleView.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatToastAlertPanelNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatUnblockInputPanelNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ChatUnreadItem.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/CheckDiskSpace.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ClearNotificationsManager.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/CommandChatInputContextPanelNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/CommandChatInputPanelItem.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ComposeController.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ComposeControllerNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ConfettiView.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ContactMultiselectionController.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ContactMultiselectionControllerNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ContactSelectionController.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ContactSelectionControllerNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ConvertToWebP.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/CreateChannelController.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/CreateGroupController.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/DeclareEncodables.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/DeleteChatInputPanelNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/DeviceContactDataManager.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/DisabledContextResultsChatInputContextPanelNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/DocumentPreviewController.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/EditAccessoryPanelNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/EditableTokenListNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/EmojiResources.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/EmojisChatInputContextPanelNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/EmojisChatInputPanelItem.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/FetchCachedRepresentations.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/FetchManager.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/FetchManagerLocation.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/FetchResource.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/FetchVideoMediaResource.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/FileMediaResourceStatus.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ForwardAccessoryPanelNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/GalleryHiddenMediaManager.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/GifPaneSearchContentNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/GlobalExperimentalSettings.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/GridHoleItem.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/GridMessageItem.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/HashtagChatInputContextPanelNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/HashtagChatInputPanelItem.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/HorizontalListContextResultsChatInputContextPanelNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/HorizontalListContextResultsChatInputPanelItem.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/HorizontalStickerGridItem.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/HorizontalStickersChatContextPanelNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ICloudResources.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ID3ArtworkReader.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/IconButtonNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/InChatPrefetchManager.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Info.plist (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/InstantVideoRadialStatusNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/LegacyCache.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/LegacyCamera.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/LegacyInstantVideoController.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/LegacyLiveUploadInterface.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/LinkHighlightingNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ListMessageDateHeader.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ListMessageFileItemNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ListMessageHoleItem.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ListMessageItem.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ListMessageNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ListMessagePlaybackOverlayNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ListMessageSnippetItemNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/LockedWindowCoveringView.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ManageSharedAccountInfo.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ManagedAudioRecorder.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/MediaInputPaneTrendingItem.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/MediaManager.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/MediaPlaybackStoredState.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/MentionChatInputContextPanelNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/MentionChatInputPanelItem.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/MultiScaleTextNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/MultiplexedSoftwareVideoNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/MultiplexedSoftwareVideoSourceManager.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/MultiplexedVideoNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/NavigateToChatController.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/NotificationContainerController.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/NotificationContainerControllerNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/NotificationContentContext.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/NotificationItem.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/NotificationItemContainerNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/OpenAddContact.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/OpenChatMessage.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/OpenResolvedUrl.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/OpenUrl.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/OverlayAudioPlayerController.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/OverlayInstantVideoDecoration.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/OverlayInstantVideoNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/OverlayMediaController.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/OverlayMediaControllerNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/OverlayPlayerControllerNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/OverlayPlayerControlsNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/PaneSearchBarNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/PaneSearchBarPlaceholderItem.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/PaneSearchContainerNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Pasteboard.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/PeerInfo/ListItems/PeerInfoScreenActionItem.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/PeerInfo/ListItems/PeerInfoScreenAddressItem.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/PeerInfo/ListItems/PeerInfoScreenCallListItem.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/PeerInfo/ListItems/PeerInfoScreenCommentItem.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/PeerInfo/ListItems/PeerInfoScreenDisclosureEncryptionKeyItem.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/PeerInfo/ListItems/PeerInfoScreenDisclosureItem.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/PeerInfo/ListItems/PeerInfoScreenHeaderItem.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/PeerInfo/ListItems/PeerInfoScreenLabeledValueItem.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/PeerInfo/ListItems/PeerInfoScreenMemberItem.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/PeerInfo/ListItems/PeerInfoScreenSelectableBackgroundNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/PeerInfo/ListItems/PeerInfoScreenSwitchItem.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/PeerInfo/Panes/PeerInfoGroupsInCommonPaneNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/PeerInfo/Panes/PeerInfoListPaneNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/PeerInfo/Panes/PeerInfoMembersPane.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/PeerInfo/Panes/PeerInfoVisualMediaPaneNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/PeerInfo/PeerInfoData.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/PeerInfo/PeerInfoHeaderNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/PeerInfo/PeerInfoMembers.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/PeerInfo/PeerInfoPaneContainerNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/PeerInfo/PeerInfoScreen.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/PeerMediaCollectionController.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/PeerMediaCollectionControllerNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/PeerMediaCollectionEmptyNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/PeerMediaCollectionInterfaceState.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/PeerMediaCollectionInterfaceStateButtons.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/PeerMediaCollectionSectionsNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/PeerMessagesMediaPlaylist.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/PeerSelectionController.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/PeerSelectionControllerNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/PeersNearbyManager.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/PollResultsController.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/PrefetchManager.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/PrepareSecretThumbnailData.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/PreparedChatHistoryViewTransition.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ProcessedPeerRestrictionText.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/RadialProgressNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/RadialTimeoutNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ReplyAccessoryPanelNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/Animations/ChatListEmpty.tgs (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/Animations/ChatListFilterEmpty.tgs (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/Animations/anim_archive.json (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/Animations/anim_archiveAvatar.json (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/Animations/anim_archiveswipe.json (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/Animations/anim_delete.json (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/Animations/anim_group.json (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/Animations/anim_hide.json (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/Animations/anim_infotip.json (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/Animations/anim_mute.json (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/Animations/anim_pin.json (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/Animations/anim_qr.json (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/Animations/anim_read.json (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/Animations/anim_success.json (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/Animations/anim_swipereply.json (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/Animations/anim_unarchive.json (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/Animations/anim_ungroup.json (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/Animations/anim_unmute.json (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/Animations/anim_unpin.json (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/Animations/anim_unread.json (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/BuiltinReactions/celebrate.tgs (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/BuiltinReactions/cry.tgs (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/BuiltinReactions/heart.tgs (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/BuiltinReactions/lol.tgs (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/BuiltinReactions/meh.tgs (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/BuiltinReactions/ok.tgs (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/BuiltinReactions/poker.tgs (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/BuiltinReactions/poop.tgs (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/BuiltinReactions/sad.tgs (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/BuiltinReactions/smile.tgs (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/BuiltinReactions/surprised.tgs (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/BuiltinReactions/thumbsup.tgs (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/ChatWallpaperBuiltin0.jpg (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/Emoji.mapping (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/Fonts/SFCompactRounded-Semibold.otf (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/PhoneCountries.txt (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/PresentationStrings.mapping (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/StillReactions/simplereaction_10@2x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/StillReactions/simplereaction_10@3x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/StillReactions/simplereaction_11@2x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/StillReactions/simplereaction_11@3x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/StillReactions/simplereaction_12@2x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/StillReactions/simplereaction_12@3x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/StillReactions/simplereaction_13@2x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/StillReactions/simplereaction_13@3x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/StillReactions/simplereaction_14@2x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/StillReactions/simplereaction_14@3x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/StillReactions/simplereaction_15@2x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/StillReactions/simplereaction_15@3x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/StillReactions/simplereaction_16@2x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/StillReactions/simplereaction_16@3x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/StillReactions/simplereaction_17@2x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/StillReactions/simplereaction_17@3x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/StillReactions/simplereaction_18@2x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/StillReactions/simplereaction_18@3x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/StillReactions/simplereaction_19@2x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/StillReactions/simplereaction_19@3x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/StillReactions/simplereaction_1@2x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/StillReactions/simplereaction_1@3x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/StillReactions/simplereaction_20@2x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/StillReactions/simplereaction_20@3x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/StillReactions/simplereaction_2@2x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/StillReactions/simplereaction_2@3x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/StillReactions/simplereaction_3@2x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/StillReactions/simplereaction_3@3x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/StillReactions/simplereaction_4@2x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/StillReactions/simplereaction_4@3x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/StillReactions/simplereaction_5@2x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/StillReactions/simplereaction_5@3x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/StillReactions/simplereaction_6@2x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/StillReactions/simplereaction_6@3x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/StillReactions/simplereaction_7@2x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/StillReactions/simplereaction_7@3x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/StillReactions/simplereaction_8@2x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/StillReactions/simplereaction_8@3x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/StillReactions/simplereaction_9@2x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/StillReactions/simplereaction_9@3x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/Stripe/stp_card_amex@2x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/Stripe/stp_card_amex@3x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/Stripe/stp_card_amex_template@2x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/Stripe/stp_card_amex_template@3x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/Stripe/stp_card_applepay@2x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/Stripe/stp_card_applepay@3x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/Stripe/stp_card_applepay_template@2x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/Stripe/stp_card_applepay_template@3x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/Stripe/stp_card_cvc@2x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/Stripe/stp_card_cvc@3x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/Stripe/stp_card_cvc_amex@2x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/Stripe/stp_card_cvc_amex@3x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/Stripe/stp_card_diners@2x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/Stripe/stp_card_diners@3x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/Stripe/stp_card_diners_template@2x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/Stripe/stp_card_diners_template@3x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/Stripe/stp_card_discover@2x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/Stripe/stp_card_discover@3x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/Stripe/stp_card_discover_template@2x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/Stripe/stp_card_discover_template@3x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/Stripe/stp_card_form_applepay@2x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/Stripe/stp_card_form_applepay@3x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/Stripe/stp_card_form_back@2x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/Stripe/stp_card_form_back@3x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/Stripe/stp_card_form_front@2x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/Stripe/stp_card_form_front@3x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/Stripe/stp_card_jcb@2x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/Stripe/stp_card_jcb@3x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/Stripe/stp_card_jcb_template@2x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/Stripe/stp_card_jcb_template@3x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/Stripe/stp_card_mastercard@2x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/Stripe/stp_card_mastercard@3x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/Stripe/stp_card_mastercard_template@2x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/Stripe/stp_card_mastercard_template@3x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/Stripe/stp_card_placeholder_template@2x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/Stripe/stp_card_placeholder_template@3x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/Stripe/stp_card_visa@2x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/Stripe/stp_card_visa@3x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/Stripe/stp_card_visa_template@2x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/Stripe/stp_card_visa_template@3x.png (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/WebEmbed/Generic.html (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/WebEmbed/GenericUserScript.js (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/WebEmbed/Instagram.html (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/WebEmbed/Twitch.html (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/WebEmbed/TwitchUserScript.js (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/WebEmbed/Vimeo.html (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/WebEmbed/VimeoUserScript.js (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/WebEmbed/Youtube.html (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/WebEmbed/YoutubeUserScript.js (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Resources/currencies.json (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/SampleBufferPool.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/SecretChatHandshakeStatusInputPanelNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ServiceSoundManager.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ShareExtensionContext.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/SharedAccountContext.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/SharedMediaPlayer.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/SharedNotificationManager.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/SharedVideoContextManager.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/SharedWakeupManager.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/SoftwareVideoLayerFrameManager.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/SoftwareVideoThumbnailLayer.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Sounds/MessageSent.caf (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Sounds/notification.caf (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/SpotlightContacts.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/StickerPanePeerSpecificSetupGridItem.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/StickerPaneSearchContentNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/StickerPaneSearchGlobaltem.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/StickerPaneSearchStickerItem.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/StickersChatInputContextPanelItem.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/StickersChatInputContextPanelNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/StoreDownloadedMedia.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/StringForMessageTimestampStatus.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/SuppressContactsWarning.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/TelegramAccountAuxiliaryMethods.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/TelegramRootController.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/TelegramUI.h (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/TextLinkHandling.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/ThemeUpdateManager.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/TimeBasedVideoPreload.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/TonePlayer.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/TransformOutgoingMessageMedia.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/UpgradedAccounts.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/VerticalListContextResultsChatInputContextPanelNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/VerticalListContextResultsChatInputPanelButtonItem.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/VerticalListContextResultsChatInputPanelItem.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/VolumeButtons.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/WalletContextImpl.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/WallpaperPreviewMedia.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/WallpaperUploadManager.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/WatchManager.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/Weak.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/WebpagePreviewAccessoryPanelNode.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/WidgetDataContext.swift (100%) rename submodules/TelegramUI/{Sources => TelegramUI}/module.private.modulemap (100%) diff --git a/submodules/Display/Sources/ASTransformLayerNode.swift b/submodules/Display/Display/ASTransformLayerNode.swift similarity index 100% rename from submodules/Display/Sources/ASTransformLayerNode.swift rename to submodules/Display/Display/ASTransformLayerNode.swift diff --git a/submodules/Display/Sources/Accessibility.swift b/submodules/Display/Display/Accessibility.swift similarity index 100% rename from submodules/Display/Sources/Accessibility.swift rename to submodules/Display/Display/Accessibility.swift diff --git a/submodules/Display/Sources/AccessibilityAreaNode.swift b/submodules/Display/Display/AccessibilityAreaNode.swift similarity index 100% rename from submodules/Display/Sources/AccessibilityAreaNode.swift rename to submodules/Display/Display/AccessibilityAreaNode.swift diff --git a/submodules/Display/Sources/ActionSheetButtonItem.swift b/submodules/Display/Display/ActionSheetButtonItem.swift similarity index 100% rename from submodules/Display/Sources/ActionSheetButtonItem.swift rename to submodules/Display/Display/ActionSheetButtonItem.swift diff --git a/submodules/Display/Sources/ActionSheetCheckboxItem.swift b/submodules/Display/Display/ActionSheetCheckboxItem.swift similarity index 100% rename from submodules/Display/Sources/ActionSheetCheckboxItem.swift rename to submodules/Display/Display/ActionSheetCheckboxItem.swift diff --git a/submodules/Display/Sources/ActionSheetController.swift b/submodules/Display/Display/ActionSheetController.swift similarity index 100% rename from submodules/Display/Sources/ActionSheetController.swift rename to submodules/Display/Display/ActionSheetController.swift diff --git a/submodules/Display/Sources/ActionSheetControllerNode.swift b/submodules/Display/Display/ActionSheetControllerNode.swift similarity index 100% rename from submodules/Display/Sources/ActionSheetControllerNode.swift rename to submodules/Display/Display/ActionSheetControllerNode.swift diff --git a/submodules/Display/Sources/ActionSheetItem.swift b/submodules/Display/Display/ActionSheetItem.swift similarity index 100% rename from submodules/Display/Sources/ActionSheetItem.swift rename to submodules/Display/Display/ActionSheetItem.swift diff --git a/submodules/Display/Sources/ActionSheetItemGroup.swift b/submodules/Display/Display/ActionSheetItemGroup.swift similarity index 100% rename from submodules/Display/Sources/ActionSheetItemGroup.swift rename to submodules/Display/Display/ActionSheetItemGroup.swift diff --git a/submodules/Display/Sources/ActionSheetItemGroupNode.swift b/submodules/Display/Display/ActionSheetItemGroupNode.swift similarity index 100% rename from submodules/Display/Sources/ActionSheetItemGroupNode.swift rename to submodules/Display/Display/ActionSheetItemGroupNode.swift diff --git a/submodules/Display/Sources/ActionSheetItemGroupsContainerNode.swift b/submodules/Display/Display/ActionSheetItemGroupsContainerNode.swift similarity index 100% rename from submodules/Display/Sources/ActionSheetItemGroupsContainerNode.swift rename to submodules/Display/Display/ActionSheetItemGroupsContainerNode.swift diff --git a/submodules/Display/Sources/ActionSheetItemNode.swift b/submodules/Display/Display/ActionSheetItemNode.swift similarity index 100% rename from submodules/Display/Sources/ActionSheetItemNode.swift rename to submodules/Display/Display/ActionSheetItemNode.swift diff --git a/submodules/Display/Sources/ActionSheetSwitchItem.swift b/submodules/Display/Display/ActionSheetSwitchItem.swift similarity index 100% rename from submodules/Display/Sources/ActionSheetSwitchItem.swift rename to submodules/Display/Display/ActionSheetSwitchItem.swift diff --git a/submodules/Display/Sources/ActionSheetTextItem.swift b/submodules/Display/Display/ActionSheetTextItem.swift similarity index 100% rename from submodules/Display/Sources/ActionSheetTextItem.swift rename to submodules/Display/Display/ActionSheetTextItem.swift diff --git a/submodules/Display/Sources/ActionSheetTheme.swift b/submodules/Display/Display/ActionSheetTheme.swift similarity index 100% rename from submodules/Display/Sources/ActionSheetTheme.swift rename to submodules/Display/Display/ActionSheetTheme.swift diff --git a/submodules/Display/Sources/AlertContentNode.swift b/submodules/Display/Display/AlertContentNode.swift similarity index 100% rename from submodules/Display/Sources/AlertContentNode.swift rename to submodules/Display/Display/AlertContentNode.swift diff --git a/submodules/Display/Sources/AlertController.swift b/submodules/Display/Display/AlertController.swift similarity index 100% rename from submodules/Display/Sources/AlertController.swift rename to submodules/Display/Display/AlertController.swift diff --git a/submodules/Display/Sources/AlertControllerNode.swift b/submodules/Display/Display/AlertControllerNode.swift similarity index 100% rename from submodules/Display/Sources/AlertControllerNode.swift rename to submodules/Display/Display/AlertControllerNode.swift diff --git a/submodules/Display/Sources/CAAnimationUtils.swift b/submodules/Display/Display/CAAnimationUtils.swift similarity index 100% rename from submodules/Display/Sources/CAAnimationUtils.swift rename to submodules/Display/Display/CAAnimationUtils.swift diff --git a/submodules/Display/Sources/CASeeThroughTracingLayer.h b/submodules/Display/Display/CASeeThroughTracingLayer.h similarity index 100% rename from submodules/Display/Sources/CASeeThroughTracingLayer.h rename to submodules/Display/Display/CASeeThroughTracingLayer.h diff --git a/submodules/Display/Sources/CASeeThroughTracingLayer.m b/submodules/Display/Display/CASeeThroughTracingLayer.m similarity index 100% rename from submodules/Display/Sources/CASeeThroughTracingLayer.m rename to submodules/Display/Display/CASeeThroughTracingLayer.m diff --git a/submodules/Display/Sources/CATracingLayer.h b/submodules/Display/Display/CATracingLayer.h similarity index 100% rename from submodules/Display/Sources/CATracingLayer.h rename to submodules/Display/Display/CATracingLayer.h diff --git a/submodules/Display/Sources/CATracingLayer.m b/submodules/Display/Display/CATracingLayer.m similarity index 100% rename from submodules/Display/Sources/CATracingLayer.m rename to submodules/Display/Display/CATracingLayer.m diff --git a/submodules/Display/Sources/ChildWindowHostView.swift b/submodules/Display/Display/ChildWindowHostView.swift similarity index 100% rename from submodules/Display/Sources/ChildWindowHostView.swift rename to submodules/Display/Display/ChildWindowHostView.swift diff --git a/submodules/Display/Sources/CollectionIndexNode.swift b/submodules/Display/Display/CollectionIndexNode.swift similarity index 100% rename from submodules/Display/Sources/CollectionIndexNode.swift rename to submodules/Display/Display/CollectionIndexNode.swift diff --git a/submodules/Display/Sources/ContainableController.swift b/submodules/Display/Display/ContainableController.swift similarity index 100% rename from submodules/Display/Sources/ContainableController.swift rename to submodules/Display/Display/ContainableController.swift diff --git a/submodules/Display/Sources/ContainedViewLayoutTransition.swift b/submodules/Display/Display/ContainedViewLayoutTransition.swift similarity index 100% rename from submodules/Display/Sources/ContainedViewLayoutTransition.swift rename to submodules/Display/Display/ContainedViewLayoutTransition.swift diff --git a/submodules/Display/Sources/ContainerViewLayout.swift b/submodules/Display/Display/ContainerViewLayout.swift similarity index 100% rename from submodules/Display/Sources/ContainerViewLayout.swift rename to submodules/Display/Display/ContainerViewLayout.swift diff --git a/submodules/Display/Sources/ContextContentContainerNode.swift b/submodules/Display/Display/ContextContentContainerNode.swift similarity index 100% rename from submodules/Display/Sources/ContextContentContainerNode.swift rename to submodules/Display/Display/ContextContentContainerNode.swift diff --git a/submodules/Display/Sources/ContextContentSourceNode.swift b/submodules/Display/Display/ContextContentSourceNode.swift similarity index 100% rename from submodules/Display/Sources/ContextContentSourceNode.swift rename to submodules/Display/Display/ContextContentSourceNode.swift diff --git a/submodules/Display/Sources/ContextControllerSourceNode.swift b/submodules/Display/Display/ContextControllerSourceNode.swift similarity index 100% rename from submodules/Display/Sources/ContextControllerSourceNode.swift rename to submodules/Display/Display/ContextControllerSourceNode.swift diff --git a/submodules/Display/Sources/ContextGesture.swift b/submodules/Display/Display/ContextGesture.swift similarity index 100% rename from submodules/Display/Sources/ContextGesture.swift rename to submodules/Display/Display/ContextGesture.swift diff --git a/submodules/Display/Sources/ContextMenuAction.swift b/submodules/Display/Display/ContextMenuAction.swift similarity index 100% rename from submodules/Display/Sources/ContextMenuAction.swift rename to submodules/Display/Display/ContextMenuAction.swift diff --git a/submodules/Display/Sources/ContextMenuActionNode.swift b/submodules/Display/Display/ContextMenuActionNode.swift similarity index 100% rename from submodules/Display/Sources/ContextMenuActionNode.swift rename to submodules/Display/Display/ContextMenuActionNode.swift diff --git a/submodules/Display/Sources/ContextMenuContainerNode.swift b/submodules/Display/Display/ContextMenuContainerNode.swift similarity index 100% rename from submodules/Display/Sources/ContextMenuContainerNode.swift rename to submodules/Display/Display/ContextMenuContainerNode.swift diff --git a/submodules/Display/Sources/ContextMenuController.swift b/submodules/Display/Display/ContextMenuController.swift similarity index 100% rename from submodules/Display/Sources/ContextMenuController.swift rename to submodules/Display/Display/ContextMenuController.swift diff --git a/submodules/Display/Sources/ContextMenuNode.swift b/submodules/Display/Display/ContextMenuNode.swift similarity index 100% rename from submodules/Display/Sources/ContextMenuNode.swift rename to submodules/Display/Display/ContextMenuNode.swift diff --git a/submodules/Display/Sources/DeviceMetrics.swift b/submodules/Display/Display/DeviceMetrics.swift similarity index 100% rename from submodules/Display/Sources/DeviceMetrics.swift rename to submodules/Display/Display/DeviceMetrics.swift diff --git a/submodules/Display/Sources/Display.h b/submodules/Display/Display/Display.h similarity index 100% rename from submodules/Display/Sources/Display.h rename to submodules/Display/Display/Display.h diff --git a/submodules/Display/Sources/DisplayLinkAnimator.swift b/submodules/Display/Display/DisplayLinkAnimator.swift similarity index 100% rename from submodules/Display/Sources/DisplayLinkAnimator.swift rename to submodules/Display/Display/DisplayLinkAnimator.swift diff --git a/submodules/Display/Sources/DisplayLinkDispatcher.swift b/submodules/Display/Display/DisplayLinkDispatcher.swift similarity index 100% rename from submodules/Display/Sources/DisplayLinkDispatcher.swift rename to submodules/Display/Display/DisplayLinkDispatcher.swift diff --git a/submodules/Display/Sources/EditableTextNode.swift b/submodules/Display/Display/EditableTextNode.swift similarity index 100% rename from submodules/Display/Sources/EditableTextNode.swift rename to submodules/Display/Display/EditableTextNode.swift diff --git a/submodules/Display/Sources/Font.swift b/submodules/Display/Display/Font.swift similarity index 100% rename from submodules/Display/Sources/Font.swift rename to submodules/Display/Display/Font.swift diff --git a/submodules/Display/Sources/GenerateImage.swift b/submodules/Display/Display/GenerateImage.swift similarity index 100% rename from submodules/Display/Sources/GenerateImage.swift rename to submodules/Display/Display/GenerateImage.swift diff --git a/submodules/Display/Sources/GlobalOverlayPresentationContext.swift b/submodules/Display/Display/GlobalOverlayPresentationContext.swift similarity index 100% rename from submodules/Display/Sources/GlobalOverlayPresentationContext.swift rename to submodules/Display/Display/GlobalOverlayPresentationContext.swift diff --git a/submodules/Display/Sources/GridItem.swift b/submodules/Display/Display/GridItem.swift similarity index 100% rename from submodules/Display/Sources/GridItem.swift rename to submodules/Display/Display/GridItem.swift diff --git a/submodules/Display/Sources/GridItemNode.swift b/submodules/Display/Display/GridItemNode.swift similarity index 100% rename from submodules/Display/Sources/GridItemNode.swift rename to submodules/Display/Display/GridItemNode.swift diff --git a/submodules/Display/Sources/GridNode.swift b/submodules/Display/Display/GridNode.swift similarity index 100% rename from submodules/Display/Sources/GridNode.swift rename to submodules/Display/Display/GridNode.swift diff --git a/submodules/Display/Sources/GridNodeScroller.swift b/submodules/Display/Display/GridNodeScroller.swift similarity index 100% rename from submodules/Display/Sources/GridNodeScroller.swift rename to submodules/Display/Display/GridNodeScroller.swift diff --git a/submodules/Display/Sources/HapticFeedback.swift b/submodules/Display/Display/HapticFeedback.swift similarity index 100% rename from submodules/Display/Sources/HapticFeedback.swift rename to submodules/Display/Display/HapticFeedback.swift diff --git a/submodules/Display/Sources/HighlightTrackingButton.swift b/submodules/Display/Display/HighlightTrackingButton.swift similarity index 100% rename from submodules/Display/Sources/HighlightTrackingButton.swift rename to submodules/Display/Display/HighlightTrackingButton.swift diff --git a/submodules/Display/Sources/HighlightableButton.swift b/submodules/Display/Display/HighlightableButton.swift similarity index 100% rename from submodules/Display/Sources/HighlightableButton.swift rename to submodules/Display/Display/HighlightableButton.swift diff --git a/submodules/Display/Sources/ImageCorners.swift b/submodules/Display/Display/ImageCorners.swift similarity index 100% rename from submodules/Display/Sources/ImageCorners.swift rename to submodules/Display/Display/ImageCorners.swift diff --git a/submodules/Display/Sources/ImageNode.swift b/submodules/Display/Display/ImageNode.swift similarity index 100% rename from submodules/Display/Sources/ImageNode.swift rename to submodules/Display/Display/ImageNode.swift diff --git a/submodules/Display/Sources/ImmediateTextNode.swift b/submodules/Display/Display/ImmediateTextNode.swift similarity index 100% rename from submodules/Display/Sources/ImmediateTextNode.swift rename to submodules/Display/Display/ImmediateTextNode.swift diff --git a/submodules/Display/Sources/Info.plist b/submodules/Display/Display/Info.plist similarity index 100% rename from submodules/Display/Sources/Info.plist rename to submodules/Display/Display/Info.plist diff --git a/submodules/Display/Sources/InteractiveTransitionGestureRecognizer.swift b/submodules/Display/Display/InteractiveTransitionGestureRecognizer.swift similarity index 100% rename from submodules/Display/Sources/InteractiveTransitionGestureRecognizer.swift rename to submodules/Display/Display/InteractiveTransitionGestureRecognizer.swift diff --git a/submodules/Display/Sources/KeyShortcut.swift b/submodules/Display/Display/KeyShortcut.swift similarity index 100% rename from submodules/Display/Sources/KeyShortcut.swift rename to submodules/Display/Display/KeyShortcut.swift diff --git a/submodules/Display/Sources/KeyShortcutsController.swift b/submodules/Display/Display/KeyShortcutsController.swift similarity index 100% rename from submodules/Display/Sources/KeyShortcutsController.swift rename to submodules/Display/Display/KeyShortcutsController.swift diff --git a/submodules/Display/Sources/Keyboard.swift b/submodules/Display/Display/Keyboard.swift similarity index 100% rename from submodules/Display/Sources/Keyboard.swift rename to submodules/Display/Display/Keyboard.swift diff --git a/submodules/Display/Sources/KeyboardManager.swift b/submodules/Display/Display/KeyboardManager.swift similarity index 100% rename from submodules/Display/Sources/KeyboardManager.swift rename to submodules/Display/Display/KeyboardManager.swift diff --git a/submodules/Display/Sources/LayoutSizes.swift b/submodules/Display/Display/LayoutSizes.swift similarity index 100% rename from submodules/Display/Sources/LayoutSizes.swift rename to submodules/Display/Display/LayoutSizes.swift diff --git a/submodules/Display/Sources/LegacyPresentedController.swift b/submodules/Display/Display/LegacyPresentedController.swift similarity index 100% rename from submodules/Display/Sources/LegacyPresentedController.swift rename to submodules/Display/Display/LegacyPresentedController.swift diff --git a/submodules/Display/Sources/LegacyPresentedControllerNode.swift b/submodules/Display/Display/LegacyPresentedControllerNode.swift similarity index 100% rename from submodules/Display/Sources/LegacyPresentedControllerNode.swift rename to submodules/Display/Display/LegacyPresentedControllerNode.swift diff --git a/submodules/Display/Sources/LinkHighlightingNode.swift b/submodules/Display/Display/LinkHighlightingNode.swift similarity index 100% rename from submodules/Display/Sources/LinkHighlightingNode.swift rename to submodules/Display/Display/LinkHighlightingNode.swift diff --git a/submodules/Display/Sources/ListView.swift b/submodules/Display/Display/ListView.swift similarity index 100% rename from submodules/Display/Sources/ListView.swift rename to submodules/Display/Display/ListView.swift diff --git a/submodules/Display/Sources/ListViewAccessoryItem.swift b/submodules/Display/Display/ListViewAccessoryItem.swift similarity index 100% rename from submodules/Display/Sources/ListViewAccessoryItem.swift rename to submodules/Display/Display/ListViewAccessoryItem.swift diff --git a/submodules/Display/Sources/ListViewAccessoryItemNode.swift b/submodules/Display/Display/ListViewAccessoryItemNode.swift similarity index 100% rename from submodules/Display/Sources/ListViewAccessoryItemNode.swift rename to submodules/Display/Display/ListViewAccessoryItemNode.swift diff --git a/submodules/Display/Sources/ListViewAnimation.swift b/submodules/Display/Display/ListViewAnimation.swift similarity index 100% rename from submodules/Display/Sources/ListViewAnimation.swift rename to submodules/Display/Display/ListViewAnimation.swift diff --git a/submodules/Display/Sources/ListViewFloatingHeaderNode.swift b/submodules/Display/Display/ListViewFloatingHeaderNode.swift similarity index 100% rename from submodules/Display/Sources/ListViewFloatingHeaderNode.swift rename to submodules/Display/Display/ListViewFloatingHeaderNode.swift diff --git a/submodules/Display/Sources/ListViewIntermediateState.swift b/submodules/Display/Display/ListViewIntermediateState.swift similarity index 100% rename from submodules/Display/Sources/ListViewIntermediateState.swift rename to submodules/Display/Display/ListViewIntermediateState.swift diff --git a/submodules/Display/Sources/ListViewItem.swift b/submodules/Display/Display/ListViewItem.swift similarity index 100% rename from submodules/Display/Sources/ListViewItem.swift rename to submodules/Display/Display/ListViewItem.swift diff --git a/submodules/Display/Sources/ListViewItemHeader.swift b/submodules/Display/Display/ListViewItemHeader.swift similarity index 100% rename from submodules/Display/Sources/ListViewItemHeader.swift rename to submodules/Display/Display/ListViewItemHeader.swift diff --git a/submodules/Display/Sources/ListViewItemNode.swift b/submodules/Display/Display/ListViewItemNode.swift similarity index 100% rename from submodules/Display/Sources/ListViewItemNode.swift rename to submodules/Display/Display/ListViewItemNode.swift diff --git a/submodules/Display/Sources/ListViewOverscrollBackgroundNode.swift b/submodules/Display/Display/ListViewOverscrollBackgroundNode.swift similarity index 100% rename from submodules/Display/Sources/ListViewOverscrollBackgroundNode.swift rename to submodules/Display/Display/ListViewOverscrollBackgroundNode.swift diff --git a/submodules/Display/Sources/ListViewReorderingGestureRecognizer.swift b/submodules/Display/Display/ListViewReorderingGestureRecognizer.swift similarity index 100% rename from submodules/Display/Sources/ListViewReorderingGestureRecognizer.swift rename to submodules/Display/Display/ListViewReorderingGestureRecognizer.swift diff --git a/submodules/Display/Sources/ListViewReorderingItemNode.swift b/submodules/Display/Display/ListViewReorderingItemNode.swift similarity index 100% rename from submodules/Display/Sources/ListViewReorderingItemNode.swift rename to submodules/Display/Display/ListViewReorderingItemNode.swift diff --git a/submodules/Display/Sources/ListViewScroller.swift b/submodules/Display/Display/ListViewScroller.swift similarity index 100% rename from submodules/Display/Sources/ListViewScroller.swift rename to submodules/Display/Display/ListViewScroller.swift diff --git a/submodules/Display/Sources/ListViewTapGestureRecognizer.swift b/submodules/Display/Display/ListViewTapGestureRecognizer.swift similarity index 100% rename from submodules/Display/Sources/ListViewTapGestureRecognizer.swift rename to submodules/Display/Display/ListViewTapGestureRecognizer.swift diff --git a/submodules/Display/Sources/ListViewTempItemNode.swift b/submodules/Display/Display/ListViewTempItemNode.swift similarity index 100% rename from submodules/Display/Sources/ListViewTempItemNode.swift rename to submodules/Display/Display/ListViewTempItemNode.swift diff --git a/submodules/Display/Sources/ListViewTransactionQueue.swift b/submodules/Display/Display/ListViewTransactionQueue.swift similarity index 100% rename from submodules/Display/Sources/ListViewTransactionQueue.swift rename to submodules/Display/Display/ListViewTransactionQueue.swift diff --git a/submodules/Display/Sources/MinimizeKeyboardGestureRecognizer.swift b/submodules/Display/Display/MinimizeKeyboardGestureRecognizer.swift similarity index 100% rename from submodules/Display/Sources/MinimizeKeyboardGestureRecognizer.swift rename to submodules/Display/Display/MinimizeKeyboardGestureRecognizer.swift diff --git a/submodules/Display/Sources/NSBag.h b/submodules/Display/Display/NSBag.h similarity index 100% rename from submodules/Display/Sources/NSBag.h rename to submodules/Display/Display/NSBag.h diff --git a/submodules/Display/Sources/NSBag.m b/submodules/Display/Display/NSBag.m similarity index 100% rename from submodules/Display/Sources/NSBag.m rename to submodules/Display/Display/NSBag.m diff --git a/submodules/Display/Sources/NSWeakReference.h b/submodules/Display/Display/NSWeakReference.h similarity index 100% rename from submodules/Display/Sources/NSWeakReference.h rename to submodules/Display/Display/NSWeakReference.h diff --git a/submodules/Display/Sources/NSWeakReference.m b/submodules/Display/Display/NSWeakReference.m similarity index 100% rename from submodules/Display/Sources/NSWeakReference.m rename to submodules/Display/Display/NSWeakReference.m diff --git a/submodules/Display/Sources/NativeWindowHostView.swift b/submodules/Display/Display/NativeWindowHostView.swift similarity index 100% rename from submodules/Display/Sources/NativeWindowHostView.swift rename to submodules/Display/Display/NativeWindowHostView.swift diff --git a/submodules/Display/Sources/Navigation/NavigationContainer.swift b/submodules/Display/Display/Navigation/NavigationContainer.swift similarity index 100% rename from submodules/Display/Sources/Navigation/NavigationContainer.swift rename to submodules/Display/Display/Navigation/NavigationContainer.swift diff --git a/submodules/Display/Sources/Navigation/NavigationController.swift b/submodules/Display/Display/Navigation/NavigationController.swift similarity index 100% rename from submodules/Display/Sources/Navigation/NavigationController.swift rename to submodules/Display/Display/Navigation/NavigationController.swift diff --git a/submodules/Display/Sources/Navigation/NavigationLayout.swift b/submodules/Display/Display/Navigation/NavigationLayout.swift similarity index 100% rename from submodules/Display/Sources/Navigation/NavigationLayout.swift rename to submodules/Display/Display/Navigation/NavigationLayout.swift diff --git a/submodules/Display/Sources/Navigation/NavigationModalContainer.swift b/submodules/Display/Display/Navigation/NavigationModalContainer.swift similarity index 100% rename from submodules/Display/Sources/Navigation/NavigationModalContainer.swift rename to submodules/Display/Display/Navigation/NavigationModalContainer.swift diff --git a/submodules/Display/Sources/Navigation/NavigationModalFrame.swift b/submodules/Display/Display/Navigation/NavigationModalFrame.swift similarity index 100% rename from submodules/Display/Sources/Navigation/NavigationModalFrame.swift rename to submodules/Display/Display/Navigation/NavigationModalFrame.swift diff --git a/submodules/Display/Sources/Navigation/NavigationOverlayContainer.swift b/submodules/Display/Display/Navigation/NavigationOverlayContainer.swift similarity index 100% rename from submodules/Display/Sources/Navigation/NavigationOverlayContainer.swift rename to submodules/Display/Display/Navigation/NavigationOverlayContainer.swift diff --git a/submodules/Display/Sources/Navigation/NavigationSplitContainer.swift b/submodules/Display/Display/Navigation/NavigationSplitContainer.swift similarity index 100% rename from submodules/Display/Sources/Navigation/NavigationSplitContainer.swift rename to submodules/Display/Display/Navigation/NavigationSplitContainer.swift diff --git a/submodules/Display/Sources/NavigationBackButtonNode.swift b/submodules/Display/Display/NavigationBackButtonNode.swift similarity index 100% rename from submodules/Display/Sources/NavigationBackButtonNode.swift rename to submodules/Display/Display/NavigationBackButtonNode.swift diff --git a/submodules/Display/Sources/NavigationBar.swift b/submodules/Display/Display/NavigationBar.swift similarity index 100% rename from submodules/Display/Sources/NavigationBar.swift rename to submodules/Display/Display/NavigationBar.swift diff --git a/submodules/Display/Sources/NavigationBarBadge.swift b/submodules/Display/Display/NavigationBarBadge.swift similarity index 100% rename from submodules/Display/Sources/NavigationBarBadge.swift rename to submodules/Display/Display/NavigationBarBadge.swift diff --git a/submodules/Display/Sources/NavigationBarContentNode.swift b/submodules/Display/Display/NavigationBarContentNode.swift similarity index 100% rename from submodules/Display/Sources/NavigationBarContentNode.swift rename to submodules/Display/Display/NavigationBarContentNode.swift diff --git a/submodules/Display/Sources/NavigationBarProxy.h b/submodules/Display/Display/NavigationBarProxy.h similarity index 100% rename from submodules/Display/Sources/NavigationBarProxy.h rename to submodules/Display/Display/NavigationBarProxy.h diff --git a/submodules/Display/Sources/NavigationBarProxy.m b/submodules/Display/Display/NavigationBarProxy.m similarity index 100% rename from submodules/Display/Sources/NavigationBarProxy.m rename to submodules/Display/Display/NavigationBarProxy.m diff --git a/submodules/Display/Sources/NavigationBarTitleTransitionNode.swift b/submodules/Display/Display/NavigationBarTitleTransitionNode.swift similarity index 100% rename from submodules/Display/Sources/NavigationBarTitleTransitionNode.swift rename to submodules/Display/Display/NavigationBarTitleTransitionNode.swift diff --git a/submodules/Display/Sources/NavigationBarTitleView.swift b/submodules/Display/Display/NavigationBarTitleView.swift similarity index 100% rename from submodules/Display/Sources/NavigationBarTitleView.swift rename to submodules/Display/Display/NavigationBarTitleView.swift diff --git a/submodules/Display/Sources/NavigationBarTransitionContainer.swift b/submodules/Display/Display/NavigationBarTransitionContainer.swift similarity index 100% rename from submodules/Display/Sources/NavigationBarTransitionContainer.swift rename to submodules/Display/Display/NavigationBarTransitionContainer.swift diff --git a/submodules/Display/Sources/NavigationBarTransitionState.swift b/submodules/Display/Display/NavigationBarTransitionState.swift similarity index 100% rename from submodules/Display/Sources/NavigationBarTransitionState.swift rename to submodules/Display/Display/NavigationBarTransitionState.swift diff --git a/submodules/Display/Sources/NavigationButtonNode.swift b/submodules/Display/Display/NavigationButtonNode.swift similarity index 100% rename from submodules/Display/Sources/NavigationButtonNode.swift rename to submodules/Display/Display/NavigationButtonNode.swift diff --git a/submodules/Display/Sources/NavigationControllerProxy.h b/submodules/Display/Display/NavigationControllerProxy.h similarity index 100% rename from submodules/Display/Sources/NavigationControllerProxy.h rename to submodules/Display/Display/NavigationControllerProxy.h diff --git a/submodules/Display/Sources/NavigationControllerProxy.m b/submodules/Display/Display/NavigationControllerProxy.m similarity index 100% rename from submodules/Display/Sources/NavigationControllerProxy.m rename to submodules/Display/Display/NavigationControllerProxy.m diff --git a/submodules/Display/Sources/NavigationTitleNode.swift b/submodules/Display/Display/NavigationTitleNode.swift similarity index 100% rename from submodules/Display/Sources/NavigationTitleNode.swift rename to submodules/Display/Display/NavigationTitleNode.swift diff --git a/submodules/Display/Sources/NavigationTransitionCoordinator.swift b/submodules/Display/Display/NavigationTransitionCoordinator.swift similarity index 100% rename from submodules/Display/Sources/NavigationTransitionCoordinator.swift rename to submodules/Display/Display/NavigationTransitionCoordinator.swift diff --git a/submodules/Display/Sources/NotificationCenterUtils.h b/submodules/Display/Display/NotificationCenterUtils.h similarity index 100% rename from submodules/Display/Sources/NotificationCenterUtils.h rename to submodules/Display/Display/NotificationCenterUtils.h diff --git a/submodules/Display/Sources/NotificationCenterUtils.m b/submodules/Display/Display/NotificationCenterUtils.m similarity index 100% rename from submodules/Display/Sources/NotificationCenterUtils.m rename to submodules/Display/Display/NotificationCenterUtils.m diff --git a/submodules/Display/Sources/PageControlNode.swift b/submodules/Display/Display/PageControlNode.swift similarity index 100% rename from submodules/Display/Sources/PageControlNode.swift rename to submodules/Display/Display/PageControlNode.swift diff --git a/submodules/Display/Sources/PeekController.swift b/submodules/Display/Display/PeekController.swift similarity index 100% rename from submodules/Display/Sources/PeekController.swift rename to submodules/Display/Display/PeekController.swift diff --git a/submodules/Display/Sources/PeekControllerContent.swift b/submodules/Display/Display/PeekControllerContent.swift similarity index 100% rename from submodules/Display/Sources/PeekControllerContent.swift rename to submodules/Display/Display/PeekControllerContent.swift diff --git a/submodules/Display/Sources/PeekControllerGestureRecognizer.swift b/submodules/Display/Display/PeekControllerGestureRecognizer.swift similarity index 100% rename from submodules/Display/Sources/PeekControllerGestureRecognizer.swift rename to submodules/Display/Display/PeekControllerGestureRecognizer.swift diff --git a/submodules/Display/Sources/PeekControllerMenuItemNode.swift b/submodules/Display/Display/PeekControllerMenuItemNode.swift similarity index 100% rename from submodules/Display/Sources/PeekControllerMenuItemNode.swift rename to submodules/Display/Display/PeekControllerMenuItemNode.swift diff --git a/submodules/Display/Sources/PeekControllerMenuNode.swift b/submodules/Display/Display/PeekControllerMenuNode.swift similarity index 100% rename from submodules/Display/Sources/PeekControllerMenuNode.swift rename to submodules/Display/Display/PeekControllerMenuNode.swift diff --git a/submodules/Display/Sources/PeekControllerNode.swift b/submodules/Display/Display/PeekControllerNode.swift similarity index 100% rename from submodules/Display/Sources/PeekControllerNode.swift rename to submodules/Display/Display/PeekControllerNode.swift diff --git a/submodules/Display/Sources/PresentationContext.swift b/submodules/Display/Display/PresentationContext.swift similarity index 100% rename from submodules/Display/Sources/PresentationContext.swift rename to submodules/Display/Display/PresentationContext.swift diff --git a/submodules/Display/Sources/RuntimeUtils.h b/submodules/Display/Display/RuntimeUtils.h similarity index 100% rename from submodules/Display/Sources/RuntimeUtils.h rename to submodules/Display/Display/RuntimeUtils.h diff --git a/submodules/Display/Sources/RuntimeUtils.m b/submodules/Display/Display/RuntimeUtils.m similarity index 100% rename from submodules/Display/Sources/RuntimeUtils.m rename to submodules/Display/Display/RuntimeUtils.m diff --git a/submodules/Display/Sources/RuntimeUtils.swift b/submodules/Display/Display/RuntimeUtils.swift similarity index 100% rename from submodules/Display/Sources/RuntimeUtils.swift rename to submodules/Display/Display/RuntimeUtils.swift diff --git a/submodules/Display/Sources/ScrollToTopProxyView.swift b/submodules/Display/Display/ScrollToTopProxyView.swift similarity index 100% rename from submodules/Display/Sources/ScrollToTopProxyView.swift rename to submodules/Display/Display/ScrollToTopProxyView.swift diff --git a/submodules/Display/Sources/ShakeAnimation.swift b/submodules/Display/Display/ShakeAnimation.swift similarity index 100% rename from submodules/Display/Sources/ShakeAnimation.swift rename to submodules/Display/Display/ShakeAnimation.swift diff --git a/submodules/Display/Sources/Spring.swift b/submodules/Display/Display/Spring.swift similarity index 100% rename from submodules/Display/Sources/Spring.swift rename to submodules/Display/Display/Spring.swift diff --git a/submodules/Display/Sources/StatusBar.swift b/submodules/Display/Display/StatusBar.swift similarity index 100% rename from submodules/Display/Sources/StatusBar.swift rename to submodules/Display/Display/StatusBar.swift diff --git a/submodules/Display/Sources/StatusBarHost.swift b/submodules/Display/Display/StatusBarHost.swift similarity index 100% rename from submodules/Display/Sources/StatusBarHost.swift rename to submodules/Display/Display/StatusBarHost.swift diff --git a/submodules/Display/Sources/StatusBarProxyNode.swift b/submodules/Display/Display/StatusBarProxyNode.swift similarity index 100% rename from submodules/Display/Sources/StatusBarProxyNode.swift rename to submodules/Display/Display/StatusBarProxyNode.swift diff --git a/submodules/Display/Sources/SubstringSearch.swift b/submodules/Display/Display/SubstringSearch.swift similarity index 100% rename from submodules/Display/Sources/SubstringSearch.swift rename to submodules/Display/Display/SubstringSearch.swift diff --git a/submodules/Display/Sources/SwitchNode.swift b/submodules/Display/Display/SwitchNode.swift similarity index 100% rename from submodules/Display/Sources/SwitchNode.swift rename to submodules/Display/Display/SwitchNode.swift diff --git a/submodules/Display/Sources/TabBarContollerNode.swift b/submodules/Display/Display/TabBarContollerNode.swift similarity index 100% rename from submodules/Display/Sources/TabBarContollerNode.swift rename to submodules/Display/Display/TabBarContollerNode.swift diff --git a/submodules/Display/Sources/TabBarController.swift b/submodules/Display/Display/TabBarController.swift similarity index 100% rename from submodules/Display/Sources/TabBarController.swift rename to submodules/Display/Display/TabBarController.swift diff --git a/submodules/Display/Sources/TabBarNode.swift b/submodules/Display/Display/TabBarNode.swift similarity index 100% rename from submodules/Display/Sources/TabBarNode.swift rename to submodules/Display/Display/TabBarNode.swift diff --git a/submodules/Display/Sources/TabBarTapRecognizer.swift b/submodules/Display/Display/TabBarTapRecognizer.swift similarity index 100% rename from submodules/Display/Sources/TabBarTapRecognizer.swift rename to submodules/Display/Display/TabBarTapRecognizer.swift diff --git a/submodules/Display/Sources/TapLongTapOrDoubleTapGestureRecognizer.swift b/submodules/Display/Display/TapLongTapOrDoubleTapGestureRecognizer.swift similarity index 100% rename from submodules/Display/Sources/TapLongTapOrDoubleTapGestureRecognizer.swift rename to submodules/Display/Display/TapLongTapOrDoubleTapGestureRecognizer.swift diff --git a/submodules/Display/Sources/TextAlertController.swift b/submodules/Display/Display/TextAlertController.swift similarity index 100% rename from submodules/Display/Sources/TextAlertController.swift rename to submodules/Display/Display/TextAlertController.swift diff --git a/submodules/Display/Sources/TextFieldNode.swift b/submodules/Display/Display/TextFieldNode.swift similarity index 100% rename from submodules/Display/Sources/TextFieldNode.swift rename to submodules/Display/Display/TextFieldNode.swift diff --git a/submodules/Display/Sources/TextNode.swift b/submodules/Display/Display/TextNode.swift similarity index 100% rename from submodules/Display/Sources/TextNode.swift rename to submodules/Display/Display/TextNode.swift diff --git a/submodules/Display/Sources/Toolbar.swift b/submodules/Display/Display/Toolbar.swift similarity index 100% rename from submodules/Display/Sources/Toolbar.swift rename to submodules/Display/Display/Toolbar.swift diff --git a/submodules/Display/Sources/ToolbarNode.swift b/submodules/Display/Display/ToolbarNode.swift similarity index 100% rename from submodules/Display/Sources/ToolbarNode.swift rename to submodules/Display/Display/ToolbarNode.swift diff --git a/submodules/Display/Sources/TooltipController.swift b/submodules/Display/Display/TooltipController.swift similarity index 100% rename from submodules/Display/Sources/TooltipController.swift rename to submodules/Display/Display/TooltipController.swift diff --git a/submodules/Display/Sources/TooltipControllerNode.swift b/submodules/Display/Display/TooltipControllerNode.swift similarity index 100% rename from submodules/Display/Sources/TooltipControllerNode.swift rename to submodules/Display/Display/TooltipControllerNode.swift diff --git a/submodules/Display/Sources/TransformImageArguments.swift b/submodules/Display/Display/TransformImageArguments.swift similarity index 100% rename from submodules/Display/Sources/TransformImageArguments.swift rename to submodules/Display/Display/TransformImageArguments.swift diff --git a/submodules/Display/Sources/TransformImageNode.swift b/submodules/Display/Display/TransformImageNode.swift similarity index 100% rename from submodules/Display/Sources/TransformImageNode.swift rename to submodules/Display/Display/TransformImageNode.swift diff --git a/submodules/Display/Sources/UIBarButtonItem+Proxy.h b/submodules/Display/Display/UIBarButtonItem+Proxy.h similarity index 100% rename from submodules/Display/Sources/UIBarButtonItem+Proxy.h rename to submodules/Display/Display/UIBarButtonItem+Proxy.h diff --git a/submodules/Display/Sources/UIBarButtonItem+Proxy.m b/submodules/Display/Display/UIBarButtonItem+Proxy.m similarity index 100% rename from submodules/Display/Sources/UIBarButtonItem+Proxy.m rename to submodules/Display/Display/UIBarButtonItem+Proxy.m diff --git a/submodules/Display/Sources/UIKitUtils.h b/submodules/Display/Display/UIKitUtils.h similarity index 100% rename from submodules/Display/Sources/UIKitUtils.h rename to submodules/Display/Display/UIKitUtils.h diff --git a/submodules/Display/Sources/UIKitUtils.m b/submodules/Display/Display/UIKitUtils.m similarity index 100% rename from submodules/Display/Sources/UIKitUtils.m rename to submodules/Display/Display/UIKitUtils.m diff --git a/submodules/Display/Sources/UIKitUtils.swift b/submodules/Display/Display/UIKitUtils.swift similarity index 100% rename from submodules/Display/Sources/UIKitUtils.swift rename to submodules/Display/Display/UIKitUtils.swift diff --git a/submodules/Display/Sources/UIMenuItem+Icons.h b/submodules/Display/Display/UIMenuItem+Icons.h similarity index 100% rename from submodules/Display/Sources/UIMenuItem+Icons.h rename to submodules/Display/Display/UIMenuItem+Icons.h diff --git a/submodules/Display/Sources/UIMenuItem+Icons.m b/submodules/Display/Display/UIMenuItem+Icons.m similarity index 100% rename from submodules/Display/Sources/UIMenuItem+Icons.m rename to submodules/Display/Display/UIMenuItem+Icons.m diff --git a/submodules/Display/Sources/UINavigationItem+Proxy.h b/submodules/Display/Display/UINavigationItem+Proxy.h similarity index 100% rename from submodules/Display/Sources/UINavigationItem+Proxy.h rename to submodules/Display/Display/UINavigationItem+Proxy.h diff --git a/submodules/Display/Sources/UINavigationItem+Proxy.m b/submodules/Display/Display/UINavigationItem+Proxy.m similarity index 100% rename from submodules/Display/Sources/UINavigationItem+Proxy.m rename to submodules/Display/Display/UINavigationItem+Proxy.m diff --git a/submodules/Display/Sources/UITracingLayerView.swift b/submodules/Display/Display/UITracingLayerView.swift similarity index 100% rename from submodules/Display/Sources/UITracingLayerView.swift rename to submodules/Display/Display/UITracingLayerView.swift diff --git a/submodules/Display/Sources/UIViewController+Navigation.h b/submodules/Display/Display/UIViewController+Navigation.h similarity index 100% rename from submodules/Display/Sources/UIViewController+Navigation.h rename to submodules/Display/Display/UIViewController+Navigation.h diff --git a/submodules/Display/Sources/UIViewController+Navigation.m b/submodules/Display/Display/UIViewController+Navigation.m similarity index 100% rename from submodules/Display/Sources/UIViewController+Navigation.m rename to submodules/Display/Display/UIViewController+Navigation.m diff --git a/submodules/Display/Sources/UIWindow+OrientationChange.h b/submodules/Display/Display/UIWindow+OrientationChange.h similarity index 100% rename from submodules/Display/Sources/UIWindow+OrientationChange.h rename to submodules/Display/Display/UIWindow+OrientationChange.h diff --git a/submodules/Display/Sources/UIWindow+OrientationChange.m b/submodules/Display/Display/UIWindow+OrientationChange.m similarity index 100% rename from submodules/Display/Sources/UIWindow+OrientationChange.m rename to submodules/Display/Display/UIWindow+OrientationChange.m diff --git a/submodules/Display/Sources/UniversalMasterController.swift b/submodules/Display/Display/UniversalMasterController.swift similarity index 100% rename from submodules/Display/Sources/UniversalMasterController.swift rename to submodules/Display/Display/UniversalMasterController.swift diff --git a/submodules/Display/Sources/UniversalTapRecognizer.swift b/submodules/Display/Display/UniversalTapRecognizer.swift similarity index 100% rename from submodules/Display/Sources/UniversalTapRecognizer.swift rename to submodules/Display/Display/UniversalTapRecognizer.swift diff --git a/submodules/Display/Sources/ViewController.swift b/submodules/Display/Display/ViewController.swift similarity index 100% rename from submodules/Display/Sources/ViewController.swift rename to submodules/Display/Display/ViewController.swift diff --git a/submodules/Display/Sources/ViewControllerPreviewing.swift b/submodules/Display/Display/ViewControllerPreviewing.swift similarity index 100% rename from submodules/Display/Sources/ViewControllerPreviewing.swift rename to submodules/Display/Display/ViewControllerPreviewing.swift diff --git a/submodules/Display/Sources/ViewControllerTracingNode.swift b/submodules/Display/Display/ViewControllerTracingNode.swift similarity index 100% rename from submodules/Display/Sources/ViewControllerTracingNode.swift rename to submodules/Display/Display/ViewControllerTracingNode.swift diff --git a/submodules/Display/Sources/VolumeControlStatusBar.swift b/submodules/Display/Display/VolumeControlStatusBar.swift similarity index 100% rename from submodules/Display/Sources/VolumeControlStatusBar.swift rename to submodules/Display/Display/VolumeControlStatusBar.swift diff --git a/submodules/Display/Sources/WallpaperBackgroundNode.swift b/submodules/Display/Display/WallpaperBackgroundNode.swift similarity index 100% rename from submodules/Display/Sources/WallpaperBackgroundNode.swift rename to submodules/Display/Display/WallpaperBackgroundNode.swift diff --git a/submodules/Display/Sources/WindowContent.swift b/submodules/Display/Display/WindowContent.swift similarity index 100% rename from submodules/Display/Sources/WindowContent.swift rename to submodules/Display/Display/WindowContent.swift diff --git a/submodules/Display/Sources/WindowCoveringView.swift b/submodules/Display/Display/WindowCoveringView.swift similarity index 100% rename from submodules/Display/Sources/WindowCoveringView.swift rename to submodules/Display/Display/WindowCoveringView.swift diff --git a/submodules/Display/Sources/WindowInputAccessoryHeightProvider.swift b/submodules/Display/Display/WindowInputAccessoryHeightProvider.swift similarity index 100% rename from submodules/Display/Sources/WindowInputAccessoryHeightProvider.swift rename to submodules/Display/Display/WindowInputAccessoryHeightProvider.swift diff --git a/submodules/Display/Sources/WindowPanRecognizer.swift b/submodules/Display/Display/WindowPanRecognizer.swift similarity index 100% rename from submodules/Display/Sources/WindowPanRecognizer.swift rename to submodules/Display/Display/WindowPanRecognizer.swift diff --git a/submodules/TelegramUI/Sources/AccessoryPanelNode.swift b/submodules/TelegramUI/TelegramUI/AccessoryPanelNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/AccessoryPanelNode.swift rename to submodules/TelegramUI/TelegramUI/AccessoryPanelNode.swift diff --git a/submodules/TelegramUI/Sources/AccountContext.swift b/submodules/TelegramUI/TelegramUI/AccountContext.swift similarity index 100% rename from submodules/TelegramUI/Sources/AccountContext.swift rename to submodules/TelegramUI/TelegramUI/AccountContext.swift diff --git a/submodules/TelegramUI/Sources/AppDelegate.swift b/submodules/TelegramUI/TelegramUI/AppDelegate.swift similarity index 100% rename from submodules/TelegramUI/Sources/AppDelegate.swift rename to submodules/TelegramUI/TelegramUI/AppDelegate.swift diff --git a/submodules/TelegramUI/Sources/ApplicationContext.swift b/submodules/TelegramUI/TelegramUI/ApplicationContext.swift similarity index 100% rename from submodules/TelegramUI/Sources/ApplicationContext.swift rename to submodules/TelegramUI/TelegramUI/ApplicationContext.swift diff --git a/submodules/TelegramUI/Sources/ApplicationShortcutItem.swift b/submodules/TelegramUI/TelegramUI/ApplicationShortcutItem.swift similarity index 100% rename from submodules/TelegramUI/Sources/ApplicationShortcutItem.swift rename to submodules/TelegramUI/TelegramUI/ApplicationShortcutItem.swift diff --git a/submodules/TelegramUI/Sources/AudioRecordningToneData.swift b/submodules/TelegramUI/TelegramUI/AudioRecordningToneData.swift similarity index 100% rename from submodules/TelegramUI/Sources/AudioRecordningToneData.swift rename to submodules/TelegramUI/TelegramUI/AudioRecordningToneData.swift diff --git a/submodules/TelegramUI/Sources/AudioWaveform.swift b/submodules/TelegramUI/TelegramUI/AudioWaveform.swift similarity index 100% rename from submodules/TelegramUI/Sources/AudioWaveform.swift rename to submodules/TelegramUI/TelegramUI/AudioWaveform.swift diff --git a/submodules/TelegramUI/Sources/AudioWaveformNode.swift b/submodules/TelegramUI/TelegramUI/AudioWaveformNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/AudioWaveformNode.swift rename to submodules/TelegramUI/TelegramUI/AudioWaveformNode.swift diff --git a/submodules/TelegramUI/Sources/AuthorizationSequenceAwaitingAccountResetController.swift b/submodules/TelegramUI/TelegramUI/AuthorizationSequenceAwaitingAccountResetController.swift similarity index 100% rename from submodules/TelegramUI/Sources/AuthorizationSequenceAwaitingAccountResetController.swift rename to submodules/TelegramUI/TelegramUI/AuthorizationSequenceAwaitingAccountResetController.swift diff --git a/submodules/TelegramUI/Sources/AuthorizationSequenceAwaitingAccountResetControllerNode.swift b/submodules/TelegramUI/TelegramUI/AuthorizationSequenceAwaitingAccountResetControllerNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/AuthorizationSequenceAwaitingAccountResetControllerNode.swift rename to submodules/TelegramUI/TelegramUI/AuthorizationSequenceAwaitingAccountResetControllerNode.swift diff --git a/submodules/TelegramUI/Sources/AuthorizationSequenceCodeEntryController.swift b/submodules/TelegramUI/TelegramUI/AuthorizationSequenceCodeEntryController.swift similarity index 100% rename from submodules/TelegramUI/Sources/AuthorizationSequenceCodeEntryController.swift rename to submodules/TelegramUI/TelegramUI/AuthorizationSequenceCodeEntryController.swift diff --git a/submodules/TelegramUI/Sources/AuthorizationSequenceCodeEntryControllerNode.swift b/submodules/TelegramUI/TelegramUI/AuthorizationSequenceCodeEntryControllerNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/AuthorizationSequenceCodeEntryControllerNode.swift rename to submodules/TelegramUI/TelegramUI/AuthorizationSequenceCodeEntryControllerNode.swift diff --git a/submodules/TelegramUI/Sources/AuthorizationSequenceController.swift b/submodules/TelegramUI/TelegramUI/AuthorizationSequenceController.swift similarity index 100% rename from submodules/TelegramUI/Sources/AuthorizationSequenceController.swift rename to submodules/TelegramUI/TelegramUI/AuthorizationSequenceController.swift diff --git a/submodules/TelegramUI/Sources/AuthorizationSequencePasswordEntryController.swift b/submodules/TelegramUI/TelegramUI/AuthorizationSequencePasswordEntryController.swift similarity index 100% rename from submodules/TelegramUI/Sources/AuthorizationSequencePasswordEntryController.swift rename to submodules/TelegramUI/TelegramUI/AuthorizationSequencePasswordEntryController.swift diff --git a/submodules/TelegramUI/Sources/AuthorizationSequencePasswordEntryControllerNode.swift b/submodules/TelegramUI/TelegramUI/AuthorizationSequencePasswordEntryControllerNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/AuthorizationSequencePasswordEntryControllerNode.swift rename to submodules/TelegramUI/TelegramUI/AuthorizationSequencePasswordEntryControllerNode.swift diff --git a/submodules/TelegramUI/Sources/AuthorizationSequencePasswordRecoveryController.swift b/submodules/TelegramUI/TelegramUI/AuthorizationSequencePasswordRecoveryController.swift similarity index 100% rename from submodules/TelegramUI/Sources/AuthorizationSequencePasswordRecoveryController.swift rename to submodules/TelegramUI/TelegramUI/AuthorizationSequencePasswordRecoveryController.swift diff --git a/submodules/TelegramUI/Sources/AuthorizationSequencePasswordRecoveryControllerNode.swift b/submodules/TelegramUI/TelegramUI/AuthorizationSequencePasswordRecoveryControllerNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/AuthorizationSequencePasswordRecoveryControllerNode.swift rename to submodules/TelegramUI/TelegramUI/AuthorizationSequencePasswordRecoveryControllerNode.swift diff --git a/submodules/TelegramUI/Sources/AuthorizationSequencePhoneEntryController.swift b/submodules/TelegramUI/TelegramUI/AuthorizationSequencePhoneEntryController.swift similarity index 100% rename from submodules/TelegramUI/Sources/AuthorizationSequencePhoneEntryController.swift rename to submodules/TelegramUI/TelegramUI/AuthorizationSequencePhoneEntryController.swift diff --git a/submodules/TelegramUI/Sources/AuthorizationSequencePhoneEntryControllerNode.swift b/submodules/TelegramUI/TelegramUI/AuthorizationSequencePhoneEntryControllerNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/AuthorizationSequencePhoneEntryControllerNode.swift rename to submodules/TelegramUI/TelegramUI/AuthorizationSequencePhoneEntryControllerNode.swift diff --git a/submodules/TelegramUI/Sources/AuthorizationSequenceSignUpController.swift b/submodules/TelegramUI/TelegramUI/AuthorizationSequenceSignUpController.swift similarity index 100% rename from submodules/TelegramUI/Sources/AuthorizationSequenceSignUpController.swift rename to submodules/TelegramUI/TelegramUI/AuthorizationSequenceSignUpController.swift diff --git a/submodules/TelegramUI/Sources/AuthorizationSequenceSignUpControllerNode.swift b/submodules/TelegramUI/TelegramUI/AuthorizationSequenceSignUpControllerNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/AuthorizationSequenceSignUpControllerNode.swift rename to submodules/TelegramUI/TelegramUI/AuthorizationSequenceSignUpControllerNode.swift diff --git a/submodules/TelegramUI/Sources/AuthorizationSequenceSplashController.swift b/submodules/TelegramUI/TelegramUI/AuthorizationSequenceSplashController.swift similarity index 100% rename from submodules/TelegramUI/Sources/AuthorizationSequenceSplashController.swift rename to submodules/TelegramUI/TelegramUI/AuthorizationSequenceSplashController.swift diff --git a/submodules/TelegramUI/Sources/AuthorizationSequenceSplashControllerNode.swift b/submodules/TelegramUI/TelegramUI/AuthorizationSequenceSplashControllerNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/AuthorizationSequenceSplashControllerNode.swift rename to submodules/TelegramUI/TelegramUI/AuthorizationSequenceSplashControllerNode.swift diff --git a/submodules/TelegramUI/Sources/ChatAvatarNavigationNode.swift b/submodules/TelegramUI/TelegramUI/ChatAvatarNavigationNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatAvatarNavigationNode.swift rename to submodules/TelegramUI/TelegramUI/ChatAvatarNavigationNode.swift diff --git a/submodules/TelegramUI/Sources/ChatBotInfoItem.swift b/submodules/TelegramUI/TelegramUI/ChatBotInfoItem.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatBotInfoItem.swift rename to submodules/TelegramUI/TelegramUI/ChatBotInfoItem.swift diff --git a/submodules/TelegramUI/Sources/ChatBotStartInputPanelNode.swift b/submodules/TelegramUI/TelegramUI/ChatBotStartInputPanelNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatBotStartInputPanelNode.swift rename to submodules/TelegramUI/TelegramUI/ChatBotStartInputPanelNode.swift diff --git a/submodules/TelegramUI/Sources/ChatButtonKeyboardInputNode.swift b/submodules/TelegramUI/TelegramUI/ChatButtonKeyboardInputNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatButtonKeyboardInputNode.swift rename to submodules/TelegramUI/TelegramUI/ChatButtonKeyboardInputNode.swift diff --git a/submodules/TelegramUI/Sources/ChatChannelSubscriberInputPanelNode.swift b/submodules/TelegramUI/TelegramUI/ChatChannelSubscriberInputPanelNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatChannelSubscriberInputPanelNode.swift rename to submodules/TelegramUI/TelegramUI/ChatChannelSubscriberInputPanelNode.swift diff --git a/submodules/TelegramUI/Sources/ChatContextResultPeekContentNode.swift b/submodules/TelegramUI/TelegramUI/ChatContextResultPeekContentNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatContextResultPeekContentNode.swift rename to submodules/TelegramUI/TelegramUI/ChatContextResultPeekContentNode.swift diff --git a/submodules/TelegramUI/Sources/ChatController.swift b/submodules/TelegramUI/TelegramUI/ChatController.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatController.swift rename to submodules/TelegramUI/TelegramUI/ChatController.swift diff --git a/submodules/TelegramUI/Sources/ChatControllerInteraction.swift b/submodules/TelegramUI/TelegramUI/ChatControllerInteraction.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatControllerInteraction.swift rename to submodules/TelegramUI/TelegramUI/ChatControllerInteraction.swift diff --git a/submodules/TelegramUI/Sources/ChatControllerNode.swift b/submodules/TelegramUI/TelegramUI/ChatControllerNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatControllerNode.swift rename to submodules/TelegramUI/TelegramUI/ChatControllerNode.swift diff --git a/submodules/TelegramUI/Sources/ChatControllerTitlePanelNodeContainer.swift b/submodules/TelegramUI/TelegramUI/ChatControllerTitlePanelNodeContainer.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatControllerTitlePanelNodeContainer.swift rename to submodules/TelegramUI/TelegramUI/ChatControllerTitlePanelNodeContainer.swift diff --git a/submodules/TelegramUI/Sources/ChatDateSelectionSheet.swift b/submodules/TelegramUI/TelegramUI/ChatDateSelectionSheet.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatDateSelectionSheet.swift rename to submodules/TelegramUI/TelegramUI/ChatDateSelectionSheet.swift diff --git a/submodules/TelegramUI/Sources/ChatEditInterfaceMessageState.swift b/submodules/TelegramUI/TelegramUI/ChatEditInterfaceMessageState.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatEditInterfaceMessageState.swift rename to submodules/TelegramUI/TelegramUI/ChatEditInterfaceMessageState.swift diff --git a/submodules/TelegramUI/Sources/ChatEditMessageMediaContext.swift b/submodules/TelegramUI/TelegramUI/ChatEditMessageMediaContext.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatEditMessageMediaContext.swift rename to submodules/TelegramUI/TelegramUI/ChatEditMessageMediaContext.swift diff --git a/submodules/TelegramUI/Sources/ChatEmptyNode.swift b/submodules/TelegramUI/TelegramUI/ChatEmptyNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatEmptyNode.swift rename to submodules/TelegramUI/TelegramUI/ChatEmptyNode.swift diff --git a/submodules/TelegramUI/Sources/ChatFeedNavigationInputPanelNode.swift b/submodules/TelegramUI/TelegramUI/ChatFeedNavigationInputPanelNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatFeedNavigationInputPanelNode.swift rename to submodules/TelegramUI/TelegramUI/ChatFeedNavigationInputPanelNode.swift diff --git a/submodules/TelegramUI/Sources/ChatHistoryEntriesForView.swift b/submodules/TelegramUI/TelegramUI/ChatHistoryEntriesForView.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatHistoryEntriesForView.swift rename to submodules/TelegramUI/TelegramUI/ChatHistoryEntriesForView.swift diff --git a/submodules/TelegramUI/Sources/ChatHistoryEntry.swift b/submodules/TelegramUI/TelegramUI/ChatHistoryEntry.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatHistoryEntry.swift rename to submodules/TelegramUI/TelegramUI/ChatHistoryEntry.swift diff --git a/submodules/TelegramUI/Sources/ChatHistoryGridNode.swift b/submodules/TelegramUI/TelegramUI/ChatHistoryGridNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatHistoryGridNode.swift rename to submodules/TelegramUI/TelegramUI/ChatHistoryGridNode.swift diff --git a/submodules/TelegramUI/Sources/ChatHistoryListNode.swift b/submodules/TelegramUI/TelegramUI/ChatHistoryListNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatHistoryListNode.swift rename to submodules/TelegramUI/TelegramUI/ChatHistoryListNode.swift diff --git a/submodules/TelegramUI/Sources/ChatHistoryLocation.swift b/submodules/TelegramUI/TelegramUI/ChatHistoryLocation.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatHistoryLocation.swift rename to submodules/TelegramUI/TelegramUI/ChatHistoryLocation.swift diff --git a/submodules/TelegramUI/Sources/ChatHistoryNavigationButtonNode.swift b/submodules/TelegramUI/TelegramUI/ChatHistoryNavigationButtonNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatHistoryNavigationButtonNode.swift rename to submodules/TelegramUI/TelegramUI/ChatHistoryNavigationButtonNode.swift diff --git a/submodules/TelegramUI/Sources/ChatHistoryNavigationButtons.swift b/submodules/TelegramUI/TelegramUI/ChatHistoryNavigationButtons.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatHistoryNavigationButtons.swift rename to submodules/TelegramUI/TelegramUI/ChatHistoryNavigationButtons.swift diff --git a/submodules/TelegramUI/Sources/ChatHistoryNavigationStack.swift b/submodules/TelegramUI/TelegramUI/ChatHistoryNavigationStack.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatHistoryNavigationStack.swift rename to submodules/TelegramUI/TelegramUI/ChatHistoryNavigationStack.swift diff --git a/submodules/TelegramUI/Sources/ChatHistoryNode.swift b/submodules/TelegramUI/TelegramUI/ChatHistoryNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatHistoryNode.swift rename to submodules/TelegramUI/TelegramUI/ChatHistoryNode.swift diff --git a/submodules/TelegramUI/Sources/ChatHistorySearchContainerNode.swift b/submodules/TelegramUI/TelegramUI/ChatHistorySearchContainerNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatHistorySearchContainerNode.swift rename to submodules/TelegramUI/TelegramUI/ChatHistorySearchContainerNode.swift diff --git a/submodules/TelegramUI/Sources/ChatHistoryViewForLocation.swift b/submodules/TelegramUI/TelegramUI/ChatHistoryViewForLocation.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatHistoryViewForLocation.swift rename to submodules/TelegramUI/TelegramUI/ChatHistoryViewForLocation.swift diff --git a/submodules/TelegramUI/Sources/ChatHoleItem.swift b/submodules/TelegramUI/TelegramUI/ChatHoleItem.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatHoleItem.swift rename to submodules/TelegramUI/TelegramUI/ChatHoleItem.swift diff --git a/submodules/TelegramUI/Sources/ChatInfo.swift b/submodules/TelegramUI/TelegramUI/ChatInfo.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatInfo.swift rename to submodules/TelegramUI/TelegramUI/ChatInfo.swift diff --git a/submodules/TelegramUI/Sources/ChatInfoTitlePanelNode.swift b/submodules/TelegramUI/TelegramUI/ChatInfoTitlePanelNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatInfoTitlePanelNode.swift rename to submodules/TelegramUI/TelegramUI/ChatInfoTitlePanelNode.swift diff --git a/submodules/TelegramUI/Sources/ChatInputContextPanelNode.swift b/submodules/TelegramUI/TelegramUI/ChatInputContextPanelNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatInputContextPanelNode.swift rename to submodules/TelegramUI/TelegramUI/ChatInputContextPanelNode.swift diff --git a/submodules/TelegramUI/Sources/ChatInputNode.swift b/submodules/TelegramUI/TelegramUI/ChatInputNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatInputNode.swift rename to submodules/TelegramUI/TelegramUI/ChatInputNode.swift diff --git a/submodules/TelegramUI/Sources/ChatInputPanelNode.swift b/submodules/TelegramUI/TelegramUI/ChatInputPanelNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatInputPanelNode.swift rename to submodules/TelegramUI/TelegramUI/ChatInputPanelNode.swift diff --git a/submodules/TelegramUI/Sources/ChatInstantVideoMessageDurationNode.swift b/submodules/TelegramUI/TelegramUI/ChatInstantVideoMessageDurationNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatInstantVideoMessageDurationNode.swift rename to submodules/TelegramUI/TelegramUI/ChatInstantVideoMessageDurationNode.swift diff --git a/submodules/TelegramUI/Sources/ChatInterfaceInputContextPanels.swift b/submodules/TelegramUI/TelegramUI/ChatInterfaceInputContextPanels.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatInterfaceInputContextPanels.swift rename to submodules/TelegramUI/TelegramUI/ChatInterfaceInputContextPanels.swift diff --git a/submodules/TelegramUI/Sources/ChatInterfaceInputContexts.swift b/submodules/TelegramUI/TelegramUI/ChatInterfaceInputContexts.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatInterfaceInputContexts.swift rename to submodules/TelegramUI/TelegramUI/ChatInterfaceInputContexts.swift diff --git a/submodules/TelegramUI/Sources/ChatInterfaceInputNodes.swift b/submodules/TelegramUI/TelegramUI/ChatInterfaceInputNodes.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatInterfaceInputNodes.swift rename to submodules/TelegramUI/TelegramUI/ChatInterfaceInputNodes.swift diff --git a/submodules/TelegramUI/Sources/ChatInterfaceState.swift b/submodules/TelegramUI/TelegramUI/ChatInterfaceState.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatInterfaceState.swift rename to submodules/TelegramUI/TelegramUI/ChatInterfaceState.swift diff --git a/submodules/TelegramUI/Sources/ChatInterfaceStateAccessoryPanels.swift b/submodules/TelegramUI/TelegramUI/ChatInterfaceStateAccessoryPanels.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatInterfaceStateAccessoryPanels.swift rename to submodules/TelegramUI/TelegramUI/ChatInterfaceStateAccessoryPanels.swift diff --git a/submodules/TelegramUI/Sources/ChatInterfaceStateContextMenus.swift b/submodules/TelegramUI/TelegramUI/ChatInterfaceStateContextMenus.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatInterfaceStateContextMenus.swift rename to submodules/TelegramUI/TelegramUI/ChatInterfaceStateContextMenus.swift diff --git a/submodules/TelegramUI/Sources/ChatInterfaceStateContextQueries.swift b/submodules/TelegramUI/TelegramUI/ChatInterfaceStateContextQueries.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatInterfaceStateContextQueries.swift rename to submodules/TelegramUI/TelegramUI/ChatInterfaceStateContextQueries.swift diff --git a/submodules/TelegramUI/Sources/ChatInterfaceStateInputPanels.swift b/submodules/TelegramUI/TelegramUI/ChatInterfaceStateInputPanels.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatInterfaceStateInputPanels.swift rename to submodules/TelegramUI/TelegramUI/ChatInterfaceStateInputPanels.swift diff --git a/submodules/TelegramUI/Sources/ChatInterfaceStateNavigationButtons.swift b/submodules/TelegramUI/TelegramUI/ChatInterfaceStateNavigationButtons.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatInterfaceStateNavigationButtons.swift rename to submodules/TelegramUI/TelegramUI/ChatInterfaceStateNavigationButtons.swift diff --git a/submodules/TelegramUI/Sources/ChatInterfaceTitlePanelNodes.swift b/submodules/TelegramUI/TelegramUI/ChatInterfaceTitlePanelNodes.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatInterfaceTitlePanelNodes.swift rename to submodules/TelegramUI/TelegramUI/ChatInterfaceTitlePanelNodes.swift diff --git a/submodules/TelegramUI/Sources/ChatLinkPreview.swift b/submodules/TelegramUI/TelegramUI/ChatLinkPreview.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatLinkPreview.swift rename to submodules/TelegramUI/TelegramUI/ChatLinkPreview.swift diff --git a/submodules/TelegramUI/Sources/ChatLoadingNode.swift b/submodules/TelegramUI/TelegramUI/ChatLoadingNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatLoadingNode.swift rename to submodules/TelegramUI/TelegramUI/ChatLoadingNode.swift diff --git a/submodules/TelegramUI/Sources/ChatMediaInputGifPane.swift b/submodules/TelegramUI/TelegramUI/ChatMediaInputGifPane.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatMediaInputGifPane.swift rename to submodules/TelegramUI/TelegramUI/ChatMediaInputGifPane.swift diff --git a/submodules/TelegramUI/Sources/ChatMediaInputGridEntries.swift b/submodules/TelegramUI/TelegramUI/ChatMediaInputGridEntries.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatMediaInputGridEntries.swift rename to submodules/TelegramUI/TelegramUI/ChatMediaInputGridEntries.swift diff --git a/submodules/TelegramUI/Sources/ChatMediaInputMetaSectionItemNode.swift b/submodules/TelegramUI/TelegramUI/ChatMediaInputMetaSectionItemNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatMediaInputMetaSectionItemNode.swift rename to submodules/TelegramUI/TelegramUI/ChatMediaInputMetaSectionItemNode.swift diff --git a/submodules/TelegramUI/Sources/ChatMediaInputNode.swift b/submodules/TelegramUI/TelegramUI/ChatMediaInputNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatMediaInputNode.swift rename to submodules/TelegramUI/TelegramUI/ChatMediaInputNode.swift diff --git a/submodules/TelegramUI/Sources/ChatMediaInputPane.swift b/submodules/TelegramUI/TelegramUI/ChatMediaInputPane.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatMediaInputPane.swift rename to submodules/TelegramUI/TelegramUI/ChatMediaInputPane.swift diff --git a/submodules/TelegramUI/Sources/ChatMediaInputPanelEntries.swift b/submodules/TelegramUI/TelegramUI/ChatMediaInputPanelEntries.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatMediaInputPanelEntries.swift rename to submodules/TelegramUI/TelegramUI/ChatMediaInputPanelEntries.swift diff --git a/submodules/TelegramUI/Sources/ChatMediaInputPeerSpecificItem.swift b/submodules/TelegramUI/TelegramUI/ChatMediaInputPeerSpecificItem.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatMediaInputPeerSpecificItem.swift rename to submodules/TelegramUI/TelegramUI/ChatMediaInputPeerSpecificItem.swift diff --git a/submodules/TelegramUI/Sources/ChatMediaInputRecentGifsItem.swift b/submodules/TelegramUI/TelegramUI/ChatMediaInputRecentGifsItem.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatMediaInputRecentGifsItem.swift rename to submodules/TelegramUI/TelegramUI/ChatMediaInputRecentGifsItem.swift diff --git a/submodules/TelegramUI/Sources/ChatMediaInputSettingsItem.swift b/submodules/TelegramUI/TelegramUI/ChatMediaInputSettingsItem.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatMediaInputSettingsItem.swift rename to submodules/TelegramUI/TelegramUI/ChatMediaInputSettingsItem.swift diff --git a/submodules/TelegramUI/Sources/ChatMediaInputStickerGridItem.swift b/submodules/TelegramUI/TelegramUI/ChatMediaInputStickerGridItem.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatMediaInputStickerGridItem.swift rename to submodules/TelegramUI/TelegramUI/ChatMediaInputStickerGridItem.swift diff --git a/submodules/TelegramUI/Sources/ChatMediaInputStickerPackItem.swift b/submodules/TelegramUI/TelegramUI/ChatMediaInputStickerPackItem.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatMediaInputStickerPackItem.swift rename to submodules/TelegramUI/TelegramUI/ChatMediaInputStickerPackItem.swift diff --git a/submodules/TelegramUI/Sources/ChatMediaInputStickerPane.swift b/submodules/TelegramUI/TelegramUI/ChatMediaInputStickerPane.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatMediaInputStickerPane.swift rename to submodules/TelegramUI/TelegramUI/ChatMediaInputStickerPane.swift diff --git a/submodules/TelegramUI/Sources/ChatMediaInputTrendingItem.swift b/submodules/TelegramUI/TelegramUI/ChatMediaInputTrendingItem.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatMediaInputTrendingItem.swift rename to submodules/TelegramUI/TelegramUI/ChatMediaInputTrendingItem.swift diff --git a/submodules/TelegramUI/Sources/ChatMediaInputTrendingPane.swift b/submodules/TelegramUI/TelegramUI/ChatMediaInputTrendingPane.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatMediaInputTrendingPane.swift rename to submodules/TelegramUI/TelegramUI/ChatMediaInputTrendingPane.swift diff --git a/submodules/TelegramUI/Sources/ChatMessageActionButtonsNode.swift b/submodules/TelegramUI/TelegramUI/ChatMessageActionButtonsNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatMessageActionButtonsNode.swift rename to submodules/TelegramUI/TelegramUI/ChatMessageActionButtonsNode.swift diff --git a/submodules/TelegramUI/Sources/ChatMessageActionItemNode.swift b/submodules/TelegramUI/TelegramUI/ChatMessageActionItemNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatMessageActionItemNode.swift rename to submodules/TelegramUI/TelegramUI/ChatMessageActionItemNode.swift diff --git a/submodules/TelegramUI/Sources/ChatMessageActionSheetController.swift b/submodules/TelegramUI/TelegramUI/ChatMessageActionSheetController.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatMessageActionSheetController.swift rename to submodules/TelegramUI/TelegramUI/ChatMessageActionSheetController.swift diff --git a/submodules/TelegramUI/Sources/ChatMessageActionSheetControllerNode.swift b/submodules/TelegramUI/TelegramUI/ChatMessageActionSheetControllerNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatMessageActionSheetControllerNode.swift rename to submodules/TelegramUI/TelegramUI/ChatMessageActionSheetControllerNode.swift diff --git a/submodules/TelegramUI/Sources/ChatMessageActionUrlAuthController.swift b/submodules/TelegramUI/TelegramUI/ChatMessageActionUrlAuthController.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatMessageActionUrlAuthController.swift rename to submodules/TelegramUI/TelegramUI/ChatMessageActionUrlAuthController.swift diff --git a/submodules/TelegramUI/Sources/ChatMessageAnimatedStickerItemNode.swift b/submodules/TelegramUI/TelegramUI/ChatMessageAnimatedStickerItemNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatMessageAnimatedStickerItemNode.swift rename to submodules/TelegramUI/TelegramUI/ChatMessageAnimatedStickerItemNode.swift diff --git a/submodules/TelegramUI/Sources/ChatMessageAttachedContentNode.swift b/submodules/TelegramUI/TelegramUI/ChatMessageAttachedContentNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatMessageAttachedContentNode.swift rename to submodules/TelegramUI/TelegramUI/ChatMessageAttachedContentNode.swift diff --git a/submodules/TelegramUI/Sources/ChatMessageAvatarAccessoryItem.swift b/submodules/TelegramUI/TelegramUI/ChatMessageAvatarAccessoryItem.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatMessageAvatarAccessoryItem.swift rename to submodules/TelegramUI/TelegramUI/ChatMessageAvatarAccessoryItem.swift diff --git a/submodules/TelegramUI/Sources/ChatMessageBackground.swift b/submodules/TelegramUI/TelegramUI/ChatMessageBackground.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatMessageBackground.swift rename to submodules/TelegramUI/TelegramUI/ChatMessageBackground.swift diff --git a/submodules/TelegramUI/Sources/ChatMessageBubbleBackdrop.swift b/submodules/TelegramUI/TelegramUI/ChatMessageBubbleBackdrop.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatMessageBubbleBackdrop.swift rename to submodules/TelegramUI/TelegramUI/ChatMessageBubbleBackdrop.swift diff --git a/submodules/TelegramUI/Sources/ChatMessageBubbleContentCalclulateImageCorners.swift b/submodules/TelegramUI/TelegramUI/ChatMessageBubbleContentCalclulateImageCorners.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatMessageBubbleContentCalclulateImageCorners.swift rename to submodules/TelegramUI/TelegramUI/ChatMessageBubbleContentCalclulateImageCorners.swift diff --git a/submodules/TelegramUI/Sources/ChatMessageBubbleContentNode.swift b/submodules/TelegramUI/TelegramUI/ChatMessageBubbleContentNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatMessageBubbleContentNode.swift rename to submodules/TelegramUI/TelegramUI/ChatMessageBubbleContentNode.swift diff --git a/submodules/TelegramUI/Sources/ChatMessageBubbleItemNode.swift b/submodules/TelegramUI/TelegramUI/ChatMessageBubbleItemNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatMessageBubbleItemNode.swift rename to submodules/TelegramUI/TelegramUI/ChatMessageBubbleItemNode.swift diff --git a/submodules/TelegramUI/Sources/ChatMessageCallBubbleContentNode.swift b/submodules/TelegramUI/TelegramUI/ChatMessageCallBubbleContentNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatMessageCallBubbleContentNode.swift rename to submodules/TelegramUI/TelegramUI/ChatMessageCallBubbleContentNode.swift diff --git a/submodules/TelegramUI/Sources/ChatMessageContactBubbleContentNode.swift b/submodules/TelegramUI/TelegramUI/ChatMessageContactBubbleContentNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatMessageContactBubbleContentNode.swift rename to submodules/TelegramUI/TelegramUI/ChatMessageContactBubbleContentNode.swift diff --git a/submodules/TelegramUI/Sources/ChatMessageContextControllerContentSource.swift b/submodules/TelegramUI/TelegramUI/ChatMessageContextControllerContentSource.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatMessageContextControllerContentSource.swift rename to submodules/TelegramUI/TelegramUI/ChatMessageContextControllerContentSource.swift diff --git a/submodules/TelegramUI/Sources/ChatMessageDateAndStatusNode.swift b/submodules/TelegramUI/TelegramUI/ChatMessageDateAndStatusNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatMessageDateAndStatusNode.swift rename to submodules/TelegramUI/TelegramUI/ChatMessageDateAndStatusNode.swift diff --git a/submodules/TelegramUI/Sources/ChatMessageDateHeader.swift b/submodules/TelegramUI/TelegramUI/ChatMessageDateHeader.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatMessageDateHeader.swift rename to submodules/TelegramUI/TelegramUI/ChatMessageDateHeader.swift diff --git a/submodules/TelegramUI/Sources/ChatMessageDeliveryFailedNode.swift b/submodules/TelegramUI/TelegramUI/ChatMessageDeliveryFailedNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatMessageDeliveryFailedNode.swift rename to submodules/TelegramUI/TelegramUI/ChatMessageDeliveryFailedNode.swift diff --git a/submodules/TelegramUI/Sources/ChatMessageEventLogPreviousDescriptionContentNode.swift b/submodules/TelegramUI/TelegramUI/ChatMessageEventLogPreviousDescriptionContentNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatMessageEventLogPreviousDescriptionContentNode.swift rename to submodules/TelegramUI/TelegramUI/ChatMessageEventLogPreviousDescriptionContentNode.swift diff --git a/submodules/TelegramUI/Sources/ChatMessageEventLogPreviousLinkContentNode.swift b/submodules/TelegramUI/TelegramUI/ChatMessageEventLogPreviousLinkContentNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatMessageEventLogPreviousLinkContentNode.swift rename to submodules/TelegramUI/TelegramUI/ChatMessageEventLogPreviousLinkContentNode.swift diff --git a/submodules/TelegramUI/Sources/ChatMessageEventLogPreviousMessageContentNode.swift b/submodules/TelegramUI/TelegramUI/ChatMessageEventLogPreviousMessageContentNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatMessageEventLogPreviousMessageContentNode.swift rename to submodules/TelegramUI/TelegramUI/ChatMessageEventLogPreviousMessageContentNode.swift diff --git a/submodules/TelegramUI/Sources/ChatMessageFileBubbleContentNode.swift b/submodules/TelegramUI/TelegramUI/ChatMessageFileBubbleContentNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatMessageFileBubbleContentNode.swift rename to submodules/TelegramUI/TelegramUI/ChatMessageFileBubbleContentNode.swift diff --git a/submodules/TelegramUI/Sources/ChatMessageForwardInfoNode.swift b/submodules/TelegramUI/TelegramUI/ChatMessageForwardInfoNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatMessageForwardInfoNode.swift rename to submodules/TelegramUI/TelegramUI/ChatMessageForwardInfoNode.swift diff --git a/submodules/TelegramUI/Sources/ChatMessageGameBubbleContentNode.swift b/submodules/TelegramUI/TelegramUI/ChatMessageGameBubbleContentNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatMessageGameBubbleContentNode.swift rename to submodules/TelegramUI/TelegramUI/ChatMessageGameBubbleContentNode.swift diff --git a/submodules/TelegramUI/Sources/ChatMessageInstantVideoItemNode.swift b/submodules/TelegramUI/TelegramUI/ChatMessageInstantVideoItemNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatMessageInstantVideoItemNode.swift rename to submodules/TelegramUI/TelegramUI/ChatMessageInstantVideoItemNode.swift diff --git a/submodules/TelegramUI/Sources/ChatMessageInteractiveFileNode.swift b/submodules/TelegramUI/TelegramUI/ChatMessageInteractiveFileNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatMessageInteractiveFileNode.swift rename to submodules/TelegramUI/TelegramUI/ChatMessageInteractiveFileNode.swift diff --git a/submodules/TelegramUI/Sources/ChatMessageInteractiveInstantVideoNode.swift b/submodules/TelegramUI/TelegramUI/ChatMessageInteractiveInstantVideoNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatMessageInteractiveInstantVideoNode.swift rename to submodules/TelegramUI/TelegramUI/ChatMessageInteractiveInstantVideoNode.swift diff --git a/submodules/TelegramUI/Sources/ChatMessageInteractiveMediaBadge.swift b/submodules/TelegramUI/TelegramUI/ChatMessageInteractiveMediaBadge.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatMessageInteractiveMediaBadge.swift rename to submodules/TelegramUI/TelegramUI/ChatMessageInteractiveMediaBadge.swift diff --git a/submodules/TelegramUI/Sources/ChatMessageInteractiveMediaNode.swift b/submodules/TelegramUI/TelegramUI/ChatMessageInteractiveMediaNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatMessageInteractiveMediaNode.swift rename to submodules/TelegramUI/TelegramUI/ChatMessageInteractiveMediaNode.swift diff --git a/submodules/TelegramUI/Sources/ChatMessageInvoiceBubbleContentNode.swift b/submodules/TelegramUI/TelegramUI/ChatMessageInvoiceBubbleContentNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatMessageInvoiceBubbleContentNode.swift rename to submodules/TelegramUI/TelegramUI/ChatMessageInvoiceBubbleContentNode.swift diff --git a/submodules/TelegramUI/Sources/ChatMessageItem.swift b/submodules/TelegramUI/TelegramUI/ChatMessageItem.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatMessageItem.swift rename to submodules/TelegramUI/TelegramUI/ChatMessageItem.swift diff --git a/submodules/TelegramUI/Sources/ChatMessageItemView.swift b/submodules/TelegramUI/TelegramUI/ChatMessageItemView.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatMessageItemView.swift rename to submodules/TelegramUI/TelegramUI/ChatMessageItemView.swift diff --git a/submodules/TelegramUI/Sources/ChatMessageLiveLocationTextNode.swift b/submodules/TelegramUI/TelegramUI/ChatMessageLiveLocationTextNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatMessageLiveLocationTextNode.swift rename to submodules/TelegramUI/TelegramUI/ChatMessageLiveLocationTextNode.swift diff --git a/submodules/TelegramUI/Sources/ChatMessageMapBubbleContentNode.swift b/submodules/TelegramUI/TelegramUI/ChatMessageMapBubbleContentNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatMessageMapBubbleContentNode.swift rename to submodules/TelegramUI/TelegramUI/ChatMessageMapBubbleContentNode.swift diff --git a/submodules/TelegramUI/Sources/ChatMessageMediaBubbleContentNode.swift b/submodules/TelegramUI/TelegramUI/ChatMessageMediaBubbleContentNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatMessageMediaBubbleContentNode.swift rename to submodules/TelegramUI/TelegramUI/ChatMessageMediaBubbleContentNode.swift diff --git a/submodules/TelegramUI/Sources/ChatMessageNotificationItem.swift b/submodules/TelegramUI/TelegramUI/ChatMessageNotificationItem.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatMessageNotificationItem.swift rename to submodules/TelegramUI/TelegramUI/ChatMessageNotificationItem.swift diff --git a/submodules/TelegramUI/Sources/ChatMessagePollBubbleContentNode.swift b/submodules/TelegramUI/TelegramUI/ChatMessagePollBubbleContentNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatMessagePollBubbleContentNode.swift rename to submodules/TelegramUI/TelegramUI/ChatMessagePollBubbleContentNode.swift diff --git a/submodules/TelegramUI/Sources/ChatMessageReplyInfoNode.swift b/submodules/TelegramUI/TelegramUI/ChatMessageReplyInfoNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatMessageReplyInfoNode.swift rename to submodules/TelegramUI/TelegramUI/ChatMessageReplyInfoNode.swift diff --git a/submodules/TelegramUI/Sources/ChatMessageRestrictedBubbleContentNode.swift b/submodules/TelegramUI/TelegramUI/ChatMessageRestrictedBubbleContentNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatMessageRestrictedBubbleContentNode.swift rename to submodules/TelegramUI/TelegramUI/ChatMessageRestrictedBubbleContentNode.swift diff --git a/submodules/TelegramUI/Sources/ChatMessageSelectionInputPanelNode.swift b/submodules/TelegramUI/TelegramUI/ChatMessageSelectionInputPanelNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatMessageSelectionInputPanelNode.swift rename to submodules/TelegramUI/TelegramUI/ChatMessageSelectionInputPanelNode.swift diff --git a/submodules/TelegramUI/Sources/ChatMessageSelectionNode.swift b/submodules/TelegramUI/TelegramUI/ChatMessageSelectionNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatMessageSelectionNode.swift rename to submodules/TelegramUI/TelegramUI/ChatMessageSelectionNode.swift diff --git a/submodules/TelegramUI/Sources/ChatMessageStickerItemNode.swift b/submodules/TelegramUI/TelegramUI/ChatMessageStickerItemNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatMessageStickerItemNode.swift rename to submodules/TelegramUI/TelegramUI/ChatMessageStickerItemNode.swift diff --git a/submodules/TelegramUI/Sources/ChatMessageSwipeToReplyNode.swift b/submodules/TelegramUI/TelegramUI/ChatMessageSwipeToReplyNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatMessageSwipeToReplyNode.swift rename to submodules/TelegramUI/TelegramUI/ChatMessageSwipeToReplyNode.swift diff --git a/submodules/TelegramUI/Sources/ChatMessageTextBubbleContentNode.swift b/submodules/TelegramUI/TelegramUI/ChatMessageTextBubbleContentNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatMessageTextBubbleContentNode.swift rename to submodules/TelegramUI/TelegramUI/ChatMessageTextBubbleContentNode.swift diff --git a/submodules/TelegramUI/Sources/ChatMessageThrottledProcessingManager.swift b/submodules/TelegramUI/TelegramUI/ChatMessageThrottledProcessingManager.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatMessageThrottledProcessingManager.swift rename to submodules/TelegramUI/TelegramUI/ChatMessageThrottledProcessingManager.swift diff --git a/submodules/TelegramUI/Sources/ChatMessageUnsupportedBubbleContentNode.swift b/submodules/TelegramUI/TelegramUI/ChatMessageUnsupportedBubbleContentNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatMessageUnsupportedBubbleContentNode.swift rename to submodules/TelegramUI/TelegramUI/ChatMessageUnsupportedBubbleContentNode.swift diff --git a/submodules/TelegramUI/Sources/ChatMessageWebpageBubbleContentNode.swift b/submodules/TelegramUI/TelegramUI/ChatMessageWebpageBubbleContentNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatMessageWebpageBubbleContentNode.swift rename to submodules/TelegramUI/TelegramUI/ChatMessageWebpageBubbleContentNode.swift diff --git a/submodules/TelegramUI/Sources/ChatOverlayNavigationBar.swift b/submodules/TelegramUI/TelegramUI/ChatOverlayNavigationBar.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatOverlayNavigationBar.swift rename to submodules/TelegramUI/TelegramUI/ChatOverlayNavigationBar.swift diff --git a/submodules/TelegramUI/Sources/ChatPanelInterfaceInteraction.swift b/submodules/TelegramUI/TelegramUI/ChatPanelInterfaceInteraction.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatPanelInterfaceInteraction.swift rename to submodules/TelegramUI/TelegramUI/ChatPanelInterfaceInteraction.swift diff --git a/submodules/TelegramUI/Sources/ChatPinnedMessageTitlePanelNode.swift b/submodules/TelegramUI/TelegramUI/ChatPinnedMessageTitlePanelNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatPinnedMessageTitlePanelNode.swift rename to submodules/TelegramUI/TelegramUI/ChatPinnedMessageTitlePanelNode.swift diff --git a/submodules/TelegramUI/Sources/ChatPresentationData.swift b/submodules/TelegramUI/TelegramUI/ChatPresentationData.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatPresentationData.swift rename to submodules/TelegramUI/TelegramUI/ChatPresentationData.swift diff --git a/submodules/TelegramUI/Sources/ChatPresentationInterfaceState.swift b/submodules/TelegramUI/TelegramUI/ChatPresentationInterfaceState.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatPresentationInterfaceState.swift rename to submodules/TelegramUI/TelegramUI/ChatPresentationInterfaceState.swift diff --git a/submodules/TelegramUI/Sources/ChatRecentActionsController.swift b/submodules/TelegramUI/TelegramUI/ChatRecentActionsController.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatRecentActionsController.swift rename to submodules/TelegramUI/TelegramUI/ChatRecentActionsController.swift diff --git a/submodules/TelegramUI/Sources/ChatRecentActionsControllerNode.swift b/submodules/TelegramUI/TelegramUI/ChatRecentActionsControllerNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatRecentActionsControllerNode.swift rename to submodules/TelegramUI/TelegramUI/ChatRecentActionsControllerNode.swift diff --git a/submodules/TelegramUI/Sources/ChatRecentActionsControllerState.swift b/submodules/TelegramUI/TelegramUI/ChatRecentActionsControllerState.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatRecentActionsControllerState.swift rename to submodules/TelegramUI/TelegramUI/ChatRecentActionsControllerState.swift diff --git a/submodules/TelegramUI/Sources/ChatRecentActionsEmptyNode.swift b/submodules/TelegramUI/TelegramUI/ChatRecentActionsEmptyNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatRecentActionsEmptyNode.swift rename to submodules/TelegramUI/TelegramUI/ChatRecentActionsEmptyNode.swift diff --git a/submodules/TelegramUI/Sources/ChatRecentActionsFilterController.swift b/submodules/TelegramUI/TelegramUI/ChatRecentActionsFilterController.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatRecentActionsFilterController.swift rename to submodules/TelegramUI/TelegramUI/ChatRecentActionsFilterController.swift diff --git a/submodules/TelegramUI/Sources/ChatRecentActionsHistoryTransition.swift b/submodules/TelegramUI/TelegramUI/ChatRecentActionsHistoryTransition.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatRecentActionsHistoryTransition.swift rename to submodules/TelegramUI/TelegramUI/ChatRecentActionsHistoryTransition.swift diff --git a/submodules/TelegramUI/Sources/ChatRecentActionsInteraction.swift b/submodules/TelegramUI/TelegramUI/ChatRecentActionsInteraction.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatRecentActionsInteraction.swift rename to submodules/TelegramUI/TelegramUI/ChatRecentActionsInteraction.swift diff --git a/submodules/TelegramUI/Sources/ChatRecentActionsSearchNavigationContentNode.swift b/submodules/TelegramUI/TelegramUI/ChatRecentActionsSearchNavigationContentNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatRecentActionsSearchNavigationContentNode.swift rename to submodules/TelegramUI/TelegramUI/ChatRecentActionsSearchNavigationContentNode.swift diff --git a/submodules/TelegramUI/Sources/ChatRecentActionsTitleView.swift b/submodules/TelegramUI/TelegramUI/ChatRecentActionsTitleView.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatRecentActionsTitleView.swift rename to submodules/TelegramUI/TelegramUI/ChatRecentActionsTitleView.swift diff --git a/submodules/TelegramUI/Sources/ChatRecordingPreviewInputPanelNode.swift b/submodules/TelegramUI/TelegramUI/ChatRecordingPreviewInputPanelNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatRecordingPreviewInputPanelNode.swift rename to submodules/TelegramUI/TelegramUI/ChatRecordingPreviewInputPanelNode.swift diff --git a/submodules/TelegramUI/Sources/ChatReportPeerTitlePanelNode.swift b/submodules/TelegramUI/TelegramUI/ChatReportPeerTitlePanelNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatReportPeerTitlePanelNode.swift rename to submodules/TelegramUI/TelegramUI/ChatReportPeerTitlePanelNode.swift diff --git a/submodules/TelegramUI/Sources/ChatRequestInProgressTitlePanelNode.swift b/submodules/TelegramUI/TelegramUI/ChatRequestInProgressTitlePanelNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatRequestInProgressTitlePanelNode.swift rename to submodules/TelegramUI/TelegramUI/ChatRequestInProgressTitlePanelNode.swift diff --git a/submodules/TelegramUI/Sources/ChatRestrictedInputPanelNode.swift b/submodules/TelegramUI/TelegramUI/ChatRestrictedInputPanelNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatRestrictedInputPanelNode.swift rename to submodules/TelegramUI/TelegramUI/ChatRestrictedInputPanelNode.swift diff --git a/submodules/TelegramUI/Sources/ChatRestrictedNode.swift b/submodules/TelegramUI/TelegramUI/ChatRestrictedNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatRestrictedNode.swift rename to submodules/TelegramUI/TelegramUI/ChatRestrictedNode.swift diff --git a/submodules/TelegramUI/Sources/ChatScheduleTimeController.swift b/submodules/TelegramUI/TelegramUI/ChatScheduleTimeController.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatScheduleTimeController.swift rename to submodules/TelegramUI/TelegramUI/ChatScheduleTimeController.swift diff --git a/submodules/TelegramUI/Sources/ChatScheduleTimeControllerNode.swift b/submodules/TelegramUI/TelegramUI/ChatScheduleTimeControllerNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatScheduleTimeControllerNode.swift rename to submodules/TelegramUI/TelegramUI/ChatScheduleTimeControllerNode.swift diff --git a/submodules/TelegramUI/Sources/ChatSearchInputPanelNode.swift b/submodules/TelegramUI/TelegramUI/ChatSearchInputPanelNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatSearchInputPanelNode.swift rename to submodules/TelegramUI/TelegramUI/ChatSearchInputPanelNode.swift diff --git a/submodules/TelegramUI/Sources/ChatSearchNavigationContentNode.swift b/submodules/TelegramUI/TelegramUI/ChatSearchNavigationContentNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatSearchNavigationContentNode.swift rename to submodules/TelegramUI/TelegramUI/ChatSearchNavigationContentNode.swift diff --git a/submodules/TelegramUI/Sources/ChatSearchResultsContollerNode.swift b/submodules/TelegramUI/TelegramUI/ChatSearchResultsContollerNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatSearchResultsContollerNode.swift rename to submodules/TelegramUI/TelegramUI/ChatSearchResultsContollerNode.swift diff --git a/submodules/TelegramUI/Sources/ChatSearchResultsController.swift b/submodules/TelegramUI/TelegramUI/ChatSearchResultsController.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatSearchResultsController.swift rename to submodules/TelegramUI/TelegramUI/ChatSearchResultsController.swift diff --git a/submodules/TelegramUI/Sources/ChatSearchState.swift b/submodules/TelegramUI/TelegramUI/ChatSearchState.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatSearchState.swift rename to submodules/TelegramUI/TelegramUI/ChatSearchState.swift diff --git a/submodules/TelegramUI/Sources/ChatSecretAutoremoveTimerActionSheet.swift b/submodules/TelegramUI/TelegramUI/ChatSecretAutoremoveTimerActionSheet.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatSecretAutoremoveTimerActionSheet.swift rename to submodules/TelegramUI/TelegramUI/ChatSecretAutoremoveTimerActionSheet.swift diff --git a/submodules/TelegramUI/Sources/ChatSendButtonRadialStatusNode.swift b/submodules/TelegramUI/TelegramUI/ChatSendButtonRadialStatusNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatSendButtonRadialStatusNode.swift rename to submodules/TelegramUI/TelegramUI/ChatSendButtonRadialStatusNode.swift diff --git a/submodules/TelegramUI/Sources/ChatSendMessageActionSheetController.swift b/submodules/TelegramUI/TelegramUI/ChatSendMessageActionSheetController.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatSendMessageActionSheetController.swift rename to submodules/TelegramUI/TelegramUI/ChatSendMessageActionSheetController.swift diff --git a/submodules/TelegramUI/Sources/ChatSendMessageActionSheetControllerNode.swift b/submodules/TelegramUI/TelegramUI/ChatSendMessageActionSheetControllerNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatSendMessageActionSheetControllerNode.swift rename to submodules/TelegramUI/TelegramUI/ChatSendMessageActionSheetControllerNode.swift diff --git a/submodules/TelegramUI/Sources/ChatSlowmodeHintController.swift b/submodules/TelegramUI/TelegramUI/ChatSlowmodeHintController.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatSlowmodeHintController.swift rename to submodules/TelegramUI/TelegramUI/ChatSlowmodeHintController.swift diff --git a/submodules/TelegramUI/Sources/ChatSwipeToReplyRecognizer.swift b/submodules/TelegramUI/TelegramUI/ChatSwipeToReplyRecognizer.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatSwipeToReplyRecognizer.swift rename to submodules/TelegramUI/TelegramUI/ChatSwipeToReplyRecognizer.swift diff --git a/submodules/TelegramUI/Sources/ChatTextFormat.swift b/submodules/TelegramUI/TelegramUI/ChatTextFormat.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatTextFormat.swift rename to submodules/TelegramUI/TelegramUI/ChatTextFormat.swift diff --git a/submodules/TelegramUI/Sources/ChatTextInputAccessoryItem.swift b/submodules/TelegramUI/TelegramUI/ChatTextInputAccessoryItem.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatTextInputAccessoryItem.swift rename to submodules/TelegramUI/TelegramUI/ChatTextInputAccessoryItem.swift diff --git a/submodules/TelegramUI/Sources/ChatTextInputActionButtonsNode.swift b/submodules/TelegramUI/TelegramUI/ChatTextInputActionButtonsNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatTextInputActionButtonsNode.swift rename to submodules/TelegramUI/TelegramUI/ChatTextInputActionButtonsNode.swift diff --git a/submodules/TelegramUI/Sources/ChatTextInputAudioRecordingCancelIndicator.swift b/submodules/TelegramUI/TelegramUI/ChatTextInputAudioRecordingCancelIndicator.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatTextInputAudioRecordingCancelIndicator.swift rename to submodules/TelegramUI/TelegramUI/ChatTextInputAudioRecordingCancelIndicator.swift diff --git a/submodules/TelegramUI/Sources/ChatTextInputAudioRecordingOverlayButton.swift b/submodules/TelegramUI/TelegramUI/ChatTextInputAudioRecordingOverlayButton.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatTextInputAudioRecordingOverlayButton.swift rename to submodules/TelegramUI/TelegramUI/ChatTextInputAudioRecordingOverlayButton.swift diff --git a/submodules/TelegramUI/Sources/ChatTextInputAudioRecordingTimeNode.swift b/submodules/TelegramUI/TelegramUI/ChatTextInputAudioRecordingTimeNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatTextInputAudioRecordingTimeNode.swift rename to submodules/TelegramUI/TelegramUI/ChatTextInputAudioRecordingTimeNode.swift diff --git a/submodules/TelegramUI/Sources/ChatTextInputMediaRecordingButton.swift b/submodules/TelegramUI/TelegramUI/ChatTextInputMediaRecordingButton.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatTextInputMediaRecordingButton.swift rename to submodules/TelegramUI/TelegramUI/ChatTextInputMediaRecordingButton.swift diff --git a/submodules/TelegramUI/Sources/ChatTextInputMenu.swift b/submodules/TelegramUI/TelegramUI/ChatTextInputMenu.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatTextInputMenu.swift rename to submodules/TelegramUI/TelegramUI/ChatTextInputMenu.swift diff --git a/submodules/TelegramUI/Sources/ChatTextInputPanelNode.swift b/submodules/TelegramUI/TelegramUI/ChatTextInputPanelNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatTextInputPanelNode.swift rename to submodules/TelegramUI/TelegramUI/ChatTextInputPanelNode.swift diff --git a/submodules/TelegramUI/Sources/ChatTextInputPanelState.swift b/submodules/TelegramUI/TelegramUI/ChatTextInputPanelState.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatTextInputPanelState.swift rename to submodules/TelegramUI/TelegramUI/ChatTextInputPanelState.swift diff --git a/submodules/TelegramUI/Sources/ChatTextInputSlowmodePlaceholderNode.swift b/submodules/TelegramUI/TelegramUI/ChatTextInputSlowmodePlaceholderNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatTextInputSlowmodePlaceholderNode.swift rename to submodules/TelegramUI/TelegramUI/ChatTextInputSlowmodePlaceholderNode.swift diff --git a/submodules/TelegramUI/Sources/ChatTextLinkEditController.swift b/submodules/TelegramUI/TelegramUI/ChatTextLinkEditController.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatTextLinkEditController.swift rename to submodules/TelegramUI/TelegramUI/ChatTextLinkEditController.swift diff --git a/submodules/TelegramUI/Sources/ChatTitleAccessoryPanelNode.swift b/submodules/TelegramUI/TelegramUI/ChatTitleAccessoryPanelNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatTitleAccessoryPanelNode.swift rename to submodules/TelegramUI/TelegramUI/ChatTitleAccessoryPanelNode.swift diff --git a/submodules/TelegramUI/Sources/ChatTitleView.swift b/submodules/TelegramUI/TelegramUI/ChatTitleView.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatTitleView.swift rename to submodules/TelegramUI/TelegramUI/ChatTitleView.swift diff --git a/submodules/TelegramUI/Sources/ChatToastAlertPanelNode.swift b/submodules/TelegramUI/TelegramUI/ChatToastAlertPanelNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatToastAlertPanelNode.swift rename to submodules/TelegramUI/TelegramUI/ChatToastAlertPanelNode.swift diff --git a/submodules/TelegramUI/Sources/ChatUnblockInputPanelNode.swift b/submodules/TelegramUI/TelegramUI/ChatUnblockInputPanelNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatUnblockInputPanelNode.swift rename to submodules/TelegramUI/TelegramUI/ChatUnblockInputPanelNode.swift diff --git a/submodules/TelegramUI/Sources/ChatUnreadItem.swift b/submodules/TelegramUI/TelegramUI/ChatUnreadItem.swift similarity index 100% rename from submodules/TelegramUI/Sources/ChatUnreadItem.swift rename to submodules/TelegramUI/TelegramUI/ChatUnreadItem.swift diff --git a/submodules/TelegramUI/Sources/CheckDiskSpace.swift b/submodules/TelegramUI/TelegramUI/CheckDiskSpace.swift similarity index 100% rename from submodules/TelegramUI/Sources/CheckDiskSpace.swift rename to submodules/TelegramUI/TelegramUI/CheckDiskSpace.swift diff --git a/submodules/TelegramUI/Sources/ClearNotificationsManager.swift b/submodules/TelegramUI/TelegramUI/ClearNotificationsManager.swift similarity index 100% rename from submodules/TelegramUI/Sources/ClearNotificationsManager.swift rename to submodules/TelegramUI/TelegramUI/ClearNotificationsManager.swift diff --git a/submodules/TelegramUI/Sources/CommandChatInputContextPanelNode.swift b/submodules/TelegramUI/TelegramUI/CommandChatInputContextPanelNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/CommandChatInputContextPanelNode.swift rename to submodules/TelegramUI/TelegramUI/CommandChatInputContextPanelNode.swift diff --git a/submodules/TelegramUI/Sources/CommandChatInputPanelItem.swift b/submodules/TelegramUI/TelegramUI/CommandChatInputPanelItem.swift similarity index 100% rename from submodules/TelegramUI/Sources/CommandChatInputPanelItem.swift rename to submodules/TelegramUI/TelegramUI/CommandChatInputPanelItem.swift diff --git a/submodules/TelegramUI/Sources/ComposeController.swift b/submodules/TelegramUI/TelegramUI/ComposeController.swift similarity index 100% rename from submodules/TelegramUI/Sources/ComposeController.swift rename to submodules/TelegramUI/TelegramUI/ComposeController.swift diff --git a/submodules/TelegramUI/Sources/ComposeControllerNode.swift b/submodules/TelegramUI/TelegramUI/ComposeControllerNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ComposeControllerNode.swift rename to submodules/TelegramUI/TelegramUI/ComposeControllerNode.swift diff --git a/submodules/TelegramUI/Sources/ConfettiView.swift b/submodules/TelegramUI/TelegramUI/ConfettiView.swift similarity index 100% rename from submodules/TelegramUI/Sources/ConfettiView.swift rename to submodules/TelegramUI/TelegramUI/ConfettiView.swift diff --git a/submodules/TelegramUI/Sources/ContactMultiselectionController.swift b/submodules/TelegramUI/TelegramUI/ContactMultiselectionController.swift similarity index 100% rename from submodules/TelegramUI/Sources/ContactMultiselectionController.swift rename to submodules/TelegramUI/TelegramUI/ContactMultiselectionController.swift diff --git a/submodules/TelegramUI/Sources/ContactMultiselectionControllerNode.swift b/submodules/TelegramUI/TelegramUI/ContactMultiselectionControllerNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ContactMultiselectionControllerNode.swift rename to submodules/TelegramUI/TelegramUI/ContactMultiselectionControllerNode.swift diff --git a/submodules/TelegramUI/Sources/ContactSelectionController.swift b/submodules/TelegramUI/TelegramUI/ContactSelectionController.swift similarity index 100% rename from submodules/TelegramUI/Sources/ContactSelectionController.swift rename to submodules/TelegramUI/TelegramUI/ContactSelectionController.swift diff --git a/submodules/TelegramUI/Sources/ContactSelectionControllerNode.swift b/submodules/TelegramUI/TelegramUI/ContactSelectionControllerNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ContactSelectionControllerNode.swift rename to submodules/TelegramUI/TelegramUI/ContactSelectionControllerNode.swift diff --git a/submodules/TelegramUI/Sources/ConvertToWebP.swift b/submodules/TelegramUI/TelegramUI/ConvertToWebP.swift similarity index 100% rename from submodules/TelegramUI/Sources/ConvertToWebP.swift rename to submodules/TelegramUI/TelegramUI/ConvertToWebP.swift diff --git a/submodules/TelegramUI/Sources/CreateChannelController.swift b/submodules/TelegramUI/TelegramUI/CreateChannelController.swift similarity index 100% rename from submodules/TelegramUI/Sources/CreateChannelController.swift rename to submodules/TelegramUI/TelegramUI/CreateChannelController.swift diff --git a/submodules/TelegramUI/Sources/CreateGroupController.swift b/submodules/TelegramUI/TelegramUI/CreateGroupController.swift similarity index 100% rename from submodules/TelegramUI/Sources/CreateGroupController.swift rename to submodules/TelegramUI/TelegramUI/CreateGroupController.swift diff --git a/submodules/TelegramUI/Sources/DeclareEncodables.swift b/submodules/TelegramUI/TelegramUI/DeclareEncodables.swift similarity index 100% rename from submodules/TelegramUI/Sources/DeclareEncodables.swift rename to submodules/TelegramUI/TelegramUI/DeclareEncodables.swift diff --git a/submodules/TelegramUI/Sources/DeleteChatInputPanelNode.swift b/submodules/TelegramUI/TelegramUI/DeleteChatInputPanelNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/DeleteChatInputPanelNode.swift rename to submodules/TelegramUI/TelegramUI/DeleteChatInputPanelNode.swift diff --git a/submodules/TelegramUI/Sources/DeviceContactDataManager.swift b/submodules/TelegramUI/TelegramUI/DeviceContactDataManager.swift similarity index 100% rename from submodules/TelegramUI/Sources/DeviceContactDataManager.swift rename to submodules/TelegramUI/TelegramUI/DeviceContactDataManager.swift diff --git a/submodules/TelegramUI/Sources/DisabledContextResultsChatInputContextPanelNode.swift b/submodules/TelegramUI/TelegramUI/DisabledContextResultsChatInputContextPanelNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/DisabledContextResultsChatInputContextPanelNode.swift rename to submodules/TelegramUI/TelegramUI/DisabledContextResultsChatInputContextPanelNode.swift diff --git a/submodules/TelegramUI/Sources/DocumentPreviewController.swift b/submodules/TelegramUI/TelegramUI/DocumentPreviewController.swift similarity index 100% rename from submodules/TelegramUI/Sources/DocumentPreviewController.swift rename to submodules/TelegramUI/TelegramUI/DocumentPreviewController.swift diff --git a/submodules/TelegramUI/Sources/EditAccessoryPanelNode.swift b/submodules/TelegramUI/TelegramUI/EditAccessoryPanelNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/EditAccessoryPanelNode.swift rename to submodules/TelegramUI/TelegramUI/EditAccessoryPanelNode.swift diff --git a/submodules/TelegramUI/Sources/EditableTokenListNode.swift b/submodules/TelegramUI/TelegramUI/EditableTokenListNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/EditableTokenListNode.swift rename to submodules/TelegramUI/TelegramUI/EditableTokenListNode.swift diff --git a/submodules/TelegramUI/Sources/EmojiResources.swift b/submodules/TelegramUI/TelegramUI/EmojiResources.swift similarity index 100% rename from submodules/TelegramUI/Sources/EmojiResources.swift rename to submodules/TelegramUI/TelegramUI/EmojiResources.swift diff --git a/submodules/TelegramUI/Sources/EmojisChatInputContextPanelNode.swift b/submodules/TelegramUI/TelegramUI/EmojisChatInputContextPanelNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/EmojisChatInputContextPanelNode.swift rename to submodules/TelegramUI/TelegramUI/EmojisChatInputContextPanelNode.swift diff --git a/submodules/TelegramUI/Sources/EmojisChatInputPanelItem.swift b/submodules/TelegramUI/TelegramUI/EmojisChatInputPanelItem.swift similarity index 100% rename from submodules/TelegramUI/Sources/EmojisChatInputPanelItem.swift rename to submodules/TelegramUI/TelegramUI/EmojisChatInputPanelItem.swift diff --git a/submodules/TelegramUI/Sources/FetchCachedRepresentations.swift b/submodules/TelegramUI/TelegramUI/FetchCachedRepresentations.swift similarity index 100% rename from submodules/TelegramUI/Sources/FetchCachedRepresentations.swift rename to submodules/TelegramUI/TelegramUI/FetchCachedRepresentations.swift diff --git a/submodules/TelegramUI/Sources/FetchManager.swift b/submodules/TelegramUI/TelegramUI/FetchManager.swift similarity index 100% rename from submodules/TelegramUI/Sources/FetchManager.swift rename to submodules/TelegramUI/TelegramUI/FetchManager.swift diff --git a/submodules/TelegramUI/Sources/FetchManagerLocation.swift b/submodules/TelegramUI/TelegramUI/FetchManagerLocation.swift similarity index 100% rename from submodules/TelegramUI/Sources/FetchManagerLocation.swift rename to submodules/TelegramUI/TelegramUI/FetchManagerLocation.swift diff --git a/submodules/TelegramUI/Sources/FetchResource.swift b/submodules/TelegramUI/TelegramUI/FetchResource.swift similarity index 100% rename from submodules/TelegramUI/Sources/FetchResource.swift rename to submodules/TelegramUI/TelegramUI/FetchResource.swift diff --git a/submodules/TelegramUI/Sources/FetchVideoMediaResource.swift b/submodules/TelegramUI/TelegramUI/FetchVideoMediaResource.swift similarity index 100% rename from submodules/TelegramUI/Sources/FetchVideoMediaResource.swift rename to submodules/TelegramUI/TelegramUI/FetchVideoMediaResource.swift diff --git a/submodules/TelegramUI/Sources/FileMediaResourceStatus.swift b/submodules/TelegramUI/TelegramUI/FileMediaResourceStatus.swift similarity index 100% rename from submodules/TelegramUI/Sources/FileMediaResourceStatus.swift rename to submodules/TelegramUI/TelegramUI/FileMediaResourceStatus.swift diff --git a/submodules/TelegramUI/Sources/ForwardAccessoryPanelNode.swift b/submodules/TelegramUI/TelegramUI/ForwardAccessoryPanelNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ForwardAccessoryPanelNode.swift rename to submodules/TelegramUI/TelegramUI/ForwardAccessoryPanelNode.swift diff --git a/submodules/TelegramUI/Sources/GalleryHiddenMediaManager.swift b/submodules/TelegramUI/TelegramUI/GalleryHiddenMediaManager.swift similarity index 100% rename from submodules/TelegramUI/Sources/GalleryHiddenMediaManager.swift rename to submodules/TelegramUI/TelegramUI/GalleryHiddenMediaManager.swift diff --git a/submodules/TelegramUI/Sources/GifPaneSearchContentNode.swift b/submodules/TelegramUI/TelegramUI/GifPaneSearchContentNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/GifPaneSearchContentNode.swift rename to submodules/TelegramUI/TelegramUI/GifPaneSearchContentNode.swift diff --git a/submodules/TelegramUI/Sources/GlobalExperimentalSettings.swift b/submodules/TelegramUI/TelegramUI/GlobalExperimentalSettings.swift similarity index 100% rename from submodules/TelegramUI/Sources/GlobalExperimentalSettings.swift rename to submodules/TelegramUI/TelegramUI/GlobalExperimentalSettings.swift diff --git a/submodules/TelegramUI/Sources/GridHoleItem.swift b/submodules/TelegramUI/TelegramUI/GridHoleItem.swift similarity index 100% rename from submodules/TelegramUI/Sources/GridHoleItem.swift rename to submodules/TelegramUI/TelegramUI/GridHoleItem.swift diff --git a/submodules/TelegramUI/Sources/GridMessageItem.swift b/submodules/TelegramUI/TelegramUI/GridMessageItem.swift similarity index 100% rename from submodules/TelegramUI/Sources/GridMessageItem.swift rename to submodules/TelegramUI/TelegramUI/GridMessageItem.swift diff --git a/submodules/TelegramUI/Sources/HashtagChatInputContextPanelNode.swift b/submodules/TelegramUI/TelegramUI/HashtagChatInputContextPanelNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/HashtagChatInputContextPanelNode.swift rename to submodules/TelegramUI/TelegramUI/HashtagChatInputContextPanelNode.swift diff --git a/submodules/TelegramUI/Sources/HashtagChatInputPanelItem.swift b/submodules/TelegramUI/TelegramUI/HashtagChatInputPanelItem.swift similarity index 100% rename from submodules/TelegramUI/Sources/HashtagChatInputPanelItem.swift rename to submodules/TelegramUI/TelegramUI/HashtagChatInputPanelItem.swift diff --git a/submodules/TelegramUI/Sources/HorizontalListContextResultsChatInputContextPanelNode.swift b/submodules/TelegramUI/TelegramUI/HorizontalListContextResultsChatInputContextPanelNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/HorizontalListContextResultsChatInputContextPanelNode.swift rename to submodules/TelegramUI/TelegramUI/HorizontalListContextResultsChatInputContextPanelNode.swift diff --git a/submodules/TelegramUI/Sources/HorizontalListContextResultsChatInputPanelItem.swift b/submodules/TelegramUI/TelegramUI/HorizontalListContextResultsChatInputPanelItem.swift similarity index 100% rename from submodules/TelegramUI/Sources/HorizontalListContextResultsChatInputPanelItem.swift rename to submodules/TelegramUI/TelegramUI/HorizontalListContextResultsChatInputPanelItem.swift diff --git a/submodules/TelegramUI/Sources/HorizontalStickerGridItem.swift b/submodules/TelegramUI/TelegramUI/HorizontalStickerGridItem.swift similarity index 100% rename from submodules/TelegramUI/Sources/HorizontalStickerGridItem.swift rename to submodules/TelegramUI/TelegramUI/HorizontalStickerGridItem.swift diff --git a/submodules/TelegramUI/Sources/HorizontalStickersChatContextPanelNode.swift b/submodules/TelegramUI/TelegramUI/HorizontalStickersChatContextPanelNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/HorizontalStickersChatContextPanelNode.swift rename to submodules/TelegramUI/TelegramUI/HorizontalStickersChatContextPanelNode.swift diff --git a/submodules/TelegramUI/Sources/ICloudResources.swift b/submodules/TelegramUI/TelegramUI/ICloudResources.swift similarity index 100% rename from submodules/TelegramUI/Sources/ICloudResources.swift rename to submodules/TelegramUI/TelegramUI/ICloudResources.swift diff --git a/submodules/TelegramUI/Sources/ID3ArtworkReader.swift b/submodules/TelegramUI/TelegramUI/ID3ArtworkReader.swift similarity index 100% rename from submodules/TelegramUI/Sources/ID3ArtworkReader.swift rename to submodules/TelegramUI/TelegramUI/ID3ArtworkReader.swift diff --git a/submodules/TelegramUI/Sources/IconButtonNode.swift b/submodules/TelegramUI/TelegramUI/IconButtonNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/IconButtonNode.swift rename to submodules/TelegramUI/TelegramUI/IconButtonNode.swift diff --git a/submodules/TelegramUI/Sources/InChatPrefetchManager.swift b/submodules/TelegramUI/TelegramUI/InChatPrefetchManager.swift similarity index 100% rename from submodules/TelegramUI/Sources/InChatPrefetchManager.swift rename to submodules/TelegramUI/TelegramUI/InChatPrefetchManager.swift diff --git a/submodules/TelegramUI/Sources/Info.plist b/submodules/TelegramUI/TelegramUI/Info.plist similarity index 100% rename from submodules/TelegramUI/Sources/Info.plist rename to submodules/TelegramUI/TelegramUI/Info.plist diff --git a/submodules/TelegramUI/Sources/InstantVideoRadialStatusNode.swift b/submodules/TelegramUI/TelegramUI/InstantVideoRadialStatusNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/InstantVideoRadialStatusNode.swift rename to submodules/TelegramUI/TelegramUI/InstantVideoRadialStatusNode.swift diff --git a/submodules/TelegramUI/Sources/LegacyCache.swift b/submodules/TelegramUI/TelegramUI/LegacyCache.swift similarity index 100% rename from submodules/TelegramUI/Sources/LegacyCache.swift rename to submodules/TelegramUI/TelegramUI/LegacyCache.swift diff --git a/submodules/TelegramUI/Sources/LegacyCamera.swift b/submodules/TelegramUI/TelegramUI/LegacyCamera.swift similarity index 100% rename from submodules/TelegramUI/Sources/LegacyCamera.swift rename to submodules/TelegramUI/TelegramUI/LegacyCamera.swift diff --git a/submodules/TelegramUI/Sources/LegacyInstantVideoController.swift b/submodules/TelegramUI/TelegramUI/LegacyInstantVideoController.swift similarity index 100% rename from submodules/TelegramUI/Sources/LegacyInstantVideoController.swift rename to submodules/TelegramUI/TelegramUI/LegacyInstantVideoController.swift diff --git a/submodules/TelegramUI/Sources/LegacyLiveUploadInterface.swift b/submodules/TelegramUI/TelegramUI/LegacyLiveUploadInterface.swift similarity index 100% rename from submodules/TelegramUI/Sources/LegacyLiveUploadInterface.swift rename to submodules/TelegramUI/TelegramUI/LegacyLiveUploadInterface.swift diff --git a/submodules/TelegramUI/Sources/LinkHighlightingNode.swift b/submodules/TelegramUI/TelegramUI/LinkHighlightingNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/LinkHighlightingNode.swift rename to submodules/TelegramUI/TelegramUI/LinkHighlightingNode.swift diff --git a/submodules/TelegramUI/Sources/ListMessageDateHeader.swift b/submodules/TelegramUI/TelegramUI/ListMessageDateHeader.swift similarity index 100% rename from submodules/TelegramUI/Sources/ListMessageDateHeader.swift rename to submodules/TelegramUI/TelegramUI/ListMessageDateHeader.swift diff --git a/submodules/TelegramUI/Sources/ListMessageFileItemNode.swift b/submodules/TelegramUI/TelegramUI/ListMessageFileItemNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ListMessageFileItemNode.swift rename to submodules/TelegramUI/TelegramUI/ListMessageFileItemNode.swift diff --git a/submodules/TelegramUI/Sources/ListMessageHoleItem.swift b/submodules/TelegramUI/TelegramUI/ListMessageHoleItem.swift similarity index 100% rename from submodules/TelegramUI/Sources/ListMessageHoleItem.swift rename to submodules/TelegramUI/TelegramUI/ListMessageHoleItem.swift diff --git a/submodules/TelegramUI/Sources/ListMessageItem.swift b/submodules/TelegramUI/TelegramUI/ListMessageItem.swift similarity index 100% rename from submodules/TelegramUI/Sources/ListMessageItem.swift rename to submodules/TelegramUI/TelegramUI/ListMessageItem.swift diff --git a/submodules/TelegramUI/Sources/ListMessageNode.swift b/submodules/TelegramUI/TelegramUI/ListMessageNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ListMessageNode.swift rename to submodules/TelegramUI/TelegramUI/ListMessageNode.swift diff --git a/submodules/TelegramUI/Sources/ListMessagePlaybackOverlayNode.swift b/submodules/TelegramUI/TelegramUI/ListMessagePlaybackOverlayNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ListMessagePlaybackOverlayNode.swift rename to submodules/TelegramUI/TelegramUI/ListMessagePlaybackOverlayNode.swift diff --git a/submodules/TelegramUI/Sources/ListMessageSnippetItemNode.swift b/submodules/TelegramUI/TelegramUI/ListMessageSnippetItemNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ListMessageSnippetItemNode.swift rename to submodules/TelegramUI/TelegramUI/ListMessageSnippetItemNode.swift diff --git a/submodules/TelegramUI/Sources/LockedWindowCoveringView.swift b/submodules/TelegramUI/TelegramUI/LockedWindowCoveringView.swift similarity index 100% rename from submodules/TelegramUI/Sources/LockedWindowCoveringView.swift rename to submodules/TelegramUI/TelegramUI/LockedWindowCoveringView.swift diff --git a/submodules/TelegramUI/Sources/ManageSharedAccountInfo.swift b/submodules/TelegramUI/TelegramUI/ManageSharedAccountInfo.swift similarity index 100% rename from submodules/TelegramUI/Sources/ManageSharedAccountInfo.swift rename to submodules/TelegramUI/TelegramUI/ManageSharedAccountInfo.swift diff --git a/submodules/TelegramUI/Sources/ManagedAudioRecorder.swift b/submodules/TelegramUI/TelegramUI/ManagedAudioRecorder.swift similarity index 100% rename from submodules/TelegramUI/Sources/ManagedAudioRecorder.swift rename to submodules/TelegramUI/TelegramUI/ManagedAudioRecorder.swift diff --git a/submodules/TelegramUI/Sources/MediaInputPaneTrendingItem.swift b/submodules/TelegramUI/TelegramUI/MediaInputPaneTrendingItem.swift similarity index 100% rename from submodules/TelegramUI/Sources/MediaInputPaneTrendingItem.swift rename to submodules/TelegramUI/TelegramUI/MediaInputPaneTrendingItem.swift diff --git a/submodules/TelegramUI/Sources/MediaManager.swift b/submodules/TelegramUI/TelegramUI/MediaManager.swift similarity index 100% rename from submodules/TelegramUI/Sources/MediaManager.swift rename to submodules/TelegramUI/TelegramUI/MediaManager.swift diff --git a/submodules/TelegramUI/Sources/MediaPlaybackStoredState.swift b/submodules/TelegramUI/TelegramUI/MediaPlaybackStoredState.swift similarity index 100% rename from submodules/TelegramUI/Sources/MediaPlaybackStoredState.swift rename to submodules/TelegramUI/TelegramUI/MediaPlaybackStoredState.swift diff --git a/submodules/TelegramUI/Sources/MentionChatInputContextPanelNode.swift b/submodules/TelegramUI/TelegramUI/MentionChatInputContextPanelNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/MentionChatInputContextPanelNode.swift rename to submodules/TelegramUI/TelegramUI/MentionChatInputContextPanelNode.swift diff --git a/submodules/TelegramUI/Sources/MentionChatInputPanelItem.swift b/submodules/TelegramUI/TelegramUI/MentionChatInputPanelItem.swift similarity index 100% rename from submodules/TelegramUI/Sources/MentionChatInputPanelItem.swift rename to submodules/TelegramUI/TelegramUI/MentionChatInputPanelItem.swift diff --git a/submodules/TelegramUI/Sources/MultiScaleTextNode.swift b/submodules/TelegramUI/TelegramUI/MultiScaleTextNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/MultiScaleTextNode.swift rename to submodules/TelegramUI/TelegramUI/MultiScaleTextNode.swift diff --git a/submodules/TelegramUI/Sources/MultiplexedSoftwareVideoNode.swift b/submodules/TelegramUI/TelegramUI/MultiplexedSoftwareVideoNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/MultiplexedSoftwareVideoNode.swift rename to submodules/TelegramUI/TelegramUI/MultiplexedSoftwareVideoNode.swift diff --git a/submodules/TelegramUI/Sources/MultiplexedSoftwareVideoSourceManager.swift b/submodules/TelegramUI/TelegramUI/MultiplexedSoftwareVideoSourceManager.swift similarity index 100% rename from submodules/TelegramUI/Sources/MultiplexedSoftwareVideoSourceManager.swift rename to submodules/TelegramUI/TelegramUI/MultiplexedSoftwareVideoSourceManager.swift diff --git a/submodules/TelegramUI/Sources/MultiplexedVideoNode.swift b/submodules/TelegramUI/TelegramUI/MultiplexedVideoNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/MultiplexedVideoNode.swift rename to submodules/TelegramUI/TelegramUI/MultiplexedVideoNode.swift diff --git a/submodules/TelegramUI/Sources/NavigateToChatController.swift b/submodules/TelegramUI/TelegramUI/NavigateToChatController.swift similarity index 100% rename from submodules/TelegramUI/Sources/NavigateToChatController.swift rename to submodules/TelegramUI/TelegramUI/NavigateToChatController.swift diff --git a/submodules/TelegramUI/Sources/NotificationContainerController.swift b/submodules/TelegramUI/TelegramUI/NotificationContainerController.swift similarity index 100% rename from submodules/TelegramUI/Sources/NotificationContainerController.swift rename to submodules/TelegramUI/TelegramUI/NotificationContainerController.swift diff --git a/submodules/TelegramUI/Sources/NotificationContainerControllerNode.swift b/submodules/TelegramUI/TelegramUI/NotificationContainerControllerNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/NotificationContainerControllerNode.swift rename to submodules/TelegramUI/TelegramUI/NotificationContainerControllerNode.swift diff --git a/submodules/TelegramUI/Sources/NotificationContentContext.swift b/submodules/TelegramUI/TelegramUI/NotificationContentContext.swift similarity index 100% rename from submodules/TelegramUI/Sources/NotificationContentContext.swift rename to submodules/TelegramUI/TelegramUI/NotificationContentContext.swift diff --git a/submodules/TelegramUI/Sources/NotificationItem.swift b/submodules/TelegramUI/TelegramUI/NotificationItem.swift similarity index 100% rename from submodules/TelegramUI/Sources/NotificationItem.swift rename to submodules/TelegramUI/TelegramUI/NotificationItem.swift diff --git a/submodules/TelegramUI/Sources/NotificationItemContainerNode.swift b/submodules/TelegramUI/TelegramUI/NotificationItemContainerNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/NotificationItemContainerNode.swift rename to submodules/TelegramUI/TelegramUI/NotificationItemContainerNode.swift diff --git a/submodules/TelegramUI/Sources/OpenAddContact.swift b/submodules/TelegramUI/TelegramUI/OpenAddContact.swift similarity index 100% rename from submodules/TelegramUI/Sources/OpenAddContact.swift rename to submodules/TelegramUI/TelegramUI/OpenAddContact.swift diff --git a/submodules/TelegramUI/Sources/OpenChatMessage.swift b/submodules/TelegramUI/TelegramUI/OpenChatMessage.swift similarity index 100% rename from submodules/TelegramUI/Sources/OpenChatMessage.swift rename to submodules/TelegramUI/TelegramUI/OpenChatMessage.swift diff --git a/submodules/TelegramUI/Sources/OpenResolvedUrl.swift b/submodules/TelegramUI/TelegramUI/OpenResolvedUrl.swift similarity index 100% rename from submodules/TelegramUI/Sources/OpenResolvedUrl.swift rename to submodules/TelegramUI/TelegramUI/OpenResolvedUrl.swift diff --git a/submodules/TelegramUI/Sources/OpenUrl.swift b/submodules/TelegramUI/TelegramUI/OpenUrl.swift similarity index 100% rename from submodules/TelegramUI/Sources/OpenUrl.swift rename to submodules/TelegramUI/TelegramUI/OpenUrl.swift diff --git a/submodules/TelegramUI/Sources/OverlayAudioPlayerController.swift b/submodules/TelegramUI/TelegramUI/OverlayAudioPlayerController.swift similarity index 100% rename from submodules/TelegramUI/Sources/OverlayAudioPlayerController.swift rename to submodules/TelegramUI/TelegramUI/OverlayAudioPlayerController.swift diff --git a/submodules/TelegramUI/Sources/OverlayInstantVideoDecoration.swift b/submodules/TelegramUI/TelegramUI/OverlayInstantVideoDecoration.swift similarity index 100% rename from submodules/TelegramUI/Sources/OverlayInstantVideoDecoration.swift rename to submodules/TelegramUI/TelegramUI/OverlayInstantVideoDecoration.swift diff --git a/submodules/TelegramUI/Sources/OverlayInstantVideoNode.swift b/submodules/TelegramUI/TelegramUI/OverlayInstantVideoNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/OverlayInstantVideoNode.swift rename to submodules/TelegramUI/TelegramUI/OverlayInstantVideoNode.swift diff --git a/submodules/TelegramUI/Sources/OverlayMediaController.swift b/submodules/TelegramUI/TelegramUI/OverlayMediaController.swift similarity index 100% rename from submodules/TelegramUI/Sources/OverlayMediaController.swift rename to submodules/TelegramUI/TelegramUI/OverlayMediaController.swift diff --git a/submodules/TelegramUI/Sources/OverlayMediaControllerNode.swift b/submodules/TelegramUI/TelegramUI/OverlayMediaControllerNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/OverlayMediaControllerNode.swift rename to submodules/TelegramUI/TelegramUI/OverlayMediaControllerNode.swift diff --git a/submodules/TelegramUI/Sources/OverlayPlayerControllerNode.swift b/submodules/TelegramUI/TelegramUI/OverlayPlayerControllerNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/OverlayPlayerControllerNode.swift rename to submodules/TelegramUI/TelegramUI/OverlayPlayerControllerNode.swift diff --git a/submodules/TelegramUI/Sources/OverlayPlayerControlsNode.swift b/submodules/TelegramUI/TelegramUI/OverlayPlayerControlsNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/OverlayPlayerControlsNode.swift rename to submodules/TelegramUI/TelegramUI/OverlayPlayerControlsNode.swift diff --git a/submodules/TelegramUI/Sources/PaneSearchBarNode.swift b/submodules/TelegramUI/TelegramUI/PaneSearchBarNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/PaneSearchBarNode.swift rename to submodules/TelegramUI/TelegramUI/PaneSearchBarNode.swift diff --git a/submodules/TelegramUI/Sources/PaneSearchBarPlaceholderItem.swift b/submodules/TelegramUI/TelegramUI/PaneSearchBarPlaceholderItem.swift similarity index 100% rename from submodules/TelegramUI/Sources/PaneSearchBarPlaceholderItem.swift rename to submodules/TelegramUI/TelegramUI/PaneSearchBarPlaceholderItem.swift diff --git a/submodules/TelegramUI/Sources/PaneSearchContainerNode.swift b/submodules/TelegramUI/TelegramUI/PaneSearchContainerNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/PaneSearchContainerNode.swift rename to submodules/TelegramUI/TelegramUI/PaneSearchContainerNode.swift diff --git a/submodules/TelegramUI/Sources/Pasteboard.swift b/submodules/TelegramUI/TelegramUI/Pasteboard.swift similarity index 100% rename from submodules/TelegramUI/Sources/Pasteboard.swift rename to submodules/TelegramUI/TelegramUI/Pasteboard.swift diff --git a/submodules/TelegramUI/Sources/PeerInfo/ListItems/PeerInfoScreenActionItem.swift b/submodules/TelegramUI/TelegramUI/PeerInfo/ListItems/PeerInfoScreenActionItem.swift similarity index 100% rename from submodules/TelegramUI/Sources/PeerInfo/ListItems/PeerInfoScreenActionItem.swift rename to submodules/TelegramUI/TelegramUI/PeerInfo/ListItems/PeerInfoScreenActionItem.swift diff --git a/submodules/TelegramUI/Sources/PeerInfo/ListItems/PeerInfoScreenAddressItem.swift b/submodules/TelegramUI/TelegramUI/PeerInfo/ListItems/PeerInfoScreenAddressItem.swift similarity index 100% rename from submodules/TelegramUI/Sources/PeerInfo/ListItems/PeerInfoScreenAddressItem.swift rename to submodules/TelegramUI/TelegramUI/PeerInfo/ListItems/PeerInfoScreenAddressItem.swift diff --git a/submodules/TelegramUI/Sources/PeerInfo/ListItems/PeerInfoScreenCallListItem.swift b/submodules/TelegramUI/TelegramUI/PeerInfo/ListItems/PeerInfoScreenCallListItem.swift similarity index 100% rename from submodules/TelegramUI/Sources/PeerInfo/ListItems/PeerInfoScreenCallListItem.swift rename to submodules/TelegramUI/TelegramUI/PeerInfo/ListItems/PeerInfoScreenCallListItem.swift diff --git a/submodules/TelegramUI/Sources/PeerInfo/ListItems/PeerInfoScreenCommentItem.swift b/submodules/TelegramUI/TelegramUI/PeerInfo/ListItems/PeerInfoScreenCommentItem.swift similarity index 100% rename from submodules/TelegramUI/Sources/PeerInfo/ListItems/PeerInfoScreenCommentItem.swift rename to submodules/TelegramUI/TelegramUI/PeerInfo/ListItems/PeerInfoScreenCommentItem.swift diff --git a/submodules/TelegramUI/Sources/PeerInfo/ListItems/PeerInfoScreenDisclosureEncryptionKeyItem.swift b/submodules/TelegramUI/TelegramUI/PeerInfo/ListItems/PeerInfoScreenDisclosureEncryptionKeyItem.swift similarity index 100% rename from submodules/TelegramUI/Sources/PeerInfo/ListItems/PeerInfoScreenDisclosureEncryptionKeyItem.swift rename to submodules/TelegramUI/TelegramUI/PeerInfo/ListItems/PeerInfoScreenDisclosureEncryptionKeyItem.swift diff --git a/submodules/TelegramUI/Sources/PeerInfo/ListItems/PeerInfoScreenDisclosureItem.swift b/submodules/TelegramUI/TelegramUI/PeerInfo/ListItems/PeerInfoScreenDisclosureItem.swift similarity index 100% rename from submodules/TelegramUI/Sources/PeerInfo/ListItems/PeerInfoScreenDisclosureItem.swift rename to submodules/TelegramUI/TelegramUI/PeerInfo/ListItems/PeerInfoScreenDisclosureItem.swift diff --git a/submodules/TelegramUI/Sources/PeerInfo/ListItems/PeerInfoScreenHeaderItem.swift b/submodules/TelegramUI/TelegramUI/PeerInfo/ListItems/PeerInfoScreenHeaderItem.swift similarity index 100% rename from submodules/TelegramUI/Sources/PeerInfo/ListItems/PeerInfoScreenHeaderItem.swift rename to submodules/TelegramUI/TelegramUI/PeerInfo/ListItems/PeerInfoScreenHeaderItem.swift diff --git a/submodules/TelegramUI/Sources/PeerInfo/ListItems/PeerInfoScreenLabeledValueItem.swift b/submodules/TelegramUI/TelegramUI/PeerInfo/ListItems/PeerInfoScreenLabeledValueItem.swift similarity index 100% rename from submodules/TelegramUI/Sources/PeerInfo/ListItems/PeerInfoScreenLabeledValueItem.swift rename to submodules/TelegramUI/TelegramUI/PeerInfo/ListItems/PeerInfoScreenLabeledValueItem.swift diff --git a/submodules/TelegramUI/Sources/PeerInfo/ListItems/PeerInfoScreenMemberItem.swift b/submodules/TelegramUI/TelegramUI/PeerInfo/ListItems/PeerInfoScreenMemberItem.swift similarity index 100% rename from submodules/TelegramUI/Sources/PeerInfo/ListItems/PeerInfoScreenMemberItem.swift rename to submodules/TelegramUI/TelegramUI/PeerInfo/ListItems/PeerInfoScreenMemberItem.swift diff --git a/submodules/TelegramUI/Sources/PeerInfo/ListItems/PeerInfoScreenSelectableBackgroundNode.swift b/submodules/TelegramUI/TelegramUI/PeerInfo/ListItems/PeerInfoScreenSelectableBackgroundNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/PeerInfo/ListItems/PeerInfoScreenSelectableBackgroundNode.swift rename to submodules/TelegramUI/TelegramUI/PeerInfo/ListItems/PeerInfoScreenSelectableBackgroundNode.swift diff --git a/submodules/TelegramUI/Sources/PeerInfo/ListItems/PeerInfoScreenSwitchItem.swift b/submodules/TelegramUI/TelegramUI/PeerInfo/ListItems/PeerInfoScreenSwitchItem.swift similarity index 100% rename from submodules/TelegramUI/Sources/PeerInfo/ListItems/PeerInfoScreenSwitchItem.swift rename to submodules/TelegramUI/TelegramUI/PeerInfo/ListItems/PeerInfoScreenSwitchItem.swift diff --git a/submodules/TelegramUI/Sources/PeerInfo/Panes/PeerInfoGroupsInCommonPaneNode.swift b/submodules/TelegramUI/TelegramUI/PeerInfo/Panes/PeerInfoGroupsInCommonPaneNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/PeerInfo/Panes/PeerInfoGroupsInCommonPaneNode.swift rename to submodules/TelegramUI/TelegramUI/PeerInfo/Panes/PeerInfoGroupsInCommonPaneNode.swift diff --git a/submodules/TelegramUI/Sources/PeerInfo/Panes/PeerInfoListPaneNode.swift b/submodules/TelegramUI/TelegramUI/PeerInfo/Panes/PeerInfoListPaneNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/PeerInfo/Panes/PeerInfoListPaneNode.swift rename to submodules/TelegramUI/TelegramUI/PeerInfo/Panes/PeerInfoListPaneNode.swift diff --git a/submodules/TelegramUI/Sources/PeerInfo/Panes/PeerInfoMembersPane.swift b/submodules/TelegramUI/TelegramUI/PeerInfo/Panes/PeerInfoMembersPane.swift similarity index 100% rename from submodules/TelegramUI/Sources/PeerInfo/Panes/PeerInfoMembersPane.swift rename to submodules/TelegramUI/TelegramUI/PeerInfo/Panes/PeerInfoMembersPane.swift diff --git a/submodules/TelegramUI/Sources/PeerInfo/Panes/PeerInfoVisualMediaPaneNode.swift b/submodules/TelegramUI/TelegramUI/PeerInfo/Panes/PeerInfoVisualMediaPaneNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/PeerInfo/Panes/PeerInfoVisualMediaPaneNode.swift rename to submodules/TelegramUI/TelegramUI/PeerInfo/Panes/PeerInfoVisualMediaPaneNode.swift diff --git a/submodules/TelegramUI/Sources/PeerInfo/PeerInfoData.swift b/submodules/TelegramUI/TelegramUI/PeerInfo/PeerInfoData.swift similarity index 100% rename from submodules/TelegramUI/Sources/PeerInfo/PeerInfoData.swift rename to submodules/TelegramUI/TelegramUI/PeerInfo/PeerInfoData.swift diff --git a/submodules/TelegramUI/Sources/PeerInfo/PeerInfoHeaderNode.swift b/submodules/TelegramUI/TelegramUI/PeerInfo/PeerInfoHeaderNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/PeerInfo/PeerInfoHeaderNode.swift rename to submodules/TelegramUI/TelegramUI/PeerInfo/PeerInfoHeaderNode.swift diff --git a/submodules/TelegramUI/Sources/PeerInfo/PeerInfoMembers.swift b/submodules/TelegramUI/TelegramUI/PeerInfo/PeerInfoMembers.swift similarity index 100% rename from submodules/TelegramUI/Sources/PeerInfo/PeerInfoMembers.swift rename to submodules/TelegramUI/TelegramUI/PeerInfo/PeerInfoMembers.swift diff --git a/submodules/TelegramUI/Sources/PeerInfo/PeerInfoPaneContainerNode.swift b/submodules/TelegramUI/TelegramUI/PeerInfo/PeerInfoPaneContainerNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/PeerInfo/PeerInfoPaneContainerNode.swift rename to submodules/TelegramUI/TelegramUI/PeerInfo/PeerInfoPaneContainerNode.swift diff --git a/submodules/TelegramUI/Sources/PeerInfo/PeerInfoScreen.swift b/submodules/TelegramUI/TelegramUI/PeerInfo/PeerInfoScreen.swift similarity index 100% rename from submodules/TelegramUI/Sources/PeerInfo/PeerInfoScreen.swift rename to submodules/TelegramUI/TelegramUI/PeerInfo/PeerInfoScreen.swift diff --git a/submodules/TelegramUI/Sources/PeerMediaCollectionController.swift b/submodules/TelegramUI/TelegramUI/PeerMediaCollectionController.swift similarity index 100% rename from submodules/TelegramUI/Sources/PeerMediaCollectionController.swift rename to submodules/TelegramUI/TelegramUI/PeerMediaCollectionController.swift diff --git a/submodules/TelegramUI/Sources/PeerMediaCollectionControllerNode.swift b/submodules/TelegramUI/TelegramUI/PeerMediaCollectionControllerNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/PeerMediaCollectionControllerNode.swift rename to submodules/TelegramUI/TelegramUI/PeerMediaCollectionControllerNode.swift diff --git a/submodules/TelegramUI/Sources/PeerMediaCollectionEmptyNode.swift b/submodules/TelegramUI/TelegramUI/PeerMediaCollectionEmptyNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/PeerMediaCollectionEmptyNode.swift rename to submodules/TelegramUI/TelegramUI/PeerMediaCollectionEmptyNode.swift diff --git a/submodules/TelegramUI/Sources/PeerMediaCollectionInterfaceState.swift b/submodules/TelegramUI/TelegramUI/PeerMediaCollectionInterfaceState.swift similarity index 100% rename from submodules/TelegramUI/Sources/PeerMediaCollectionInterfaceState.swift rename to submodules/TelegramUI/TelegramUI/PeerMediaCollectionInterfaceState.swift diff --git a/submodules/TelegramUI/Sources/PeerMediaCollectionInterfaceStateButtons.swift b/submodules/TelegramUI/TelegramUI/PeerMediaCollectionInterfaceStateButtons.swift similarity index 100% rename from submodules/TelegramUI/Sources/PeerMediaCollectionInterfaceStateButtons.swift rename to submodules/TelegramUI/TelegramUI/PeerMediaCollectionInterfaceStateButtons.swift diff --git a/submodules/TelegramUI/Sources/PeerMediaCollectionSectionsNode.swift b/submodules/TelegramUI/TelegramUI/PeerMediaCollectionSectionsNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/PeerMediaCollectionSectionsNode.swift rename to submodules/TelegramUI/TelegramUI/PeerMediaCollectionSectionsNode.swift diff --git a/submodules/TelegramUI/Sources/PeerMessagesMediaPlaylist.swift b/submodules/TelegramUI/TelegramUI/PeerMessagesMediaPlaylist.swift similarity index 100% rename from submodules/TelegramUI/Sources/PeerMessagesMediaPlaylist.swift rename to submodules/TelegramUI/TelegramUI/PeerMessagesMediaPlaylist.swift diff --git a/submodules/TelegramUI/Sources/PeerSelectionController.swift b/submodules/TelegramUI/TelegramUI/PeerSelectionController.swift similarity index 100% rename from submodules/TelegramUI/Sources/PeerSelectionController.swift rename to submodules/TelegramUI/TelegramUI/PeerSelectionController.swift diff --git a/submodules/TelegramUI/Sources/PeerSelectionControllerNode.swift b/submodules/TelegramUI/TelegramUI/PeerSelectionControllerNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/PeerSelectionControllerNode.swift rename to submodules/TelegramUI/TelegramUI/PeerSelectionControllerNode.swift diff --git a/submodules/TelegramUI/Sources/PeersNearbyManager.swift b/submodules/TelegramUI/TelegramUI/PeersNearbyManager.swift similarity index 100% rename from submodules/TelegramUI/Sources/PeersNearbyManager.swift rename to submodules/TelegramUI/TelegramUI/PeersNearbyManager.swift diff --git a/submodules/TelegramUI/Sources/PollResultsController.swift b/submodules/TelegramUI/TelegramUI/PollResultsController.swift similarity index 100% rename from submodules/TelegramUI/Sources/PollResultsController.swift rename to submodules/TelegramUI/TelegramUI/PollResultsController.swift diff --git a/submodules/TelegramUI/Sources/PrefetchManager.swift b/submodules/TelegramUI/TelegramUI/PrefetchManager.swift similarity index 100% rename from submodules/TelegramUI/Sources/PrefetchManager.swift rename to submodules/TelegramUI/TelegramUI/PrefetchManager.swift diff --git a/submodules/TelegramUI/Sources/PrepareSecretThumbnailData.swift b/submodules/TelegramUI/TelegramUI/PrepareSecretThumbnailData.swift similarity index 100% rename from submodules/TelegramUI/Sources/PrepareSecretThumbnailData.swift rename to submodules/TelegramUI/TelegramUI/PrepareSecretThumbnailData.swift diff --git a/submodules/TelegramUI/Sources/PreparedChatHistoryViewTransition.swift b/submodules/TelegramUI/TelegramUI/PreparedChatHistoryViewTransition.swift similarity index 100% rename from submodules/TelegramUI/Sources/PreparedChatHistoryViewTransition.swift rename to submodules/TelegramUI/TelegramUI/PreparedChatHistoryViewTransition.swift diff --git a/submodules/TelegramUI/Sources/ProcessedPeerRestrictionText.swift b/submodules/TelegramUI/TelegramUI/ProcessedPeerRestrictionText.swift similarity index 100% rename from submodules/TelegramUI/Sources/ProcessedPeerRestrictionText.swift rename to submodules/TelegramUI/TelegramUI/ProcessedPeerRestrictionText.swift diff --git a/submodules/TelegramUI/Sources/RadialProgressNode.swift b/submodules/TelegramUI/TelegramUI/RadialProgressNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/RadialProgressNode.swift rename to submodules/TelegramUI/TelegramUI/RadialProgressNode.swift diff --git a/submodules/TelegramUI/Sources/RadialTimeoutNode.swift b/submodules/TelegramUI/TelegramUI/RadialTimeoutNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/RadialTimeoutNode.swift rename to submodules/TelegramUI/TelegramUI/RadialTimeoutNode.swift diff --git a/submodules/TelegramUI/Sources/ReplyAccessoryPanelNode.swift b/submodules/TelegramUI/TelegramUI/ReplyAccessoryPanelNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/ReplyAccessoryPanelNode.swift rename to submodules/TelegramUI/TelegramUI/ReplyAccessoryPanelNode.swift diff --git a/submodules/TelegramUI/Sources/Resources/Animations/ChatListEmpty.tgs b/submodules/TelegramUI/TelegramUI/Resources/Animations/ChatListEmpty.tgs similarity index 100% rename from submodules/TelegramUI/Sources/Resources/Animations/ChatListEmpty.tgs rename to submodules/TelegramUI/TelegramUI/Resources/Animations/ChatListEmpty.tgs diff --git a/submodules/TelegramUI/Sources/Resources/Animations/ChatListFilterEmpty.tgs b/submodules/TelegramUI/TelegramUI/Resources/Animations/ChatListFilterEmpty.tgs similarity index 100% rename from submodules/TelegramUI/Sources/Resources/Animations/ChatListFilterEmpty.tgs rename to submodules/TelegramUI/TelegramUI/Resources/Animations/ChatListFilterEmpty.tgs diff --git a/submodules/TelegramUI/Sources/Resources/Animations/anim_archive.json b/submodules/TelegramUI/TelegramUI/Resources/Animations/anim_archive.json similarity index 100% rename from submodules/TelegramUI/Sources/Resources/Animations/anim_archive.json rename to submodules/TelegramUI/TelegramUI/Resources/Animations/anim_archive.json diff --git a/submodules/TelegramUI/Sources/Resources/Animations/anim_archiveAvatar.json b/submodules/TelegramUI/TelegramUI/Resources/Animations/anim_archiveAvatar.json similarity index 100% rename from submodules/TelegramUI/Sources/Resources/Animations/anim_archiveAvatar.json rename to submodules/TelegramUI/TelegramUI/Resources/Animations/anim_archiveAvatar.json diff --git a/submodules/TelegramUI/Sources/Resources/Animations/anim_archiveswipe.json b/submodules/TelegramUI/TelegramUI/Resources/Animations/anim_archiveswipe.json similarity index 100% rename from submodules/TelegramUI/Sources/Resources/Animations/anim_archiveswipe.json rename to submodules/TelegramUI/TelegramUI/Resources/Animations/anim_archiveswipe.json diff --git a/submodules/TelegramUI/Sources/Resources/Animations/anim_delete.json b/submodules/TelegramUI/TelegramUI/Resources/Animations/anim_delete.json similarity index 100% rename from submodules/TelegramUI/Sources/Resources/Animations/anim_delete.json rename to submodules/TelegramUI/TelegramUI/Resources/Animations/anim_delete.json diff --git a/submodules/TelegramUI/Sources/Resources/Animations/anim_group.json b/submodules/TelegramUI/TelegramUI/Resources/Animations/anim_group.json similarity index 100% rename from submodules/TelegramUI/Sources/Resources/Animations/anim_group.json rename to submodules/TelegramUI/TelegramUI/Resources/Animations/anim_group.json diff --git a/submodules/TelegramUI/Sources/Resources/Animations/anim_hide.json b/submodules/TelegramUI/TelegramUI/Resources/Animations/anim_hide.json similarity index 100% rename from submodules/TelegramUI/Sources/Resources/Animations/anim_hide.json rename to submodules/TelegramUI/TelegramUI/Resources/Animations/anim_hide.json diff --git a/submodules/TelegramUI/Sources/Resources/Animations/anim_infotip.json b/submodules/TelegramUI/TelegramUI/Resources/Animations/anim_infotip.json similarity index 100% rename from submodules/TelegramUI/Sources/Resources/Animations/anim_infotip.json rename to submodules/TelegramUI/TelegramUI/Resources/Animations/anim_infotip.json diff --git a/submodules/TelegramUI/Sources/Resources/Animations/anim_mute.json b/submodules/TelegramUI/TelegramUI/Resources/Animations/anim_mute.json similarity index 100% rename from submodules/TelegramUI/Sources/Resources/Animations/anim_mute.json rename to submodules/TelegramUI/TelegramUI/Resources/Animations/anim_mute.json diff --git a/submodules/TelegramUI/Sources/Resources/Animations/anim_pin.json b/submodules/TelegramUI/TelegramUI/Resources/Animations/anim_pin.json similarity index 100% rename from submodules/TelegramUI/Sources/Resources/Animations/anim_pin.json rename to submodules/TelegramUI/TelegramUI/Resources/Animations/anim_pin.json diff --git a/submodules/TelegramUI/Sources/Resources/Animations/anim_qr.json b/submodules/TelegramUI/TelegramUI/Resources/Animations/anim_qr.json similarity index 100% rename from submodules/TelegramUI/Sources/Resources/Animations/anim_qr.json rename to submodules/TelegramUI/TelegramUI/Resources/Animations/anim_qr.json diff --git a/submodules/TelegramUI/Sources/Resources/Animations/anim_read.json b/submodules/TelegramUI/TelegramUI/Resources/Animations/anim_read.json similarity index 100% rename from submodules/TelegramUI/Sources/Resources/Animations/anim_read.json rename to submodules/TelegramUI/TelegramUI/Resources/Animations/anim_read.json diff --git a/submodules/TelegramUI/Sources/Resources/Animations/anim_success.json b/submodules/TelegramUI/TelegramUI/Resources/Animations/anim_success.json similarity index 100% rename from submodules/TelegramUI/Sources/Resources/Animations/anim_success.json rename to submodules/TelegramUI/TelegramUI/Resources/Animations/anim_success.json diff --git a/submodules/TelegramUI/Sources/Resources/Animations/anim_swipereply.json b/submodules/TelegramUI/TelegramUI/Resources/Animations/anim_swipereply.json similarity index 100% rename from submodules/TelegramUI/Sources/Resources/Animations/anim_swipereply.json rename to submodules/TelegramUI/TelegramUI/Resources/Animations/anim_swipereply.json diff --git a/submodules/TelegramUI/Sources/Resources/Animations/anim_unarchive.json b/submodules/TelegramUI/TelegramUI/Resources/Animations/anim_unarchive.json similarity index 100% rename from submodules/TelegramUI/Sources/Resources/Animations/anim_unarchive.json rename to submodules/TelegramUI/TelegramUI/Resources/Animations/anim_unarchive.json diff --git a/submodules/TelegramUI/Sources/Resources/Animations/anim_ungroup.json b/submodules/TelegramUI/TelegramUI/Resources/Animations/anim_ungroup.json similarity index 100% rename from submodules/TelegramUI/Sources/Resources/Animations/anim_ungroup.json rename to submodules/TelegramUI/TelegramUI/Resources/Animations/anim_ungroup.json diff --git a/submodules/TelegramUI/Sources/Resources/Animations/anim_unmute.json b/submodules/TelegramUI/TelegramUI/Resources/Animations/anim_unmute.json similarity index 100% rename from submodules/TelegramUI/Sources/Resources/Animations/anim_unmute.json rename to submodules/TelegramUI/TelegramUI/Resources/Animations/anim_unmute.json diff --git a/submodules/TelegramUI/Sources/Resources/Animations/anim_unpin.json b/submodules/TelegramUI/TelegramUI/Resources/Animations/anim_unpin.json similarity index 100% rename from submodules/TelegramUI/Sources/Resources/Animations/anim_unpin.json rename to submodules/TelegramUI/TelegramUI/Resources/Animations/anim_unpin.json diff --git a/submodules/TelegramUI/Sources/Resources/Animations/anim_unread.json b/submodules/TelegramUI/TelegramUI/Resources/Animations/anim_unread.json similarity index 100% rename from submodules/TelegramUI/Sources/Resources/Animations/anim_unread.json rename to submodules/TelegramUI/TelegramUI/Resources/Animations/anim_unread.json diff --git a/submodules/TelegramUI/Sources/Resources/BuiltinReactions/celebrate.tgs b/submodules/TelegramUI/TelegramUI/Resources/BuiltinReactions/celebrate.tgs similarity index 100% rename from submodules/TelegramUI/Sources/Resources/BuiltinReactions/celebrate.tgs rename to submodules/TelegramUI/TelegramUI/Resources/BuiltinReactions/celebrate.tgs diff --git a/submodules/TelegramUI/Sources/Resources/BuiltinReactions/cry.tgs b/submodules/TelegramUI/TelegramUI/Resources/BuiltinReactions/cry.tgs similarity index 100% rename from submodules/TelegramUI/Sources/Resources/BuiltinReactions/cry.tgs rename to submodules/TelegramUI/TelegramUI/Resources/BuiltinReactions/cry.tgs diff --git a/submodules/TelegramUI/Sources/Resources/BuiltinReactions/heart.tgs b/submodules/TelegramUI/TelegramUI/Resources/BuiltinReactions/heart.tgs similarity index 100% rename from submodules/TelegramUI/Sources/Resources/BuiltinReactions/heart.tgs rename to submodules/TelegramUI/TelegramUI/Resources/BuiltinReactions/heart.tgs diff --git a/submodules/TelegramUI/Sources/Resources/BuiltinReactions/lol.tgs b/submodules/TelegramUI/TelegramUI/Resources/BuiltinReactions/lol.tgs similarity index 100% rename from submodules/TelegramUI/Sources/Resources/BuiltinReactions/lol.tgs rename to submodules/TelegramUI/TelegramUI/Resources/BuiltinReactions/lol.tgs diff --git a/submodules/TelegramUI/Sources/Resources/BuiltinReactions/meh.tgs b/submodules/TelegramUI/TelegramUI/Resources/BuiltinReactions/meh.tgs similarity index 100% rename from submodules/TelegramUI/Sources/Resources/BuiltinReactions/meh.tgs rename to submodules/TelegramUI/TelegramUI/Resources/BuiltinReactions/meh.tgs diff --git a/submodules/TelegramUI/Sources/Resources/BuiltinReactions/ok.tgs b/submodules/TelegramUI/TelegramUI/Resources/BuiltinReactions/ok.tgs similarity index 100% rename from submodules/TelegramUI/Sources/Resources/BuiltinReactions/ok.tgs rename to submodules/TelegramUI/TelegramUI/Resources/BuiltinReactions/ok.tgs diff --git a/submodules/TelegramUI/Sources/Resources/BuiltinReactions/poker.tgs b/submodules/TelegramUI/TelegramUI/Resources/BuiltinReactions/poker.tgs similarity index 100% rename from submodules/TelegramUI/Sources/Resources/BuiltinReactions/poker.tgs rename to submodules/TelegramUI/TelegramUI/Resources/BuiltinReactions/poker.tgs diff --git a/submodules/TelegramUI/Sources/Resources/BuiltinReactions/poop.tgs b/submodules/TelegramUI/TelegramUI/Resources/BuiltinReactions/poop.tgs similarity index 100% rename from submodules/TelegramUI/Sources/Resources/BuiltinReactions/poop.tgs rename to submodules/TelegramUI/TelegramUI/Resources/BuiltinReactions/poop.tgs diff --git a/submodules/TelegramUI/Sources/Resources/BuiltinReactions/sad.tgs b/submodules/TelegramUI/TelegramUI/Resources/BuiltinReactions/sad.tgs similarity index 100% rename from submodules/TelegramUI/Sources/Resources/BuiltinReactions/sad.tgs rename to submodules/TelegramUI/TelegramUI/Resources/BuiltinReactions/sad.tgs diff --git a/submodules/TelegramUI/Sources/Resources/BuiltinReactions/smile.tgs b/submodules/TelegramUI/TelegramUI/Resources/BuiltinReactions/smile.tgs similarity index 100% rename from submodules/TelegramUI/Sources/Resources/BuiltinReactions/smile.tgs rename to submodules/TelegramUI/TelegramUI/Resources/BuiltinReactions/smile.tgs diff --git a/submodules/TelegramUI/Sources/Resources/BuiltinReactions/surprised.tgs b/submodules/TelegramUI/TelegramUI/Resources/BuiltinReactions/surprised.tgs similarity index 100% rename from submodules/TelegramUI/Sources/Resources/BuiltinReactions/surprised.tgs rename to submodules/TelegramUI/TelegramUI/Resources/BuiltinReactions/surprised.tgs diff --git a/submodules/TelegramUI/Sources/Resources/BuiltinReactions/thumbsup.tgs b/submodules/TelegramUI/TelegramUI/Resources/BuiltinReactions/thumbsup.tgs similarity index 100% rename from submodules/TelegramUI/Sources/Resources/BuiltinReactions/thumbsup.tgs rename to submodules/TelegramUI/TelegramUI/Resources/BuiltinReactions/thumbsup.tgs diff --git a/submodules/TelegramUI/Sources/Resources/ChatWallpaperBuiltin0.jpg b/submodules/TelegramUI/TelegramUI/Resources/ChatWallpaperBuiltin0.jpg similarity index 100% rename from submodules/TelegramUI/Sources/Resources/ChatWallpaperBuiltin0.jpg rename to submodules/TelegramUI/TelegramUI/Resources/ChatWallpaperBuiltin0.jpg diff --git a/submodules/TelegramUI/Sources/Resources/Emoji.mapping b/submodules/TelegramUI/TelegramUI/Resources/Emoji.mapping similarity index 100% rename from submodules/TelegramUI/Sources/Resources/Emoji.mapping rename to submodules/TelegramUI/TelegramUI/Resources/Emoji.mapping diff --git a/submodules/TelegramUI/Sources/Resources/Fonts/SFCompactRounded-Semibold.otf b/submodules/TelegramUI/TelegramUI/Resources/Fonts/SFCompactRounded-Semibold.otf similarity index 100% rename from submodules/TelegramUI/Sources/Resources/Fonts/SFCompactRounded-Semibold.otf rename to submodules/TelegramUI/TelegramUI/Resources/Fonts/SFCompactRounded-Semibold.otf diff --git a/submodules/TelegramUI/Sources/Resources/PhoneCountries.txt b/submodules/TelegramUI/TelegramUI/Resources/PhoneCountries.txt similarity index 100% rename from submodules/TelegramUI/Sources/Resources/PhoneCountries.txt rename to submodules/TelegramUI/TelegramUI/Resources/PhoneCountries.txt diff --git a/submodules/TelegramUI/Sources/Resources/PresentationStrings.mapping b/submodules/TelegramUI/TelegramUI/Resources/PresentationStrings.mapping similarity index 100% rename from submodules/TelegramUI/Sources/Resources/PresentationStrings.mapping rename to submodules/TelegramUI/TelegramUI/Resources/PresentationStrings.mapping diff --git a/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_10@2x.png b/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_10@2x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_10@2x.png rename to submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_10@2x.png diff --git a/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_10@3x.png b/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_10@3x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_10@3x.png rename to submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_10@3x.png diff --git a/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_11@2x.png b/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_11@2x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_11@2x.png rename to submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_11@2x.png diff --git a/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_11@3x.png b/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_11@3x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_11@3x.png rename to submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_11@3x.png diff --git a/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_12@2x.png b/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_12@2x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_12@2x.png rename to submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_12@2x.png diff --git a/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_12@3x.png b/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_12@3x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_12@3x.png rename to submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_12@3x.png diff --git a/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_13@2x.png b/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_13@2x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_13@2x.png rename to submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_13@2x.png diff --git a/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_13@3x.png b/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_13@3x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_13@3x.png rename to submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_13@3x.png diff --git a/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_14@2x.png b/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_14@2x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_14@2x.png rename to submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_14@2x.png diff --git a/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_14@3x.png b/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_14@3x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_14@3x.png rename to submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_14@3x.png diff --git a/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_15@2x.png b/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_15@2x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_15@2x.png rename to submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_15@2x.png diff --git a/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_15@3x.png b/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_15@3x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_15@3x.png rename to submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_15@3x.png diff --git a/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_16@2x.png b/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_16@2x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_16@2x.png rename to submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_16@2x.png diff --git a/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_16@3x.png b/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_16@3x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_16@3x.png rename to submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_16@3x.png diff --git a/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_17@2x.png b/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_17@2x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_17@2x.png rename to submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_17@2x.png diff --git a/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_17@3x.png b/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_17@3x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_17@3x.png rename to submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_17@3x.png diff --git a/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_18@2x.png b/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_18@2x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_18@2x.png rename to submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_18@2x.png diff --git a/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_18@3x.png b/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_18@3x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_18@3x.png rename to submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_18@3x.png diff --git a/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_19@2x.png b/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_19@2x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_19@2x.png rename to submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_19@2x.png diff --git a/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_19@3x.png b/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_19@3x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_19@3x.png rename to submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_19@3x.png diff --git a/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_1@2x.png b/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_1@2x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_1@2x.png rename to submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_1@2x.png diff --git a/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_1@3x.png b/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_1@3x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_1@3x.png rename to submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_1@3x.png diff --git a/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_20@2x.png b/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_20@2x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_20@2x.png rename to submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_20@2x.png diff --git a/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_20@3x.png b/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_20@3x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_20@3x.png rename to submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_20@3x.png diff --git a/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_2@2x.png b/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_2@2x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_2@2x.png rename to submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_2@2x.png diff --git a/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_2@3x.png b/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_2@3x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_2@3x.png rename to submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_2@3x.png diff --git a/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_3@2x.png b/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_3@2x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_3@2x.png rename to submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_3@2x.png diff --git a/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_3@3x.png b/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_3@3x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_3@3x.png rename to submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_3@3x.png diff --git a/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_4@2x.png b/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_4@2x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_4@2x.png rename to submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_4@2x.png diff --git a/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_4@3x.png b/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_4@3x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_4@3x.png rename to submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_4@3x.png diff --git a/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_5@2x.png b/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_5@2x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_5@2x.png rename to submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_5@2x.png diff --git a/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_5@3x.png b/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_5@3x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_5@3x.png rename to submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_5@3x.png diff --git a/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_6@2x.png b/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_6@2x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_6@2x.png rename to submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_6@2x.png diff --git a/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_6@3x.png b/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_6@3x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_6@3x.png rename to submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_6@3x.png diff --git a/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_7@2x.png b/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_7@2x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_7@2x.png rename to submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_7@2x.png diff --git a/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_7@3x.png b/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_7@3x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_7@3x.png rename to submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_7@3x.png diff --git a/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_8@2x.png b/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_8@2x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_8@2x.png rename to submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_8@2x.png diff --git a/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_8@3x.png b/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_8@3x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_8@3x.png rename to submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_8@3x.png diff --git a/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_9@2x.png b/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_9@2x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_9@2x.png rename to submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_9@2x.png diff --git a/submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_9@3x.png b/submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_9@3x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/StillReactions/simplereaction_9@3x.png rename to submodules/TelegramUI/TelegramUI/Resources/StillReactions/simplereaction_9@3x.png diff --git a/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_amex@2x.png b/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_amex@2x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/Stripe/stp_card_amex@2x.png rename to submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_amex@2x.png diff --git a/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_amex@3x.png b/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_amex@3x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/Stripe/stp_card_amex@3x.png rename to submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_amex@3x.png diff --git a/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_amex_template@2x.png b/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_amex_template@2x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/Stripe/stp_card_amex_template@2x.png rename to submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_amex_template@2x.png diff --git a/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_amex_template@3x.png b/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_amex_template@3x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/Stripe/stp_card_amex_template@3x.png rename to submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_amex_template@3x.png diff --git a/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_applepay@2x.png b/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_applepay@2x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/Stripe/stp_card_applepay@2x.png rename to submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_applepay@2x.png diff --git a/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_applepay@3x.png b/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_applepay@3x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/Stripe/stp_card_applepay@3x.png rename to submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_applepay@3x.png diff --git a/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_applepay_template@2x.png b/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_applepay_template@2x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/Stripe/stp_card_applepay_template@2x.png rename to submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_applepay_template@2x.png diff --git a/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_applepay_template@3x.png b/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_applepay_template@3x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/Stripe/stp_card_applepay_template@3x.png rename to submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_applepay_template@3x.png diff --git a/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_cvc@2x.png b/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_cvc@2x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/Stripe/stp_card_cvc@2x.png rename to submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_cvc@2x.png diff --git a/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_cvc@3x.png b/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_cvc@3x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/Stripe/stp_card_cvc@3x.png rename to submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_cvc@3x.png diff --git a/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_cvc_amex@2x.png b/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_cvc_amex@2x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/Stripe/stp_card_cvc_amex@2x.png rename to submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_cvc_amex@2x.png diff --git a/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_cvc_amex@3x.png b/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_cvc_amex@3x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/Stripe/stp_card_cvc_amex@3x.png rename to submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_cvc_amex@3x.png diff --git a/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_diners@2x.png b/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_diners@2x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/Stripe/stp_card_diners@2x.png rename to submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_diners@2x.png diff --git a/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_diners@3x.png b/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_diners@3x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/Stripe/stp_card_diners@3x.png rename to submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_diners@3x.png diff --git a/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_diners_template@2x.png b/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_diners_template@2x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/Stripe/stp_card_diners_template@2x.png rename to submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_diners_template@2x.png diff --git a/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_diners_template@3x.png b/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_diners_template@3x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/Stripe/stp_card_diners_template@3x.png rename to submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_diners_template@3x.png diff --git a/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_discover@2x.png b/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_discover@2x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/Stripe/stp_card_discover@2x.png rename to submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_discover@2x.png diff --git a/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_discover@3x.png b/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_discover@3x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/Stripe/stp_card_discover@3x.png rename to submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_discover@3x.png diff --git a/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_discover_template@2x.png b/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_discover_template@2x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/Stripe/stp_card_discover_template@2x.png rename to submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_discover_template@2x.png diff --git a/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_discover_template@3x.png b/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_discover_template@3x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/Stripe/stp_card_discover_template@3x.png rename to submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_discover_template@3x.png diff --git a/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_form_applepay@2x.png b/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_form_applepay@2x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/Stripe/stp_card_form_applepay@2x.png rename to submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_form_applepay@2x.png diff --git a/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_form_applepay@3x.png b/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_form_applepay@3x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/Stripe/stp_card_form_applepay@3x.png rename to submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_form_applepay@3x.png diff --git a/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_form_back@2x.png b/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_form_back@2x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/Stripe/stp_card_form_back@2x.png rename to submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_form_back@2x.png diff --git a/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_form_back@3x.png b/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_form_back@3x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/Stripe/stp_card_form_back@3x.png rename to submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_form_back@3x.png diff --git a/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_form_front@2x.png b/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_form_front@2x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/Stripe/stp_card_form_front@2x.png rename to submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_form_front@2x.png diff --git a/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_form_front@3x.png b/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_form_front@3x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/Stripe/stp_card_form_front@3x.png rename to submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_form_front@3x.png diff --git a/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_jcb@2x.png b/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_jcb@2x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/Stripe/stp_card_jcb@2x.png rename to submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_jcb@2x.png diff --git a/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_jcb@3x.png b/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_jcb@3x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/Stripe/stp_card_jcb@3x.png rename to submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_jcb@3x.png diff --git a/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_jcb_template@2x.png b/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_jcb_template@2x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/Stripe/stp_card_jcb_template@2x.png rename to submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_jcb_template@2x.png diff --git a/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_jcb_template@3x.png b/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_jcb_template@3x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/Stripe/stp_card_jcb_template@3x.png rename to submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_jcb_template@3x.png diff --git a/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_mastercard@2x.png b/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_mastercard@2x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/Stripe/stp_card_mastercard@2x.png rename to submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_mastercard@2x.png diff --git a/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_mastercard@3x.png b/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_mastercard@3x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/Stripe/stp_card_mastercard@3x.png rename to submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_mastercard@3x.png diff --git a/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_mastercard_template@2x.png b/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_mastercard_template@2x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/Stripe/stp_card_mastercard_template@2x.png rename to submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_mastercard_template@2x.png diff --git a/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_mastercard_template@3x.png b/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_mastercard_template@3x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/Stripe/stp_card_mastercard_template@3x.png rename to submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_mastercard_template@3x.png diff --git a/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_placeholder_template@2x.png b/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_placeholder_template@2x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/Stripe/stp_card_placeholder_template@2x.png rename to submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_placeholder_template@2x.png diff --git a/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_placeholder_template@3x.png b/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_placeholder_template@3x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/Stripe/stp_card_placeholder_template@3x.png rename to submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_placeholder_template@3x.png diff --git a/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_visa@2x.png b/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_visa@2x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/Stripe/stp_card_visa@2x.png rename to submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_visa@2x.png diff --git a/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_visa@3x.png b/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_visa@3x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/Stripe/stp_card_visa@3x.png rename to submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_visa@3x.png diff --git a/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_visa_template@2x.png b/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_visa_template@2x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/Stripe/stp_card_visa_template@2x.png rename to submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_visa_template@2x.png diff --git a/submodules/TelegramUI/Sources/Resources/Stripe/stp_card_visa_template@3x.png b/submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_visa_template@3x.png similarity index 100% rename from submodules/TelegramUI/Sources/Resources/Stripe/stp_card_visa_template@3x.png rename to submodules/TelegramUI/TelegramUI/Resources/Stripe/stp_card_visa_template@3x.png diff --git a/submodules/TelegramUI/Sources/Resources/WebEmbed/Generic.html b/submodules/TelegramUI/TelegramUI/Resources/WebEmbed/Generic.html similarity index 100% rename from submodules/TelegramUI/Sources/Resources/WebEmbed/Generic.html rename to submodules/TelegramUI/TelegramUI/Resources/WebEmbed/Generic.html diff --git a/submodules/TelegramUI/Sources/Resources/WebEmbed/GenericUserScript.js b/submodules/TelegramUI/TelegramUI/Resources/WebEmbed/GenericUserScript.js similarity index 100% rename from submodules/TelegramUI/Sources/Resources/WebEmbed/GenericUserScript.js rename to submodules/TelegramUI/TelegramUI/Resources/WebEmbed/GenericUserScript.js diff --git a/submodules/TelegramUI/Sources/Resources/WebEmbed/Instagram.html b/submodules/TelegramUI/TelegramUI/Resources/WebEmbed/Instagram.html similarity index 100% rename from submodules/TelegramUI/Sources/Resources/WebEmbed/Instagram.html rename to submodules/TelegramUI/TelegramUI/Resources/WebEmbed/Instagram.html diff --git a/submodules/TelegramUI/Sources/Resources/WebEmbed/Twitch.html b/submodules/TelegramUI/TelegramUI/Resources/WebEmbed/Twitch.html similarity index 100% rename from submodules/TelegramUI/Sources/Resources/WebEmbed/Twitch.html rename to submodules/TelegramUI/TelegramUI/Resources/WebEmbed/Twitch.html diff --git a/submodules/TelegramUI/Sources/Resources/WebEmbed/TwitchUserScript.js b/submodules/TelegramUI/TelegramUI/Resources/WebEmbed/TwitchUserScript.js similarity index 100% rename from submodules/TelegramUI/Sources/Resources/WebEmbed/TwitchUserScript.js rename to submodules/TelegramUI/TelegramUI/Resources/WebEmbed/TwitchUserScript.js diff --git a/submodules/TelegramUI/Sources/Resources/WebEmbed/Vimeo.html b/submodules/TelegramUI/TelegramUI/Resources/WebEmbed/Vimeo.html similarity index 100% rename from submodules/TelegramUI/Sources/Resources/WebEmbed/Vimeo.html rename to submodules/TelegramUI/TelegramUI/Resources/WebEmbed/Vimeo.html diff --git a/submodules/TelegramUI/Sources/Resources/WebEmbed/VimeoUserScript.js b/submodules/TelegramUI/TelegramUI/Resources/WebEmbed/VimeoUserScript.js similarity index 100% rename from submodules/TelegramUI/Sources/Resources/WebEmbed/VimeoUserScript.js rename to submodules/TelegramUI/TelegramUI/Resources/WebEmbed/VimeoUserScript.js diff --git a/submodules/TelegramUI/Sources/Resources/WebEmbed/Youtube.html b/submodules/TelegramUI/TelegramUI/Resources/WebEmbed/Youtube.html similarity index 100% rename from submodules/TelegramUI/Sources/Resources/WebEmbed/Youtube.html rename to submodules/TelegramUI/TelegramUI/Resources/WebEmbed/Youtube.html diff --git a/submodules/TelegramUI/Sources/Resources/WebEmbed/YoutubeUserScript.js b/submodules/TelegramUI/TelegramUI/Resources/WebEmbed/YoutubeUserScript.js similarity index 100% rename from submodules/TelegramUI/Sources/Resources/WebEmbed/YoutubeUserScript.js rename to submodules/TelegramUI/TelegramUI/Resources/WebEmbed/YoutubeUserScript.js diff --git a/submodules/TelegramUI/Sources/Resources/currencies.json b/submodules/TelegramUI/TelegramUI/Resources/currencies.json similarity index 100% rename from submodules/TelegramUI/Sources/Resources/currencies.json rename to submodules/TelegramUI/TelegramUI/Resources/currencies.json diff --git a/submodules/TelegramUI/Sources/SampleBufferPool.swift b/submodules/TelegramUI/TelegramUI/SampleBufferPool.swift similarity index 100% rename from submodules/TelegramUI/Sources/SampleBufferPool.swift rename to submodules/TelegramUI/TelegramUI/SampleBufferPool.swift diff --git a/submodules/TelegramUI/Sources/SecretChatHandshakeStatusInputPanelNode.swift b/submodules/TelegramUI/TelegramUI/SecretChatHandshakeStatusInputPanelNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/SecretChatHandshakeStatusInputPanelNode.swift rename to submodules/TelegramUI/TelegramUI/SecretChatHandshakeStatusInputPanelNode.swift diff --git a/submodules/TelegramUI/Sources/ServiceSoundManager.swift b/submodules/TelegramUI/TelegramUI/ServiceSoundManager.swift similarity index 100% rename from submodules/TelegramUI/Sources/ServiceSoundManager.swift rename to submodules/TelegramUI/TelegramUI/ServiceSoundManager.swift diff --git a/submodules/TelegramUI/Sources/ShareExtensionContext.swift b/submodules/TelegramUI/TelegramUI/ShareExtensionContext.swift similarity index 100% rename from submodules/TelegramUI/Sources/ShareExtensionContext.swift rename to submodules/TelegramUI/TelegramUI/ShareExtensionContext.swift diff --git a/submodules/TelegramUI/Sources/SharedAccountContext.swift b/submodules/TelegramUI/TelegramUI/SharedAccountContext.swift similarity index 100% rename from submodules/TelegramUI/Sources/SharedAccountContext.swift rename to submodules/TelegramUI/TelegramUI/SharedAccountContext.swift diff --git a/submodules/TelegramUI/Sources/SharedMediaPlayer.swift b/submodules/TelegramUI/TelegramUI/SharedMediaPlayer.swift similarity index 100% rename from submodules/TelegramUI/Sources/SharedMediaPlayer.swift rename to submodules/TelegramUI/TelegramUI/SharedMediaPlayer.swift diff --git a/submodules/TelegramUI/Sources/SharedNotificationManager.swift b/submodules/TelegramUI/TelegramUI/SharedNotificationManager.swift similarity index 100% rename from submodules/TelegramUI/Sources/SharedNotificationManager.swift rename to submodules/TelegramUI/TelegramUI/SharedNotificationManager.swift diff --git a/submodules/TelegramUI/Sources/SharedVideoContextManager.swift b/submodules/TelegramUI/TelegramUI/SharedVideoContextManager.swift similarity index 100% rename from submodules/TelegramUI/Sources/SharedVideoContextManager.swift rename to submodules/TelegramUI/TelegramUI/SharedVideoContextManager.swift diff --git a/submodules/TelegramUI/Sources/SharedWakeupManager.swift b/submodules/TelegramUI/TelegramUI/SharedWakeupManager.swift similarity index 100% rename from submodules/TelegramUI/Sources/SharedWakeupManager.swift rename to submodules/TelegramUI/TelegramUI/SharedWakeupManager.swift diff --git a/submodules/TelegramUI/Sources/SoftwareVideoLayerFrameManager.swift b/submodules/TelegramUI/TelegramUI/SoftwareVideoLayerFrameManager.swift similarity index 100% rename from submodules/TelegramUI/Sources/SoftwareVideoLayerFrameManager.swift rename to submodules/TelegramUI/TelegramUI/SoftwareVideoLayerFrameManager.swift diff --git a/submodules/TelegramUI/Sources/SoftwareVideoThumbnailLayer.swift b/submodules/TelegramUI/TelegramUI/SoftwareVideoThumbnailLayer.swift similarity index 100% rename from submodules/TelegramUI/Sources/SoftwareVideoThumbnailLayer.swift rename to submodules/TelegramUI/TelegramUI/SoftwareVideoThumbnailLayer.swift diff --git a/submodules/TelegramUI/Sources/Sounds/MessageSent.caf b/submodules/TelegramUI/TelegramUI/Sounds/MessageSent.caf similarity index 100% rename from submodules/TelegramUI/Sources/Sounds/MessageSent.caf rename to submodules/TelegramUI/TelegramUI/Sounds/MessageSent.caf diff --git a/submodules/TelegramUI/Sources/Sounds/notification.caf b/submodules/TelegramUI/TelegramUI/Sounds/notification.caf similarity index 100% rename from submodules/TelegramUI/Sources/Sounds/notification.caf rename to submodules/TelegramUI/TelegramUI/Sounds/notification.caf diff --git a/submodules/TelegramUI/Sources/SpotlightContacts.swift b/submodules/TelegramUI/TelegramUI/SpotlightContacts.swift similarity index 100% rename from submodules/TelegramUI/Sources/SpotlightContacts.swift rename to submodules/TelegramUI/TelegramUI/SpotlightContacts.swift diff --git a/submodules/TelegramUI/Sources/StickerPanePeerSpecificSetupGridItem.swift b/submodules/TelegramUI/TelegramUI/StickerPanePeerSpecificSetupGridItem.swift similarity index 100% rename from submodules/TelegramUI/Sources/StickerPanePeerSpecificSetupGridItem.swift rename to submodules/TelegramUI/TelegramUI/StickerPanePeerSpecificSetupGridItem.swift diff --git a/submodules/TelegramUI/Sources/StickerPaneSearchContentNode.swift b/submodules/TelegramUI/TelegramUI/StickerPaneSearchContentNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/StickerPaneSearchContentNode.swift rename to submodules/TelegramUI/TelegramUI/StickerPaneSearchContentNode.swift diff --git a/submodules/TelegramUI/Sources/StickerPaneSearchGlobaltem.swift b/submodules/TelegramUI/TelegramUI/StickerPaneSearchGlobaltem.swift similarity index 100% rename from submodules/TelegramUI/Sources/StickerPaneSearchGlobaltem.swift rename to submodules/TelegramUI/TelegramUI/StickerPaneSearchGlobaltem.swift diff --git a/submodules/TelegramUI/Sources/StickerPaneSearchStickerItem.swift b/submodules/TelegramUI/TelegramUI/StickerPaneSearchStickerItem.swift similarity index 100% rename from submodules/TelegramUI/Sources/StickerPaneSearchStickerItem.swift rename to submodules/TelegramUI/TelegramUI/StickerPaneSearchStickerItem.swift diff --git a/submodules/TelegramUI/Sources/StickersChatInputContextPanelItem.swift b/submodules/TelegramUI/TelegramUI/StickersChatInputContextPanelItem.swift similarity index 100% rename from submodules/TelegramUI/Sources/StickersChatInputContextPanelItem.swift rename to submodules/TelegramUI/TelegramUI/StickersChatInputContextPanelItem.swift diff --git a/submodules/TelegramUI/Sources/StickersChatInputContextPanelNode.swift b/submodules/TelegramUI/TelegramUI/StickersChatInputContextPanelNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/StickersChatInputContextPanelNode.swift rename to submodules/TelegramUI/TelegramUI/StickersChatInputContextPanelNode.swift diff --git a/submodules/TelegramUI/Sources/StoreDownloadedMedia.swift b/submodules/TelegramUI/TelegramUI/StoreDownloadedMedia.swift similarity index 100% rename from submodules/TelegramUI/Sources/StoreDownloadedMedia.swift rename to submodules/TelegramUI/TelegramUI/StoreDownloadedMedia.swift diff --git a/submodules/TelegramUI/Sources/StringForMessageTimestampStatus.swift b/submodules/TelegramUI/TelegramUI/StringForMessageTimestampStatus.swift similarity index 100% rename from submodules/TelegramUI/Sources/StringForMessageTimestampStatus.swift rename to submodules/TelegramUI/TelegramUI/StringForMessageTimestampStatus.swift diff --git a/submodules/TelegramUI/Sources/SuppressContactsWarning.swift b/submodules/TelegramUI/TelegramUI/SuppressContactsWarning.swift similarity index 100% rename from submodules/TelegramUI/Sources/SuppressContactsWarning.swift rename to submodules/TelegramUI/TelegramUI/SuppressContactsWarning.swift diff --git a/submodules/TelegramUI/Sources/TelegramAccountAuxiliaryMethods.swift b/submodules/TelegramUI/TelegramUI/TelegramAccountAuxiliaryMethods.swift similarity index 100% rename from submodules/TelegramUI/Sources/TelegramAccountAuxiliaryMethods.swift rename to submodules/TelegramUI/TelegramUI/TelegramAccountAuxiliaryMethods.swift diff --git a/submodules/TelegramUI/Sources/TelegramRootController.swift b/submodules/TelegramUI/TelegramUI/TelegramRootController.swift similarity index 100% rename from submodules/TelegramUI/Sources/TelegramRootController.swift rename to submodules/TelegramUI/TelegramUI/TelegramRootController.swift diff --git a/submodules/TelegramUI/Sources/TelegramUI.h b/submodules/TelegramUI/TelegramUI/TelegramUI.h similarity index 100% rename from submodules/TelegramUI/Sources/TelegramUI.h rename to submodules/TelegramUI/TelegramUI/TelegramUI.h diff --git a/submodules/TelegramUI/Sources/TextLinkHandling.swift b/submodules/TelegramUI/TelegramUI/TextLinkHandling.swift similarity index 100% rename from submodules/TelegramUI/Sources/TextLinkHandling.swift rename to submodules/TelegramUI/TelegramUI/TextLinkHandling.swift diff --git a/submodules/TelegramUI/Sources/ThemeUpdateManager.swift b/submodules/TelegramUI/TelegramUI/ThemeUpdateManager.swift similarity index 100% rename from submodules/TelegramUI/Sources/ThemeUpdateManager.swift rename to submodules/TelegramUI/TelegramUI/ThemeUpdateManager.swift diff --git a/submodules/TelegramUI/Sources/TimeBasedVideoPreload.swift b/submodules/TelegramUI/TelegramUI/TimeBasedVideoPreload.swift similarity index 100% rename from submodules/TelegramUI/Sources/TimeBasedVideoPreload.swift rename to submodules/TelegramUI/TelegramUI/TimeBasedVideoPreload.swift diff --git a/submodules/TelegramUI/Sources/TonePlayer.swift b/submodules/TelegramUI/TelegramUI/TonePlayer.swift similarity index 100% rename from submodules/TelegramUI/Sources/TonePlayer.swift rename to submodules/TelegramUI/TelegramUI/TonePlayer.swift diff --git a/submodules/TelegramUI/Sources/TransformOutgoingMessageMedia.swift b/submodules/TelegramUI/TelegramUI/TransformOutgoingMessageMedia.swift similarity index 100% rename from submodules/TelegramUI/Sources/TransformOutgoingMessageMedia.swift rename to submodules/TelegramUI/TelegramUI/TransformOutgoingMessageMedia.swift diff --git a/submodules/TelegramUI/Sources/UpgradedAccounts.swift b/submodules/TelegramUI/TelegramUI/UpgradedAccounts.swift similarity index 100% rename from submodules/TelegramUI/Sources/UpgradedAccounts.swift rename to submodules/TelegramUI/TelegramUI/UpgradedAccounts.swift diff --git a/submodules/TelegramUI/Sources/VerticalListContextResultsChatInputContextPanelNode.swift b/submodules/TelegramUI/TelegramUI/VerticalListContextResultsChatInputContextPanelNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/VerticalListContextResultsChatInputContextPanelNode.swift rename to submodules/TelegramUI/TelegramUI/VerticalListContextResultsChatInputContextPanelNode.swift diff --git a/submodules/TelegramUI/Sources/VerticalListContextResultsChatInputPanelButtonItem.swift b/submodules/TelegramUI/TelegramUI/VerticalListContextResultsChatInputPanelButtonItem.swift similarity index 100% rename from submodules/TelegramUI/Sources/VerticalListContextResultsChatInputPanelButtonItem.swift rename to submodules/TelegramUI/TelegramUI/VerticalListContextResultsChatInputPanelButtonItem.swift diff --git a/submodules/TelegramUI/Sources/VerticalListContextResultsChatInputPanelItem.swift b/submodules/TelegramUI/TelegramUI/VerticalListContextResultsChatInputPanelItem.swift similarity index 100% rename from submodules/TelegramUI/Sources/VerticalListContextResultsChatInputPanelItem.swift rename to submodules/TelegramUI/TelegramUI/VerticalListContextResultsChatInputPanelItem.swift diff --git a/submodules/TelegramUI/Sources/VolumeButtons.swift b/submodules/TelegramUI/TelegramUI/VolumeButtons.swift similarity index 100% rename from submodules/TelegramUI/Sources/VolumeButtons.swift rename to submodules/TelegramUI/TelegramUI/VolumeButtons.swift diff --git a/submodules/TelegramUI/Sources/WalletContextImpl.swift b/submodules/TelegramUI/TelegramUI/WalletContextImpl.swift similarity index 100% rename from submodules/TelegramUI/Sources/WalletContextImpl.swift rename to submodules/TelegramUI/TelegramUI/WalletContextImpl.swift diff --git a/submodules/TelegramUI/Sources/WallpaperPreviewMedia.swift b/submodules/TelegramUI/TelegramUI/WallpaperPreviewMedia.swift similarity index 100% rename from submodules/TelegramUI/Sources/WallpaperPreviewMedia.swift rename to submodules/TelegramUI/TelegramUI/WallpaperPreviewMedia.swift diff --git a/submodules/TelegramUI/Sources/WallpaperUploadManager.swift b/submodules/TelegramUI/TelegramUI/WallpaperUploadManager.swift similarity index 100% rename from submodules/TelegramUI/Sources/WallpaperUploadManager.swift rename to submodules/TelegramUI/TelegramUI/WallpaperUploadManager.swift diff --git a/submodules/TelegramUI/Sources/WatchManager.swift b/submodules/TelegramUI/TelegramUI/WatchManager.swift similarity index 100% rename from submodules/TelegramUI/Sources/WatchManager.swift rename to submodules/TelegramUI/TelegramUI/WatchManager.swift diff --git a/submodules/TelegramUI/Sources/Weak.swift b/submodules/TelegramUI/TelegramUI/Weak.swift similarity index 100% rename from submodules/TelegramUI/Sources/Weak.swift rename to submodules/TelegramUI/TelegramUI/Weak.swift diff --git a/submodules/TelegramUI/Sources/WebpagePreviewAccessoryPanelNode.swift b/submodules/TelegramUI/TelegramUI/WebpagePreviewAccessoryPanelNode.swift similarity index 100% rename from submodules/TelegramUI/Sources/WebpagePreviewAccessoryPanelNode.swift rename to submodules/TelegramUI/TelegramUI/WebpagePreviewAccessoryPanelNode.swift diff --git a/submodules/TelegramUI/Sources/WidgetDataContext.swift b/submodules/TelegramUI/TelegramUI/WidgetDataContext.swift similarity index 100% rename from submodules/TelegramUI/Sources/WidgetDataContext.swift rename to submodules/TelegramUI/TelegramUI/WidgetDataContext.swift diff --git a/submodules/TelegramUI/Sources/module.private.modulemap b/submodules/TelegramUI/TelegramUI/module.private.modulemap similarity index 100% rename from submodules/TelegramUI/Sources/module.private.modulemap rename to submodules/TelegramUI/TelegramUI/module.private.modulemap