-
Notifications
You must be signed in to change notification settings - Fork 1.8k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Tag: when a Tag is actionable(has an onClick), the pointer icon does not change #7592
Comments
confirmed the above described behavior. |
@carbon-design-system/design is the intention that tags are used like buttons as described above? |
Yes, exactly - we display tags which have an onClick action similar to buttons. |
cc @carbon-design-system/design does the default Tag support click actions or is that specific to Filter Tags only? |
this was briefly discussed on Slack, seems like a proposal/feature enhancement to me. Converting and moving to the right pipeline |
Any Tag (default or with a filter prop) supports and actionable callback (like onClick).
I would suggest that the mouse icon change should be tied to having an actionable callback (like onClick) not to the flag filter prop. |
@guigueb yeah, although onClick works for non-filter tags, it seems like from a design spec standpoint, that's not a intended use case at the moment. Hover, active, focus states need to be determined etc etc. 👍🏽 |
Shouldn't all the hover, active, focus states already be in place for a filter tag - as it is an actionable tag? |
the states are in place for the filter variant which has specific use cases and guidance. As it stands a clickable action on a non-filter tag isn't something we support from a design system standpoint even though as you point out the API seems to support this behavior. |
OK. |
This also goes hand in hand with #7160, as click events are passed directly to the |
In the prior version of Cognos Analytics, the cursor does change when a tag has an action associated with it. From our point of view, it is a regression that Carbon does not support this. |
The default tag should continue to not have a cursor change. However, we can add a new variant for interactive tag that has a hover background color change and a cursor change. I'm curious what the use case for this is and what other states might be needed. Does there also need to be a selected state? What kind of actions are you attaching to the tag? |
agreed - The default tag should continue to not have a cursor change. I'm not sure a new variant is needed - just have the tag be aware of any onXXX events it may have. We don't use a selected state... but I suppose that could be an enhancement. I am only aware of using the actions onClick and onClose, but who's to say what users will add. This sandbox example shows how we use it... https://codesandbox.io/s/actionable-tag-icon-does-not-change-3fpff The Carbon tag page https://www.carbondesignsystem.com/components/tag/usage has a non-working example of pretty much what we are doing. |
Ok what I'm seeing the sandbox seems ok with me then. I was thinking more of a "selectable" which would be another variant. |
@tw15egan I know this is closed and it does address the onClick event. I suppose it can be faked by adding a no-op onClick event = { onClick={() => {}} } to get the visible changes while doing the other action but it seems kinda silly. Is there a reason why we choose to only deal with the onClick event? |
can you elaborate on what you mean by addressing other actionable events? they should already be spread into the component and the interactive outline appears on focus and clicks |
The PR handled onClick but not other actionable events like onDoubleClick, onMouseOver, etc Either they should be allowed - and all give UI feedback, // addressed |
the PR modified the cursor when the component is interactive, and the component already had focus and hover styles which overlap with are you suggesting that there should be additional visual feedback on double clicks and mouseovers? although I am assuming from your code snippet that you are implying that these events are not handled? that should not be the case in the current component, but I will need additional clarification from you about that |
Q) are you suggesting that there should be additional visual feedback on double clicks and mouseovers? And I'm pretty sure there are other actionable events that need to be considered. From the PR only onClick flags the interactive tag. This sandbox will show that only onClick is handled.. https://codesandbox.io/s/actionable-tags-qxqyj |
I'm not sure if double click interactions are part of the design system (cc @aagonzales) but the workaround here of course is to manually add the interactive class. on a general note, we typically do not modify styles based on JS event handlers outside of ones that coincide with the hover, focus, etc. CSS pseudoclasses, and I think it would be unreasonable to include the entire list of JS events here to get the on a side note, I am not certain if double click interactions are fully supported by screen readers |
Agreed, which is why I initially suggested an 'isInteractive' property.
|
Double-clicking typically selects a paragraph or line of text and HTML content. You can "double-click" icons of apps to open them, even on web, which is a behavior imported from the desktop apps. Also you could "double-click" to perform cell-based interactions of web tables, but here usually you have 2 actions back-to-back: selecting the cell with the first click and entering edit mode with the second, or selecting the app icon with the first and opening it with the second (On the accessibility part, its Tab for selection and Enter/Return for the action). I didn't find any submitting actions through buttons that use a hover and also a double-click event on the web. I'm sure there are, but I don't believe that's the norm. Clicking usually means a change in the webpage, either through hyperlinks or submit buttons. Hovering is used to show the responsiveness to the clicking of different elements on the screen: hyperlinks, drop-down menus, buttons, etc. I think it would be tricky from a user experience point of view to try to override the double click behavior of the browser. So for clickable tags, if they have the hover/focus/active/etc usual button states, the double-click should be treated just like the regular button treats it. Double-clicking a tag feels like should be a visual feature for a CMS admin in the add/edit/delete tag nomenclator functionality that opens the |
Title line template: Tag: when a Tag is actionable(has an onClick), change the pointer icon
What package(s) are you using?
carbon-components
carbon-components-react
Detailed description
When a Tag has a filter property, the mouse icon will change when hovering over the Tag.
<Tag type="red" title="Clear Filter" filter> Red </Tag>
If a Tag does not have the filter property but does have an actionable property(onClick), the mouse will NOT change when hovering over the Tag.
<Tag type="red" title="Clear Filter" onClick={()=>alert("red")}> Red </Tag>
I expected the mouse icon to change when actionable in the same way as when filter property is set.
This happens in any browser.
This happens in any version of the Carbon Design System.
Steps to reproduce the issue
<Tag type="red" title="Clear Filter" filter> Red </Tag>
<Tag type="red" title="Clear Filter" onClick={()=>alert("red")}> Red </Tag>
Use case
The product has a search input.
The product has three suggestions for searching "Platform", "Runtimes", and "Services".
It shows these as clickable tags for quick filtering.
This is on the Carbon Design System Tag page just above the Live Demo.
https://www.carbondesignsystem.com/components/tag/usage#live-demo
Work arounds
The child of Tag is a node, so it could be coded as an input.
Styling could be applied, to account for the hover.
Always create a filter tag - and apply display: none; to the filter button when not a filter tag.
All of these are client work and they come with their own problems.
The text was updated successfully, but these errors were encountered: