mirror of
https://github.com/Swiftgram/Telegram-iOS.git
synced 2025-06-16 05:55:20 +00:00
306 lines
13 KiB
Swift
306 lines
13 KiB
Swift
import Postbox
|
|
import UIKit
|
|
import TelegramCore
|
|
import SyncCore
|
|
import SwiftSignalKit
|
|
import Display
|
|
import TelegramPresentationData
|
|
import MergeLists
|
|
import AccountContext
|
|
|
|
enum ChatMediaInputPanelAuxiliaryNamespace: Int32 {
|
|
case savedStickers = 2
|
|
case recentGifs = 3
|
|
case recentStickers = 4
|
|
case peerSpecific = 5
|
|
case trending = 6
|
|
case settings = 7
|
|
}
|
|
|
|
enum ChatMediaInputPanelEntryStableId: Hashable {
|
|
case recentGifs
|
|
case savedStickers
|
|
case recentPacks
|
|
case stickerPack(Int64)
|
|
case peerSpecific
|
|
case trending
|
|
case settings
|
|
case stickersMode
|
|
case savedGifs
|
|
case trendingGifs
|
|
case gifEmotion(String)
|
|
}
|
|
|
|
enum ChatMediaInputPanelEntry: Comparable, Identifiable {
|
|
case recentGifs(PresentationTheme)
|
|
case savedStickers(PresentationTheme)
|
|
case recentPacks(PresentationTheme)
|
|
case trending(Bool, PresentationTheme)
|
|
case settings(PresentationTheme)
|
|
case peerSpecific(theme: PresentationTheme, peer: Peer)
|
|
case stickerPack(index: Int, info: StickerPackCollectionInfo, topItem: StickerPackItem?, theme: PresentationTheme)
|
|
|
|
case stickersMode(PresentationTheme)
|
|
case savedGifs(PresentationTheme)
|
|
case trendingGifs(PresentationTheme)
|
|
case gifEmotion(Int, PresentationTheme, String)
|
|
|
|
var stableId: ChatMediaInputPanelEntryStableId {
|
|
switch self {
|
|
case .recentGifs:
|
|
return .recentGifs
|
|
case .savedStickers:
|
|
return .savedStickers
|
|
case .recentPacks:
|
|
return .recentPacks
|
|
case .trending:
|
|
return .trending
|
|
case .settings:
|
|
return .settings
|
|
case .peerSpecific:
|
|
return .peerSpecific
|
|
case let .stickerPack(_, info, _, _):
|
|
return .stickerPack(info.id.id)
|
|
case .stickersMode:
|
|
return .stickersMode
|
|
case .savedGifs:
|
|
return .savedGifs
|
|
case .trendingGifs:
|
|
return .trendingGifs
|
|
case let .gifEmotion(_, _, emoji):
|
|
return .gifEmotion(emoji)
|
|
}
|
|
}
|
|
|
|
static func ==(lhs: ChatMediaInputPanelEntry, rhs: ChatMediaInputPanelEntry) -> Bool {
|
|
switch lhs {
|
|
case let .recentGifs(lhsTheme):
|
|
if case let .recentGifs(rhsTheme) = rhs, lhsTheme === rhsTheme {
|
|
return true
|
|
} else {
|
|
return false
|
|
}
|
|
case let .savedStickers(lhsTheme):
|
|
if case let .savedStickers(rhsTheme) = rhs, lhsTheme === rhsTheme {
|
|
return true
|
|
} else {
|
|
return false
|
|
}
|
|
case let .recentPacks(lhsTheme):
|
|
if case let .recentPacks(rhsTheme) = rhs, lhsTheme === rhsTheme {
|
|
return true
|
|
} else {
|
|
return false
|
|
}
|
|
case let .trending(lhsElevated, lhsTheme):
|
|
if case let .trending(rhsElevated, rhsTheme) = rhs, lhsTheme === rhsTheme, lhsElevated == rhsElevated {
|
|
return true
|
|
} else {
|
|
return false
|
|
}
|
|
case let .settings(lhsTheme):
|
|
if case let .settings(rhsTheme) = rhs, lhsTheme === rhsTheme {
|
|
return true
|
|
} else {
|
|
return false
|
|
}
|
|
case let .peerSpecific(lhsTheme, lhsPeer):
|
|
if case let .peerSpecific(rhsTheme, rhsPeer) = rhs, lhsTheme === rhsTheme, lhsPeer.isEqual(rhsPeer) {
|
|
return true
|
|
} else {
|
|
return false
|
|
}
|
|
case let .stickerPack(index, info, topItem, lhsTheme):
|
|
if case let .stickerPack(rhsIndex, rhsInfo, rhsTopItem, rhsTheme) = rhs, index == rhsIndex, info == rhsInfo, topItem == rhsTopItem, lhsTheme === rhsTheme {
|
|
return true
|
|
} else {
|
|
return false
|
|
}
|
|
case let .stickersMode(lhsTheme):
|
|
if case let .stickersMode(rhsTheme) = rhs, lhsTheme === rhsTheme {
|
|
return true
|
|
} else {
|
|
return false
|
|
}
|
|
case let .savedGifs(lhsTheme):
|
|
if case let .savedGifs(rhsTheme) = rhs, lhsTheme === rhsTheme {
|
|
return true
|
|
} else {
|
|
return false
|
|
}
|
|
case let .trendingGifs(lhsTheme):
|
|
if case let .trendingGifs(rhsTheme) = rhs, lhsTheme === rhsTheme {
|
|
return true
|
|
} else {
|
|
return false
|
|
}
|
|
case let .gifEmotion(lhsIndex, lhsTheme, lhsEmoji):
|
|
if case let .gifEmotion(rhsIndex, rhsTheme, rhsEmoji) = rhs, lhsIndex == rhsIndex, lhsTheme === rhsTheme, lhsEmoji == rhsEmoji {
|
|
return true
|
|
} else {
|
|
return false
|
|
}
|
|
}
|
|
}
|
|
|
|
static func <(lhs: ChatMediaInputPanelEntry, rhs: ChatMediaInputPanelEntry) -> Bool {
|
|
switch lhs {
|
|
case .recentGifs:
|
|
switch rhs {
|
|
case .recentGifs:
|
|
return false
|
|
default:
|
|
return true
|
|
}
|
|
case .savedStickers:
|
|
switch rhs {
|
|
case .recentGifs, savedStickers:
|
|
return false
|
|
case let .trending(elevated, _) where elevated:
|
|
return false
|
|
default:
|
|
return true
|
|
}
|
|
case .recentPacks:
|
|
switch rhs {
|
|
case .recentGifs, .savedStickers, recentPacks:
|
|
return false
|
|
case let .trending(elevated, _) where elevated:
|
|
return false
|
|
default:
|
|
return true
|
|
}
|
|
case .peerSpecific:
|
|
switch rhs {
|
|
case .recentGifs, .savedStickers, recentPacks, .peerSpecific:
|
|
return false
|
|
case let .trending(elevated, _) where elevated:
|
|
return false
|
|
default:
|
|
return true
|
|
}
|
|
case let .stickerPack(lhsIndex, lhsInfo, _, _):
|
|
switch rhs {
|
|
case .recentGifs, .savedStickers, .recentPacks, .peerSpecific:
|
|
return false
|
|
case let .trending(elevated, _):
|
|
if elevated {
|
|
return false
|
|
} else {
|
|
return true
|
|
}
|
|
case .settings:
|
|
return true
|
|
case let .stickerPack(rhsIndex, rhsInfo, _, _):
|
|
if lhsIndex == rhsIndex {
|
|
return lhsInfo.id.id < rhsInfo.id.id
|
|
} else {
|
|
return lhsIndex <= rhsIndex
|
|
}
|
|
default:
|
|
return true
|
|
}
|
|
case let .trending(elevated, _):
|
|
if elevated {
|
|
switch rhs {
|
|
case .recentGifs, .trending:
|
|
return false
|
|
default:
|
|
return true
|
|
}
|
|
} else {
|
|
if case .settings = rhs {
|
|
return true
|
|
} else {
|
|
return false
|
|
}
|
|
}
|
|
case .stickersMode:
|
|
return false
|
|
case .savedGifs:
|
|
switch rhs {
|
|
case .savedGifs:
|
|
return false
|
|
default:
|
|
return true
|
|
}
|
|
case .trendingGifs:
|
|
switch rhs {
|
|
case .stickersMode, .savedGifs, .trendingGifs:
|
|
return false
|
|
default:
|
|
return true
|
|
}
|
|
case let .gifEmotion(lhsIndex, _, _):
|
|
switch rhs {
|
|
case .stickersMode, .savedGifs, .trendingGifs:
|
|
return false
|
|
case let .gifEmotion(rhsIndex, _, _):
|
|
return lhsIndex < rhsIndex
|
|
default:
|
|
return true
|
|
}
|
|
case .settings:
|
|
if case .settings = rhs {
|
|
return false
|
|
} else {
|
|
return true
|
|
}
|
|
}
|
|
}
|
|
|
|
func item(context: AccountContext, inputNodeInteraction: ChatMediaInputNodeInteraction) -> ListViewItem {
|
|
switch self {
|
|
case let .recentGifs(theme):
|
|
return ChatMediaInputRecentGifsItem(inputNodeInteraction: inputNodeInteraction, theme: theme, selected: {
|
|
let collectionId = ItemCollectionId(namespace: ChatMediaInputPanelAuxiliaryNamespace.recentGifs.rawValue, id: 0)
|
|
inputNodeInteraction.navigateToCollectionId(collectionId)
|
|
})
|
|
case let .savedStickers(theme):
|
|
return ChatMediaInputMetaSectionItem(inputNodeInteraction: inputNodeInteraction, type: .savedStickers, theme: theme, selected: {
|
|
let collectionId = ItemCollectionId(namespace: ChatMediaInputPanelAuxiliaryNamespace.savedStickers.rawValue, id: 0)
|
|
inputNodeInteraction.navigateToCollectionId(collectionId)
|
|
})
|
|
case let .recentPacks(theme):
|
|
return ChatMediaInputMetaSectionItem(inputNodeInteraction: inputNodeInteraction, type: .recentStickers, theme: theme, selected: {
|
|
let collectionId = ItemCollectionId(namespace: ChatMediaInputPanelAuxiliaryNamespace.recentStickers.rawValue, id: 0)
|
|
inputNodeInteraction.navigateToCollectionId(collectionId)
|
|
})
|
|
case let .trending(elevated, theme):
|
|
return ChatMediaInputTrendingItem(inputNodeInteraction: inputNodeInteraction, elevated: elevated, theme: theme, selected: {
|
|
let collectionId = ItemCollectionId(namespace: ChatMediaInputPanelAuxiliaryNamespace.trending.rawValue, id: 0)
|
|
inputNodeInteraction.navigateToCollectionId(collectionId)
|
|
})
|
|
case let .settings(theme):
|
|
return ChatMediaInputSettingsItem(inputNodeInteraction: inputNodeInteraction, theme: theme, selected: {
|
|
inputNodeInteraction.openSettings()
|
|
})
|
|
case let .peerSpecific(theme, peer):
|
|
let collectionId = ItemCollectionId(namespace: ChatMediaInputPanelAuxiliaryNamespace.peerSpecific.rawValue, id: 0)
|
|
return ChatMediaInputPeerSpecificItem(context: context, inputNodeInteraction: inputNodeInteraction, collectionId: collectionId, peer: peer, theme: theme, selected: {
|
|
inputNodeInteraction.navigateToCollectionId(collectionId)
|
|
})
|
|
case let .stickerPack(index, info, topItem, theme):
|
|
return ChatMediaInputStickerPackItem(account: context.account, inputNodeInteraction: inputNodeInteraction, collectionId: info.id, collectionInfo: info, stickerPackItem: topItem, index: index, theme: theme, selected: {
|
|
inputNodeInteraction.navigateToCollectionId(info.id)
|
|
})
|
|
case let .stickersMode(theme):
|
|
return ChatMediaInputMetaSectionItem(inputNodeInteraction: inputNodeInteraction, type: .stickersMode, theme: theme, selected: {
|
|
inputNodeInteraction.navigateBackToStickers()
|
|
})
|
|
case let .savedGifs(theme):
|
|
return ChatMediaInputMetaSectionItem(inputNodeInteraction: inputNodeInteraction, type: .savedGifs, theme: theme, selected: {
|
|
inputNodeInteraction.setGifMode(.recent)
|
|
})
|
|
case let .trendingGifs(theme):
|
|
return ChatMediaInputMetaSectionItem(inputNodeInteraction: inputNodeInteraction, type: .trendingGifs, theme: theme, selected: {
|
|
inputNodeInteraction.setGifMode(.trending)
|
|
})
|
|
case let .gifEmotion(_, theme, emoji):
|
|
return ChatMediaInputMetaSectionItem(inputNodeInteraction: inputNodeInteraction, type: .gifEmoji(emoji), theme: theme, selected: {
|
|
inputNodeInteraction.setGifMode(.emojiSearch(emoji))
|
|
})
|
|
}
|
|
}
|
|
}
|