angular-devtools
angular-devtools copied to clipboard
Components panel has unintuitive display for components that match native HTML elements
Angular DevTools version (required): 1.0.0
Angular version (required): 9.0.6
Link to a minimal stackblitz reproduction (strongly encouraged): https://stackblitz.com/edit/angular-devtools-directive-matching
Description of issue:
When a native HTML element matches a @Component
selector, the Angular DevTools Components panel lists the component by its native tag name in the component tree, and attributes the component's property values to the native element rather than the matching component class. This can lead to confusion about which component is matching an element, and about where inputs/outputs/properties are coming from.
In the following screenshot, the highlighted node matches an AuthFooterComponent
with the selector footer[hamAuthFooter]
and a property currentYear
. Note how the component is listed as footer
in both the component tree and the sidebar. (The link to the component's source code navigates to AuthFooterComponent
as expected.)
data:image/s3,"s3://crabby-images/019b0/019b079c07023580aa7a032a347ff164117f65cf" alt="Screen Shot 2021-05-21 at 12 52 59 AM"
In the next screenshot, the highlighted link matches both LinkComponent
(a[hlLink]
) and ExternalLinkDirective
(a[target="_blank"]
). The element tree only indicates a match for ExternalLinkDirective
, and it wouldn't be surprising if someone mistakenly thought that the input and property listed in the sidebar derived from ExternalLinkDirective
, when they actually derive from LinkComponent
.
data:image/s3,"s3://crabby-images/dbeb3/dbeb334e2b54465ef788efe553a8edd8cda72c05" alt="Screen Shot 2021-05-21 at 12 13 04 AM"
Steps to reproduce:
- Create a component whose selector matches a native HTML element (e.g.,
a[myComponent]
). - Observe how Angular DevTools represents that component in the Components panel.
I'd change this to a feature request rather than an issue. The current behavior is by design, but I agree it could be confusing and we can change it.