mirror of
https://github.com/confirmedcode/Lockdown-iOS.git
synced 2025-12-25 12:13:52 +01:00
commit 1c1067e30104c2670c6339d1f16b7bd55406481b Merge: d3d2df9 70a2319 Author: Pavel Vilbik <Pavel.Vilbik@joinappex.com> Date: Wed Jun 28 14:07:47 2023 +0300 Merge branch 'local/KB-6393_questionnaire' of https://github.com/joinappex/lockdown-ios-2.0 into local/KB-6393_questionnaire commit d3d2df991e9b6358982ba6d38541f726772f2fd1 Author: Pavel Vilbik <Pavel.Vilbik@joinappex.com> Date: Wed Jun 28 13:19:42 2023 +0300 add sending message commit 70a23193dcb3deae1341ee318bf536e49ecf3c2a Author: Pavel Vilbik <Pavel.Vilbik@joinappex.com> Date: Wed Jun 28 13:19:42 2023 +0300 add sending message commit 9a290eb556f0ad4751b49cd53be17de903edd0ac Author: Pavel Vilbik <Pavel.Vilbik@joinappex.com> Date: Wed Jun 28 13:05:32 2023 +0300 add generating message commit 341293cab9466eab31a1886b6d43d59cc43a3e61 Author: Pavel Vilbik <Pavel.Vilbik@joinappex.com> Date: Wed Jun 28 12:35:53 2023 +0300 refactoring model of questions commit 0482bce1c1955a0562deaaabeb48aca04f16302c Author: Pavel Vilbik <Pavel.Vilbik@joinappex.com> Date: Wed Jun 28 12:12:02 2023 +0300 add select region commit 151b94c742fe9cc29e730c18d57a7cf868878ea3 Author: Pavel Vilbik <Pavel.Vilbik@joinappex.com> Date: Wed Jun 28 11:30:03 2023 +0300 add select country commit f75596a13b9e17dacfc05a57674acb4d65680229 Author: Pavel Vilbik <Pavel.Vilbik@joinappex.com> Date: Tue Jun 27 14:19:40 2023 +0300 add navigation link view commit a9a83f462ffa3c7ec066d8ee5254b2d8cb6416ed Author: Pavel Vilbik <Pavel.Vilbik@joinappex.com> Date: Mon Jun 26 18:25:23 2023 +0300 add questions title view commit 08d3eb1d7873bf4ccedd4b8fbf280213520bb9c3 Author: Pavel Vilbik <Pavel.Vilbik@joinappex.com> Date: Mon Jun 26 16:20:01 2023 +0300 add yes/no views commit b6a16aa2bbd0c1bbe607170d16f430ad522c4d5f Author: Pavel Vilbik <Pavel.Vilbik@joinappex.com> Date: Mon Jun 26 12:48:23 2023 +0300 fixed skip button commit 5bf7fb8799f4b79e1a37a58a2f3b5862ea9f1da5 Author: Pavel Vilbik <Pavel.Vilbik@joinappex.com> Date: Mon Jun 26 12:41:59 2023 +0300 refactoring step view model commit 8871dc2ebc0728d3491e6807b4426963741baa4a Author: Pavel Vilbik <Pavel.Vilbik@joinappex.com> Date: Mon Jun 26 12:04:26 2023 +0300 refactoring step view model commit e5b2e02191217546d47454a471e101c242d89464 Author: Pavel Vilbik <Pavel.Vilbik@joinappex.com> Date: Fri Jun 23 18:49:07 2023 +0300 add view model for content commit b84b9130771aaa521acee0abdf28f3bba2b82771 Author: Pavel Vilbik <p.vilbik@softteco.com> Date: Fri Jun 23 14:44:41 2023 +0300 add textview cell commit e0985ae6c1a5c519e4fd83d5359b68621a18093b Author: Pavel Vilbik <p.vilbik@softteco.com> Date: Fri Jun 23 12:16:51 2023 +0300 add title view commit 24908af4d5b914364df3542b77cecdaaa497d105 Author: Pavel Vilbik <p.vilbik@softteco.com> Date: Thu Jun 22 17:34:07 2023 +0300 add view for problem cell commit 9df1a479a404528efba0452bde0d4291648b49b7 Author: Pavel Vilbik <p.vilbik@softteco.com> Date: Thu Jun 22 17:14:49 2023 +0300 add radio switcher view commit 5ed6c1d3bd4acf00d40f5dbe81cfcbbbd8bf63c0 Author: Pavel Vilbik <p.vilbik@softteco.com> Date: Thu Jun 22 15:49:32 2023 +0300 add base view for questionnaire
97 lines
3.0 KiB
Swift
97 lines
3.0 KiB
Swift
//
|
|
// WhatProblemStepViewModel.swift
|
|
// Lockdown
|
|
//
|
|
// Created by Pavel Vilbik on 23.06.23.
|
|
// Copyright © 2023 Confirmed Inc. All rights reserved.
|
|
//
|
|
|
|
import UIKit
|
|
|
|
class WhatProblemStepViewModel: BaseStepViewModel, StepViewModelProtocol {
|
|
private let problemList = [
|
|
NSLocalizedString("Internet connection is blocked", comment: ""),
|
|
NSLocalizedString("VPN not connecting", comment: ""),
|
|
NSLocalizedString("Blocking not working", comment: ""),
|
|
NSLocalizedString("Battery Drain", comment: ""),
|
|
NSLocalizedString("Other", comment: "")
|
|
]
|
|
|
|
private var selectedProblemIndex = -1
|
|
private var otherInput: String?
|
|
|
|
private var selectedProblem: String? {
|
|
if (0..<problemList.count).contains(selectedProblemIndex) {
|
|
return problemList[selectedProblemIndex]
|
|
}
|
|
return nil
|
|
}
|
|
|
|
private var otherDescription: String? {
|
|
if selectedProblemIndex == problemList.count - 1 {
|
|
return otherInput
|
|
}
|
|
return nil
|
|
}
|
|
|
|
var step: Steps = .whatsProblem
|
|
var message: String? {
|
|
guard !isSkiped, selectedProblemIndex >= 0 else { return nil }
|
|
var result = ""
|
|
result.append(problemList[selectedProblemIndex])
|
|
if isSelectedOther(),
|
|
let otherInput {
|
|
result.append("\n")
|
|
result.append(otherInput)
|
|
}
|
|
return result
|
|
}
|
|
|
|
override func updateRows() {
|
|
staticTableView?.clear()
|
|
addTitleRow(
|
|
NSLocalizedString("What problem are you experiencing?", comment: ""),
|
|
subtitle: NSLocalizedString("Select your problem", comment: "")
|
|
)
|
|
|
|
for index in 0..<problemList.count {
|
|
staticTableView?.addRowCell { [unowned self] cell in
|
|
let view = SelectableRadioSwitcherWithTitle()
|
|
view.titleLabel.text = problemList[index]
|
|
view.isSelected = self.selectedProblemIndex == index
|
|
view.didSelect = { self.updateForSelect(problemIndex: index, isSelected: $0) }
|
|
self.setupClear(cell)
|
|
cell.addSubview(view)
|
|
view.anchors.edges.pin(insets: .init(top: 5, left: 2, bottom: 5, right: 2))
|
|
}
|
|
}
|
|
|
|
if isSelectedOther() {
|
|
addTextViewRow(
|
|
text: otherInput,
|
|
placeholder: NSLocalizedString("Write here...", comment: "")
|
|
) { [weak self] text in
|
|
self?.otherInput = text
|
|
|
|
}
|
|
}
|
|
staticTableView?.reloadData()
|
|
}
|
|
|
|
private func isSelectedOther() -> Bool {
|
|
selectedProblemIndex != problemList.count - 1
|
|
}
|
|
|
|
private func updateForSelect(problemIndex: Int, isSelected: Bool) {
|
|
if isSelected {
|
|
selectedProblemIndex = problemIndex
|
|
} else {
|
|
selectedProblemIndex = -1
|
|
}
|
|
if !isSelectedOther() {
|
|
otherInput = nil
|
|
}
|
|
updateRows()
|
|
}
|
|
}
|