diff --git a/src/core/drive/morph_renderer.js b/src/core/drive/morph_renderer.js index 6537b8d2f..07b58cd9a 100644 --- a/src/core/drive/morph_renderer.js +++ b/src/core/drive/morph_renderer.js @@ -33,8 +33,7 @@ export class MorphRenderer extends Renderer { callbacks: { beforeNodeAdded: this.#shouldAddElement, beforeNodeMorphed: this.#shouldMorphElement, - beforeNodeRemoved: this.#shouldRemoveElement, - afterNodeMorphed: this.#reloadStimulusControllers + beforeNodeRemoved: this.#shouldRemoveElement } }) } @@ -78,15 +77,6 @@ export class MorphRenderer extends Renderer { this.#morphElements(currentElement, newElement.children, "innerHTML") } - #reloadStimulusControllers = async (node) => { - if (node instanceof HTMLElement && node.hasAttribute("data-controller")) { - const originalAttribute = node.getAttribute("data-controller") - node.removeAttribute("data-controller") - await nextAnimationFrame() - node.setAttribute("data-controller", originalAttribute) - } - } - #isRemoteFrame(element) { return element.nodeName.toLowerCase() === "turbo-frame" && element.src } diff --git a/src/tests/functional/page_refresh_tests.js b/src/tests/functional/page_refresh_tests.js index 4d657db7f..b06065ba6 100644 --- a/src/tests/functional/page_refresh_tests.js +++ b/src/tests/functional/page_refresh_tests.js @@ -127,23 +127,6 @@ test("it preserves data-turbo-permanent elements that don't match when their ids await expect(page.locator("#preserve-me")).toHaveText("Preserve me, I have a family!") }) -test("it reloads data-controller attributes after a morph", async ({ page }) => { - await page.goto("/src/tests/fixtures/page_refresh.html") - - await page.click("#form-submit") - await nextEventNamed(page, "turbo:render", { renderMethod: "morph" }) - - expect( - await nextAttributeMutationNamed(page, "stimulus-controller", "data-controller") - ).toEqual(null) - - await nextBeat() - - expect( - await nextAttributeMutationNamed(page, "stimulus-controller", "data-controller") - ).toEqual("test") -}) - async function assertPageScroll(page, top, left) { const [scrollTop, scrollLeft] = await page.evaluate(() => { return [