-
Notifications
You must be signed in to change notification settings - Fork 787
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
bug: Watching Native HTML Attributes requires at least one @Prop() declaration #5854
bug: Watching Native HTML Attributes requires at least one @Prop() declaration #5854
Comments
Additionally tested in Browser Firefox 127.0.1 In
|
@rvantonisse I was able to confirm this issue. Gonna get this ingested into our backlog so we can take a closer look! Thanks! |
* fix(runtime): allow watchers to fire w/ no Stencil members Fixes #5854 STENCIL-1338 * resolve test failures
A fix for this was included in today's v4.19.0 release! |
### Release Notes <details> <summary>ionic-team/stencil (@​stencil/core)</summary> ### [`v4.19.0`](https://togithub.com/ionic-team/stencil/blob/HEAD/CHANGELOG.md#-4190-2024-06-26) [Compare Source](https://togithub.com/ionic-team/stencil/compare/v4.18.3...v4.19.0) ### Bug Fixes * **compiler:** support rollup's external input option ([#3227](ionic-team/stencil#3227)) ([2c68849](ionic-team/stencil@2c68849)), fixes [#3226](ionic-team/stencil#3226) * **emit:** don't emit test files ([#5789](ionic-team/stencil#5789)) ([50892f1](ionic-team/stencil@50892f1)), fixes [#5788](ionic-team/stencil#5788) * **hyrdate:** support vdom annotation in nested dsd structures ([#5856](ionic-team/stencil#5856)) ([61bb5e3](ionic-team/stencil@61bb5e3)) * label attribute not toggling input ([#3474](ionic-team/stencil#3474)) ([13db920](ionic-team/stencil@13db920)), fixes [#3473](ionic-team/stencil#3473) * **mock-doc:** expose ShadowRoot and DocumentFragment globals ([#5827](ionic-team/stencil#5827)) ([98bbd7c](ionic-team/stencil@98bbd7c)), fixes [#3260](ionic-team/stencil#3260) * **runtime:** allow watchers to fire w/ no Stencil members ([#5855](ionic-team/stencil#5855)) ([850ad4f](ionic-team/stencil@850ad4f)), fixes [#5854](ionic-team/stencil#5854) * **runtime:** catch errors in async lifecycle methods ([#5826](ionic-team/stencil#5826)) ([87e5b33](ionic-team/stencil@87e5b33)), fixes [#5824](ionic-team/stencil#5824) * **runtime:** don't register listener before connected to DOM ([#5844](ionic-team/stencil#5844)) ([9d7021f](ionic-team/stencil@9d7021f)), fixes [#4067](ionic-team/stencil#4067) * **runtime:** properly assign style declarations ([#5838](ionic-team/stencil#5838)) ([5c10ebf](ionic-team/stencil@5c10ebf)) * **testing:** allow to re-use pages across it blocks ([#5830](ionic-team/stencil#5830)) ([561eab4](ionic-team/stencil@561eab4)), fixes [#3720](ionic-team/stencil#3720) * **typescript:** remove unsupported label property ([#5840](ionic-team/stencil#5840)) ([d26ea2b](ionic-team/stencil@d26ea2b)), fixes [#3473](ionic-team/stencil#3473) ### Features * **cli:** support generation of sass and less files ([#5857](ionic-team/stencil#5857)) ([1883812](ionic-team/stencil@1883812)), closes [#2155](ionic-team/stencil#2155) * **compiler:** generate export maps on build ([#5809](ionic-team/stencil#5809)) ([b6d2404](ionic-team/stencil@b6d2404)) * **complier:** support type import aliasing ([#5836](ionic-team/stencil#5836)) ([7ffb25d](ionic-team/stencil@7ffb25d)), closes [#2335](ionic-team/stencil#2335) * **runtime:** support declarative shadow DOM ([#5792](ionic-team/stencil#5792)) ([c837063](ionic-team/stencil@c837063)), closes [#4010](ionic-team/stencil#4010) * **testing:** add `toHaveLastReceivedEventDetail` event spy matcher ([#5829](ionic-team/stencil#5829)) ([63491de](ionic-team/stencil@63491de)), closes [#2488](ionic-team/stencil#2488) * **testing:** allow to disable network error logging via 'logFailingNetworkRequests' option ([#5839](ionic-team/stencil#5839)) ([dac3e33](ionic-team/stencil@dac3e33)), closes [#2572](ionic-team/stencil#2572) * **testing:** expose captureBeyondViewport in pageCompareScreenshot ([#5828](ionic-team/stencil#5828)) ([cf6a450](ionic-team/stencil@cf6a450)), closes [#3188](ionic-team/stencil#3188) </details>
hey I know it's already implemented, however, we were having the same issue in our project and we were able to fix it by using /**
* Role of the host element which is used for accessibility
* @ignore
*/
@Prop({ attribute: 'role' }) hostRole: 'textbox' | 'combobox' = 'textbox';
/**
* ID of the host element which is used for accessibility
* @ignore
*/
@Prop({ attribute: 'id' }) hostId: string = generateElementId(this.hostElement); I just wanted to state it for the ones who are not able to upgrade to v4.19.0 |
Prerequisites
Stencil Version
4.18.3
Current Behavior
I want to
@Watch()
the host id attribute, but it requires at least one@Prop()
set.Without a
@Prop()
set, the@Watch()
will not trigger.With any
@Prop()
set,@Watch("id")
will trigger on attribute change.Expected Behavior
Preferred:
Setting an attribute watcher like
@Watch("id")
, triggers when changing the attribute;Without requiring any
@Prop()
set.Second best:
Might also agree with requiring at least an equal property like
@Prop("id")
as it is an attribute expected to be set on the component. But this might require additional code to reflect the exact HTML attribute behavior. (This side-effect is warned for by stencil's console output)But in this case
@Watch("id")
is expected to only trigger when@Prop("id")
is exact set.System Info
Code Reproduction URL
https://github.com/rvantonisse/reproduction-stencil-issues/tree/rvantonisse/bug/5854-watching-native-html-attributes-requires-prop
Additional Information
I cant share my work code repo so I need to recreate a this code with a private account.
For now an empty repo, will fill later today.
EDITS
The text was updated successfully, but these errors were encountered: