[bug 706] 706-Favorites-Bookmarks-Plugin #706

- the dialog window taking command for bookmark via shortcut keybinding will have focus on OK Button for faster interaction
- fixed a transient window issue for loading pref window via shortcut and context menu
- filed new command text area  was getting filled with last command
- fixed list store init
This commit is contained in:
Vishweshwar Saran Singh Deo 2023-10-17 01:11:21 +05:30
parent 86337ad326
commit a5ddcbe255

View File

@ -160,6 +160,7 @@ class CustomCommandsMenu(plugin.MenuItem):
if act == PluginActAdd: if act == PluginActAdd:
dbg("add bookmark") dbg("add bookmark")
self.setup_store()
dialog_vars = self.get_last_exe_cmd_dialog_vars() dialog_vars = self.get_last_exe_cmd_dialog_vars()
self.on_new(None, {'dialog_vars' : dialog_vars }) self.on_new(None, {'dialog_vars' : dialog_vars })
self.update_cmd_list(self.store) self.update_cmd_list(self.store)
@ -167,13 +168,13 @@ class CustomCommandsMenu(plugin.MenuItem):
return True return True
if act == PluginActBmk: if act == PluginActBmk:
dbg("open bookmark preferences") dbg("open custom command preferences")
cur_win = Terminator().last_focused_term.get_toplevel() self.configure(None)
self.configure(cur_win)
return True return True
def callback(self, menuitems, menu, terminal): def callback(self, menuitems, menu, terminal):
"""Add our menu items to the menu""" """Add our menu items to the menu"""
submenus = {} submenus = {}
item = Gtk.MenuItem.new_with_mnemonic(_('_Custom Commands')) item = Gtk.MenuItem.new_with_mnemonic(_('_Custom Commands'))
@ -270,6 +271,7 @@ class CustomCommandsMenu(plugin.MenuItem):
_("_OK"), Gtk.ResponseType.ACCEPT _("_OK"), Gtk.ResponseType.ACCEPT
) )
) )
if widget:
dbox.set_transient_for(widget.get_toplevel()) dbox.set_transient_for(widget.get_toplevel())
icon_theme = Gtk.IconTheme.get_default() icon_theme = Gtk.IconTheme.get_default()
@ -356,8 +358,7 @@ class CustomCommandsMenu(plugin.MenuItem):
button = Gtk.Button(_("Bookmark Last Cmd")) button = Gtk.Button(_("Bookmark Last Cmd"))
button_box.pack_start(button, False, True, 0) button_box.pack_start(button, False, True, 0)
ui['dialog_vars'] = self.get_last_exe_cmd_dialog_vars() button.connect("clicked", self.on_last_exe_cmd, ui)
button.connect("clicked", self.on_new, ui)
ui['button_save_last_cmd'] = button ui['button_save_last_cmd'] = button
hbox.pack_start(button_box, False, True, 0) hbox.pack_start(button_box, False, True, 0)
@ -424,8 +425,16 @@ class CustomCommandsMenu(plugin.MenuItem):
_("_OK"), Gtk.ResponseType.ACCEPT _("_OK"), Gtk.ResponseType.ACCEPT
) )
) )
#since we call this via shortcut keybinding
#lets focus on OK button
buttonbox = dialog.get_action_area()
buttons = buttonbox.get_children()
dialog.set_focus(buttons[1])
# dbox is init in configure function, in case we want to # dbox is init in configure function, in case we want to
# create dialog directly # create dialog directly
if self.dbox: if self.dbox:
dialog.set_transient_for(self.dbox) dialog.set_transient_for(self.dbox)
@ -463,6 +472,11 @@ class CustomCommandsMenu(plugin.MenuItem):
dialog.show_all() dialog.show_all()
return (dialog,enabled,name,name_parse,command) return (dialog,enabled,name,name_parse,command)
def on_last_exe_cmd(self, button, data):
new_data = data.copy()
new_data['dialog_vars'] = self.get_last_exe_cmd_dialog_vars()
self.on_new(button, new_data)
def on_new(self, button, data): def on_new(self, button, data):
#default values can be passed to dialogue window if required #default values can be passed to dialogue window if required