* Introduce a `MediaEventsTimelineFlowCoordinator` * Update SDK API and architecture * Add a feature flag, add translations * Move the media events timeline presentation under the room flow coordinator state machine * Rename `TimelineViewState.timelineViewState` of type `TimelineState` to `timelineState` * Enabled SwiftLint's `trailing_closure` rule and fix the warnings.
89 lines
3.0 KiB
Swift
89 lines
3.0 KiB
Swift
//
|
|
// Copyright 2022-2024 New Vector Ltd.
|
|
//
|
|
// SPDX-License-Identifier: AGPL-3.0-only
|
|
// Please see LICENSE in the repository root for full details.
|
|
//
|
|
|
|
import Combine
|
|
import MatrixRustSDK
|
|
import SwiftUI
|
|
|
|
enum RoomTimelineControllerCallback {
|
|
case updatedTimelineItems(timelineItems: [RoomTimelineItemProtocol], isSwitchingTimelines: Bool)
|
|
case paginationState(PaginationState)
|
|
case isLive(Bool)
|
|
}
|
|
|
|
enum RoomTimelineControllerAction {
|
|
case displayMediaFile(file: MediaFileHandleProxy, title: String?)
|
|
case displayLocation(body: String, geoURI: GeoURI, description: String?)
|
|
case none
|
|
}
|
|
|
|
enum RoomTimelineControllerError: Error {
|
|
case generic
|
|
case eventNotFound
|
|
}
|
|
|
|
@MainActor
|
|
protocol RoomTimelineControllerProtocol {
|
|
var roomID: String { get }
|
|
var timelineKind: TimelineKind { get }
|
|
|
|
/// The currently known items, use only for setting up the intial state.
|
|
var timelineItems: [RoomTimelineItemProtocol] { get }
|
|
|
|
/// The current pagination state, use only for setting up the intial state
|
|
var paginationState: PaginationState { get }
|
|
|
|
var callbacks: PassthroughSubject<RoomTimelineControllerCallback, Never> { get }
|
|
|
|
func processItemAppearance(_ itemID: TimelineItemIdentifier) async
|
|
|
|
func processItemDisappearance(_ itemID: TimelineItemIdentifier) async
|
|
|
|
func focusOnEvent(_ eventID: String, timelineSize: UInt16) async -> Result<Void, RoomTimelineControllerError>
|
|
func focusLive()
|
|
|
|
func paginateBackwards(requestSize: UInt16) async -> Result<Void, RoomTimelineControllerError>
|
|
func paginateForwards(requestSize: UInt16) async -> Result<Void, RoomTimelineControllerError>
|
|
|
|
func sendReadReceipt(for itemID: TimelineItemIdentifier) async
|
|
|
|
func sendMessage(_ message: String,
|
|
html: String?,
|
|
inReplyToEventID: String?,
|
|
intentionalMentions: IntentionalMentions) async
|
|
|
|
func edit(_ eventOrTransactionID: EventOrTransactionId,
|
|
message: String,
|
|
html: String?,
|
|
intentionalMentions: IntentionalMentions) async
|
|
|
|
func editCaption(_ eventOrTransactionID: EventOrTransactionId,
|
|
message: String,
|
|
html: String?,
|
|
intentionalMentions: IntentionalMentions) async
|
|
|
|
func removeCaption(_ eventOrTransactionID: EventOrTransactionId) async
|
|
|
|
func toggleReaction(_ reaction: String, to eventOrTransactionID: EventOrTransactionId) async
|
|
|
|
func redact(_ eventOrTransactionID: EventOrTransactionId) async
|
|
|
|
func pin(eventID: String) async
|
|
|
|
func unpin(eventID: String) async
|
|
|
|
func messageEventContent(for itemID: TimelineItemIdentifier) async -> RoomMessageEventContentWithoutRelation?
|
|
|
|
func debugInfo(for itemID: TimelineItemIdentifier) -> TimelineItemDebugInfo
|
|
|
|
func sendHandle(for itemID: TimelineItemIdentifier) -> SendHandleProxy?
|
|
|
|
func retryDecryption(for sessionID: String) async
|
|
|
|
func eventTimestamp(for itemID: TimelineItemIdentifier) -> Date?
|
|
}
|