rewrite the way clicking on items work
This commit is contained in:
parent
39b166bf17
commit
628ed1dc40
22
libs/mouse.c
22
libs/mouse.c
|
@ -114,13 +114,14 @@ buttonpress(XEvent *e)
|
|||
y += h;
|
||||
|
||||
if (ev->y >= y && ev->y <= (y + h) && ev->x >= x && ev->x <= (x + w / columns)) {
|
||||
|
||||
// TODO: make clickitem a thing
|
||||
if (ev->button != Button1)
|
||||
return;
|
||||
|
||||
for (i = 0; i < LENGTH(buttons); i++) {
|
||||
if (buttons[i].click == clickselitem && buttons[i].button == ev->button && CLEANMASK(buttons[i].mask) == CLEANMASK(ev->state)) {
|
||||
puts(item->text);
|
||||
exit(0);
|
||||
} else if (buttons[i].click == clickitem) {
|
||||
click = clickitem;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
} else if (matches) {
|
||||
|
@ -138,12 +139,15 @@ buttonpress(XEvent *e)
|
|||
x += w;
|
||||
w = MIN(TEXTW(item->text), mw - x - rarrowWidth);
|
||||
if (ev->x >= x && ev->x <= x + w) {
|
||||
// TODO: make clickitem a thing
|
||||
if (ev->button != Button1)
|
||||
return;
|
||||
|
||||
for (i = 0; i < LENGTH(buttons); i++) {
|
||||
if (buttons[i].click == clickselitem && buttons[i].button == ev->button && CLEANMASK(buttons[i].mask) == CLEANMASK(ev->state)) {
|
||||
puts(item->text);
|
||||
exit(0);
|
||||
} else if (buttons[i].click == clickitem) {
|
||||
click = clickitem;
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
}
|
||||
// left-click on right arrow
|
||||
|
|
|
@ -12,6 +12,8 @@ enum {
|
|||
clickprompt,
|
||||
clickinput,
|
||||
clicklarrow,
|
||||
clickitem,
|
||||
clickselitem,
|
||||
clickrarrow,
|
||||
clicknumber,
|
||||
clickmode,
|
||||
|
|
3
mouse.h
3
mouse.h
|
@ -7,6 +7,8 @@
|
|||
* clickinput: - Input box
|
||||
* clickprompt: - Prompt
|
||||
* clicklarrow: - Left arrow
|
||||
* clickitem: - Item
|
||||
* clickselitem: - Item hovered over (function doesn't matter, this will always select the item)
|
||||
* clickrarrow: - Right arrow
|
||||
* clicknumber: - Match count
|
||||
* clickmode: - Mode indicator
|
||||
|
@ -25,4 +27,5 @@ static Mouse buttons[] = {
|
|||
{ clickprompt, 0, Button1, clear, {0} },
|
||||
{ clickmode, 0, Button1, switchmode, {0} },
|
||||
{ clicknumber, 0, Button1, viewhist, {0} },
|
||||
{ clickselitem, 0, Button1, NULL, {0} },
|
||||
};
|
||||
|
|
Loading…
Reference in a new issue