Support versioning docs (#259)

* Setup versioned docs

* changelog

* correct version number
This commit is contained in:
Will Hunt 2022-03-30 11:36:37 +01:00 committed by GitHub
parent e287cca495
commit 3cf1552ea7
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
5 changed files with 76 additions and 1 deletions

View File

@ -24,4 +24,4 @@ jobs:
github_token: ${{ secrets.GITHUB_TOKEN }} github_token: ${{ secrets.GITHUB_TOKEN }}
keep_files: true keep_files: true
publish_dir: ./book publish_dir: ./book
destination_dir: ./ destination_dir: ./latest

32
.github/workflows/docs-release.yml vendored Normal file
View File

@ -0,0 +1,32 @@
name: Build docs
on:
release:
types: [published]
jobs:
deploy:
runs-on: ubuntu-20.04
steps:
- uses: actions/checkout@v2
- name: Get release tag
run: echo "RELEASE_VERSION=${GITHUB_REF#refs/*/}" >> $GITHUB_ENV
- name: Setup mdBook
uses: peaceiris/actions-mdbook@v1
with:
mdbook-version: '0.4.11'
- name: Set version of docs
run: echo 'window.HOOKSHOT_VERSION = "${{ env.RELEASE_VERSION }}";' > ./docs/_site/version.js
- run: mdbook build
- name: Deploy latest
uses: peaceiris/actions-gh-pages@v3
with:
github_token: ${{ secrets.GITHUB_TOKEN }}
keep_files: true
publish_dir: ./book
destination_dir: ./${{ env.RELEASE_VERSION }}

View File

@ -22,3 +22,8 @@ git-repository-url = "https://github.com/matrix-org/matrix-hookshot"
additional-css = [ additional-css = [
"docs/_site/style.css" "docs/_site/style.css"
] ]
additional-js = [
"docs/_site/main.js",
"docs/_site/version.js"
]

36
docs/_site/main.js Normal file
View File

@ -0,0 +1,36 @@
window.addEventListener("load", () => {
const scrollbox = document.querySelector(".sidebar-scrollbox");
scrollbox.innerHTML = `<div class="version-box"><span>Version: </span></div>${scrollbox.innerHTML}`;
const currentVersion = window.HOOKSHOT_VERSION || 'latest';
const selectElement = document.createElement("select");
fetch("https://api.github.com/repos/matrix-org/matrix-hookshot/releases", {
cache: "force-cache",
}).then(res =>
res.json()
).then(releases => {
selectElement.innerHTML = "";
for (const version of ['latest', ...releases.map(r => r.tag_name).filter(s => s !== "0.1.0")]) {
const option = document.createElement("option");
option.innerHTML = version;
selectElement.add(option);
if (currentVersion === version) {
option.setAttribute('selected', '');
}
}
}).catch(ex => {
console.error("Failed to fetch version data", ex);
})
const option = document.createElement("option");
option.innerHTML = 'loading...';
selectElement.add(option);
selectElement.addEventListener('change', (event) => {
const versionlessPath = window.location.pathname.split('/').slice(2).join('/');
window.location = `${window.location.origin}/${event.target.value}/${versionlessPath}`;
});
document.querySelector(".version-box").appendChild(selectElement);
});

2
docs/_site/version.js Normal file
View File

@ -0,0 +1,2 @@
// This is modified by the build script
window.HOOKSHOT_VERSION = "latest";