From ff00c45f77ca79cdcf06266b2faefc4a172b10b3 Mon Sep 17 00:00:00 2001 From: erroneousboat Date: Fri, 14 Oct 2016 23:57:34 +0200 Subject: [PATCH 1/2] Start with fixing paste issue --- src/handlers/event.go | 22 +++++++++++++++++++++- 1 file changed, 21 insertions(+), 1 deletion(-) diff --git a/src/handlers/event.go b/src/handlers/event.go index bcbb2ab..0ecff51 100644 --- a/src/handlers/event.go +++ b/src/handlers/event.go @@ -1,6 +1,11 @@ package handlers import ( + "bufio" + "io" + "log" + "os" + "github.com/gizak/termui" "github.com/nlopes/slack" @@ -60,7 +65,7 @@ func anyKeyHandler(ctx *context.AppContext) func(termui.Event) { case "": actionMoveCursorLeft(ctx.View) default: - actionInput(ctx.View, key) + // actionInput(ctx.View, key) } } } @@ -170,6 +175,21 @@ func actionInsertMode(ctx *context.AppContext) { ctx.Mode = context.InsertMode ctx.View.Mode.Par.Text = "INSERT" termui.Render(ctx.View.Mode) + + r := bufio.NewReader(os.Stdin) + for { + if c, _, err := r.ReadRune(); err != nil { + if err == io.EOF { + break + } else { + log.Fatal(err) + } + } else { + log.Fatal(string(c)) + ctx.View.Input.Insert(string(c)) + } + } + } func actionCommandMode(ctx *context.AppContext) { From 965495fb171e1f82e41df155d3765e27d078ff25 Mon Sep 17 00:00:00 2001 From: erroneousboat Date: Sat, 15 Oct 2016 20:55:05 +0200 Subject: [PATCH 2/2] Use termbox PollEvent instead of termui EventHandler Fixes #5 --- src/handlers/event.go | 124 +++++++++++++++++++----------------------- 1 file changed, 55 insertions(+), 69 deletions(-) diff --git a/src/handlers/event.go b/src/handlers/event.go index 0ecff51..19efaa8 100644 --- a/src/handlers/event.go +++ b/src/handlers/event.go @@ -1,74 +1,75 @@ package handlers import ( - "bufio" - "io" - "log" - "os" - "github.com/gizak/termui" "github.com/nlopes/slack" + termbox "github.com/nsf/termbox-go" "github.com/erroneousboat/slack-term/src/context" "github.com/erroneousboat/slack-term/src/views" ) func RegisterEventHandlers(ctx *context.AppContext) { - termui.Handle("/sys/kbd/", anyKeyHandler(ctx)) - termui.Handle("/sys/wnd/resize", resizeHandler(ctx)) + anyKeyHandler(ctx) incomingMessageHandler(ctx) + termui.Handle("/sys/wnd/resize", resizeHandler(ctx)) } -func anyKeyHandler(ctx *context.AppContext) func(termui.Event) { - return func(e termui.Event) { - key := e.Data.(termui.EvtKbd).KeyStr +func anyKeyHandler(ctx *context.AppContext) { + go func() { + for { + ev := termbox.PollEvent() - if ctx.Mode == context.CommandMode { - switch key { - case "q": - actionQuit() - case "j": - actionMoveCursorDownChannels(ctx) - case "k": - actionMoveCursorUpChannels(ctx) - case "i": - actionInsertMode(ctx) - case "": - actionScrollUpChat(ctx) - case "C-b": - actionScrollUpChat(ctx) - case "C-u": - actionScrollUpChat(ctx) - case "": - actionScrollDownChat(ctx) - case "C-f": - actionScrollDownChat(ctx) - case "C-d": - actionScrollDownChat(ctx) - } - } else if ctx.Mode == context.InsertMode { - switch key { - case "": - actionCommandMode(ctx) - case "": - actionSend(ctx) - case "": - actionInput(ctx.View, " ") - case "": - actionBackSpace(ctx.View) - case "C-8": - actionBackSpace(ctx.View) - case "": - actionDelete(ctx.View) - case "": - actionMoveCursorRight(ctx.View) - case "": - actionMoveCursorLeft(ctx.View) - default: - // actionInput(ctx.View, key) + if ev.Type == termbox.EventKey { + if ctx.Mode == context.CommandMode { + switch ev.Key { + case termbox.KeyPgup: + actionScrollUpChat(ctx) + case termbox.KeyCtrlB: + actionScrollUpChat(ctx) + case termbox.KeyCtrlU: + actionScrollUpChat(ctx) + case termbox.KeyPgdn: + actionScrollDownChat(ctx) + case termbox.KeyCtrlF: + actionScrollDownChat(ctx) + case termbox.KeyCtrlD: + actionScrollDownChat(ctx) + default: + switch ev.Ch { + case 'q': + actionQuit() + case 'j': + actionMoveCursorDownChannels(ctx) + case 'k': + actionMoveCursorUpChannels(ctx) + case 'i': + actionInsertMode(ctx) + } + } + } else if ctx.Mode == context.InsertMode { + switch ev.Key { + case termbox.KeyEsc: + actionCommandMode(ctx) + case termbox.KeyEnter: + actionSend(ctx) + case termbox.KeySpace: + actionInput(ctx.View, " ") + case termbox.KeyBackspace, termbox.KeyBackspace2: + actionBackSpace(ctx.View) + case termbox.KeyDelete: + actionDelete(ctx.View) + case termbox.KeyArrowRight: + actionMoveCursorRight(ctx.View) + case termbox.KeyArrowLeft: + actionMoveCursorLeft(ctx.View) + default: + actionInput(ctx.View, string(ev.Ch)) + } + } } } - } + }() } func resizeHandler(ctx *context.AppContext) func(termui.Event) { @@ -175,21 +176,6 @@ func actionInsertMode(ctx *context.AppContext) { ctx.Mode = context.InsertMode ctx.View.Mode.Par.Text = "INSERT" termui.Render(ctx.View.Mode) - - r := bufio.NewReader(os.Stdin) - for { - if c, _, err := r.ReadRune(); err != nil { - if err == io.EOF { - break - } else { - log.Fatal(err) - } - } else { - log.Fatal(string(c)) - ctx.View.Input.Insert(string(c)) - } - } - } func actionCommandMode(ctx *context.AppContext) {