Swiftgram/submodules/TelegramUI/Sources/ChatMediaInputPanelEntries.swift
2020-02-20 18:08:36 +04:00

284 lines
11 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
static func ==(lhs: ChatMediaInputPanelEntryStableId, rhs: ChatMediaInputPanelEntryStableId) -> Bool {
switch lhs {
case .recentGifs:
if case .recentGifs = rhs {
return true
} else {
return false
}
case .savedStickers:
if case .savedStickers = rhs {
return true
} else {
return false
}
case .recentPacks:
if case .recentPacks = rhs {
return true
} else {
return false
}
case let .stickerPack(lhsId):
if case let .stickerPack(rhsId) = rhs, lhsId == rhsId {
return true
} else {
return false
}
case .peerSpecific:
if case .peerSpecific = rhs {
return true
} else {
return false
}
case .trending:
if case .trending = rhs {
return true
} else {
return false
}
case .settings:
if case .settings = rhs {
return true
} else {
return false
}
}
}
var hashValue: Int {
switch self {
case .recentGifs:
return 0
case .savedStickers:
return 1
case .recentPacks:
return 2
case .trending:
return 3
case .settings:
return 4
case .peerSpecific:
return 5
case let .stickerPack(id):
return id.hashValue
}
}
}
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)
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)
}
}
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
}
}
}
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
}
}
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 .settings:
return false
}
}
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)
})
}
}
}