Merge pull request #3671 from orestisf1993/full_render_width

child_handle_button: Call only if x >= offset
This commit is contained in:
Ingo Bürk 2019-03-29 15:21:27 +01:00 committed by GitHub
commit 88912d6f00
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 21 additions and 14 deletions

View File

@ -454,19 +454,12 @@ static bool execute_custom_command(xcb_keycode_t input_code, bool event_is_relea
return false; return false;
} }
static void child_handle_button(xcb_button_press_event_t *event, i3_output *output, int32_t x) { static void child_handle_button(xcb_button_press_event_t *event, i3_output *output, uint32_t statusline_x) {
if (!child_want_click_events()) { if (!child_want_click_events()) {
return; return;
} }
const int tray_width = get_tray_width(output->trayclients); if (statusline_x > (uint32_t)output->statusline_width) {
/* Calculate the horizontal coordinate (x) of the start of the statusline by
* subtracting its width and the width of the tray from the bar width. */
const int offset = output->rect.w - output->statusline_width - tray_width - logical_px((tray_width > 0) * sb_hoff_px);
/* x of the click event relative to the start of the statusline. */
const uint32_t statusline_x = x - offset;
if (x < offset || statusline_x > (uint32_t)output->statusline_width) {
return; return;
} }
@ -551,12 +544,26 @@ static void handle_button(xcb_button_press_event_t *event) {
} }
if (x > workspace_width) { if (x > workspace_width) {
if (!event_is_release) { const int tray_width = get_tray_width(walk->trayclients);
child_handle_button(event, walk, x); /* Calculate the horizontal coordinate (x) of the start of the
* statusline by subtracting its width and the width of the tray from
* the bar width. */
const int offset = walk->rect.w - walk->statusline_width -
tray_width - logical_px((tray_width > 0) * sb_hoff_px);
if (x >= offset) {
/* Click was after the start of the statusline, return to avoid
* executing any other actions even if a click event is not
* produced eventually. */
if (!event_is_release) {
/* x of the click event relative to the start of the
* statusline. */
const uint32_t statusline_x = x - offset;
child_handle_button(event, walk, statusline_x);
}
return;
} }
/* Return to avoid executing any other actions when a separator is
* clicked. */
return;
} }
/* If a custom command was specified for this mouse button, it overrides /* If a custom command was specified for this mouse button, it overrides