-
Notifications
You must be signed in to change notification settings - Fork 432
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
Re-structure turbo-stream[action=morph]
support
#1240
Re-structure turbo-stream[action=morph]
support
#1240
Conversation
Related to [hotwired/turbo#1240][] Since the `<turbo-stream action="morph">` hasn't yet been part of a release, there's an opportunity to rename it without being considerate of backwards compatibility. As an alternative to introduce a new Stream Action, this commit changes existing actions to be more flexible. For example, the `<turbo-stream method="morph">` element behaves like a specialized version of a `<turbo-stream method="replace">`, since it operates on the target element's `outerHTML` property. Similarly, the `<turbo-stream method="morph" children-only>` element behaves like a specialized version of a `<turbo-stream method="update">`, since it operates on the target element's `innerHTML` property. ```diff -<turbo-stream action="morph"> +<turbo-stream action="replace" method="morph"> <template>Replace me with morphing</template> </turbo-stream> -<turbo-stream action="morph" children-only> +<turbo-stream action="update" method="morph"> <template>Update me with morphing</template> </turbo-stream> ``` [hotwired/turbo#1240]: hotwired/turbo#1240
I started to open a PR related to hotwired/turbo-rails#583 to remove For example, the If this PR's proposal is well-received, I'll open a corresponding PR to |
After doing some more research, I see that the original implementation introduced in #1185 intentionally overlaps with the Since that package integrates with morphdom, support for the Since Turbo 8's morphing is powered by Idiomorph, drawing inspiration from the Morphdom API isn't as compelling as it is for the Instead, utilizing existing Turbo terminology (instead of something like |
@jorgemanrubia does this feel like an improvement? |
Not sure that my 2 cents are of value here but I do like the idea of having a different api for stream morphing that would not conflict with the @seanpdoyle, I am curious if you have a sense of when this feature might be released? As noted in #1229 it is in the docs but not actually functional yet which tripped me up. As other folks have mentioned in #1185 I have a pattern that I use in an app in which I post back to the same action (e.g. new or edit) to update the state of an object but without persisting it to the database so a redirect is not possible. I would like the UI to adjust as the state of the form object changes without doing a full replace since that would lose focus so morphing would be ideal. I think I did at least finally figure out how to get the full page render to trigger a morph refresh by passing a status code other than 200. Does that sound right? Tricky. |
057ad5e
to
8162495
Compare
I love this @seanpdoyle. It makes the API tighter and more consistent. Thanks 🙏 . I would imagine this will require some adjustments after merging #1234. Happy to tackle this one next. Thanks. |
@seanpdoyle if you can rebase and adapt to the last changes I'll merge. Thanks! |
This commit re-structures the new support for `turbo-stream[action="morph"]` elements introduced in [hotwired#1185][]. Since the `<turbo-stream action="morph">` hasn't yet been part of a release, there's an opportunity to rename it without being considerate of backwards compatibility. As an alternative to introduce a new Stream Action, this commit changes existing actions to be more flexible. For example, the `<turbo-stream method="morph">` element behaves like a specialized version of a `<turbo-stream method="replace">`, since it operates on the target element's `outerHTML` property. Similarly, the `<turbo-stream method="morph" children-only>` element behaves like a specialized version of a `<turbo-stream method="update">`, since it operates on the target element's `innerHTML` property. ```diff -<turbo-stream action="morph"> +<turbo-stream action="replace" method="morph"> <template>Replace me with morphing</template> </turbo-stream> -<turbo-stream action="morph" children-only> +<turbo-stream action="update" method="morph"> <template>Update me with morphing</template> </turbo-stream> ``` This commit removes the `[action="morph"]` support entirely, and re-implements it in terms of the `[action="replace"]` and `[action="update"]` support. By consolidating concepts, the "scope" of the modifications is more clearly communicated to callers that are familiar with the underlying DOM interfaces (`Element.replaceWith` and `Element.innerHTML`) that are invoked by the conventionally established Replace and Update actions. This proposal also aims to reinforce the "method" terminology introduced by the Page Refresh `<meta name="refresh-method" content="morph">` element. [hotwired#1185]: hotwired#1185
Related to [hotwired/turbo#1240][] Since the `<turbo-stream action="morph">` hasn't yet been part of a release, there's an opportunity to rename it without being considerate of backwards compatibility. As an alternative to introduce a new Stream Action, this commit changes existing actions to be more flexible. For example, the `<turbo-stream method="morph">` element behaves like a specialized version of a `<turbo-stream method="replace">`, since it operates on the target element's `outerHTML` property. Similarly, the `<turbo-stream method="morph" children-only>` element behaves like a specialized version of a `<turbo-stream method="update">`, since it operates on the target element's `innerHTML` property. ```diff -<turbo-stream action="morph"> +<turbo-stream action="replace" method="morph"> <template>Replace me with morphing</template> </turbo-stream> -<turbo-stream action="morph" children-only> +<turbo-stream action="update" method="morph"> <template>Update me with morphing</template> </turbo-stream> ``` [hotwired/turbo#1240]: hotwired/turbo#1240
8162495
to
9369eb9
Compare
@jorgemanrubia I've rebased. I've also opened hotwired/turbo-site#186 to document this change. |
@seanpdoyle Im happy to take on the refactor on the turbo-rails side if you haven't started it yet cc: @jorgemanrubia |
@omarluq I hadn't started anything on the Rails side. Go for it! Thank you for the help. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks, @seanpdoyle. This is a great change 👍 .
Reading the play-by-play, this change makes a lot of sense to me. Update and Replace are the actions. |
Would it make sense to keep the |
I don't think so, because no version was released with the Turbo stream morph action |
@marcoroth, my understanding was it was never actually included in a release (the fact it didn't work is how I found these issues initially) |
Oh right, nevermind then. I guess I confused it with the |
I just released turbo v8.0.5 and turbo-rails v2.0.6. I'll merge those site docs next. |
Thanks! I'll try incorporating this next week and may update this blog post I recently wrote |
Closes #1163
Follow-up to #1185
turbo-site PR
This commit re-structures the new support for
turbo-stream[action="morph"]
elements introduced in #1185.Since the
<turbo-stream action="morph">
hasn't yet been part of a release, there's an opportunity to rename it without being considerate of backwards compatibility.As an alternative to introduce a new Stream Action, this commit changes existing actions to be more flexible.
For example, the
<turbo-stream method="morph">
element behaves like a specialized version of a<turbo-stream method="replace">
, since it operates on the target element'souterHTML
property.Similarly, the
<turbo-stream method="morph" children-only>
element behaves like a specialized version of a<turbo-stream method="update">
, since it operates on the target element'sinnerHTML
property.This commit removes the
[action="morph"]
support entirely, and re-implements it in terms of the[action="replace"]
and[action="update"]
support.By consolidating concepts, the "scope" of the modifications is more clearly communicated to callers that are familiar with the underlying DOM interfaces (
Element.replaceWith
andElement.innerHTML
) that are invoked by the conventionally established Replace and Update actions.This proposal also aims to reinforce the "method" terminology introduced by the Page Refresh
<meta name="turbo-refresh-method" content="morph">
element.