mirror of
https://github.com/Nystik-gh/ignis.git
synced 2026-06-17 04:35:53 +00:00
add version to vault manager
This commit is contained in:
@@ -45,10 +45,12 @@ app.use((req, res, next) => {
|
|||||||
const fsRoutes = require("./routes/fs");
|
const fsRoutes = require("./routes/fs");
|
||||||
const vaultRoutes = require("./routes/vault");
|
const vaultRoutes = require("./routes/vault");
|
||||||
const proxyRoutes = require("./routes/proxy");
|
const proxyRoutes = require("./routes/proxy");
|
||||||
|
const versionRoutes = require("./routes/version");
|
||||||
|
|
||||||
app.use("/api/fs", fsRoutes);
|
app.use("/api/fs", fsRoutes);
|
||||||
app.use("/api/vault", vaultRoutes);
|
app.use("/api/vault", vaultRoutes);
|
||||||
app.use("/api/proxy", proxyRoutes);
|
app.use("/api/proxy", proxyRoutes);
|
||||||
|
app.use("/api/version", versionRoutes);
|
||||||
|
|
||||||
// Serve vault files for resource URLs (images, attachments, etc.)
|
// Serve vault files for resource URLs (images, attachments, etc.)
|
||||||
// Vault ID is the first path segment: /vault-files/<vault-id>/path/to/file
|
// Vault ID is the first path segment: /vault-files/<vault-id>/path/to/file
|
||||||
|
|||||||
17
server/routes/version.js
Normal file
17
server/routes/version.js
Normal file
@@ -0,0 +1,17 @@
|
|||||||
|
const express = require("express");
|
||||||
|
const { getVersion } = require("../version");
|
||||||
|
const config = require("../config");
|
||||||
|
|
||||||
|
const router = express.Router();
|
||||||
|
|
||||||
|
router.get("/", (req, res) => {
|
||||||
|
const pkg = require("../../package.json");
|
||||||
|
|
||||||
|
res.json({
|
||||||
|
version: getVersion(),
|
||||||
|
semver: pkg.version,
|
||||||
|
obsidianVersion: config.obsidianVersion,
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
module.exports = router;
|
||||||
@@ -30,6 +30,7 @@
|
|||||||
let dialogValue = "";
|
let dialogValue = "";
|
||||||
let errorMessage = "";
|
let errorMessage = "";
|
||||||
let pendingReload = false;
|
let pendingReload = false;
|
||||||
|
let version = "";
|
||||||
|
|
||||||
const menuItems = [
|
const menuItems = [
|
||||||
{ id: "rename", label: "Rename" },
|
{ id: "rename", label: "Rename" },
|
||||||
@@ -47,6 +48,16 @@
|
|||||||
)
|
)
|
||||||
: vaults;
|
: vaults;
|
||||||
|
|
||||||
|
async function fetchVersion() {
|
||||||
|
try {
|
||||||
|
const res = await fetch("/api/version");
|
||||||
|
const data = await res.json();
|
||||||
|
version = data.version;
|
||||||
|
} catch (e) {
|
||||||
|
console.warn("[VaultManager] Failed to fetch version:", e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
async function refreshVaults() {
|
async function refreshVaults() {
|
||||||
try {
|
try {
|
||||||
vaults = await vaultService.listVaults();
|
vaults = await vaultService.listVaults();
|
||||||
@@ -177,6 +188,7 @@
|
|||||||
|
|
||||||
onMount(() => {
|
onMount(() => {
|
||||||
refreshVaults();
|
refreshVaults();
|
||||||
|
fetchVersion();
|
||||||
});
|
});
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
@@ -246,6 +258,11 @@
|
|||||||
</div>
|
</div>
|
||||||
|
|
||||||
<svelte:fragment slot="footer">
|
<svelte:fragment slot="footer">
|
||||||
|
<div class="footer-left">
|
||||||
|
{#if version}
|
||||||
|
<span class="version-info">Ignis v{version}</span>
|
||||||
|
{/if}
|
||||||
|
</div>
|
||||||
<div class="footer-right">
|
<div class="footer-right">
|
||||||
<Button variant="ghost" on:click={showCreateDialog}>
|
<Button variant="ghost" on:click={showCreateDialog}>
|
||||||
<svelte:fragment slot="icon">
|
<svelte:fragment slot="icon">
|
||||||
@@ -400,8 +417,19 @@
|
|||||||
white-space: nowrap;
|
white-space: nowrap;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.footer-left {
|
||||||
|
display: flex;
|
||||||
|
align-items: center;
|
||||||
|
}
|
||||||
|
|
||||||
.footer-right {
|
.footer-right {
|
||||||
display: flex;
|
display: flex;
|
||||||
justify-content: flex-end;
|
justify-content: flex-end;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.version-info {
|
||||||
|
font-size: 0.75rem;
|
||||||
|
color: var(--text-muted);
|
||||||
|
user-select: none;
|
||||||
|
}
|
||||||
</style>
|
</style>
|
||||||
|
|||||||
Reference in New Issue
Block a user