From b76c8d01478bcdeb8e0f0c00ca56f577a425674b Mon Sep 17 00:00:00 2001 From: Tulir Asokan Date: Thu, 24 May 2018 23:26:57 +0300 Subject: Add UI preferences and simplify config save/load (ref #43) --- ui/message-view.go | 2 +- ui/ui.go | 8 ++++++++ ui/view-main.go | 27 +++++++++++++++++++++++++++ 3 files changed, 36 insertions(+), 1 deletion(-) (limited to 'ui') diff --git a/ui/message-view.go b/ui/message-view.go index b6b7ee4..de8e412 100644 --- a/ui/message-view.go +++ b/ui/message-view.go @@ -491,7 +491,7 @@ func (view *MessageView) Draw(screen tcell.Screen) { bareMode := view.parent.parent.bareMessages if bareMode { - messageX = 0 + messageX = x } indexOffset := view.getIndexOffset(screen, height, messageX) diff --git a/ui/ui.go b/ui/ui.go index 5e06d16..c8acede 100644 --- a/ui/ui.go +++ b/ui/ui.go @@ -86,6 +86,14 @@ func (ui *GomuksUI) OnLogout() { ui.app.SetFocus(ui.loginView) } +func (ui *GomuksUI) HandleNewPreferences() { + prefs := ui.gmx.Config().Preferences + ui.mainView.bareMessages = prefs.BareMessageView + ui.mainView.hideUserList = prefs.HideUserList + ui.mainView.hideRoomList = prefs.HideRoomList + ui.Render() +} + func (ui *GomuksUI) SetView(name View) { ui.views.SwitchToPage(string(name)) } diff --git a/ui/view-main.go b/ui/view-main.go index fd9d606..9f4f247 100644 --- a/ui/view-main.go +++ b/ui/view-main.go @@ -57,6 +57,7 @@ type MainView struct { } func (ui *GomuksUI) NewMainView() tview.Primitive { + prefs := ui.gmx.Config().Preferences mainView := &MainView{ Flex: tview.NewFlex(), roomList: NewRoomList(), @@ -67,6 +68,10 @@ func (ui *GomuksUI) NewMainView() tview.Primitive { gmx: ui.gmx, config: ui.gmx.Config(), parent: ui, + + hideUserList: prefs.HideUserList, + hideRoomList: prefs.HideRoomList, + bareMessages: prefs.BareMessageView, } mainView. @@ -185,6 +190,28 @@ func (view *MainView) HandleCommand(roomView *RoomView, command string, args []s if err == nil { view.RemoveRoom(roomView.Room) } + case "/uitoggle": + if len(args) == 0 { + roomView.AddServiceMessage("Usage: /uitoggle ") + break + } + switch args[0] { + case "rooms": + view.hideRoomList = !view.hideRoomList + view.config.Preferences.HideRoomList = view.hideRoomList + case "users": + view.hideUserList = !view.hideUserList + view.config.Preferences.HideUserList = view.hideUserList + case "baremessages": + view.bareMessages = !view.bareMessages + view.config.Preferences.BareMessageView = view.bareMessages + default: + roomView.AddServiceMessage("Usage: /uitoggle ") + return + } + view.parent.Render() + view.parent.Render() + go view.matrix.SendPreferencesToMatrix() case "/join": if len(args) == 0 { roomView.AddServiceMessage("Usage: /join ") -- cgit v1.2.3