mirror of
https://github.com/immich-app/immich.git
synced 2025-01-21 00:52:43 -05:00
docs: version switcher (#10091)
* docs: version switcher * chore: pump script * chore: fix linting on bash script * chore: remove 1.106.0 from archived versions * chore: change version archive script to take next server version not current version --------- Co-authored-by: Zack Pollard <zackpollard@ymail.com>
This commit is contained in:
parent
05874bd84e
commit
321c3ccfc6
6 changed files with 95 additions and 0 deletions
|
@ -94,6 +94,10 @@ const config = {
|
||||||
srcDark: 'img/immich-logo-inline-dark.png',
|
srcDark: 'img/immich-logo-inline-dark.png',
|
||||||
},
|
},
|
||||||
items: [
|
items: [
|
||||||
|
{
|
||||||
|
type: 'custom-versionSwitcher',
|
||||||
|
position: 'right',
|
||||||
|
},
|
||||||
{
|
{
|
||||||
to: '/docs/overview/introduction',
|
to: '/docs/overview/introduction',
|
||||||
position: 'right',
|
position: 'right',
|
||||||
|
|
59
docs/src/components/version-switcher.tsx
Normal file
59
docs/src/components/version-switcher.tsx
Normal file
|
@ -0,0 +1,59 @@
|
||||||
|
import '@docusaurus/theme-classic/lib/theme/Unlisted/index';
|
||||||
|
import { useWindowSize } from '@docusaurus/theme-common';
|
||||||
|
import DropdownNavbarItem from '@theme/NavbarItem/DropdownNavbarItem';
|
||||||
|
import React, { useEffect, useState } from 'react';
|
||||||
|
|
||||||
|
export default function VersionSwitcher(): JSX.Element {
|
||||||
|
const [versions, setVersions] = useState([]);
|
||||||
|
const [label, setLabel] = useState('Versions');
|
||||||
|
|
||||||
|
const windowSize = useWindowSize();
|
||||||
|
|
||||||
|
useEffect(() => {
|
||||||
|
async function getVersions() {
|
||||||
|
try {
|
||||||
|
let baseUrl = 'https://immich.app';
|
||||||
|
if (window.location.origin === 'http://localhost:3005') {
|
||||||
|
baseUrl = window.location.origin;
|
||||||
|
}
|
||||||
|
|
||||||
|
const response = await fetch(`${baseUrl}/archived-versions.json`);
|
||||||
|
|
||||||
|
const archiveVersions = await response.json();
|
||||||
|
|
||||||
|
const allVersions = [
|
||||||
|
{ label: 'Next', url: 'https://main.preview.immich.app' },
|
||||||
|
{ label: 'Latest', url: 'https://immich.app' },
|
||||||
|
...archiveVersions,
|
||||||
|
];
|
||||||
|
setVersions(allVersions);
|
||||||
|
|
||||||
|
const activeVersion = allVersions.find((version) => new URL(version.url).origin === window.location.origin);
|
||||||
|
if (activeVersion) {
|
||||||
|
setLabel(activeVersion.label);
|
||||||
|
}
|
||||||
|
} catch (error) {
|
||||||
|
console.error('Failed to fetch versions', error);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (versions.length === 0) {
|
||||||
|
getVersions();
|
||||||
|
}
|
||||||
|
}, []);
|
||||||
|
|
||||||
|
return (
|
||||||
|
versions.length > 0 && (
|
||||||
|
<DropdownNavbarItem
|
||||||
|
className="navbar__item"
|
||||||
|
label={label}
|
||||||
|
mobile={windowSize === 'mobile'}
|
||||||
|
items={versions.map(({ label, url }) => ({
|
||||||
|
label,
|
||||||
|
to: url,
|
||||||
|
target: '_self',
|
||||||
|
}))}
|
||||||
|
/>
|
||||||
|
)
|
||||||
|
);
|
||||||
|
}
|
7
docs/src/theme/NavbarItem/ComponentTypes.js
Normal file
7
docs/src/theme/NavbarItem/ComponentTypes.js
Normal file
|
@ -0,0 +1,7 @@
|
||||||
|
import ComponentTypes from '@theme-original/NavbarItem/ComponentTypes';
|
||||||
|
import VersionSwitcher from '@site/src/components/version-switcher';
|
||||||
|
|
||||||
|
export default {
|
||||||
|
...ComponentTypes,
|
||||||
|
'custom-versionSwitcher': VersionSwitcher,
|
||||||
|
};
|
6
docs/static/archived-versions.json
vendored
Normal file
6
docs/static/archived-versions.json
vendored
Normal file
|
@ -0,0 +1,6 @@
|
||||||
|
[
|
||||||
|
{
|
||||||
|
"label": "v1.105.1",
|
||||||
|
"url": "https://v1.105.1.archive.immich.app/"
|
||||||
|
}
|
||||||
|
]
|
17
misc/release/archive-version.js
Executable file
17
misc/release/archive-version.js
Executable file
|
@ -0,0 +1,17 @@
|
||||||
|
#! /usr/bin/env node
|
||||||
|
const { readFileSync, writeFileSync } = require('node:fs');
|
||||||
|
|
||||||
|
const lastVersion = process.argv[2];
|
||||||
|
if (!lastVersion) {
|
||||||
|
console.log('Usage: archive-version.js <version>');
|
||||||
|
process.exit(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
const filename = './docs/static/archived-versions.json';
|
||||||
|
const oldVersions = JSON.parse(readFileSync(filename));
|
||||||
|
const newVersions = [
|
||||||
|
{ label: lastVersion, url: `https://${lastVersion}.archive.immich.app` },
|
||||||
|
...oldVersions,
|
||||||
|
];
|
||||||
|
|
||||||
|
writeFileSync(filename, JSON.stringify(newVersions, null, 2) + '\n');
|
|
@ -83,4 +83,6 @@ sed -i "s/version_number: \"$CURRENT_SERVER\"$/version_number: \"$NEXT_SERVER\"/
|
||||||
sed -i "s/\"android\.injected\.version\.code\" => $CURRENT_MOBILE,/\"android\.injected\.version\.code\" => $NEXT_MOBILE,/" mobile/android/fastlane/Fastfile
|
sed -i "s/\"android\.injected\.version\.code\" => $CURRENT_MOBILE,/\"android\.injected\.version\.code\" => $NEXT_MOBILE,/" mobile/android/fastlane/Fastfile
|
||||||
sed -i "s/^version: $CURRENT_SERVER+$CURRENT_MOBILE$/version: $NEXT_SERVER+$NEXT_MOBILE/" mobile/pubspec.yaml
|
sed -i "s/^version: $CURRENT_SERVER+$CURRENT_MOBILE$/version: $NEXT_SERVER+$NEXT_MOBILE/" mobile/pubspec.yaml
|
||||||
|
|
||||||
|
./misc/release/archive-version.js "$NEXT_SERVER"
|
||||||
|
|
||||||
echo "IMMICH_VERSION=v$NEXT_SERVER" >>"$GITHUB_ENV"
|
echo "IMMICH_VERSION=v$NEXT_SERVER" >>"$GITHUB_ENV"
|
||||||
|
|
Loading…
Add table
Reference in a new issue