palantir/blueprint

Table header cell - Clicking on an an element also selects the column.

Open

#3,685 opened on Jul 30, 2019

View on GitHub
 (1 comment) (0 reactions) (0 assignees)TypeScript (20,263 stars) (2,167 forks)batch import
Domain: APIPackage: tablehelp wanted

Description

Environment

  • Package version(s): blueprint-table 3.4.1
  • Browser and OS versions: Chrome 75.0.3770.142

Steps to reproduce

  1. Have a table with buttons or a drag handle in the column header cells, and selection enabled.
  2. Click on the button or handle.

Actual behavior

The column is selected, since selection is enabled.

selection

This is particularly annoying when selection causes other things on the page to render, potentially moving the table and then no longer executing the intended click action.

selection-move

Expected behavior

Clicking on an element in the header that has interaction ignores selection.

Possible solution

I noticed that header cells have an ignoredSelectors prop, which does exactly what is needed here, but isn't exposed. Would be nice if this was exposed, so we can add css selectors that could be ignored.

I also noticed the isHeaderMouseTarget static method in the ColumnHeaderCell, but then we need some sort of callback on header click to know what the target is.

Contributor guide

Table header cell - Clicking on an an element also selects the column. · palantir/blueprint#3685 | Good First Issue