* Rename onboarding and login user/pass accessibility ids. * Refactor remaining server change accessibility IDs * Avoid accessibilityIdentifier spreading to all decorations on the textBox. Required because otherwise there are multiple items tagged with the accessibilityId which means we can't click on "the" item. * Move all accessibility identifiers to `AccessibilityIdentifiers.swft` - use same naming convention on all of them - remove the unused ones - fix build errors in integration tests and invalid identifiers (still broken until autodiscovery lands on rosa) --------- Co-authored-by: Stefan Ceriu <stefanc@matrix.org>
84 lines
3.1 KiB
Swift
84 lines
3.1 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(),
|
|
timelineViewFactory: RoomTimelineViewFactory(),
|
|
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(),
|
|
timelineViewFactory: RoomTimelineViewFactory(),
|
|
mediaProvider: MockMediaProvider(),
|
|
roomName: "Some Room name",
|
|
roomAvatarUrl: nil)
|
|
|
|
RoomHeaderView(context: viewModel.context)
|
|
.previewLayout(.sizeThatFits)
|
|
.padding()
|
|
}
|
|
}
|