Files
letro-ios/UnitTests/Sources/LayoutTests/LayoutMocks.swift
David Langley 9f7808e8da Reactions: Add more button (#1314)
* Add expand/collapse UI for reactions

- Adds a CollapsibleFlowLayout for controlling the layout
- Adds tests for  this layout and some mocks for testing layouts generally
- Improves the rendering of the reaction buttons which were not pixel perfect
- Adds the UI for the expand collapse buttons including the count of hidden items in the collapsed state.

* Add comment for reactionsCollapsed binding.

* Add the add more button and change the layout to be reactions specific and account for the add more button specifics.

* Update CollapsibleReactionLayout.swift

* Rename lines to rows, to hopefully ease the incoming merge.

* Add LayoutValueKey to organise subviews by item type.

- create ReactionLayoutItemType to tag subviews with ReactionLayoutItem
- Add LayoutValueKey support to the layout mocks
- Fix some mistakes in the merge
- Make the test code a bit more DRY
- Make the animation of the addMore and collapse buttons consistent

* Fix naming of the add more button label

* Address comments and fix padding

- Fix typos
- Use pdf/svg for icon
- Fix incorrect padding from a bad merge

* Fix "Add more" button padding to match designs

* Update snapshot test reference images.

* Fix naming, add Preserves Vector Data
2023-07-14 16:32:32 +00:00

88 lines
2.8 KiB
Swift

//
// Copyright 2023 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.
//
@testable import ElementX
import Foundation
import SwiftUI
/// A mock of the SwiftUI `LayoutSubviews` struct
struct LayoutSubviewsMock: Equatable, RandomAccessCollection {
var subviews: [LayoutSubviewMock]
/// A type that contains a subsequence of proxy values.
typealias SubSequence = LayoutSubviewsMock
/// A type that contains a proxy value.
typealias Element = LayoutSubviewMock
/// A type that you can use to index proxy values.
typealias Index = Int
/// The index of the first subview.
var startIndex: Int {
subviews.startIndex
}
/// An index that's one higher than the last subview.
var endIndex: Int {
subviews.endIndex
}
/// Gets the subview proxy at a specified index.
subscript(index: Int) -> LayoutSubviewsMock.Element {
subviews[index]
}
/// Gets the subview proxies in the specified range.
subscript(bounds: Range<Int>) -> LayoutSubviewsMock {
LayoutSubviewsMock(subviews: Array(subviews[bounds]))
}
/// Gets the subview proxies with the specified indicies.
subscript<S>(indices: S) -> LayoutSubviewsMock where S: Sequence, S.Element == Int {
LayoutSubviewsMock(subviews: Array(indices.map { subviews[$0] }))
}
}
/// A mock of the SwiftUI `LayoutSubview` struct
struct LayoutSubviewMock: FlowLayoutSubview, Equatable {
var size: CGSize
var layoutValues = [String: Any]()
var placedPositionCallback: (CGRect) -> Void
subscript<K>(key: K.Type) -> K.Value where K: LayoutValueKey {
guard let value = layoutValues[String(describing: key.self)] as? K.Value else {
fatalError("There is no value for the provided layout key.")
}
return value
}
func sizeThatFits(_ proposal: ProposedViewSize) -> CGSize {
size
}
func place(at position: CGPoint, anchor: UnitPoint, proposal: ProposedViewSize) {
let rect = CGRect(origin: position, size: CGSize(width: proposal.width ?? 0, height: proposal.height ?? 0))
placedPositionCallback(rect)
}
static func == (lhs: LayoutSubviewMock, rhs: LayoutSubviewMock) -> Bool {
lhs.size == rhs.size
}
}
extension LayoutSubviewsMock: FlowLayoutSubviews { }