diff options
-rw-r--r-- | src/c_defs.go | 1 | ||||
-rw-r--r-- | src/i_events.go | 44 | ||||
-rw-r--r-- | src/i_ui.go | 30 |
3 files changed, 57 insertions, 18 deletions
diff --git a/src/c_defs.go b/src/c_defs.go index c54232e..6d49da9 100644 --- a/src/c_defs.go +++ b/src/c_defs.go @@ -75,6 +75,7 @@ const ( LOAD_MODE = 2 ERROR_MODE = 3 WELCOME_MODE = 4 + MKDIR_MODE = 5 ) const ( diff --git a/src/i_events.go b/src/i_events.go index 613709b..b543fc6 100644 --- a/src/i_events.go +++ b/src/i_events.go @@ -245,6 +245,18 @@ func i_delete_host(data *HardData) error { return nil } +func i_readline(event *tcell.EventKey, data *HardData) { + if len(data.ui.buff) > 0 && + (event.Key() == tcell.KeyBackspace || + event.Key() == tcell.KeyBackspace2) { + data.ui.buff = data.ui.buff[:len(data.ui.buff) - 1] + } else if event.Key() == tcell.KeyCtrlU { + data.ui.buff = "" + } else if event.Rune() >= 32 && event.Rune() <= 126 { + data.ui.buff += string(event.Rune()) + } +} + // screen events such as keypresses func i_events(data *HardData) { ui := &data.ui @@ -324,6 +336,9 @@ func i_events(data *HardData) { } else if event.Key() == tcell.KeyCtrlR { event = nil i_reload_data(data) + } else if event.Rune() == 'm' || + event.Key() == tcell.KeyF7 { + data.ui.mode = MKDIR_MODE } i_list_follow_cursor(data.litems, ui) case DELETE_MODE: @@ -365,22 +380,19 @@ func i_events(data *HardData) { data.opts.GPG = "" } } + case MKDIR_MODE: + if event.Key() == tcell.KeyEscape || + event.Key() == tcell.KeyCtrlC { + ui.s.HideCursor() + ui.buff = "" + ui.mode = NORMAL_MODE + } else if event.Key() == tcell.KeyEnter { + ui.s.HideCursor() + ui.buff = "" + ui.mode = NORMAL_MODE + } else { + i_readline(event, data) + } } - } } - -// readline type beat -// if len(data.ui.buff) > 0 && -// (event.Key() == tcell.KeyBackspace || -// event.Key() == tcell.KeyBackspace2) { -// data.ui.buff = data.ui.buff[:len(data.ui.buff) - 1] -// } else if event.Key() == tcell.KeyCtrlU { -// data.ui.buff = "" -// } else if event.Key() == tcell.KeyEnter { -// data.opts.GPG = data.ui.buff -// data.ui.buff = "" -// data.ui.s.HideCursor() -// } else if event.Rune() >= 32 && event.Rune() <= 126 { -// data.ui.buff += string(event.Rune()) -// } diff --git a/src/i_ui.go b/src/i_ui.go index 97921e0..1eccdcc 100644 --- a/src/i_ui.go +++ b/src/i_ui.go @@ -300,8 +300,8 @@ func i_prompt_gpg(ui HardUI, keys [][2]string) { } i_draw_text(ui.s, 1, ui.dim[H] - 1, ui.dim[W] - 1, ui.dim[H] - 1, - ui.style[STYLE_BOT], "gpg: ") - ui.s.ShowCursor(6 + len(ui.buff), ui.dim[H] - 1) + ui.style[STYLE_DEF], "gpg: ") + ui.s.ShowCursor(6, ui.dim[H] - 1) } func i_prompt_confirm_gpg(ui HardUI, opts HardOpts) { @@ -323,6 +323,29 @@ func i_prompt_confirm_gpg(ui HardUI, opts HardOpts) { ui.style[STYLE_DEF], opts.GPG) } +func i_draw_mkdir(ui HardUI, curr *ItemsNode) { + path := "" + if curr != nil { + if curr.is_dir() == true { + path = curr.Dirs.path() + } else { + path = curr.Host.Parent.path() + } + } + path = path[1:] + prompt := "mkdir: " + i_draw_text(ui.s, + 1, ui.dim[H] - 1, ui.dim[W] - 1, ui.dim[H] - 1, + ui.style[STYLE_DEF], prompt) + i_draw_text(ui.s, len(prompt) + 1, + ui.dim[H] - 1, ui.dim[W] - 1, ui.dim[H] - 1, + ui.style[STYLE_DEF], path) + i_draw_text(ui.s, len(prompt) + 1 + len(path), + ui.dim[H] - 1, ui.dim[W] - 1, ui.dim[H] - 1, + ui.style[STYLE_DEF].Bold(true), ui.buff) + ui.s.ShowCursor(len(prompt) + 1 + len(path) + len(ui.buff), ui.dim[H] - 1) +} + func i_draw_zhosts_box(ui HardUI) { i_draw_msg(ui.s, 1, ui.style[STYLE_BOX], ui.dim, " No hosts ") text := "Hosts list empty. Add hosts/folders by pressing (a/m)" @@ -554,6 +577,9 @@ func i_ui(data_dir string) { if data.ui.mode == ERROR_MODE { i_draw_error_msg(data.ui, data.load_err) } + if data.ui.mode == MKDIR_MODE { + i_draw_mkdir(data.ui, data.litems.curr) + } data.ui.s.Show() i_events(&data) } |