Difference between revisions of "AwesomeWM"

From Things and Stuff Wiki
Jump to navigation Jump to search
 
(19 intermediate revisions by the same user not shown)
Line 28: Line 28:
  
  
==== Scripts ====
+
== Scripts ==
  
 
* https://github.com/lcpz/lain - Layouts, widgets and utilities for Awesome WM 4.x
 
* https://github.com/lcpz/lain - Layouts, widgets and utilities for Awesome WM 4.x
Line 49: Line 49:
  
 
* https://github.com/intrntbrn/icon_customizer - awesomewm icon_customizer: set custom icons for gui and terminal applications  
 
* https://github.com/intrntbrn/icon_customizer - awesomewm icon_customizer: set custom icons for gui and terminal applications  
 +
 +
 +
* https://gist.github.com/intrntbrn/08af1058d887f4d10a464c6f272ceafa - a taglist that contains a tasklist for each tag
 +
  
  
Line 57: Line 61:
 
* https://bitbucket.org/grumph/home_config/src/master/.config/awesome/helpers/click_to_hide.lua [https://www.reddit.com/r/awesomewm/comments/o049bd/how_to_close_awesome_menu_with_left_click/]
 
* https://bitbucket.org/grumph/home_config/src/master/.config/awesome/helpers/click_to_hide.lua [https://www.reddit.com/r/awesomewm/comments/o049bd/how_to_close_awesome_menu_with_left_click/]
  
==== Hotkeys ====
+
 
 +
