From 7934d6b0c798924c859a4b0d55f6561d48f6eaff Mon Sep 17 00:00:00 2001 From: Roopesh Chander Date: Wed, 2 Jan 2019 01:07:46 +0530 Subject: macOS: Manage tunnels window: Tunnels list Signed-off-by: Roopesh Chander --- .../ManageTunnelsRootViewController.swift | 56 ++++++++++++++++++++++ .../TunnelsListTableViewController.swift | 55 +++++++++++++++++++++ 2 files changed, 111 insertions(+) create mode 100644 WireGuard/WireGuard/UI/macOS/ViewController/ManageTunnelsRootViewController.swift create mode 100644 WireGuard/WireGuard/UI/macOS/ViewController/TunnelsListTableViewController.swift (limited to 'WireGuard/WireGuard/UI/macOS/ViewController') diff --git a/WireGuard/WireGuard/UI/macOS/ViewController/ManageTunnelsRootViewController.swift b/WireGuard/WireGuard/UI/macOS/ViewController/ManageTunnelsRootViewController.swift new file mode 100644 index 0000000..e63235a --- /dev/null +++ b/WireGuard/WireGuard/UI/macOS/ViewController/ManageTunnelsRootViewController.swift @@ -0,0 +1,56 @@ +// SPDX-License-Identifier: MIT +// Copyright © 2018 WireGuard LLC. All Rights Reserved. + +import Cocoa + +class ManageTunnelsRootViewController: NSViewController { + + let tunnelsManager: TunnelsManager + + init(tunnelsManager: TunnelsManager) { + self.tunnelsManager = tunnelsManager + super.init(nibName: nil, bundle: nil) + } + + required init?(coder: NSCoder) { + fatalError("init(coder:) has not been implemented") + } + + override func loadView() { + view = NSView() + + let horizontalSpacing: CGFloat = 30 + let verticalSpacing: CGFloat = 20 + + let container = NSLayoutGuide() + view.addLayoutGuide(container) + NSLayoutConstraint.activate([ + container.topAnchor.constraint(equalTo: view.topAnchor, constant: verticalSpacing), + view.bottomAnchor.constraint(equalTo: container.bottomAnchor, constant: verticalSpacing), + container.leadingAnchor.constraint(equalTo: view.leadingAnchor, constant: horizontalSpacing), + view.trailingAnchor.constraint(equalTo: container.trailingAnchor, constant: horizontalSpacing) + ]) + + let tunnelsListVC = TunnelsListTableViewController(tunnelsManager: tunnelsManager) + let tunnelsListView = tunnelsListVC.view + let tunnelDetailView = NSView() + tunnelDetailView.wantsLayer = true + tunnelDetailView.layer?.backgroundColor = NSColor.gray.cgColor + + addChild(tunnelsListVC) + view.addSubview(tunnelsListView) + view.addSubview(tunnelDetailView) + + tunnelsListView.translatesAutoresizingMaskIntoConstraints = false + tunnelDetailView.translatesAutoresizingMaskIntoConstraints = false + + NSLayoutConstraint.activate([ + tunnelsListView.topAnchor.constraint(equalTo: container.topAnchor), + tunnelsListView.bottomAnchor.constraint(equalTo: container.bottomAnchor), + tunnelsListView.leadingAnchor.constraint(equalTo: container.leadingAnchor), + tunnelDetailView.leadingAnchor.constraint(equalTo: tunnelsListView.trailingAnchor, constant: horizontalSpacing), + tunnelDetailView.trailingAnchor.constraint(equalTo: container.trailingAnchor), + tunnelsListView.widthAnchor.constraint(equalTo: container.widthAnchor, multiplier: 0.3) + ]) + } +} diff --git a/WireGuard/WireGuard/UI/macOS/ViewController/TunnelsListTableViewController.swift b/WireGuard/WireGuard/UI/macOS/ViewController/TunnelsListTableViewController.swift new file mode 100644 index 0000000..47658d6 --- /dev/null +++ b/WireGuard/WireGuard/UI/macOS/ViewController/TunnelsListTableViewController.swift @@ -0,0 +1,55 @@ +// SPDX-License-Identifier: MIT +// Copyright © 2018 WireGuard LLC. All Rights Reserved. + +import Cocoa + +class TunnelsListTableViewController: NSViewController { + + let tunnelsManager: TunnelsManager + + let tableView: NSTableView = { + let tableView = NSTableView() + tableView.addTableColumn(NSTableColumn(identifier: NSUserInterfaceItemIdentifier("TunnelsList"))) + tableView.headerView = nil + tableView.rowSizeStyle = .medium + return tableView + }() + + init(tunnelsManager: TunnelsManager) { + self.tunnelsManager = tunnelsManager + super.init(nibName: nil, bundle: nil) + } + + required init?(coder: NSCoder) { + fatalError("init(coder:) has not been implemented") + } + + override func loadView() { + tableView.dataSource = self + tableView.delegate = self + + let scrollView = NSScrollView() + scrollView.hasVerticalScroller = true + scrollView.autohidesScrollers = true + + let clipView = NSClipView() + clipView.documentView = tableView + scrollView.contentView = clipView + + self.view = scrollView + } +} + +extension TunnelsListTableViewController: NSTableViewDataSource { + func numberOfRows(in tableView: NSTableView) -> Int { + return tunnelsManager.numberOfTunnels() + } +} + +extension TunnelsListTableViewController: NSTableViewDelegate { + func tableView(_ tableView: NSTableView, viewFor tableColumn: NSTableColumn?, row: Int) -> NSView? { + let cell: TunnelListCell = tableView.dequeueReusableCell() + cell.tunnel = tunnelsManager.tunnel(at: row) + return cell + } +} -- cgit v1.2.3-59-g8ed1b