mirror of
https://github.com/Swiftgram/Telegram-iOS.git
synced 2025-06-16 05:55:20 +00:00
104 lines
3.7 KiB
Swift
104 lines
3.7 KiB
Swift
import Foundation
|
|
import Postbox
|
|
import SwiftSignalKit
|
|
|
|
|
|
private struct PeerParticipants: Equatable {
|
|
let peers: [Peer]
|
|
|
|
static func ==(lhs: PeerParticipants, rhs: PeerParticipants) -> Bool {
|
|
if lhs.peers.count != rhs.peers.count {
|
|
return false
|
|
}
|
|
for i in 0 ..< lhs.peers.count {
|
|
if !lhs.peers[i].isEqual(rhs.peers[i]) {
|
|
return false
|
|
}
|
|
}
|
|
return true
|
|
}
|
|
}
|
|
|
|
private func peerParticipants(postbox: Postbox, id: PeerId) -> Signal<[Peer], NoError> {
|
|
return postbox.peerView(id: id) |> map { view -> PeerParticipants in
|
|
if let cachedGroupData = view.cachedData as? CachedGroupData, let participants = cachedGroupData.participants {
|
|
var peers: [Peer] = []
|
|
for participant in participants.participants {
|
|
if let peer = view.peers[participant.peerId] {
|
|
peers.append(peer)
|
|
}
|
|
}
|
|
return PeerParticipants(peers: peers)
|
|
} else {
|
|
return PeerParticipants(peers: [])
|
|
}
|
|
}
|
|
|> distinctUntilChanged |> map { participants in
|
|
return participants.peers
|
|
}
|
|
}
|
|
|
|
private func searchLocalGroupMembers(postbox: Postbox, peerId: PeerId, query: String) -> Signal<[Peer], NoError> {
|
|
return peerParticipants(postbox: postbox, id: peerId)
|
|
|> map { peers -> [Peer] in
|
|
let normalizedQuery = query.lowercased()
|
|
|
|
if normalizedQuery.isEmpty {
|
|
return peers
|
|
}
|
|
|
|
return peers.filter { peer in
|
|
if peer.debugDisplayTitle.isEmpty {
|
|
return false
|
|
}
|
|
if peer.indexName.matchesByTokens(normalizedQuery) {
|
|
return true
|
|
}
|
|
if let addressName = peer.addressName, addressName.lowercased().hasPrefix(normalizedQuery) {
|
|
return true
|
|
}
|
|
return false
|
|
}
|
|
}
|
|
}
|
|
|
|
func _internal_searchGroupMembers(postbox: Postbox, network: Network, accountPeerId: PeerId, peerId: PeerId, query: String) -> Signal<[Peer], NoError> {
|
|
if peerId.namespace == Namespaces.Peer.CloudChannel && !query.isEmpty {
|
|
return searchLocalGroupMembers(postbox: postbox, peerId: peerId, query: query)
|
|
|> mapToSignal { local -> Signal<[Peer], NoError> in
|
|
let localResult: Signal<[Peer], NoError>
|
|
if local.isEmpty {
|
|
localResult = .complete()
|
|
} else {
|
|
localResult = .single(local)
|
|
}
|
|
return localResult
|
|
|> then(
|
|
_internal_channelMembers(postbox: postbox, network: network, accountPeerId: accountPeerId, peerId: peerId, category: .recent(.search(query)))
|
|
|> map { participants -> [Peer] in
|
|
var result: [Peer] = local
|
|
let existingIds = Set(local.map { $0.id })
|
|
let filtered: [Peer]
|
|
if let participants = participants {
|
|
filtered = participants.map({ $0.peer }).filter({ peer in
|
|
if existingIds.contains(peer.id) {
|
|
return false
|
|
}
|
|
if peer.debugDisplayTitle.isEmpty {
|
|
return false
|
|
}
|
|
return true
|
|
})
|
|
} else {
|
|
filtered = []
|
|
}
|
|
result.append(contentsOf: filtered)
|
|
return result
|
|
}
|
|
)
|
|
}
|
|
} else {
|
|
return searchLocalGroupMembers(postbox: postbox, peerId: peerId, query: query)
|
|
}
|
|
}
|