radical/README.md

311 lines
17 KiB
Markdown

# Radical menu system for AwesomeWM
=======================================
This is Radical, one of the largest Awesome extension module. It provide un
unified interface to generate multiple types of menus.
[![Too many menus](https://raw.github.com/Elv13/radical/master/screenshot/all.png)](https://raw.github.com/Elv13/radical/master/screenshot/all.png)
## Installation
Installing Radical is simple, just move to ~/.config/awesome and clone the
repository
```sh
cd ~/.config/awesome
git clone https://github.com/Elv13/radical.git
```
The require it at the top of your rc.lua:
```lua
local radical = require("radical")
```
## Usage
Unlike awful.menu, radical act like other Awesome 3.5 layouts. You need to add
items one by one. This have the benefit of letting you interact with the items
themselves programatically.
The most simple kind of menus, contexts one, can be created like this:
```lua
local menu = radical.context{}
menu:add_item {text="Screen 1",button1=function(_menu,item,mods) print("Hello World! ") end}
menu:add_item {text="Screen 9",icon=beautiful.path.."Icon/layouts/tileleft.png"}
menu:add_item {text="Sub Menu",sub_menu = function()
local smenu = radical.context{}
smenu:add_item{text="item 1"}
smenu:add_item{text="item 2"}
return smenu
end}
-- To add the menu to a widget:
local mytextbox = wibox.widget.textbox()
mytextbox:set_menu(menu,3) -- 3 = right mouse button, 1 = left mouse button
-- To add a key binding on a "box" menu (and every other types)
menu:add_key_binding({"Mod4"},",")
```
In this example, a simple 3 item menu is created with a dynamically generated
submenu. Please note that generating submenus using function will generate it
every time it is being shown. For static menus, it is faster to simply create
them once and passing the submenu object to the "sub_menu" item property.
`:set_menu` can also take a lazy-loading function instead of a
menu. The second parameter is not mandatory, the default is `1`.
`:add_key_binding` will add a key binding. It can also take a function as 3rd
parameter. However, it wont correctly place "context" menu as it have no idea
where you expect them. It work better with "box" menus.
### Menu types
The current valid types are:
* **Context:** Regular context menu
* **Box:** Centered menus (think Windows alt-tab menu)
* **Embed:** Menus in menus. This can be used as subsections in large menus
### Menu style
Each menus come in various styles for various applications. New style can also
be created by beautiful themes. The current ones are:
* **Arrow:** Gnome3 and Mac OSX like menus with border radius and an arrow
* **Classic:** Replicate awful.menu look
Arrow also have a few types:
* radical.base.arrow_type.NONE
* radical.base.arrow_type.PRETTY
* radical.base.arrow_type.CENTERED
### Item style
Like menus, items can have their own style. Valid values:
* **Basic:** The most simple kind of items, no borders or special shape
* **Classic:** 1px border at the end of each items
* **Rounded:** A 3px border radius at each corner
### Menu layouts
On top of each styles, menu can also have different layouts to display items:
* **Vertical:** Items are displayed on top of each other
* **Horizontal:** Items are displayed alongside each other
* **Grid:** Items are displayed as a 2D array
### Item layout
Item layouts are how widgets (icons, label, prefix) are disposed in the item
* **horizontal:** Default layout used by the context style
* **icon:** Look like a desktop icon, used by horizontal menus
* **centerred:** Align widgets at the center instead of using all space
### Using styles and layouts
```lua
local radical = require("radical")
local m = radical.context {
style = radical.style.classic ,
item_style = radical.item_style.classic ,
layout = radical.layout.vertical }
```
### Tooltip
Radical also have its own styled tooltip widget. It can be used in menus, but
also in every widgets using the `set_tooltip` method:
```lua
local mytextbox = wibox.widget.textbox()
mytextbox:set_tooltip("foo bar")
```
## Options
Radical offer a (very, very) wide range of options to allow the creation of rich
and novel menus. The options are available in 2 formats: menu wide and item
specific. Menu wide options will take effect on all items and on the way the
menu itself is being displayed while items ones apply only to a specific item.
Multiple items can have multiple sets of options.
### Menu options
| Name | Description | Type |
| ------------------- | -------------------------------------------------- | ----------------------------- |
| bg | Background color | String/gradient/pattern |
| fg | Foreground (text) color | String/gradient/pattern |
| bg_focus | Background of focussed items | String/gradient/pattern |
| fg_focus | Foreground of focussed items | String/gradient/pattern |
| bg_hover | Background of hoverred items | String/gradient/pattern |
| fg_hover | Foreground of hoverred items | String/gradient/pattern |
| bg_alternate | Alternate background color | String/gradient/pattern |
| bg_highlight | Highlight background color | String/gradient/pattern |
| bg_header | Header (see widgets section) color | String/gradient/pattern |
| bg_prefix | Prefix background for item_styles that support it | String/gradient/pattern |
| border_color | Border color | String/gradient/pattern |
| border_width | Border width | number |
| item_height | Default height of items | number |
| item_width | Default width of items | number |
| width | Original width | number |
| default_width | Default menu width | number |
| icon_size | Icon size | number |
| auto_resize | Resize menu if items are too large | boolean |
| parent_geometry | Set the menu parent | geometry array |
| arrow_type | Set the arrow type when use arrow style | see "arrow_type" enum |
| visible | Show or hide the menu | boolean |
| direction | The direction from which the arrow will point | "left","right","top","bottom" |
| row | Number of row (in grid layout) | number |
| column | Number of columns (in grid layout) | number |
| layout | The menu layout (default:vertical) | see "Menu layouts" section |
| style | The menu style (default:arrow) | see "Menu style" |
| item_style | The item style (default:basic) | see "Item style" |
| filter | Filter the menu when the user type | boolean |
| show_filter | Show a filter widget at the bottom | boolean |
| filter_string | Default filter string | string |
| fkeys_prefix | Display F1-F12 indicators for easy navigation | boolean |
| underlay_alpha | Underlay (see item options) opacity | 0-1 |
| filter_prefix | Text to be shown at begenning of the filter string | string |
| max_items | Maximum number of items before showing scrollbar | number |
| enable_keyboard | Enable or disable keyboard navigation / hooks | boolean |
| disable_markup | Disable pango markup in items text | boolean |
| x | X position (absolute) | number |
| y | Y position (absolute) | number |
| sub_menu_on | Show submenu on selection or when clicking | see "event" enum |
| select_on | The event used to trigger item selection | see "event" enum |
| overlay | A layer on top of the item | function(data,item,cr,w,h) |
| opacity | Make this menu translucent (require a compositor) | number (0 to 1) |
| icon_transformation | Hijack the icon drawing function | function(icon,data,item) |
###Item options
| Name | Description | Type |
| -------------- | -------------------------------------------- | ----------------- |
| text | The item text | string |
| height | The item height | number |
| icon | The item icon | string or pattern |
| bg | See menu options | see menu options |
| fg | See menu options | see menu options |
| fg_focus | See menu options | see menu options |
| bg_focus | See menu options | see menu options |
| sub_menu | Add a submenu to this item | menu or function |
| selected | Select this item | boolean |
| checkable | Is the item dual state (a checkbox) | boolean |
| checked | Is the item checked or not | boolean |
| underlay | Text to render at the far-right of the item | [array of] string |
| prefix_widget | Widget to append at the begenning of the item| widget |
| suffix_widget | Widget to append at the end of the item | widget |
| item_style | Custom item_style for this item | item_style |
| item_layout | Custom item_layout for this item | item_layout |
| tooltip | A tooltip shown on the side or bottom | string |
| button1 | Left mouse button action | function |
| button2 | Mid mouse button action | function |
| button3 | Right mouse button action | function |
| button4 | Scroll up action | function |
| button5 | Scroll down action | function |
| overlay | See menu.overlay | function |
###Common methods
All menus provide a bunch of methods. Most of them have been coverred above, but
here is the list:
| Name | Description | Arguments | Return |
| ---------------- | -------------------------------------------- | --------------------- | ------ |
| add_item | Add new item to a menu | array of options | item |
| add_widget | Add a new widget instead of an item | a widget, args | --- |
| add_embeded_menu | Add an inline menu to another menu | an "embed" menu | --- |
| add_key_binding | Add a global key binding to a menu | mod array, key | --- |
| add_key_hook | Add a callback when a key is pressed | mod, key, event, func | --- |
| clear | Remove all items | --- | --- |
| scroll_down | If the menu is cropped, scroll down | --- | --- |
| scroll_up | If the menu is cropped, scroll up | --- | --- |
| swap | Swap 2 items | both items | --- |
| move | Move an item | the item, the new idx | --- |
| remove | Remove the item | the item | --- |
| append | Append an existing (but unused) item | the item | --- |
###Signals
Menu also emit many signals, the syntax is usually `PROPERTY_NAME::changed`.
Some others are `item::moved`, `item::swapped`, `item::removed`, `item::appended`
Here is an example of how to catch an "opacity" change:
```lua
mymenu:connect_signal("opacity::changed",function(value)
-- Do something
end)
```
Most item_layout also repackage the default widget signals. It usually does the
same as using the `buttonX` menu attributes, but is preferrable in some scenarios
like when a modifier is applied.
| Name | Description | Arguments |
| ----------------- | ----------------------------- | ------------------------ |
| button::press | A button press | menu,item,button_id,mods |
| button::release | A button release | menu,item,button_id,mods |
| mouse::enter | When the mouse enter | menu,item |
| mouse::leave | When the mouse leave | menu,item |
`mods` is an array with the applied modifier as **key**. If the value is `nil`,
then the modifier is not present. Usual modifiers are `Control`, `Shift`, `mod1`
(Alt) and `mod4`.
An example of how to use them:
```lua
local menubar = radical.bar{}
menubar:connect_signal("button::press",function(data,item,button,mods)
if mods.Control then
print("Foo menu pressed!",item.text,button,data.rowcount)
end
end)
-- Also work on items
menubar:add_item{text="bar"}:connect_signal("button::release",function(d,i,b,m)
print("bar click released!")
end)
```
###Beautiful options
Radical also use the some of the same theme options as awful.menu, plus some:
| Name | Description | Type |
| ---------------------------- | ------------------------------------- | ------------------------- |
| menu_height | Menu height | String/Gradient/Pattern |
| menu_width | Menu default/minimum width | Number |
| menu_border_width | Border width | Number |
| menu_border_color | Border color | String/Gradient/Pattern |
| menu_fg_normal | Text/Foreground color | String/Gradient/Pattern |
| menu_bg_focus | Selected item color | String/Gradient/Pattern |
| menu_bg_header | Header widget background color | String/Gradient/Pattern |
| menu_bg_alternate | Scrollbar and other widget color | String/Gradient/Pattern |
| menu_bg_normal | Default background | String/Gradient/Pattern |
| menu_bg_highlight | Highlighted item background | String/Gradient/Pattern |
| menu_submenu_icon | Sub menu pixmap (aka >) | Path/Pattern |
| menu_separator_color | Menu separator color | String/Gradient/Pattern |
| menu_opacity | Use your favorite compositor | Number (0=0%, 1=100%) |
| menu_draw_underlay | Function returning the underlay pixmap | function(array,width) |
| menu_icon_transformation | The function used to draw the icon | function(image,data,item) |
Styling can also be done using the icon_transformation option. This feature
allow masks such as desaturation, tinting, invert or some matrix to be applied
on the pixmap before it is being drawn. This function take the path/surface as
only parameter and return the transformed surface.