// // RadioBoxGroupViewController.swift // VDSSample // // Created by Matt Bruce on 8/23/22. // import Foundation import UIKit import VDS import VDSColorTokens import Combine class RadioBoxGroupViewController: ModelScrollViewController { var disabledSwitch = UISwitch() var strikeThroughSwitch = UISwitch() var textField = TextField() var subTextField = TextField() var subTextRightField = TextField() var showErrorSwitch = UISwitch() var radioBoxGroup = RadioBoxGroup() override func viewDidLoad() { super.viewDidLoad() addContentTopView(view: radioBoxGroup) setupForm() setupPicker() setupModel() } func setupForm() { addFormRow(label: "Disabled", view: disabledSwitch) addFormRow(label: "Surface", view: surfacePickerSelectorView) addFormRow(label: "Strikethrough", view: strikeThroughSwitch) addFormRow(label: "Text", view: textField) addFormRow(label: "Sub Text", view: subTextField) addFormRow(label: "Sub Text Right", view: subTextRightField) disabledSwitch .publisher(for: .valueChanged) .sink { [weak self] sender in self?.radioBoxGroup.disabled = sender.isOn }.store(in: &subscribers) strikeThroughSwitch .publisher(for: .valueChanged) .sink { [weak self] sender in self?.radioBox?.strikethrough = sender.isOn }.store(in: &subscribers) textField .textPublisher .sink { [weak self] text in self?.radioBox?.text = text }.store(in: &subscribers) subTextField .textPublisher .sink { [weak self] text in self?.radioBox?.subText = text }.store(in: &subscribers) subTextRightField .textPublisher .sink { [weak self] text in self?.radioBox?.subTextRight = text }.store(in: &subscribers) } func setupModel(){ var defaultModel = DefaultRadioBoxGroupModel() var model1 = DefaultRadioBoxModel() model1.inputId = "model1" model1.selected = true model1.value = "model 1 Value" model1.text = "iPhone 11 Bundle 1" model1.subText = "Apple iPhone 11 - 64 GB\nOtterbox Case Red\nScreen Protector" model1.subTextRight = "Right Text" var model2 = DefaultRadioBoxModel() model2.inputId = "model2" model2.value = "model 2 Value" model2.text = "iPhone 11 Bundle 2" model2.subText = "Apple iPhone 11 - 128 GB\nOtterbox Case Black\nScreen Protector" defaultModel.selectors = [model1, model2] set(with: defaultModel) //update the model radioBoxGroup .handlerPublisher() .sink { [weak self] updatedModel in self?.model = updatedModel self?.showErrorSwitch.isOn = updatedModel.showError self?.disabledSwitch.isOn = updatedModel.disabled } .store(in: &subscribers) radioBoxGroup .publisher(for: .valueChanged) .sink { group in print("Selected: \(group.selectedModelHandler?.text ?? "none")") }.store(in: &subscribers) //set UI values surfacePickerSelectorView.text = model.surface.rawValue disabledSwitch.isOn = model.disabled textField.text = model1.text subTextField.text = model1.subText subTextRightField.text = model1.subTextRight } override func updateView(viewModel: ModelType) { print("\(Self.self) updateView(viewModel)") showErrorSwitch.isOn = viewModel.showError disabledSwitch.isOn = viewModel.disabled radioBoxGroup.set(with: viewModel) } var radioBox: RadioBox? { radioBoxGroup.selectorViews.first } //Picker func setupPicker(){ surfacePickerSelectorView.onPickerDidSelect = { [weak self] item in self?.radioBoxGroup.surface = item self?.contentTopView.backgroundColor = item.color self?.surfacePickerSelectorView.text = item.rawValue } } }