|
17 | 17 | * - The header JS to dispatch `boost:version-changed` with detail |
18 | 18 | * { slug, label, isLatest, docUrl }. |
19 | 19 | */ |
| 20 | + |
| 21 | +function _getOrCreateLiveRegion() { |
| 22 | + var el = document.getElementById("install-card-live"); |
| 23 | + if (el) return el; |
| 24 | + el = document.createElement("span"); |
| 25 | + el.id = "install-card-live"; |
| 26 | + el.setAttribute("aria-live", "polite"); |
| 27 | + el.style.cssText = |
| 28 | + "position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;"; |
| 29 | + document.body.appendChild(el); |
| 30 | + return el; |
| 31 | +} |
| 32 | + |
20 | 33 | document.addEventListener("boost:version-changed", function (e) { |
21 | 34 | var detail = e.detail || {}; |
22 | 35 | var isLatest = detail.isLatest === true; |
23 | 36 | var docUrl = detail.docUrl || ""; |
| 37 | + var label = detail.label || ""; |
24 | 38 |
|
25 | 39 | document |
26 | 40 | .querySelectorAll("[data-install-card-wrapper]") |
27 | 41 | .forEach(function (wrapper) { |
28 | | - wrapper.setAttribute( |
29 | | - "data-active-variant", |
30 | | - isLatest ? "latest" : "older" |
31 | | - ); |
| 42 | + var prev = wrapper.getAttribute("data-active-variant"); |
| 43 | + var next = isLatest ? "latest" : "older"; |
| 44 | + |
| 45 | + wrapper.setAttribute("data-active-variant", next); |
| 46 | + |
32 | 47 | if (!isLatest && docUrl) { |
33 | 48 | var linkWrapper = wrapper.querySelector( |
34 | 49 | "[data-install-card-doc-link-wrapper]" |
35 | 50 | ); |
36 | 51 | var link = linkWrapper && linkWrapper.querySelector("a"); |
37 | 52 | if (link) link.setAttribute("href", docUrl); |
38 | 53 | } |
| 54 | + |
| 55 | + if (prev !== next) { |
| 56 | + var visible = isLatest |
| 57 | + ? wrapper.querySelector(".install-card:not(.install-card--older)") |
| 58 | + : wrapper.querySelector(".install-card--older"); |
| 59 | + if (visible) { |
| 60 | + visible.classList.remove("install-card--entering"); |
| 61 | + void visible.offsetWidth; |
| 62 | + visible.classList.add("install-card--entering"); |
| 63 | + visible.addEventListener( |
| 64 | + "animationend", |
| 65 | + function () { |
| 66 | + visible.classList.remove("install-card--entering"); |
| 67 | + }, |
| 68 | + { once: true } |
| 69 | + ); |
| 70 | + } |
| 71 | + } |
39 | 72 | }); |
| 73 | + |
| 74 | + var liveRegion = _getOrCreateLiveRegion(); |
| 75 | + liveRegion.textContent = isLatest |
| 76 | + ? "Showing install steps for the latest version." |
| 77 | + : "Showing documentation link for Boost " + label + "."; |
40 | 78 | }); |
0 commit comments