-
Notifications
You must be signed in to change notification settings - Fork 194
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
[popup] Boolean property for show state #610
Comments
I think the "toggle" API isn't a bad idea, perhaps you should open a separate issue for that case specifically? I don't think I like the idea of a shown attribute controlling whether a popup is shown or not, and if it did exist it should be readonly rather than controlling behavior. I like having things that "do" things as methods, and things that are "observable" as properties. |
Can you elaborate on why a writable property would be undesirable? It seems like it would be idiomatic and in-line with other DOM API properties like It seems like a settable property controlling its state would be vital for its adoption in contexts where a frontend UI framework that relies on setting properties is used. Without it, people would be left with having to create their own abstractions on top of the native element for each framework; as with the property missing, people would be unable to write templates declaratively, and would instead be forced to figure out a way to call a function in an imperative way. As demonstrated above, that makes for considerably less legible code. |
But it's inconsistent with other UI elements, like showModal, read the note in the spec about removing the "open" attribute, since the attribute is now readonly. Because events, animations, etc. might all be triggered by a close or open mutation, those mutations should in my opinion be best represented as a method, rather than a property. The difference between a browser native that does show/hide and something like a web framework is that (taking React as an example), The vanilla web as currently written does no such thing, there is no "data" model that you can mutate to cause the browser to do a (batched) re-rendering of the DOM. When in React you're reading the "isOpen" property of your data model, that's different than reading properties directly from the underlying DOM node itself. If there were a way to link data Objects with DOM Objects, I agree that it would be pretty reasonable to have a data property map to "open." |
+100 to avoiding a writable attribute that "does" things, not just because of the arguments above, but because there are myriad corner cases. E.g. what happens when the element is not connected to a document (and so, can't be shown), but you do Assuming we don't do that, and just have a readable value, then I suppose this is just sugar over The suggestion to add I'll agenda+ this to discuss. |
The Open UI Community Group just discussed The full IRC log of that discussion<gregwhitworth> Topic: [popup] Boolean property for show state<JonathanNeal> masonf: this is #610. it’s a request for 3 different things. <JonathanNeal> masonf: one of the suggestions is to add a popup shown attribute. <JonathanNeal> masonf: it might be convenient <JonathanNeal> masonf: request 2 is to make the property (I missed this part) <scotto_> q+ <JonathanNeal> request 3 is to add a toggle popup <gregwhitworth> github: https://github.com//issues/610 <JonathanNeal> masonf: request 3 is to add a toggle popup <JonathanNeal> masonf: and if you want, I have proposed resolution. <gregwhitworth> ack scotto_ <masonf> Proposed resolution: add `togglePopUp()` method which toggles a pop-up. Hold off for now on adding a `popUpShown` attribute. <bkardell_> q+ <JonathanNeal> scotto_: I know this is something people would want to try to do. For the button that shows the popup, how much one style that to indicate that the popup is in the shown state? <flackr> q+ to align attribute on name - e.g. open <tantek> only feedback I have is I'd prefer "shown" rather than "true", per the pattern of avoiding literal boolean attributes <JonathanNeal> scotto_: it sounds like we’ve been talking about the pseudo class for the popup itself, but what about for the triggering element? <JonathanNeal> scotto_: an html attribute, that could be styled. right now we do that with aria-expanded="true"/"false" but <JonathanNeal> scotto_: we don’t have that for this. <tantek> also what's the value of such an attribute *while* it is animating from one state to the other? <JonathanNeal> masonf: yes, right now there is no way to style the element that triggered the popup. <tantek> (i.e. neither true nor false is correct) <JonathanNeal> masonf: on the specific select menu use case, you can style it based on open and closed, but the general case doesn’t have anything. <JonathanNeal> gregwhitworth: but on the general use case on the button being tied, I agree. <gregwhitworth> ack bkardell_ <JonathanNeal> bkardell_: so, "open" is conceptually kind of a state, but "show" and "hide", they seem <JonathanNeal> bkardell_: they seem to be about the visual presentation <JonathanNeal> bkardell_: I don’t know in the use cases that remain, at least for hint, there are use cases where you may want to print them <JonathanNeal> bkardell_: and you can totally show the popup all the time instead of waiting for it to require activation <JonathanNeal> bkardell_: so I’m curious if we’ve made this by a conceptual thing like "active" rather than "show" or "hide". <JonathanNeal> masonf: is the suggestion to rename "show" and "hide" for popup? <JonathanNeal> bkardell_: yea. as far as I understand, we are talking about renaming them. <JonathanNeal> bkardell_: so, if we change the display to block, is it shown? <JonathanNeal> masonf: no, if you manually change it, it will now match "open". <JonathanNeal> bkardell_: but in your author styles, if you put style block, it will be showing. <JonathanNeal> masonf: it will be shown, but it won’t be "shown" <JonathanNeal> bkardell_: these things have bitten us in the past <JonathanNeal> bkardell_: part of me kind of like discussing this in terms of a state <JonathanNeal> bkardell_: and that it might be tied to visibility, but it might not. <gregwhitworth> ack flackr <Zakim> flackr, you wanted to align attribute on name - e.g. open <JonathanNeal> masonf: and I think we want that which is why we picked open and closed <JonathanNeal> gregwhitworth: this was a great summary, and let’s pick this up next week <JonathanNeal> gregwhitworth: please weigh in the proposed solution. <gregwhitworth> Zakim, end meeting <Zakim> As of this point the attendees have been miriam, una, masonf, JonathanNeal, dandclark, scotto_, flackr, dbaron, emilio, +q, tantek <Zakim> RRSAgent, please draft minutes <RRSAgent> I have made the request to generate https://www.w3.org/2022/10/13-openui-minutes.html Zakim <Zakim> I am happy to have been of service, gregwhitworth; please remember to excuse RRSAgent. Goodbye |
without commenting on more, I like the idea of adding a toggle for parity with some similar things in the platform already even |
The Open UI Community Group just discussed
The full IRC log of that discussion<gregwhitworth> Topic: [popup] Boolean property for show state<gregwhitworth> github: https://github.com//issues/610 <JonathanNeal> masonf: we talked about this last time, briefly. The issue brakes down into 3 things: <JonathanNeal> masonf: request for a boolean attribute called something like popup shown <JonathanNeal> masonf: it would give the same output as open. <JonathanNeal> masonf: second request, make that attribute writable; so it can open and close it. <JonathanNeal> masonf: third request, add another method, toggle popup, that only opens or closes popups <gregwhitworth> I'm supportive of 1 & 3, not 2 <JonathanNeal> masonf: These are all things you can already do. The one that seems reasonable right now is the toggle popup method. <JonathanNeal> masonf: This would make the JS methods align very nicely. <gregwhitworth> q+ <JonathanNeal> masonf: the code you have to write otherwise is a lot more. <masonf> - Proposed resolution: add `togglePopUp()` method which toggles a pop-up. Hold off for now on adding a `popUpShown` attribute. <JonathanNeal> masonf: the code you have to write otherwise for toggle popup is a lot more. <JonathanNeal> gregwhitworth: I'm not supportive of making it writable, because it would pair to other existing APIs. <tantek> I'm ok with that. Same comments as before about popUpShown / boolean attributes, preferring not just true/false values <JonathanNeal> gregwhitworth: when you say “hold off”, do you mean like V2? <JonathanNeal> gregwhitworth: are you saying this isn’t something we need to ship right now, and that’s why we want to pause it? <JonathanNeal> gregwhitworth: I would rather resolve they both exist, separately from whether it is shipped. <gregwhitworth> ack gregwhitworth <JonathanNeal> masonf: my motivation for punting that part for now is to de-risk the spec. <masonf> Proposed resolution: add `togglePopUp()` method which toggles a pop-up. <JonathanNeal> gregwhitworth: I'm supportive, so I would adjust the proposal so we can pick it up some time later down the road. <masonf> RESOLVED: add `togglePopUp()` method which toggles a pop-up. |
Per the resolution [1] there's a desire to add a togglePopover() convenience method. This CL adds that method plus tests. [1] openui/open-ui#610 (comment) Bug: 1307772 Change-Id: Icd39c766786e7d1f6475a86ca8a7a1e89b66182e
Per the resolution [1] there's a desire to add a togglePopover() convenience method. This CL adds that method plus tests. [1] openui/open-ui#610 (comment) Bug: 1307772 Change-Id: Icd39c766786e7d1f6475a86ca8a7a1e89b66182e
Per the resolution [1] there's a desire to add a togglePopover() convenience method. This CL adds that method plus tests. [1] openui/open-ui#610 (comment) Bug: 1307772 Change-Id: Icd39c766786e7d1f6475a86ca8a7a1e89b66182e Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/4000073 Commit-Queue: Joey Arhar <jarhar@chromium.org> Auto-Submit: Mason Freed <masonf@chromium.org> Reviewed-by: Joey Arhar <jarhar@chromium.org> Cr-Commit-Position: refs/heads/main@{#1067805}
Per the resolution [1] there's a desire to add a togglePopover() convenience method. This CL adds that method plus tests. [1] openui/open-ui#610 (comment) Bug: 1307772 Change-Id: Icd39c766786e7d1f6475a86ca8a7a1e89b66182e Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/4000073 Commit-Queue: Joey Arhar <jarhar@chromium.org> Auto-Submit: Mason Freed <masonf@chromium.org> Reviewed-by: Joey Arhar <jarhar@chromium.org> Cr-Commit-Position: refs/heads/main@{#1067805}
Per the resolution [1] there's a desire to add a togglePopover() convenience method. This CL adds that method plus tests. [1] openui/open-ui#610 (comment) Bug: 1307772 Change-Id: Icd39c766786e7d1f6475a86ca8a7a1e89b66182e Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/4000073 Commit-Queue: Joey Arhar <jarhar@chromium.org> Auto-Submit: Mason Freed <masonf@chromium.org> Reviewed-by: Joey Arhar <jarhar@chromium.org> Cr-Commit-Position: refs/heads/main@{#1067805}
… a=testonly Automatic update from web-platform-tests Add togglePopover() method for popovers Per the resolution [1] there's a desire to add a togglePopover() convenience method. This CL adds that method plus tests. [1] openui/open-ui#610 (comment) Bug: 1307772 Change-Id: Icd39c766786e7d1f6475a86ca8a7a1e89b66182e Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/4000073 Commit-Queue: Joey Arhar <jarhar@chromium.org> Auto-Submit: Mason Freed <masonf@chromium.org> Reviewed-by: Joey Arhar <jarhar@chromium.org> Cr-Commit-Position: refs/heads/main@{#1067805} -- wpt-commits: 1c0c07fc028ab6745609b755ccefc680d4c28230 wpt-pr: 36808
… a=testonly Automatic update from web-platform-tests Add togglePopover() method for popovers Per the resolution [1] there's a desire to add a togglePopover() convenience method. This CL adds that method plus tests. [1] openui/open-ui#610 (comment) Bug: 1307772 Change-Id: Icd39c766786e7d1f6475a86ca8a7a1e89b66182e Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/4000073 Commit-Queue: Joey Arhar <jarhar@chromium.org> Auto-Submit: Mason Freed <masonf@chromium.org> Reviewed-by: Joey Arhar <jarhar@chromium.org> Cr-Commit-Position: refs/heads/main@{#1067805} -- wpt-commits: 1c0c07fc028ab6745609b755ccefc680d4c28230 wpt-pr: 36808
Is there a reason why there's no mention (that I can find) of a writable property for the "shown" state of a popup?
For example, it could look something like this:
Or alternatively, it could be called
popUpOpen
.I realize that one can check if a popup is being shown using
popUp.matches(":open")
as described in the explainer. However, this does not allow assigning a boolean value for the state. This would be helpful in a framework setting:While, from what I understand, the current API would require one to write cumbersome code like this:
This would be less cumbersome if there was a toggle method that takes an argument for forcing the state similar to APIs like
element.toggleAttribute()
,classList.toggle()
, etc. (which also doesn't seem to be present), though it would still be less ergonomic than having the proposed property:The text was updated successfully, but these errors were encountered: