feat : Add version settings and API endpoint to display application version

This commit is contained in:
Yash 2025-12-25 00:21:10 +05:30
parent 860e6390f1
commit 612b00179b
4 changed files with 72 additions and 0 deletions

View file

@ -4,6 +4,7 @@ import { DateRangeSetting } from './DateRangeSetting';
import { LanguageSetting } from './LanguageSetting';
import { ThemeSetting } from './ThemeSetting';
import { TimezoneSetting } from './TimezoneSetting';
import { VersionSetting } from './VersionSetting';
export function PreferenceSettings() {
const { user } = useLoginQuery();
@ -31,6 +32,10 @@ export function PreferenceSettings() {
<Label>{formatMessage(labels.theme)}</Label>
<ThemeSetting />
</Column>
<Column>
<Label>{formatMessage(labels.version)}</Label>
<VersionSetting />
</Column>
</Column>
);
}

View file

@ -0,0 +1,31 @@
'use client';
import { Text } from '@umami/react-zen';
import { useEffect, useState } from 'react';
export function VersionSetting() {
const [version, setVersion] = useState<string>('');
const [loading, setLoading] = useState(true);
useEffect(() => {
const fetchVersion = async () => {
try {
const response = await fetch('/api/version');
const data = await response.json();
setVersion(data.version || 'unknown');
} catch (error) {
setVersion('unknown');
} finally {
setLoading(false);
}
};
fetchVersion();
}, []);
if (loading) {
return <Text>Loading...</Text>;
}
return <Text>{version}</Text>;
}