Skip to content

Commit

Permalink
Clean up unnecessary code now that same-page link clicks are handled …
Browse files Browse the repository at this point in the history
…outside a Visit
  • Loading branch information
domchristie committed Jul 20, 2024
1 parent 4ba8aea commit 120847d
Show file tree
Hide file tree
Showing 4 changed files with 7 additions and 60 deletions.
16 changes: 3 additions & 13 deletions src/core/drive/navigator.js
Original file line number Diff line number Diff line change
Expand Up @@ -128,20 +128,10 @@ export class Navigator {
delete this.currentVisit
}

// Same-page links are no longer handled with a Visit.
// This method is still needed for Turbo Native adapters.
locationWithActionIsSamePage(location, action) {
const anchor = getAnchor(location)
const currentAnchor = getAnchor(this.view.lastRenderedLocation)
const isRestorationToTop = action === "restore" && typeof anchor === "undefined"

return (
action !== "replace" &&
getRequestURL(location) === getRequestURL(this.view.lastRenderedLocation) &&
(isRestorationToTop || (anchor != null && anchor !== currentAnchor))
)
}

visitScrolledToSamePageLocation(oldURL, newURL) {
this.delegate.visitScrolledToSamePageLocation(oldURL, newURL)
return false
}

// Visits
Expand Down
25 changes: 2 additions & 23 deletions src/core/drive/visit.js
Original file line number Diff line number Diff line change
Expand Up @@ -83,7 +83,6 @@ export class Visit {
this.snapshot = snapshot
this.snapshotHTML = snapshotHTML
this.response = response
this.isSamePage = this.delegate.locationWithActionIsSamePage(this.location, this.action)
this.isPageRefresh = this.view.isPageRefresh(this)
this.visitCachedSnapshot = visitCachedSnapshot
this.willRender = willRender
Expand All @@ -110,10 +109,6 @@ export class Visit {
return this.history.getRestorationDataForIdentifier(this.restorationIdentifier)
}

get silent() {
return this.isSamePage
}

start() {
if (this.state == VisitState.initialized) {
this.recordTimingMetric(TimingMetric.visitStart)
Expand Down Expand Up @@ -250,7 +245,7 @@ export class Visit {
const isPreview = this.shouldIssueRequest()
this.render(async () => {
this.cacheSnapshot()
if (this.isSamePage || this.isPageRefresh) {
if (this.isPageRefresh) {
this.adapter.visitRendered(this)
} else {
if (this.view.renderPromise) await this.view.renderPromise
Expand Down Expand Up @@ -278,17 +273,6 @@ export class Visit {
}
}

goToSamePageAnchor() {
if (this.isSamePage) {
this.render(async () => {
this.cacheSnapshot()
this.performScroll()
this.changeHistory()
this.adapter.visitRendered(this)
})
}
}

// Fetch request delegate

prepareRequest(request) {
Expand Down Expand Up @@ -350,9 +334,6 @@ export class Visit {
} else {
this.scrollToAnchor() || this.view.scrollToTop()
}
if (this.isSamePage) {
this.delegate.visitScrolledToSamePageLocation(this.view.lastRenderedLocation, this.location)
}

this.scrolled = true
}
Expand Down Expand Up @@ -401,9 +382,7 @@ export class Visit {
}

shouldIssueRequest() {
if (this.isSamePage) {
return false
} else if (this.action == "restore") {
if (this.action == "restore") {
return !this.hasCachedSnapshot()
} else {
return this.willRender
Expand Down
1 change: 0 additions & 1 deletion src/core/native/browser_adapter.js
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,6 @@ export class BrowserAdapter {
this.location = visit.location
visit.loadCachedSnapshot()
visit.issueRequest()
visit.goToSamePageAnchor()
}

visitRequestStarted(visit) {
Expand Down
25 changes: 2 additions & 23 deletions src/core/session.js
Original file line number Diff line number Diff line change
Expand Up @@ -253,9 +253,7 @@ export class Session {
this.view.markVisitDirection(visit.direction)
}
extendURLWithDeprecatedProperties(visit.location)
if (!visit.silent) {
this.notifyApplicationAfterVisitingLocation(visit.location, visit.action)
}
this.notifyApplicationAfterVisitingLocation(visit.location, visit.action)
}

visitCompleted(visit) {
Expand All @@ -264,14 +262,6 @@ export class Session {
this.notifyApplicationAfterPageLoad(visit.getTimingMetrics())
}

locationWithActionIsSamePage(location, action) {
return this.navigator.locationWithActionIsSamePage(location, action)
}

visitScrolledToSamePageLocation(oldURL, newURL) {
this.notifyApplicationAfterVisitingSamePageLocation(oldURL, newURL)
}

// Form submit observer delegate

willSubmitForm(form, submitter) {
Expand Down Expand Up @@ -311,9 +301,7 @@ export class Session {
// Page view delegate

viewWillCacheSnapshot() {
if (!this.navigator.currentVisit?.silent) {
this.notifyApplicationBeforeCachingSnapshot()
}
this.notifyApplicationBeforeCachingSnapshot()
}

allowsImmediateRender({ element }, options) {
Expand Down Expand Up @@ -405,15 +393,6 @@ export class Session {
})
}

notifyApplicationAfterVisitingSamePageLocation(oldURL, newURL) {
dispatchEvent(
new HashChangeEvent("hashchange", {
oldURL: oldURL.toString(),
newURL: newURL.toString()
})
)
}

notifyApplicationAfterFrameLoad(frame) {
return dispatch("turbo:frame-load", { target: frame })
}
Expand Down

0 comments on commit 120847d

Please sign in to comment.