mirror of
https://github.com/wizbright/waybox.git
synced 2025-10-29 05:40:20 -04:00
Simple rofi menu
This commit is contained in:
parent
35b3e5af11
commit
c9b187afc8
6 changed files with 72 additions and 0 deletions
44
data/menu
Normal file
44
data/menu
Normal file
|
|
@ -0,0 +1,44 @@
|
|||
#!/bin/env python
|
||||
|
||||
import os, subprocess, sys
|
||||
import xml.dom.minidom as dom
|
||||
|
||||
def get_waybox_pid(name='waybox'):
|
||||
lines = subprocess.Popen(['pgrep', '-x', name], stdout=subprocess.PIPE).stdout.read().splitlines()
|
||||
if lines:
|
||||
return int(lines[0])
|
||||
else:
|
||||
return 0
|
||||
|
||||
def get_menu_items(menu, indent):
|
||||
print("%s⇢ %s\0nonselectable\x1ftrue\x1ficon\x1fgo-next-symbolic" % (indent, menu.getAttribute('label').replace('_', '') or menu.getAttribute('id')))
|
||||
indent = indent + " "
|
||||
children = menu.childNodes
|
||||
for i in range(0, children.length):
|
||||
if children[i].nodeType == dom.Node.ELEMENT_NODE and children[i].tagName == 'item':
|
||||
action = children[i].getElementsByTagName('action')[0].getAttribute('name')
|
||||
cmd = ""
|
||||
icon = children[i].getAttribute('icon')
|
||||
label = children[i].getAttribute('label').replace('_', '')
|
||||
if action == 'Execute':
|
||||
cmd = children[i].getElementsByTagName('execute')[0].firstChild.nodeValue
|
||||
elif action == 'Exit':
|
||||
cmd = "kill -s SIGTERM %d" % get_waybox_pid()
|
||||
elif action == 'Reconfigure':
|
||||
cmd = "kill -s SIGUSR2 %d" % get_waybox_pid()
|
||||
print("%s %s\0info\x1f%s\x1ficon\x1f%s" % (indent, label, cmd, icon))
|
||||
elif children[i].nodeType == dom.Node.ELEMENT_NODE and children[i].tagName == 'menu':
|
||||
get_menu_items(children[i], indent)
|
||||
|
||||
menu_xml = os.getenv("WB_MENU_XML") or "menu.xml"
|
||||
# If ran as a rofi script (not possible with wofi)
|
||||
if not os.getenv('ROFI_RETV') is None:
|
||||
import shlex
|
||||
print("\0message\x1f%s" % os.path.abspath(menu_xml))
|
||||
if not (info := os.getenv('ROFI_INFO')) is None:
|
||||
subprocess.Popen(shlex.split(info), stdout=subprocess.PIPE)
|
||||
sys.exit(0)
|
||||
|
||||
document = dom.parse(menu_xml)
|
||||
root_menu = document.getElementsByTagName('menu')[0]
|
||||
get_menu_items(root_menu, "")
|
||||
|
|
@ -16,6 +16,7 @@ configure_file(
|
|||
scripts = files(
|
||||
'autostart',
|
||||
'environment',
|
||||
'menu',
|
||||
'xdg-autostart',
|
||||
)
|
||||
|
||||
|
|
|
|||
|
|
@ -69,6 +69,11 @@
|
|||
<execute>grim -g "$(slurp -d)" "$(xdg-user-dir PICTURES)/$(date +'%Y-%m-%d-%H%M%S_grim_sel.png')"</execute>
|
||||
</action>
|
||||
</keybind>
|
||||
<keybind key="A-r">
|
||||
<action name="Execute">
|
||||
<execute>rofi -show menu:$WB_CONF_DIR/menu</execute>
|
||||
</action>
|
||||
</keybind>
|
||||
<keybind key="A-F2">
|
||||
<action name="Execute">
|
||||
<execute>obrun l</execute>
|
||||
|
|
|
|||
|
|
@ -72,6 +72,26 @@ then
|
|||
WB_XDG_AUTOSTART="@libexecdir@/openbox-autostart OPENBOX";
|
||||
fi
|
||||
|
||||
if test -f $WB_USER_CONF_DIR/menu.xml;
|
||||
then
|
||||
WB_MENU_XML=$WB_USER_CONF_DIR/menu.xml
|
||||
elif test -f $WB_SYS_CONF_DIR/menu.xml;
|
||||
then
|
||||
WB_MENU_XML=$WB_SYS_CONF_DIR/menu.xml
|
||||
elif test -f $OB_USER_CONF_DIR/menu.xml;
|
||||
then
|
||||
_ "WARNING: Using files from Openbox. These may not work correctly."
|
||||
WB_MENU_XML=$OB_USER_CONF_DIR/menu.xml
|
||||
elif test -f $OB_SYS_CONF_DIR/menu.xml;
|
||||
then
|
||||
_ "WARNING: Using files from Openbox. These may not work correctly."
|
||||
WB_MENU_XML=$OB_SYS_CONF_DIR/menu.xml;
|
||||
else
|
||||
_ "ERROR: No menu file found." >&2
|
||||
exit 1
|
||||
fi
|
||||
export WB_MENU_XML
|
||||
|
||||
if test -f $WB_USER_CONF_DIR/rc.xml;
|
||||
then
|
||||
WB_RC_XML=$WB_USER_CONF_DIR/rc.xml
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue