diff --git a/src/core/session.js b/src/core/session.js index 05e6c0289..928e03aae 100644 --- a/src/core/session.js +++ b/src/core/session.js @@ -16,6 +16,7 @@ import { clearBusyState, dispatch, findClosestRecursively, getVisitAction, markA import { PageView } from "./drive/page_view" import { FrameElement } from "../elements/frame_element" import { Preloader } from "./drive/preloader" +import { LimitedSet } from "./drive/limited_set" import { Cache } from "./cache" export class Session { @@ -34,7 +35,8 @@ export class Session { formLinkClickObserver = new FormLinkClickObserver(this, document.documentElement) frameRedirector = new FrameRedirector(this, document.documentElement) streamMessageRenderer = new StreamMessageRenderer() - cache = new Cache() + cache = new Cache(this) + recentRequests = new LimitedSet(20) drive = true enabled = true @@ -93,6 +95,14 @@ export class Session { } } + refresh(url, requestId) { + const isRecentRequest = requestId && this.recentRequests.has(requestId) + if (!isRecentRequest) { + this.cache.exemptPageFromPreview() + this.visit(url, { action: "replace" }) + } + } + connectStreamSource(source) { this.streamObserver.connectStreamSource(source) } diff --git a/src/core/streams/stream_actions.js b/src/core/streams/stream_actions.js index 62801fd69..064e94ca4 100644 --- a/src/core/streams/stream_actions.js +++ b/src/core/streams/stream_actions.js @@ -1,3 +1,5 @@ +import { session } from "../" + export const StreamActions = { after() { this.targetElements.forEach((e) => e.parentElement?.insertBefore(this.templateContent, e.nextSibling)) @@ -33,11 +35,6 @@ export const StreamActions = { }, refresh() { - const requestId = this.getAttribute("request-id") - const isRecentRequest = requestId && window.Turbo.recentRequests.has(requestId) - if (!isRecentRequest) { - window.Turbo.cache.exemptPageFromPreview() - window.Turbo.visit(window.location.href, { action: "replace" }) - } + session.refresh(this.baseURI, this.requestId) } } diff --git a/src/elements/stream_element.js b/src/elements/stream_element.js index f73084cc2..b9bcf35f0 100644 --- a/src/elements/stream_element.js +++ b/src/elements/stream_element.js @@ -143,6 +143,13 @@ export class StreamElement extends HTMLElement { return this.getAttribute("targets") } + /** + * Reads the request-id attribute + */ + get requestId() { + return this.getAttribute("request-id") + } + #raise(message) { throw new Error(`${this.description}: ${message}`) } diff --git a/src/http/recent_fetch_requests.js b/src/http/recent_fetch_requests.js index 620afd0a5..36f878ea8 100644 --- a/src/http/recent_fetch_requests.js +++ b/src/http/recent_fetch_requests.js @@ -5,7 +5,7 @@ const originalFetch = window.fetch window.fetch = async function(url, options = {}) { const modifiedHeaders = new Headers(options.headers || {}) const requestUID = uuid() - window.Turbo.recentRequests.add(requestUID) + window.Turbo.session.recentRequests.add(requestUID) modifiedHeaders.append("X-Turbo-Request-Id", requestUID) return originalFetch(url, { diff --git a/src/tests/functional/page_refresh_stream_action_tests.js b/src/tests/functional/page_refresh_stream_action_tests.js index 22cf17e8d..c3c5b869c 100644 --- a/src/tests/functional/page_refresh_stream_action_tests.js +++ b/src/tests/functional/page_refresh_stream_action_tests.js @@ -22,7 +22,7 @@ test("don't refresh the page on self-originated request ids", async ({ page }) = assert.match(await textContent(page), /Hello/) await page.locator("#content").evaluate((content)=>content.innerHTML = "") - page.evaluate(()=> { window.Turbo.recentRequests.add("123") }) + page.evaluate(()=> { window.Turbo.session.recentRequests.add("123") }) await page.locator("#request-id").evaluate((input)=>input.value = "123") await page.click("#refresh button") diff --git a/src/tests/unit/stream_element_tests.js b/src/tests/unit/stream_element_tests.js index 601608563..8ca8c48f3 100644 --- a/src/tests/unit/stream_element_tests.js +++ b/src/tests/unit/stream_element_tests.js @@ -183,7 +183,7 @@ test("test action=refresh", async () => { }) test("test action=refresh discarded when matching request id", async () => { - Turbo.recentRequests.add("123") + Turbo.session.recentRequests.add("123") document.body.setAttribute("data-modified", "") assert.ok(document.body.hasAttribute("data-modified"))