* [https://www.reddit.com/r/awesomewm/comments/mmt4ms/colour_cycling_active_window_border_snippet/ Colour cycling active window border snippet : awesomewm] - an animated border to help give me an ambient awareness via my peripheral vision of where the window focus was (registering motion is easier than static colours or textures
 +
 
 +
== Hotkeys ==
 
* https://awesomewm.org/apidoc/input_handling/awful.key.html
 
* https://awesomewm.org/apidoc/input_handling/awful.key.html
  
Line 82: Line 89:
  
  
==== Multihead ====
+
== Multihead ==
 
* http://awesome.naquadah.org/wiki/Using_Multiple_Screens
 
* http://awesome.naquadah.org/wiki/Using_Multiple_Screens
  
  
==== Freedesktop menu ====
+
== Freedesktop menu ==
 
* https://github.com/terceiro/awesome-freedesktop
 
* https://github.com/terceiro/awesome-freedesktop
  
==== Windows ====
+
== Windows ==
  
 
* https://github.com/awesomeWM/awesome/issues/2092#issuecomment-462029778 - make rofi possible to raise minimized clients
 
* https://github.com/awesomeWM/awesome/issues/2092#issuecomment-462029778 - make rofi possible to raise minimized clients
  
==== Notifications ====
+
 
 +
* [https://bbs.archlinux.org/viewtopic.php?pid=838153#p838153 Awesome WM / Minimized windows / Applications & Desktop Environments / Arch Linux Forums]
 +
 
 +
 
 +
 
 +
awful.key({ modkey, "Shift"  }, "y", awful.placement.centered),
 +
 
 +
== Notifications ==
 
* [https://awesomewm.org/doc/api/libraries/naughty.html Module naughty - awesome API documentation]
 
* [https://awesomewm.org/doc/api/libraries/naughty.html Module naughty - awesome API documentation]
  
  
==== Tags ====
+
== Tags ==
  
 
* https://github.com/bioe007/awesome-shifty - an Awesome 3 extension that implements dynamic tagging.
 
* https://github.com/bioe007/awesome-shifty - an Awesome 3 extension that implements dynamic tagging.
Line 125: Line 139:
 
* [https://stackoverflow.com/questions/59496736/cycle-between-minimized-windows-while-preserving-position awesome wm - Cycle between minimized windows while preserving position - Stack Overflow]
 
* [https://stackoverflow.com/questions/59496736/cycle-between-minimized-windows-while-preserving-position awesome wm - Cycle between minimized windows while preserving position - Stack Overflow]
  
==== Layouts ====
+
 
 +
 
 +
* https://gist.github.com/intrntbrn/08af1058d887f4d10a464c6f272ceafa - a taglist that contains a tasklist for each tag.
 +
 
 +
 
 +
* [https://awesomewm.org/recipes/awesome-taglist/ awesome-taglist - awesome window manager] - 'awesome' or 'awesomewm' (if you want to keep 9 tags) in the taglist using characters from the Awesome logo.
 +
 
 +
 
 +
* https://github.com/lmanul/awesome-workspace-grid
 +
 
 +
== Layouts ==
 
* https://elv13.github.io/client_tiling/dynamite.html -A drop-in replacment for the stateless layout suitsThis system also add the possibility to write handlers enabling the use of tabs, spliters or custom client decorator.
 
* https://elv13.github.io/client_tiling/dynamite.html -A drop-in replacment for the stateless layout suitsThis system also add the possibility to write handlers enabling the use of tabs, spliters or custom client decorator.
  
Line 172: Line 196:
 
* https://github.com/lmanul/awesome-workspace-grid
 
* https://github.com/lmanul/awesome-workspace-grid
  
==== Wibox ====
+
== Wibox ==
 
* comp.window-managers.awesome: [http://comments.gmane.org/gmane.comp.window-managers.awesome/5460 Re: Multiple row wibox]
 
* comp.window-managers.awesome: [http://comments.gmane.org/gmane.comp.window-managers.awesome/5460 Re: Multiple row wibox]
  
Line 179: Line 203:
  
  
==== Widgets ====
+
== Widgets ==
 
* http://awesome.naquadah.org/wiki/Awesome_3.3_to_3.4#Widget_Layouts
 
* http://awesome.naquadah.org/wiki/Awesome_3.3_to_3.4#Widget_Layouts
 +
 +
* [https://www.reddit.com/r/awesomewm/comments/10fls8m/how_to_make_tag_boxes_wider/ How to make tag boxes wider? : awesomewm]
 +
 +
 +
 +
* https://github.com/streetturtle/awesome-buttons - Button widget library for Awesome Window Manager
 +
  
  
Line 199: Line 230:
 
* https://github.com/deficient/keyboard-layout-indicator - Keyboard layout indicator/switcher widget for awesome-wm  
 
* https://github.com/deficient/keyboard-layout-indicator - Keyboard layout indicator/switcher widget for awesome-wm  
  
* https://github.com/deficient/quicklaunch -Simple quicklaunchbar widget.
+
 
  
 
* https://github.com/deficient/cpuinfo
 
* https://github.com/deficient/cpuinfo
 +
  
 
* https://github.com/deficient/calendar - Calendar popup for awesome WM  
 
* https://github.com/deficient/calendar - Calendar popup for awesome WM  
Line 208: Line 240:
 
* https://github.com/daskol/awesome-pulseaudio-widget - Awesome WM text widget to display volume which leverages D-Bus PulseAudio interface.  
 
* https://github.com/daskol/awesome-pulseaudio-widget - Awesome WM text widget to display volume which leverages D-Bus PulseAudio interface.  
  
 
+
* https://github.com/deficient/volume-control - Volume indicator+control widget for awesome window manager.
 
 
* https://github.com/berlam/awesome-upower-battery
 
 
 
* https://github.com/deficient/battery-widget - Battery status indicator for awesome WM
 
  
  
Line 225: Line 253:
  
  
* https://github.com/streetturtle/awesome-buttons - Button widget library for Awesome Window Manager
 
  
  
* https://github.com/sgnix/awesome-dmenu -native dmenu widget
+
 
 +
* https://github.com/sgnix/awesome-dmenu - native dmenu widget
  
  
Line 235: Line 263:
  
  
===== Media =====
+
 
 +
* https://github.com/intrntbrn/icon_customizer - set custom icons for gui and terminal applications in awesomewm
 +
 
 +
 
 +
=== Battery/power ===
 +
* https://github.com/berlam/awesome-upower-battery
 +
 
 +
 
 +
* https://github.com/deficient/battery-widget -  Battery status indicator for awesome WM
 +
 
 +
 
 +
* https://github.com/stefano-m/awesome-power_widget - This widget uses the upower_dbus library.
 +
 
 +
 
 +
=== Launcher ===
 +
* https://github.com/nwdamgaard/awesomewm-app-drawer - A minimal .desktop launcher for Awesome Window Manager
 +
 
 +
* https://github.com/deficient/quicklaunch - Simple quicklaunchbar widget.
 +
 
 +
 
 +
=== Media ===
 
* http://awesome.naquadah.org/wiki/Awesompd_widget
 
* http://awesome.naquadah.org/wiki/Awesompd_widget
  
Line 246: Line 294:
 
* https://github.com/Stebalien/awesomewm-config/blob/master/music.lua
 
* https://github.com/Stebalien/awesomewm-config/blob/master/music.lua
  
==== Hints ====
+
== Hints ==
 
* https://github.com/zackpete/hints - Window picker with hints for Awesome
 
* https://github.com/zackpete/hints - Window picker with hints for Awesome
  
  
==== Revelation ====
+
== Revelation ==
 
* http://awesome.naquadah.org/wiki/Revelation - Expose-like client selection.
 
* http://awesome.naquadah.org/wiki/Revelation - Expose-like client selection.
 
** https://github.com/guotsuan/awesome-revelation
 
** https://github.com/guotsuan/awesome-revelation
  
  
==== Radical ====
+
== Radical ==
 
* https://github.com/Elv13/radical - large Awesome extension module, provides a unified interface to generate multiple types of menus.
 
* https://github.com/Elv13/radical - large Awesome extension module, provides a unified interface to generate multiple types of menus.
  
  
  
==== Text format ====
+
== Text format ==
 
You can use [http://developer.gnome.org/pango/stable/PangoMarkupFormat.html Pango] markup in a text string. This allows formatting the text rendered inside widgets. Pango markup documentation can be found in the Pango documentation at http://library.gnome.org/devel/pango/stable/PangoMarkupFormat.html.
 
You can use [http://developer.gnome.org/pango/stable/PangoMarkupFormat.html Pango] markup in a text string. This allows formatting the text rendered inside widgets. Pango markup documentation can be found in the Pango documentation at http://library.gnome.org/devel/pango/stable/PangoMarkupFormat.html.
  
 
A Pango markup example: <span weight="bold" foreground="#336699">…</span>.
 
A Pango markup example: <span weight="bold" foreground="#336699">…</span>.
  
=== Helpers ===
+
== Helpers ==
  
 
* https://github.com/jechasteen/gratuitous - an IDE for awesome window manager configs and themes. The name is a play on the adjective names of the awesome libs (awful, beautiful, vicious)
 
* https://github.com/jechasteen/gratuitous - an IDE for awesome window manager configs and themes. The name is a play on the adjective names of the awesome libs (awful, beautiful, vicious)
Line 287: Line 335:
  
  
* https://github.com/Elv13/collision - A window management module for AwesomeWM
+
* https://github.com/Elv13/collision - This module add some visual indicators for common window management operations. It is now easier to know the impact of a given command as a visual queue will be printed on the screen. Collision has 3 modes: Focus: Move the focus from client to client; Move: Move a client; Resize: Change a client dimensions; Tag: Move to the previous/next tag
  
  
Line 300: Line 348:
  
 
* https://github.com/berlam/awesome-switcher - Switch clients in Awesome WM with the familiar preview functionality  
 
* https://github.com/berlam/awesome-switcher - Switch clients in Awesome WM with the familiar preview functionality  
 +
** https://github.com/grenzionky/awesome-switcher - works across all tabs
 +
** https://github.com/wyv3rn/awesome-switcher-macstyle - Switch clients in Awesome WM with the familiar preview functionality known from e.g. Mac OS X
 +
  
  
Line 317: Line 368:
  
  
==== Scratchpad ====
+
* https://github.com/osleg/Re-rodentbane - Reincarnation of rodentbane - awesomeWM mouse-less navigation
 +
 
 +
== Scratchpad ==
 
* https://github.com/notnew/awesome-scratch - used to show and hide scratch windows. It takes a shell command to launch the scratch window and a rule to match the scratch window.
 
* https://github.com/notnew/awesome-scratch - used to show and hide scratch windows. It takes a shell command to launch the scratch window and a rule to match the scratch window.
  
 
* [https://blingcorp.github.io/bling/#/module/scratch Scratchpad] - An easy way to create multiple scratchpads.
 
* [https://blingcorp.github.io/bling/#/module/scratch Scratchpad] - An easy way to create multiple scratchpads.
  
=== Themes and configs ===
+
== Themes and configs ==
 
The color format in awesome is either a standard X color name (blue, darkblue, lightred, etc) or a hexadecimal formatted color (#rrggbb or #rrggbbaa). By using the hexadecimal format, you can also specify an alpha channel: that means that #00ff00 will draw pure green, but #00ff00aa will set the alpha channel to ‘aa’ and will blend the green with the color under it.
 
The color format in awesome is either a standard X color name (blue, darkblue, lightred, etc) or a hexadecimal formatted color (#rrggbb or #rrggbbaa). By using the hexadecimal format, you can also specify an alpha channel: that means that #00ff00 will draw pure green, but #00ff00aa will set the alpha channel to ‘aa’ and will blend the green with the color under it.
  

Latest revision as of 22:16, 4 February 2024

General

  • awesome - a highly configurable, next generation framework window manager for X. It is very fast, extensible and licensed under the GNU GPLv2 license.It is primarily targeted at power users, developers and any people dealing with every day computing tasks and who want to have fine-grained control on their graphical environment.






To debug rc.lua changes:

Xephyr :1 -ac -br -noreset -screen 1152x720 &
DISPLAY=:1.0 awesome -c ~/.config/awesome/rc.lua.new


Scripts


  • https://github.com/montagdude/awesome-appmenu - a tool to create a menu of installed applications for the awesome window manager. It searches for and parses .desktop files to find the name, execution command, and icon of installed applications. These are then grouped into categories, sorted, and written to a lua script ($HOME/.config/awesome/appmenu.lua) that can be used in your awesome WM configuration script.










Hotkeys





  • https://github.com/jcrd/awesome-ez -a library for Awesome window manager that aims to simplify the creation of key and button bindings. It is based on code from the old Awesome wiki.





Multihead


Freedesktop menu

Windows



awful.key({ modkey, "Shift"   }, "y", awful.placement.centered),

Notifications


Tags











Layouts












  • https://github.com/notnew/awesome-frames - Divides the workarea into 3 frames, which are like emacs windows. Each frame may be associated with a client window to show in the frame. Functions are provided to switch between frames and to pull windows unassociated windows into the current frame.This is similar (though less flexible than) the layout used by stumpwm or emacs' windows and buffers.




Wibox



Widgets












  • https://github.com/pltanton/net_widgets -If you use netctl or another network manager which doesn't provide any good tray icon or if you want something more native than nm-applet, this is for you.







Battery/power




Launcher


Media

Hints


Revelation


Radical


Text format

You can use Pango markup in a text string. This allows formatting the text rendered inside widgets. Pango markup documentation can be found in the Pango documentation at http://library.gnome.org/devel/pango/stable/PangoMarkupFormat.html.

A Pango markup example: .

Helpers






  • :carrot: - Carrot awesomeWM personalization application


  • https://github.com/Elv13/collision - This module add some visual indicators for common window management operations. It is now easier to know the impact of a given command as a visual queue will be printed on the screen. Collision has 3 modes: Focus: Move the focus from client to client; Move: Move a client; Resize: Change a client dimensions; Tag: Move to the previous/next tag






  • https://github.com/grandchild/autohidewibox -Auto-hide the awesome-wibox/taskbarIf you ever wanted to squeeze out that last bit of screen real estate in awesome and only show the wibox when needed (i.e when pressing the ModKey), this is for you.Since awesome doesn't allow easy access to the states of the Super/Mod-Key itself in rc.lua, one cannot simply show the wibox while the ModKey is pressed and hide it again on release. This little python daemon will sit in the background and do just that.


  • https://github.com/vladimir-g/awpwkb -a simple per-window keyboard layout switcher for Awesome WM.It uses awesome XKB functions, so awesome 4 is required. Layouts stored in X property awpwkb_layout and they are persistent between awesome restarts.





Scratchpad

  • Scratchpad - An easy way to create multiple scratchpads.

Themes and configs

The color format in awesome is either a standard X color name (blue, darkblue, lightred, etc) or a hexadecimal formatted color (#rrggbb or #rrggbbaa). By using the hexadecimal format, you can also specify an alpha channel: that means that #00ff00 will draw pure green, but #00ff00aa will set the alpha channel to ‘aa’ and will blend the green with the color under it.


If xdg/awesome default config loads instead of .config/awesome, this is due to error in the rc.lua.




  • https://github.com/Kasper24/KwesomeDE - the most powerful and highly configurable, next generation framework window manager for X, Although it takes time and effort to configure it, but I'm very satisfied with the result.