LeadKit/TIUIElements/Sources/Views/StatefulButton/DefaultConfigurableStateful.../DefaultConfigurableStateful...

75 lines
2.7 KiB
Swift

//
// Copyright (c) 2023 Touch Instinct
//
// Permission is hereby granted, free of charge, to any person obtaining a copy
// of this software and associated documentation files (the Software), to deal
// in the Software without restriction, including without limitation the rights
// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
// copies of the Software, and to permit persons to whom the Software is
// furnished to do so, subject to the following conditions:
//
// The above copyright notice and this permission notice shall be included in
// all copies or substantial portions of the Software.
//
// THE SOFTWARE IS PROVIDED AS IS, WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
// THE SOFTWARE.
//
import TIUIKitCore
import UIKit
public final class DefaultConfigurableStatefulButton: StatefulButton, ConfigurableView, AppearanceConfigurable {
private var appearance: Appearance = .defaultAppearance
// MARK: - ConfigurableView
public func configure(with viewModel: ViewModel) {
viewModel.willReuse(view: self)
stateViewModelMap = viewModel.stateViewModelMap
for (state, viewModel) in viewModel.stateViewModelMap {
setTitle(viewModel.title, for: state)
setImage(viewModel.image, for: state)
setBackgroundImage(viewModel.backgroundImage, for: state)
}
apply(state: viewModel.currentState)
configureStatefulButton(appearance: appearance)
viewModel.didCompleteConfiguration(of: self)
}
// MARK: - AppearanceConfigurable
public func configure(appearance: DefaultPositionAppearance) {
self.appearance = appearance
configureStatefulButton(appearance: appearance)
}
}
extension DefaultConfigurableStatefulButton {
public final class ViewModel: DefaultUIViewPresenter<DefaultConfigurableStatefulButton> {
public var stateViewModelMap: [State: BaseButtonViewModel]
public var currentState: State {
didSet {
view?.apply(state: currentState)
}
}
public init(stateViewModelMap: [State: BaseButtonViewModel],
currentState: State) {
self.stateViewModelMap = stateViewModelMap
self.currentState = currentState
}
}
}