177 lines
6.0 KiB
Swift
177 lines
6.0 KiB
Swift
//
|
|
// TabsViewController.swift
|
|
// VDSSample
|
|
//
|
|
// Created by Matt Bruce on 5/18/23.
|
|
//
|
|
|
|
import Foundation
|
|
import UIKit
|
|
import VDS
|
|
import Combine
|
|
import VDSTokens
|
|
|
|
class TabsViewController: BaseViewController<Tabs> {
|
|
|
|
var disabledSwitch = Toggle()
|
|
var borderlineSwitch = Toggle()
|
|
var fillContainerSwitch = Toggle()
|
|
var sampleSwitch = Toggle()
|
|
var selectedTabLabel = Label().with { $0.textStyle = .boldBodyLarge }
|
|
|
|
var horizontalOrientationFormStackView = FormSection()
|
|
|
|
lazy var orientationPickerSelectorView = {
|
|
PickerSelectorView(title: "",
|
|
picker: self.picker,
|
|
items: Tabs.Orientation.allCases)
|
|
}()
|
|
|
|
lazy var indicatorPositionPickerSelectorView = {
|
|
PickerSelectorView(title: "",
|
|
picker: self.picker,
|
|
items: Tabs.IndicatorPosition.allCases)
|
|
}()
|
|
|
|
lazy var sizePickerSelectorView = {
|
|
PickerSelectorView(title: "",
|
|
picker: self.picker,
|
|
items: Tabs.Size.allCases)
|
|
}()
|
|
|
|
// var overflowRow: UIView?
|
|
// lazy var overflowPickerSelectorView = {
|
|
// PickerSelectorView(title: "",
|
|
// picker: self.picker,
|
|
// items: Tabs.Overflow.allCases)
|
|
// }()
|
|
|
|
override func viewDidLoad() {
|
|
super.viewDidLoad()
|
|
let stack = UIStackView(arrangedSubviews: [component, selectedTabLabel]).with {
|
|
$0.axis = .vertical
|
|
$0.spacing = 10
|
|
}
|
|
addContentTopView(view: stack)
|
|
setupPicker()
|
|
setupModel()
|
|
}
|
|
|
|
override func setupForm(){
|
|
super.setupForm()
|
|
addFormRow(label: "Large Sample", view: sampleSwitch)
|
|
addFormRow(label: "Show Borderline", view: borderlineSwitch)
|
|
addFormRow(label: "Surface", view: surfacePickerSelectorView)
|
|
addFormRow(label: "Size", view: sizePickerSelectorView)
|
|
|
|
if UIDevice.isIPad {
|
|
addFormRow(label: "Orientation", view: orientationPickerSelectorView)
|
|
}
|
|
|
|
//only in horizontal mode
|
|
horizontalOrientationFormStackView.addFormRow(label: "Fill Container", view: fillContainerSwitch)
|
|
horizontalOrientationFormStackView.addFormRow(label: "Indicator Position", view: indicatorPositionPickerSelectorView)
|
|
//overflowRow = horizontalOrientationFormStackView.addFormRow(label: "Overflow", view: overflowPickerSelectorView)
|
|
|
|
append(section: horizontalOrientationFormStackView)
|
|
|
|
disabledSwitch.onChange = { [weak self] sender in
|
|
self?.component.isEnabled = !sender.isOn
|
|
}
|
|
|
|
borderlineSwitch.onChange = { [weak self] sender in
|
|
self?.component.borderLine = sender.isOn
|
|
}
|
|
|
|
fillContainerSwitch.onChange = { [weak self] sender in
|
|
self?.component.fillContainer = sender.isOn
|
|
//self?.overflowRow?.isHidden = sender.isOn
|
|
}
|
|
|
|
sampleSwitch.onChange = { [weak self] sender in
|
|
guard let self else { return }
|
|
self.component.selectedIndex = 0
|
|
self.component.tabModels = sender.isOn ? self.allTabs : self.some
|
|
}
|
|
}
|
|
|
|
var allTabs: [Tabs.TabModel] = [
|
|
.init(text: "Accessories"),
|
|
.init(text: "Internet and TV"),
|
|
.init(text: "Customer Service"),
|
|
.init(text: "Contact Us")
|
|
]
|
|
|
|
var some: [Tabs.TabModel] = [
|
|
.init(text: "Accessories"),
|
|
.init(text: "Internet and TV")
|
|
]
|
|
|
|
func setupModel() {
|
|
//set to the large sample
|
|
component.tabModels = allTabs
|
|
updateTabLabel(index: 0)
|
|
|
|
//setup tester to show component was picked
|
|
component.onTabDidSelect = { [weak self] index in
|
|
guard let self else { return }
|
|
self.updateTabLabel(index: index)
|
|
}
|
|
|
|
//setup UI
|
|
surfacePickerSelectorView.text = component.surface.rawValue
|
|
sizePickerSelectorView.text = component.size.rawValue
|
|
orientationPickerSelectorView.text = component.orientation.rawValue
|
|
indicatorPositionPickerSelectorView.text = component.indicatorPosition.rawValue
|
|
//overflowPickerSelectorView.text = component.overflow.rawValue
|
|
disabledSwitch.isOn = !component.isEnabled
|
|
borderlineSwitch.isOn = component.borderLine
|
|
fillContainerSwitch.isOn = component.fillContainer
|
|
sampleSwitch.isOn = true
|
|
}
|
|
|
|
func updateTabLabel(index: Int) {
|
|
let tabs = sampleSwitch.isOn ? self.allTabs : self.some
|
|
selectedTabLabel.text = "Selected Tab: \(tabs[index].text) Tab"
|
|
}
|
|
|
|
func setupPicker(){
|
|
surfacePickerSelectorView.onPickerDidSelect = { [weak self] item in
|
|
self?.component.surface = item
|
|
self?.contentTopView.backgroundColor = item.color
|
|
}
|
|
|
|
sizePickerSelectorView.onPickerDidSelect = { [weak self] item in
|
|
self?.component.size = item
|
|
}
|
|
|
|
orientationPickerSelectorView.onPickerDidSelect = { [weak self] item in
|
|
self?.component.orientation = item
|
|
self?.horizontalOrientationFormStackView.isHidden = item == .vertical
|
|
}
|
|
|
|
indicatorPositionPickerSelectorView.onPickerDidSelect = { [weak self] item in
|
|
self?.component.indicatorPosition = item
|
|
}
|
|
|
|
// overflowPickerSelectorView.onPickerDidSelect = { [weak self] item in
|
|
// self?.component.overflow = item
|
|
// }
|
|
}
|
|
}
|
|
extension TabsViewController: TooltipLaunchable {}
|
|
|
|
extension TabsViewController: ComponentSampleable {
|
|
static func makeSample() -> ComponentSample {
|
|
let component = Self.makeComponent()
|
|
component.tabModels = [
|
|
.init(text: "Accessories"),
|
|
.init(text: "Internet and TV"),
|
|
.init(text: "Customer Service"),
|
|
.init(text: "Contact Us")
|
|
]
|
|
|
|
return ComponentSample(component: component)
|
|
}
|
|
}
|