Compare commits

...

3 commits

Author SHA1 Message Date
Andrew Morgan 00e0ba37b4
Merge 42a1bc370f into 705240da72 2025-12-05 15:57:36 +00:00
Andrew Morgan 705240da72
Prevent PurgeCSS from deleting dynamically-added version picker CSS classes (#2260) 2025-12-05 15:19:24 +00:00
Johannes Marbach 4dbe080570
Append version number to 'latest' entry in the picker (#2261) 2025-12-05 14:12:05 +00:00
4 changed files with 16 additions and 8 deletions

View file

@ -40,13 +40,13 @@ const currentSegment = segmentMatches ? segmentMatches[0] : undefined;
// fall back to the version as defined in Hugo. // fall back to the version as defined in Hugo.
const selected = currentSegment ?? currentVersion; const selected = currentSegment ?? currentVersion;
function appendVersion(parent, name, url) { function appendVersion(parent, name, segment, url) {
// The list item // The list item
const li = document.createElement("li"); const li = document.createElement("li");
if (name === selected) { if (segment === selected) {
li.classList.add("selected"); li.classList.add("selected");
} }
if (name === "latest") { if (segment === "latest") {
li.classList.add("latest"); li.classList.add("latest");
} }
parent.appendChild(li); parent.appendChild(li);
@ -74,7 +74,7 @@ function appendVersion(parent, name, url) {
// Otherwise, stop further event handling and replace the segment // Otherwise, stop further event handling and replace the segment
ev.preventDefault(); ev.preventDefault();
ev.stopPropagation(); ev.stopPropagation();
window.location.href = href.replace(`/${currentSegment}/`, `/${name}/`); window.location.href = href.replace(`/${currentSegment}/`, `/${segment}/`);
}); });
// The link text // The link text
@ -100,12 +100,13 @@ fetch(url)
} }
// Add a entries for the unstable version and the "latest" shortcut // Add a entries for the unstable version and the "latest" shortcut
appendVersion(ul, "unstable", "https://spec.matrix.org/unstable"); appendVersion(ul, "unstable", "unstable", "https://spec.matrix.org/unstable");
appendVersion(ul, "latest", "https://spec.matrix.org/latest"); const latestName = versions?.length ? `latest (${versions[0].name})` : "latest";
appendVersion(ul, latestName, "latest", "https://spec.matrix.org/latest");
// Add an entry for each proper version // Add an entry for each proper version
for (const version of versions) { for (const version of versions) {
appendVersion(ul, version.name, `https://spec.matrix.org/${version.name}`); appendVersion(ul, version.name, version.name, `https://spec.matrix.org/${version.name}`);
} }
// For historical versions, simply link to the changelog // For historical versions, simply link to the changelog

View file

@ -51,12 +51,16 @@ Custom SCSS for the Matrix spec
color: $black; color: $black;
} }
/* Make the version dropdown scroll if its too large */ /* Make the version dropdown scroll if it's too large */
ul#version-selector { ul#version-selector {
max-height: 80vh; max-height: 80vh;
overflow-y: auto; overflow-y: auto;
} }
/* As these styles are only applied by JavaScript, PurgeCSS doesn't see them
* in the source code and removes them unless we explicitly tell it not to.
*/
/* purgecss start ignore */
ul#version-selector li.selected a { ul#version-selector li.selected a {
font-weight: bold; font-weight: bold;
} }
@ -64,6 +68,7 @@ Custom SCSS for the Matrix spec
ul#version-selector li.latest a { ul#version-selector li.latest a {
color: $secondary; color: $secondary;
} }
/* purgecss end ignore */
} }
/* Styles for the sidebar nav */ /* Styles for the sidebar nav */

View file

@ -0,0 +1 @@
Add version picker in the navbar.

View file

@ -0,0 +1 @@
Add version picker in the navbar.