- Decryption banner on the timeline - Bubble colours - Background insets - Multiline composer corner radius - Read marker - GIF indicator - Reactions shape - Use RoomTimelineViewLabelStyle everywhere possible - Only set a line limit on reply quotes, allow all the lines for regular quotes. - Message label icons - Yes/No button casing - Make sender profiles immutable. - Enable copy link and invite buttons. - Fix layout loop detecting multiline composer text. - Add animation to the encryption banner.
75 lines
2.1 KiB
Swift
75 lines
2.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 Foundation
|
|
import UIKit
|
|
|
|
enum TimelineItemGroupState: Hashable {
|
|
case single
|
|
case beginning
|
|
case middle
|
|
case end
|
|
|
|
var shouldShowSenderDetails: Bool {
|
|
switch self {
|
|
case .single, .beginning:
|
|
return true
|
|
default:
|
|
return false
|
|
}
|
|
}
|
|
}
|
|
|
|
protocol EventBasedTimelineItemProtocol: RoomTimelineItemProtocol {
|
|
var text: String { get }
|
|
var timestamp: String { get }
|
|
var shouldShowSenderDetails: Bool { get }
|
|
var groupState: TimelineItemGroupState { get }
|
|
var isOutgoing: Bool { get }
|
|
var isEditable: Bool { get }
|
|
|
|
var sender: TimelineItemSender { get }
|
|
|
|
var properties: RoomTimelineItemProperties { get }
|
|
}
|
|
|
|
extension EventBasedTimelineItemProtocol {
|
|
var shouldShowSenderDetails: Bool {
|
|
groupState.shouldShowSenderDetails
|
|
}
|
|
|
|
var roundedCorners: UIRectCorner {
|
|
switch groupState {
|
|
case .single:
|
|
return .allCorners
|
|
case .beginning:
|
|
if isOutgoing {
|
|
return [.topLeft, .topRight, .bottomLeft]
|
|
} else {
|
|
return [.topLeft, .topRight, .bottomRight]
|
|
}
|
|
case .middle:
|
|
return isOutgoing ? [.topLeft, .bottomLeft] : [.topRight, .bottomRight]
|
|
case .end:
|
|
if isOutgoing {
|
|
return [.topLeft, .bottomLeft, .bottomRight]
|
|
} else {
|
|
return [.topRight, .bottomLeft, .bottomRight]
|
|
}
|
|
}
|
|
}
|
|
}
|