mirror of
https://github.com/Swiftgram/Telegram-iOS.git
synced 2025-06-16 05:55:20 +00:00
119 lines
5.2 KiB
Swift
119 lines
5.2 KiB
Swift
import Foundation
|
|
import Postbox
|
|
import TelegramApi
|
|
import SwiftSignalKit
|
|
|
|
extension StickerPackReference {
|
|
init(_ stickerPackInfo: StickerPackCollectionInfo) {
|
|
self = .id(id: stickerPackInfo.id.id, accessHash: stickerPackInfo.accessHash)
|
|
}
|
|
|
|
var apiInputStickerSet: Api.InputStickerSet {
|
|
switch self {
|
|
case let .id(id, accessHash):
|
|
return .inputStickerSetID(id: id, accessHash: accessHash)
|
|
case let .name(name):
|
|
return .inputStickerSetShortName(shortName: name)
|
|
case .animatedEmoji:
|
|
return .inputStickerSetAnimatedEmoji
|
|
case let .dice(emoji):
|
|
return .inputStickerSetDice(emoticon: emoji)
|
|
case .animatedEmojiAnimations:
|
|
return .inputStickerSetAnimatedEmojiAnimations
|
|
case .premiumGifts:
|
|
return .inputStickerSetPremiumGifts
|
|
case .emojiGenericAnimations:
|
|
return .inputStickerSetEmojiGenericAnimations
|
|
}
|
|
}
|
|
}
|
|
|
|
public enum LoadedStickerPack {
|
|
case fetching
|
|
case none
|
|
case result(info: StickerPackCollectionInfo, items: [StickerPackItem], installed: Bool)
|
|
}
|
|
|
|
func updatedRemoteStickerPack(postbox: Postbox, network: Network, reference: StickerPackReference) -> Signal<(StickerPackCollectionInfo, [StickerPackItem])?, NoError> {
|
|
return network.request(Api.functions.messages.getStickerSet(stickerset: reference.apiInputStickerSet, hash: 0))
|
|
|> map(Optional.init)
|
|
|> `catch` { _ -> Signal<Api.messages.StickerSet?, NoError> in
|
|
return .single(nil)
|
|
}
|
|
|> mapToSignal { result -> Signal<(StickerPackCollectionInfo, [StickerPackItem])?, NoError> in
|
|
guard let result = result else {
|
|
return .single(nil)
|
|
}
|
|
|
|
let info: StickerPackCollectionInfo
|
|
var items: [StickerPackItem] = []
|
|
switch result {
|
|
case .stickerSetNotModified:
|
|
return .complete()
|
|
case let .stickerSet(set, packs, documents):
|
|
let namespace: ItemCollectionId.Namespace
|
|
switch set {
|
|
case let .stickerSet(flags, _, _, _, _, _, _, _, _, _, _, _):
|
|
if (flags & (1 << 3)) != 0 {
|
|
namespace = Namespaces.ItemCollection.CloudMaskPacks
|
|
} else if (flags & (1 << 7)) != 0 {
|
|
namespace = Namespaces.ItemCollection.CloudEmojiPacks
|
|
} else {
|
|
namespace = Namespaces.ItemCollection.CloudStickerPacks
|
|
}
|
|
}
|
|
info = StickerPackCollectionInfo(apiSet: set, namespace: namespace)
|
|
var indexKeysByFile: [MediaId: [MemoryBuffer]] = [:]
|
|
for pack in packs {
|
|
switch pack {
|
|
case let .stickerPack(text, fileIds):
|
|
let key = ValueBoxKey(text).toMemoryBuffer()
|
|
for fileId in fileIds {
|
|
let mediaId = MediaId(namespace: Namespaces.Media.CloudFile, id: fileId)
|
|
if indexKeysByFile[mediaId] == nil {
|
|
indexKeysByFile[mediaId] = [key]
|
|
} else {
|
|
indexKeysByFile[mediaId]!.append(key)
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
for apiDocument in documents {
|
|
if let file = telegramMediaFileFromApiDocument(apiDocument), let id = file.id {
|
|
let fileIndexKeys: [MemoryBuffer]
|
|
if let indexKeys = indexKeysByFile[id] {
|
|
fileIndexKeys = indexKeys
|
|
} else {
|
|
fileIndexKeys = []
|
|
}
|
|
items.append(StickerPackItem(index: ItemCollectionItemIndex(index: Int32(items.count), id: id.id), file: file, indexKeys: fileIndexKeys))
|
|
}
|
|
}
|
|
}
|
|
|
|
return postbox.transaction { transaction -> (StickerPackCollectionInfo, [StickerPackItem])? in
|
|
if transaction.getItemCollectionInfo(collectionId: info.id) != nil {
|
|
transaction.replaceItemCollectionItems(collectionId: info.id, items: items)
|
|
}
|
|
cacheStickerPack(transaction: transaction, info: info, items: items)
|
|
|
|
return (info, items)
|
|
}
|
|
}
|
|
}
|
|
|
|
func _internal_loadedStickerPack(postbox: Postbox, network: Network, reference: StickerPackReference, forceActualized: Bool) -> Signal<LoadedStickerPack, NoError> {
|
|
return _internal_cachedStickerPack(postbox: postbox, network: network, reference: reference, forceRemote: forceActualized)
|
|
|> map { result -> LoadedStickerPack in
|
|
switch result {
|
|
case .none:
|
|
return .none
|
|
case .fetching:
|
|
return .fetching
|
|
case let .result(info, items, installed):
|
|
return .result(info: info, items: items, installed: installed)
|
|
}
|
|
}
|
|
}
|