Digital ACT-191 ONEAPP-6827 story: Updated code as per review feedback
This commit is contained in:
parent
3fe3ede2f8
commit
16857ade9f
@ -99,11 +99,4 @@ extension BaseViewController {
|
|||||||
$0.labelPublisher(label)
|
$0.labelPublisher(label)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func makeBreadcrumbItem(_ text: String, label: UILabel) -> BreadcrumbItem {
|
|
||||||
return BreadcrumbItem().with{
|
|
||||||
$0.text = text
|
|
||||||
$0.labelPublisher(label)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|||||||
@ -14,33 +14,51 @@ import Combine
|
|||||||
class BreadcrumbsViewController: BaseViewController<Breadcrumbs> {
|
class BreadcrumbsViewController: BaseViewController<Breadcrumbs> {
|
||||||
|
|
||||||
var selectedSwitch = Toggle()
|
var selectedSwitch = Toggle()
|
||||||
|
var sampleSwitch = Toggle()
|
||||||
|
var selectedCrumbLabel = Label().with { $0.textStyle = .boldBodyMedium }
|
||||||
|
|
||||||
|
var allBreadcrumbs: [Breadcrumbs.BreadcrumbItemModel] = [
|
||||||
|
.init(text: "Home", link: "https://www.verizon.com/"),
|
||||||
|
.init(text: "Support", link: "https://www.verizon.com/"),
|
||||||
|
.init(text: "Servie & Apps", link: "https://www.verizon.com/"),
|
||||||
|
.init(text: "My Verizon", link: "https://www.verizon.com/"),
|
||||||
|
.init(text: "Bill", link: "https://www.verizon.com/"),
|
||||||
|
.init(text: "Mobile Billing & Payments", link: "https://www.verizon.com/"),
|
||||||
|
.init(text: "Billing statement FAQs", link: "https://www.verizon.com/", isSelected: true)
|
||||||
|
]
|
||||||
|
|
||||||
|
var some: [Breadcrumbs.BreadcrumbItemModel] = [
|
||||||
|
.init(text: "Plans", link: "https://www.verizon.com/"),
|
||||||
|
.init(text: "Upgrade Plan", link: "https://www.verizon.com/", isSelected: true)
|
||||||
|
]
|
||||||
|
|
||||||
override func viewDidLoad() {
|
override func viewDidLoad() {
|
||||||
super.viewDidLoad()
|
super.viewDidLoad()
|
||||||
let label = actionLabel
|
let stack = UIStackView(arrangedSubviews: [component, selectedCrumbLabel]).with {
|
||||||
|
$0.axis = .vertical
|
||||||
component.breadcrumbItems = [
|
$0.spacing = 4
|
||||||
makeBreadcrumbItem("Home", label: label).with{ $0.link = "https://www.verizon.com/" },
|
}
|
||||||
makeBreadcrumbItem("Support", label: label).with{ $0.link = "https://www.verizon.com/"; $0.selectable = false },
|
addContentTopView(view: stack)
|
||||||
makeBreadcrumbItem("Servie & Apps", label: label).with{ $0.link = "https://www.verizon.com/" },
|
|
||||||
makeBreadcrumbItem("My Verizon", label: label).with{ $0.link = "https://www.verizon.com/"; $0.selectable = false },
|
|
||||||
makeBreadcrumbItem("Bill", label: label).with{ $0.link = "https://www.verizon.com/" },
|
|
||||||
makeBreadcrumbItem("Billing statement FAQs", label: label).with{ $0.link = "https://www.verizon.com/"; $0.selectable = true }
|
|
||||||
]
|
|
||||||
addContentTopView(view: component)
|
|
||||||
setupPicker()
|
setupPicker()
|
||||||
setupModel()
|
setupModel()
|
||||||
}
|
}
|
||||||
|
|
||||||
override func setupForm(){
|
override func setupForm(){
|
||||||
super.setupForm()
|
super.setupForm()
|
||||||
addActionRow()
|
|
||||||
addFormRow(label: "Surface", view: surfacePickerSelectorView)
|
addFormRow(label: "Surface", view: surfacePickerSelectorView)
|
||||||
addFormRow(label: "Last Crumb Selected", view: selectedSwitch)
|
addFormRow(label: "Last Crumb Selected", view: selectedSwitch)
|
||||||
|
addFormRow(label: "Large Sample", view: sampleSwitch)
|
||||||
|
|
||||||
selectedSwitch.onChange = { [weak self] sender in
|
selectedSwitch.onChange = { [weak self] sender in
|
||||||
guard let self else { return }
|
guard let self else { return }
|
||||||
component.breadcrumbItems.last?.selectable = sender.isOn
|
component.breadcrumbs.last?.isSelected = sender.isOn
|
||||||
|
}
|
||||||
|
|
||||||
|
sampleSwitch.onChange = { [weak self] sender in
|
||||||
|
guard let self else { return }
|
||||||
|
self.component.breadcrumbModels = sender.isOn ? self.allBreadcrumbs : self.some
|
||||||
|
selectedSwitch.isOn = true
|
||||||
|
updatedCrumbLabel(crumb: component.breadcrumbs.last ?? nil)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -51,9 +69,23 @@ class BreadcrumbsViewController: BaseViewController<Breadcrumbs> {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func updatedCrumbLabel(crumb: BreadcrumbItem?) {
|
||||||
|
selectedCrumbLabel.text = "Selected Crumb : \(crumb?.text ?? "")"
|
||||||
|
}
|
||||||
|
|
||||||
func setupModel() {
|
func setupModel() {
|
||||||
//setup UI
|
//setup UI
|
||||||
|
component.breadcrumbModels = allBreadcrumbs
|
||||||
selectedSwitch.isOn = true
|
selectedSwitch.isOn = true
|
||||||
|
sampleSwitch.isOn = true
|
||||||
surfacePickerSelectorView.text = component.surface.rawValue
|
surfacePickerSelectorView.text = component.surface.rawValue
|
||||||
|
|
||||||
|
updatedCrumbLabel(crumb: component.breadcrumbs.last ?? nil)
|
||||||
|
//test setup to show component was picked
|
||||||
|
component.onBreadcrumbDidSelect = { [weak self] crumb in
|
||||||
|
guard let self else { return }
|
||||||
|
self.updatedCrumbLabel(crumb: crumb)
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user