Digital ACT-191 ONEAPP-7016 story: Hide/Show indicators by toggling on/off

This commit is contained in:
vasavk 2024-05-04 15:03:23 +05:30
parent a6b06f5076
commit c45775759a

View File

@ -31,12 +31,11 @@ class CalendarViewController: BaseViewController<CalendarBase> {
override func viewDidLoad() {
super.viewDidLoad()
addContentTopView(view: component)
addContentTopView(view: component)
setupPicker()
setupModel()
}
override func setupForm() {
super.setupForm()
configurePicker(datePickerOne)
@ -52,7 +51,7 @@ class CalendarViewController: BaseViewController<CalendarBase> {
indicators = [
.init(label: "Due Date", date: datePickerOne.date),
.init(label: "Auto Pay", date: datePickerTwo.date),
.init(label: "Scheduled", date: datePickerTwo.date),
.init(label: "Scheduled", date: datePickerTwo.date)
]
//add form rows
@ -92,6 +91,41 @@ class CalendarViewController: BaseViewController<CalendarBase> {
[weak self] text in
self?.updateIndicatorData(label: text, date: self?.datePickerThree.date, index: 2)
}.store(in: &subscribers)
indicatorOneSwitch.onChange = { [weak self] sender in
guard let self else { return }
if !sender.isOn {
component.indicators.removeAll()
} else {
self.setIndicatorsData()
}
}
indicatorTwoSwitch.onChange = { [weak self] sender in
guard let self else { return }
if !sender.isOn {
if component.indicators.count > 2 {
component.indicators.removeLast()
component.indicators.removeLast()
} else if component.indicators.count == 2 {
component.indicators.removeLast()
}
} else {
self.setIndicatorsData()
}
}
indicatorThreeSwitch.onChange = { [weak self] sender in
guard let self else { return }
if !sender.isOn {
if component.indicators.count > 2 {
component.indicators.removeLast()
}
} else {
self.setIndicatorsData()
}
}
}
func setupPicker(){
@ -106,6 +140,9 @@ class CalendarViewController: BaseViewController<CalendarBase> {
legendOneField.text = "Due Date"
legendTwoField.text = "Auto Pay"
legendThreeField.text = "Scheduled"
indicatorOneSwitch.isOn = true
indicatorTwoSwitch.isOn = true
indicatorThreeSwitch.isOn = true
}
func updateIndicatorData(label: String = "", date: Date?, index:Int) {
@ -113,7 +150,27 @@ class CalendarViewController: BaseViewController<CalendarBase> {
indicators[index].date = date ?? Date()
component.indicators = indicators
}
func setIndicatorsData() {
if indicatorOneSwitch.isOn && indicatorTwoSwitch.isOn && indicatorThreeSwitch.isOn {
component.indicators = [
.init(label: self.legendOneField.text ?? "", date: datePickerOne.date),
.init(label: self.legendTwoField.text ?? "", date: datePickerTwo.date),
.init(label: self.legendThreeField.text ?? "", date: datePickerTwo.date)
]
} else if indicatorOneSwitch.isOn && indicatorTwoSwitch.isOn && !indicatorThreeSwitch.isOn {
component.indicators = [
.init(label: self.legendOneField.text ?? "", date: datePickerOne.date),
.init(label: self.legendTwoField.text ?? "", date: datePickerTwo.date),
]
} else if indicatorOneSwitch.isOn && !indicatorTwoSwitch.isOn {
component.indicators = [
.init(label: self.legendOneField.text ?? "", date: datePickerOne.date),
]
}
}
func configurePicker(_ sender:UIDatePicker) {
// Set some of UIDatePicker properties
sender.timeZone = NSTimeZone.local
@ -132,7 +189,7 @@ class CalendarViewController: BaseViewController<CalendarBase> {
dateFormatter.dateFormat = "MM/dd/yyyy hh:mm a"
// Apply date format
// let selectedDate: String = dateFormatter.string(from: sender.date)
// let selectedDate: String = dateFormatter.string(from: sender.date)
switch sender.tag {
case 1: updateIndicatorData(label: legendOneField.text ?? "", date: sender.date, index: 0)
@ -140,6 +197,6 @@ class CalendarViewController: BaseViewController<CalendarBase> {
case 3: updateIndicatorData(label: legendThreeField.text ?? "", date: sender.date, index: 2)
default: break
}
// print("Selected value \(selectedDate)")
// print("Selected value \(selectedDate)")
}
}