aboutsummaryrefslogtreecommitdiffstats
path: root/WireGuard/WireGuard/UI/iOS/TunnelsListTableViewController.swift
diff options
context:
space:
mode:
authorRoopesh Chander <roop@roopc.net>2018-10-28 14:56:10 +0530
committerRoopesh Chander <roop@roopc.net>2018-10-28 14:56:15 +0530
commitdfbdcf3c28d0666fab23590ed238552f405f0530 (patch)
tree9af4b1225552cae89e95174ea3ffce7a6d7d3d13 /WireGuard/WireGuard/UI/iOS/TunnelsListTableViewController.swift
parentVPN: Save the tunnel name when modifying a tunnel (diff)
downloadwireguard-apple-dfbdcf3c28d0666fab23590ed238552f405f0530.tar.xz
wireguard-apple-dfbdcf3c28d0666fab23590ed238552f405f0530.zip
Tunnels list: Add a switch and an activity indicator to the list view
They track the status of the tunnel. The switch can also be used to bring the tunnel up and down. Signed-off-by: Roopesh Chander <roop@roopc.net>
Diffstat (limited to 'WireGuard/WireGuard/UI/iOS/TunnelsListTableViewController.swift')
-rw-r--r--WireGuard/WireGuard/UI/iOS/TunnelsListTableViewController.swift93
1 files changed, 89 insertions, 4 deletions
diff --git a/WireGuard/WireGuard/UI/iOS/TunnelsListTableViewController.swift b/WireGuard/WireGuard/UI/iOS/TunnelsListTableViewController.swift
index 45e7280..d103fa0 100644
--- a/WireGuard/WireGuard/UI/iOS/TunnelsListTableViewController.swift
+++ b/WireGuard/WireGuard/UI/iOS/TunnelsListTableViewController.swift
@@ -22,6 +22,8 @@ class TunnelsListTableViewController: UITableViewController {
let addButtonItem = UIBarButtonItem(barButtonSystemItem: .add, target: self, action: #selector(addButtonTapped(sender:)))
self.navigationItem.rightBarButtonItem = addButtonItem
+ self.tableView.rowHeight = 60
+
self.tableView.register(TunnelsListTableViewCell.self, forCellReuseIdentifier: TunnelsListTableViewCell.id)
TunnelsManager.create { [weak self] tunnelsManager in
@@ -143,7 +145,19 @@ extension TunnelsListTableViewController {
let cell = tableView.dequeueReusableCell(withIdentifier: TunnelsListTableViewCell.id, for: indexPath) as! TunnelsListTableViewCell
if let tunnelsManager = tunnelsManager {
let tunnel = tunnelsManager.tunnel(at: indexPath.row)
- cell.tunnelName = tunnel.name
+ cell.tunnel = tunnel
+ cell.onSwitchToggled = { [weak self] isOn in
+ guard let s = self, let tunnelsManager = s.tunnelsManager else { return }
+ if (isOn) {
+ tunnelsManager.startActivation(of: tunnel) { error in
+ print("Error while activating: \(String(describing: error))")
+ }
+ } else {
+ tunnelsManager.startDeactivation(of: tunnel) { error in
+ print("Error while deactivating: \(String(describing: error))")
+ }
+ }
+ }
}
return cell
}
@@ -180,21 +194,92 @@ extension TunnelsListTableViewController: TunnelsManagerDelegate {
class TunnelsListTableViewCell: UITableViewCell {
static let id: String = "TunnelsListTableViewCell"
- var tunnelName: String {
- get { return textLabel?.text ?? "" }
- set(value) { textLabel?.text = value }
+ var tunnel: TunnelContainer? {
+ didSet(value) {
+ // Bind to the tunnel's name
+ nameLabel.text = tunnel?.name ?? ""
+ nameObservervationToken = tunnel?.observe(\.name) { [weak self] (tunnel, _) in
+ self?.nameLabel.text = tunnel.name
+ }
+ // Bind to the tunnel's status
+ update(from: tunnel?.status)
+ statusObservervationToken = tunnel?.observe(\.status) { [weak self] (tunnel, _) in
+ self?.update(from: tunnel.status)
+ }
+ }
}
+ var onSwitchToggled: ((Bool) -> Void)? = nil
+
+ let nameLabel: UILabel
+ let busyIndicator: UIActivityIndicatorView
+ let statusSwitch: UISwitch
+
+ private var statusObservervationToken: AnyObject? = nil
+ private var nameObservervationToken: AnyObject? = nil
override init(style: UITableViewCellStyle, reuseIdentifier: String?) {
+ nameLabel = UILabel()
+ busyIndicator = UIActivityIndicatorView(activityIndicatorStyle: .gray)
+ busyIndicator.hidesWhenStopped = true
+ statusSwitch = UISwitch()
super.init(style: style, reuseIdentifier: reuseIdentifier)
+ contentView.addSubview(statusSwitch)
+ statusSwitch.translatesAutoresizingMaskIntoConstraints = false
+ NSLayoutConstraint.activate([
+ statusSwitch.centerYAnchor.constraint(equalTo: contentView.centerYAnchor),
+ statusSwitch.rightAnchor.constraint(equalTo: contentView.rightAnchor, constant: -8)
+ ])
+ contentView.addSubview(busyIndicator)
+ busyIndicator.translatesAutoresizingMaskIntoConstraints = false
+ NSLayoutConstraint.activate([
+ busyIndicator.centerYAnchor.constraint(equalTo: contentView.centerYAnchor),
+ busyIndicator.rightAnchor.constraint(equalTo: statusSwitch.leftAnchor, constant: -8)
+ ])
+ contentView.addSubview(nameLabel)
+ nameLabel.translatesAutoresizingMaskIntoConstraints = false
+ NSLayoutConstraint.activate([
+ nameLabel.centerYAnchor.constraint(equalTo: contentView.centerYAnchor),
+ nameLabel.leftAnchor.constraint(equalTo: contentView.leftAnchor, constant: 16),
+ nameLabel.rightAnchor.constraint(equalTo: busyIndicator.leftAnchor)
+ ])
self.accessoryType = .disclosureIndicator
+
+ statusSwitch.addTarget(self, action: #selector(switchToggled), for: .valueChanged)
+ }
+
+ @objc func switchToggled() {
+ onSwitchToggled?(statusSwitch.isOn)
+ }
+
+ private func update(from status: TunnelStatus?) {
+ guard let status = status else {
+ reset()
+ return
+ }
+ DispatchQueue.main.async { [weak statusSwitch, weak busyIndicator] in
+ guard let statusSwitch = statusSwitch, let busyIndicator = busyIndicator else { return }
+ statusSwitch.isOn = !(status == .deactivating || status == .inactive)
+ statusSwitch.isUserInteractionEnabled = (status == .inactive || status == .active)
+ if (status == .inactive || status == .active) {
+ busyIndicator.stopAnimating()
+ } else {
+ busyIndicator.startAnimating()
+ }
+ }
}
required init?(coder aDecoder: NSCoder) {
fatalError("init(coder:) has not been implemented")
}
+ private func reset() {
+ statusSwitch.isOn = false
+ statusSwitch.isUserInteractionEnabled = false
+ busyIndicator.stopAnimating()
+ }
+
override func prepareForReuse() {
super.prepareForReuse()
+ reset()
}
}