* prefire basic implementation force the unit tests to run on iPhone 14 skipping plugin validation archive artifacts better workflow removed the OS restriction lfs custom stencil new test file deleting * git lfs * lfs * test * customised the stencil to support our internal protocol * for now we can remove the OS check from the stencil * added a delay * tests have been moved * improvement * recommit * perceptual precision lowered * updated snapshot testing and selected also iOS version * added ios version control
131 lines
5.6 KiB
Swift
131 lines
5.6 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 Foundation
|
|
import SwiftUI
|
|
|
|
// MARK: - TimelineStyler
|
|
|
|
struct TimelineStyler<Content: View>: View {
|
|
@Environment(\.timelineStyle) private var style
|
|
|
|
let timelineItem: EventBasedTimelineItemProtocol
|
|
@ViewBuilder let content: () -> Content
|
|
|
|
var body: some View {
|
|
switch style {
|
|
case .plain:
|
|
TimelineItemPlainStylerView(timelineItem: timelineItem, content: content)
|
|
case .bubbles:
|
|
TimelineItemBubbledStylerView(timelineItem: timelineItem, content: content)
|
|
}
|
|
}
|
|
}
|
|
|
|
struct TimelineItemStyler_Previews: TestablePreviewProvider {
|
|
static let viewModel = RoomScreenViewModel.mock
|
|
|
|
static let base = TextRoomTimelineItem(id: .random, timestamp: "Now", isOutgoing: true, isEditable: false, isThreaded: false, sender: .test, content: .init(body: "Test"))
|
|
|
|
static let sentNonLast: TextRoomTimelineItem = {
|
|
var result = base
|
|
result.properties.deliveryStatus = .sent
|
|
return result
|
|
}()
|
|
|
|
static let sendingNonLast: TextRoomTimelineItem = {
|
|
var result = base
|
|
result.properties.deliveryStatus = .sending
|
|
return result
|
|
}()
|
|
|
|
static let sendingLast: TextRoomTimelineItem = {
|
|
let id = viewModel.state.timelineViewState.timelineIDs.last ?? UUID().uuidString
|
|
var result = TextRoomTimelineItem(id: .init(timelineID: id), timestamp: "Now", isOutgoing: true, isEditable: false, isThreaded: false, sender: .test, content: .init(body: "Test"))
|
|
result.properties.deliveryStatus = .sending
|
|
return result
|
|
}()
|
|
|
|
static let failed: TextRoomTimelineItem = {
|
|
var result = base
|
|
result.properties.deliveryStatus = .sendingFailed
|
|
return result
|
|
}()
|
|
|
|
static let sentLast: TextRoomTimelineItem = {
|
|
let id = viewModel.state.timelineViewState.timelineIDs.last ?? UUID().uuidString
|
|
let result = TextRoomTimelineItem(id: .init(timelineID: id), timestamp: "Now", isOutgoing: true, isEditable: false, isThreaded: false, sender: .test, content: .init(body: "Test"))
|
|
return result
|
|
}()
|
|
|
|
static let ltrString = TextRoomTimelineItem(id: .random, timestamp: "Now", isOutgoing: true, isEditable: false, isThreaded: false, sender: .test, content: .init(body: "house!"))
|
|
|
|
static let rtlString = TextRoomTimelineItem(id: .random, timestamp: "Now", isOutgoing: true, isEditable: false, isThreaded: false, sender: .test, content: .init(body: "באמת!"))
|
|
|
|
static let ltrStringThatContainsRtl = TextRoomTimelineItem(id: .random, timestamp: "Now", isOutgoing: true, isEditable: false, isThreaded: false, sender: .test, content: .init(body: "house! -- באמת! -- house!"))
|
|
|
|
static let rtlStringThatContainsLtr = TextRoomTimelineItem(id: .random, timestamp: "Now", isOutgoing: true, isEditable: false, isThreaded: false, sender: .test, content: .init(body: "באמת! -- house! -- באמת!"))
|
|
|
|
static let ltrStringThatFinishesInRtl = TextRoomTimelineItem(id: .random, timestamp: "Now", isOutgoing: true, isEditable: false, isThreaded: false, sender: .test, content: .init(body: "house! -- באמת!"))
|
|
|
|
static let rtlStringThatFinishesInLtr = TextRoomTimelineItem(id: .random, timestamp: "Now", isOutgoing: true, isEditable: false, isThreaded: false, sender: .test, content: .init(body: "באמת! -- house!"))
|
|
|
|
static var testView: some View {
|
|
VStack {
|
|
TextRoomTimelineView(timelineItem: base)
|
|
TextRoomTimelineView(timelineItem: sentNonLast)
|
|
TextRoomTimelineView(timelineItem: sentLast)
|
|
TextRoomTimelineView(timelineItem: sendingNonLast)
|
|
TextRoomTimelineView(timelineItem: sendingLast)
|
|
TextRoomTimelineView(timelineItem: failed)
|
|
}
|
|
}
|
|
|
|
static var languagesTestView: some View {
|
|
VStack {
|
|
TextRoomTimelineView(timelineItem: ltrString)
|
|
TextRoomTimelineView(timelineItem: rtlString)
|
|
TextRoomTimelineView(timelineItem: ltrStringThatContainsRtl)
|
|
TextRoomTimelineView(timelineItem: rtlStringThatContainsLtr)
|
|
TextRoomTimelineView(timelineItem: ltrStringThatFinishesInRtl)
|
|
TextRoomTimelineView(timelineItem: rtlStringThatFinishesInLtr)
|
|
}
|
|
}
|
|
|
|
static var previews: some View {
|
|
testView
|
|
.environmentObject(viewModel.context)
|
|
.environment(\.timelineStyle, .bubbles)
|
|
.previewDisplayName("Bubbles")
|
|
|
|
testView
|
|
.environmentObject(viewModel.context)
|
|
.environment(\.timelineStyle, .plain)
|
|
.previewDisplayName("Plain")
|
|
|
|
languagesTestView
|
|
.environmentObject(viewModel.context)
|
|
.environment(\.timelineStyle, .bubbles)
|
|
.previewDisplayName("Bubbles LTR with different layout languages")
|
|
|
|
languagesTestView
|
|
.environmentObject(viewModel.context)
|
|
.environment(\.timelineStyle, .bubbles)
|
|
.environment(\.layoutDirection, .rightToLeft)
|
|
.previewDisplayName("Bubbles RTL with different layout languages")
|
|
}
|
|
}
|