Squashed commits: [42e45fc] Even more tweaks following code review [5dcd5be] Add swift-algoritms and switch bubbling detection to its `chunked` method [4ac70ed] Move the groupBy implementation to Collection instead of Array [6aeffc3] Tweaks following code review [0ca5ac2] Bubbles working again, grouping computed closer to the UI level [3a66030] Refactor how timeline items are built in the RoomTimelineController [57d51e9] Remove grouping from timeline items [8608950] Remove the RoomTimelineViewFactory, update the GroupRoomTimelineView [9e52e61] Add array grouping extension, unit tests and switched the timeline controller to it [7d213a1] First attempt [90bb1d7] Remove now unused `RoomTimelineController` `updatedTimelineItem` calback
82 lines
2.9 KiB
Swift
82 lines
2.9 KiB
Swift
//
|
|
// Copyright 2022 New Vector Ltd
|
|
//
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
// you may not use this file except in compliance with the License.
|
|
// You may obtain a copy of the License at
|
|
//
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
//
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
// See the License for the specific language governing permissions and
|
|
// limitations under the License.
|
|
//
|
|
|
|
import Combine
|
|
import Foundation
|
|
import SwiftUI
|
|
|
|
import Introspect
|
|
|
|
struct RoomHeaderView: View {
|
|
@ObservedObject var context: RoomScreenViewModel.Context
|
|
|
|
var body: some View {
|
|
HStack(spacing: 12) {
|
|
roomAvatar
|
|
.accessibilityHidden(true)
|
|
Text(context.viewState.roomTitle)
|
|
.font(.element.headline)
|
|
.accessibilityIdentifier(A11yIdentifiers.roomScreen.name)
|
|
}
|
|
// Leading align whilst using the principal toolbar position.
|
|
.frame(maxWidth: .infinity, alignment: .leading)
|
|
// Using a button stops is from getting truncated in the navigation bar
|
|
.onTapGesture {
|
|
context.send(viewAction: .displayRoomDetails)
|
|
}
|
|
}
|
|
|
|
@ViewBuilder private var roomAvatar: some View {
|
|
LoadableAvatarImage(url: context.viewState.roomAvatarURL,
|
|
name: context.viewState.roomTitle,
|
|
contentID: context.viewState.roomId,
|
|
avatarSize: .room(on: .timeline),
|
|
imageProvider: context.imageProvider)
|
|
.accessibilityIdentifier(A11yIdentifiers.roomScreen.avatar)
|
|
}
|
|
}
|
|
|
|
struct RoomHeaderView_Previews: PreviewProvider {
|
|
static var previews: some View {
|
|
bodyPlain
|
|
bodyEncrypted
|
|
}
|
|
|
|
@ViewBuilder
|
|
static var bodyPlain: some View {
|
|
let viewModel = RoomScreenViewModel(timelineController: MockRoomTimelineController(),
|
|
mediaProvider: MockMediaProvider(),
|
|
roomName: "Some Room name",
|
|
roomAvatarUrl: URL.picturesDirectory)
|
|
|
|
RoomHeaderView(context: viewModel.context)
|
|
.previewLayout(.sizeThatFits)
|
|
.padding()
|
|
}
|
|
|
|
@ViewBuilder
|
|
static var bodyEncrypted: some View {
|
|
let viewModel = RoomScreenViewModel(timelineController: MockRoomTimelineController(),
|
|
mediaProvider: MockMediaProvider(),
|
|
roomName: "Some Room name",
|
|
roomAvatarUrl: nil)
|
|
|
|
RoomHeaderView(context: viewModel.context)
|
|
.previewLayout(.sizeThatFits)
|
|
.padding()
|
|
}
|
|
}
|