<p></p>
<blockquote>
<p dir="auto">with the url changing to a working permalink (instead of trying to save state in cookies or local storage etc).</p>
</blockquote>
<p dir="auto">This is a strange statement. That "save state in local storage" (actually in session storage in my case) is done to cache the page fragment and it's not a replacement for url rewriting. You do both url rewriting and caching, and this is what Turbo does as well, I assume. Turbo doesn't need to store things in local/session storage for this purpose because you're supposed to have the majority of pages working without full reloads. In this case you can store fragments by cloning their dom elements or just copying html to some javascript variable.</p>
<p dir="auto">I can do the same thing here and it would be simpler code except the osm website is far from being able to work without full page reloads. The cache would persist only as long as the user stays on router.js-controlled pages, the ones that have a map displayed. For example if you're on a changeset list page and you click a changeset link, the changeset list would still be cached and you could go back to the list without reloading everything. But if you click a user link, the cache would be gone.</p>
<p dir="auto">The approach above is better than no caching at all, but I still need utility functions like <a class="issue-link js-issue-link" data-error-text="Failed to load title" data-id="1425744119" data-permission-text="Title is private" data-url="https://github.com/openstreetmap/openstreetmap-website/issues/3773" data-hovercard-type="pull_request" data-hovercard-url="/openstreetmap/openstreetmap-website/pull/3773/hovercard" href="https://github.com/openstreetmap/openstreetmap-website/pull/3773">#3773</a> to implement it.</p>
<p style="font-size:small;-webkit-text-size-adjust:none;color:#666;">—<br />Reply to this email directly, <a href="https://github.com/openstreetmap/openstreetmap-website/issues/647#issuecomment-1328049429">view it on GitHub</a>, or <a href="https://github.com/notifications/unsubscribe-auth/AAK2OLOTEBAVAH2AXQS47T3WKIIBVANCNFSM4AKLXOMQ">unsubscribe</a>.<br />You are receiving this because you are subscribed to this thread.<img src="https://github.com/notifications/beacon/AAK2OLNRQ67NVUX45MCV3WTWKIIBVA5CNFSM4AKLXOM2YY3PNVWWK3TUL52HS4DFVREXG43VMVBW63LNMVXHJKTDN5WW2ZLOORPWSZGOJ4UG2FI.gif" height="1" width="1" alt="" /><span style="color: transparent; font-size: 0; display: none; visibility: hidden; overflow: hidden; opacity: 0; width: 0; height: 0; max-width: 0; max-height: 0; mso-hide: all">Message ID: <span><openstreetmap/openstreetmap-website/issues/647/1328049429</span><span>@</span><span>github</span><span>.</span><span>com></span></span></p>
<script type="application/ld+json">[
{
"@context": "http://schema.org",
"@type": "EmailMessage",
"potentialAction": {
"@type": "ViewAction",
"target": "https://github.com/openstreetmap/openstreetmap-website/issues/647#issuecomment-1328049429",
"url": "https://github.com/openstreetmap/openstreetmap-website/issues/647#issuecomment-1328049429",
"name": "View Issue"
},
"description": "View this Issue on GitHub",
"publisher": {
"@type": "Organization",
"name": "GitHub",
"url": "https://github.com"
}
}
]</script>