From c2d40839465987e9583cb66b2be936b1c3a33de0 Mon Sep 17 00:00:00 2001 From: Alexander Neumann Date: Tue, 2 Apr 2019 18:05:12 +0200 Subject: ui: add initial support for [de]activating tunnels Signed-off-by: Alexander Neumann Signed-off-by: Jason A. Donenfeld --- ui/manage_tunnels.go | 24 +++++++++--------------- 1 file changed, 9 insertions(+), 15 deletions(-) (limited to 'ui/manage_tunnels.go') diff --git a/ui/manage_tunnels.go b/ui/manage_tunnels.go index 4568d394..6ab20873 100644 --- a/ui/manage_tunnels.go +++ b/ui/manage_tunnels.go @@ -61,10 +61,16 @@ func (mtw *ManageTunnelsWindow) setup() error { tunnelsContainer, _ := walk.NewComposite(splitter) tunnelsContainer.SetLayout(walk.NewVBoxLayout()) + splitter.SetFixed(tunnelsContainer, true) + mtw.tunnelsView, _ = NewTunnelsView(tunnelsContainer) mtw.tunnelsView.ItemActivated().Attach(mtw.onEditTunnel) mtw.tunnelsView.CurrentIndexChanged().Attach(mtw.updateConfView) + service.IPCClientRegisterTunnelChange(func(tunnel *service.Tunnel, state service.TunnelState, err error) { + mtw.tunnelsView.Invalidate() + }) + // ToolBar actions { // HACK: Because of https://github.com/lxn/walk/issues/481 @@ -168,19 +174,7 @@ func (mtw *ManageTunnelsWindow) updateConfView() { return } - currentTunnel := mtw.tunnelsView.CurrentTunnel() - if currentTunnel == nil { - // TODO: config must be non-nil right now - // mtw.confView.SetConfiguration(nil) - return - } - - config, err := currentTunnel.RuntimeConfig() - if err != nil { - return - } - - mtw.confView.SetConfiguration(&config) + mtw.confView.SetTunnel(mtw.tunnelsView.CurrentTunnel()) } func (mtw *ManageTunnelsWindow) runTunnelEdit(tunnel *service.Tunnel) *conf.Config { @@ -199,7 +193,7 @@ func (mtw *ManageTunnelsWindow) runTunnelEdit(tunnel *service.Tunnel) *conf.Conf } else { title = "Edit tunnel" name = tunnel.Name - config, _ = tunnel.RuntimeConfig() + config, _ = tunnel.StoredConfig() } dlg, _ := walk.NewDialog(mtw) @@ -416,7 +410,7 @@ func (mtw *ManageTunnelsWindow) addTunnel(config *conf.Config) { } } - mtw.confView.SetConfiguration(config) + mtw.confView.SetTunnel(&tunnel) } func (mtw *ManageTunnelsWindow) deleteTunnel(tunnel *service.Tunnel) { -- cgit v1.2.3-59-g8ed1b