mirror of
https://github.com/pockethost/pockethost.git
synced 2025-06-07 14:46:41 +00:00
fix: incorrect instance information displaying on dashboard details
This commit is contained in:
parent
a63105cfd2
commit
b5d3cf48a6
@ -10,6 +10,7 @@
|
|||||||
const { instanceId } = $page.params
|
const { instanceId } = $page.params
|
||||||
|
|
||||||
const cm = createCleanupManagerSync()
|
const cm = createCleanupManagerSync()
|
||||||
|
instance.set(undefined)
|
||||||
onMount(async () => {
|
onMount(async () => {
|
||||||
const { watchInstanceById } = client()
|
const { watchInstanceById } = client()
|
||||||
watchInstanceById(instanceId, (r) => {
|
watchInstanceById(instanceId, (r) => {
|
||||||
@ -19,6 +20,9 @@
|
|||||||
instance.set(record)
|
instance.set(record)
|
||||||
}).then(cm.add)
|
}).then(cm.add)
|
||||||
})
|
})
|
||||||
|
cm.add(() => {
|
||||||
|
instance.set(undefined)
|
||||||
|
})
|
||||||
onDestroy(cm.cleanupAll)
|
onDestroy(cm.cleanupAll)
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
|
@ -1,12 +1,14 @@
|
|||||||
<script lang="ts">
|
<script lang="ts">
|
||||||
import { PUBLIC_PB_PROTOCOL } from '$env/static/public'
|
import { PUBLIC_PB_PROTOCOL } from '$env/static/public'
|
||||||
import { PUBLIC_PB_DOMAIN } from '$src/env'
|
import { PUBLIC_PB_DOMAIN } from '$src/env'
|
||||||
|
import { assertExists } from '@pockethost/common'
|
||||||
import Backup from './Backup.svelte'
|
import Backup from './Backup.svelte'
|
||||||
import Code from './Code.svelte'
|
import Code from './Code.svelte'
|
||||||
import Overview from './Overview.svelte'
|
import Overview from './Overview.svelte'
|
||||||
import Restore from './Restore.svelte'
|
import Restore from './Restore.svelte'
|
||||||
import { instance } from './store'
|
import { instance } from './store'
|
||||||
|
|
||||||
|
assertExists($instance, `Expected instance here`)
|
||||||
const { subdomain, status, platform, version } = $instance
|
const { subdomain, status, platform, version } = $instance
|
||||||
const url = `${PUBLIC_PB_PROTOCOL}://${subdomain}.${PUBLIC_PB_DOMAIN}`
|
const url = `${PUBLIC_PB_PROTOCOL}://${subdomain}.${PUBLIC_PB_DOMAIN}`
|
||||||
const code = `const url = '${url}'\nconst client = new PocketBase(url)`
|
const code = `const url = '${url}'\nconst client = new PocketBase(url)`
|
||||||
@ -15,8 +17,9 @@
|
|||||||
<svelte:head>
|
<svelte:head>
|
||||||
<title>{subdomain} details - PocketHost</title>
|
<title>{subdomain} details - PocketHost</title>
|
||||||
</svelte:head>
|
</svelte:head>
|
||||||
|
{#if $instance}
|
||||||
<Overview />
|
<Overview instance={$instance} />
|
||||||
<Code />
|
<Code instance={$instance} />
|
||||||
<Backup />
|
<Backup instance={$instance} />
|
||||||
<Restore />
|
<Restore instance={$instance} />
|
||||||
|
{/if}
|
||||||
|
@ -6,6 +6,7 @@
|
|||||||
BackupStatus,
|
BackupStatus,
|
||||||
type BackupRecord,
|
type BackupRecord,
|
||||||
type BackupRecordId,
|
type BackupRecordId,
|
||||||
|
type InstancesRecord,
|
||||||
type RecordId
|
type RecordId
|
||||||
} from '@pockethost/common'
|
} from '@pockethost/common'
|
||||||
import { reduce, sortBy } from '@s-libs/micro-dash'
|
import { reduce, sortBy } from '@s-libs/micro-dash'
|
||||||
@ -13,14 +14,15 @@
|
|||||||
import prettyBytes from 'pretty-bytes'
|
import prettyBytes from 'pretty-bytes'
|
||||||
import { onDestroy, onMount } from 'svelte'
|
import { onDestroy, onMount } from 'svelte'
|
||||||
import { writable } from 'svelte/store'
|
import { writable } from 'svelte/store'
|
||||||
import { instance } from './store'
|
|
||||||
|
export let instance: InstancesRecord
|
||||||
|
|
||||||
const cm = createCleanupManagerSync()
|
const cm = createCleanupManagerSync()
|
||||||
const backups = writable<BackupRecord[]>([])
|
const backups = writable<BackupRecord[]>([])
|
||||||
let isBackingUp = false
|
let isBackingUp = false
|
||||||
onMount(async () => {
|
onMount(async () => {
|
||||||
const { watchBackupsByInstanceId } = client()
|
const { watchBackupsByInstanceId } = client()
|
||||||
watchBackupsByInstanceId($instance.id, (r) => {
|
watchBackupsByInstanceId(instance.id, (r) => {
|
||||||
// console.log(`Handling backup update`, r)
|
// console.log(`Handling backup update`, r)
|
||||||
const { action, record } = r
|
const { action, record } = r
|
||||||
const _backups = reduce(
|
const _backups = reduce(
|
||||||
@ -48,7 +50,7 @@
|
|||||||
|
|
||||||
const startBackup = () => {
|
const startBackup = () => {
|
||||||
const { createInstanceBackupJob } = client()
|
const { createInstanceBackupJob } = client()
|
||||||
createInstanceBackupJob($instance.id)
|
createInstanceBackupJob(instance.id)
|
||||||
}
|
}
|
||||||
|
|
||||||
const restoreBackup = (backupId: BackupRecordId) => {
|
const restoreBackup = (backupId: BackupRecordId) => {
|
||||||
|
@ -2,9 +2,11 @@
|
|||||||
import CodeSample from '$components/CodeSample.svelte'
|
import CodeSample from '$components/CodeSample.svelte'
|
||||||
import { PUBLIC_PB_PROTOCOL } from '$env/static/public'
|
import { PUBLIC_PB_PROTOCOL } from '$env/static/public'
|
||||||
import { PUBLIC_PB_DOMAIN } from '$src/env'
|
import { PUBLIC_PB_DOMAIN } from '$src/env'
|
||||||
import { instance } from './store'
|
import type { InstancesRecord } from '@pockethost/common'
|
||||||
|
|
||||||
const { subdomain, status, platform, version } = $instance
|
export let instance: InstancesRecord
|
||||||
|
|
||||||
|
const { subdomain, status, platform, version } = instance
|
||||||
const url = `${PUBLIC_PB_PROTOCOL}://${subdomain}.${PUBLIC_PB_DOMAIN}`
|
const url = `${PUBLIC_PB_PROTOCOL}://${subdomain}.${PUBLIC_PB_DOMAIN}`
|
||||||
const code = `const url = '${url}'\nconst client = new PocketBase(url)`
|
const code = `const url = '${url}'\nconst client = new PocketBase(url)`
|
||||||
</script>
|
</script>
|
||||||
|
@ -2,10 +2,12 @@
|
|||||||
import ProvisioningStatus from '$components/ProvisioningStatus.svelte'
|
import ProvisioningStatus from '$components/ProvisioningStatus.svelte'
|
||||||
import { PUBLIC_PB_PROTOCOL } from '$env/static/public'
|
import { PUBLIC_PB_PROTOCOL } from '$env/static/public'
|
||||||
import { PUBLIC_PB_DOMAIN } from '$src/env'
|
import { PUBLIC_PB_DOMAIN } from '$src/env'
|
||||||
|
import type { InstancesRecord } from '@pockethost/common'
|
||||||
import { humanVersion } from '@pockethost/common'
|
import { humanVersion } from '@pockethost/common'
|
||||||
import { instance } from './store'
|
|
||||||
|
|
||||||
const { subdomain, status, platform, version } = $instance
|
export let instance: InstancesRecord
|
||||||
|
|
||||||
|
const { subdomain, status, platform, version } = instance
|
||||||
const url = `${PUBLIC_PB_PROTOCOL}://${subdomain}.${PUBLIC_PB_DOMAIN}`
|
const url = `${PUBLIC_PB_PROTOCOL}://${subdomain}.${PUBLIC_PB_DOMAIN}`
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
|
@ -2,19 +2,25 @@
|
|||||||
import { PUBLIC_APP_DOMAIN } from '$env/static/public'
|
import { PUBLIC_APP_DOMAIN } from '$env/static/public'
|
||||||
import { client } from '$src/pocketbase'
|
import { client } from '$src/pocketbase'
|
||||||
import { createCleanupManagerSync } from '$util/CleanupManager'
|
import { createCleanupManagerSync } from '$util/CleanupManager'
|
||||||
import { BackupStatus, type BackupRecord, type RecordId } from '@pockethost/common'
|
import {
|
||||||
|
BackupStatus,
|
||||||
|
type BackupRecord,
|
||||||
|
type InstancesRecord,
|
||||||
|
type RecordId
|
||||||
|
} from '@pockethost/common'
|
||||||
import { reduce, sortBy } from '@s-libs/micro-dash'
|
import { reduce, sortBy } from '@s-libs/micro-dash'
|
||||||
import prettyBytes from 'pretty-bytes'
|
import prettyBytes from 'pretty-bytes'
|
||||||
import { onDestroy, onMount } from 'svelte'
|
import { onDestroy, onMount } from 'svelte'
|
||||||
import { writable } from 'svelte/store'
|
import { writable } from 'svelte/store'
|
||||||
import { instance } from './store'
|
|
||||||
|
export let instance: InstancesRecord
|
||||||
|
|
||||||
const cm = createCleanupManagerSync()
|
const cm = createCleanupManagerSync()
|
||||||
const backups = writable<BackupRecord[]>([])
|
const backups = writable<BackupRecord[]>([])
|
||||||
let isBackingUp = false
|
let isBackingUp = false
|
||||||
onMount(async () => {
|
onMount(async () => {
|
||||||
const { watchBackupsByInstanceId } = client()
|
const { watchBackupsByInstanceId } = client()
|
||||||
watchBackupsByInstanceId($instance.id, (r) => {
|
watchBackupsByInstanceId(instance.id, (r) => {
|
||||||
// console.log(`Handling backup update`, r)
|
// console.log(`Handling backup update`, r)
|
||||||
const { action, record } = r
|
const { action, record } = r
|
||||||
const _backups = reduce(
|
const _backups = reduce(
|
||||||
@ -42,7 +48,7 @@
|
|||||||
|
|
||||||
const startRestore = () => {
|
const startRestore = () => {
|
||||||
const { createInstanceBackupJob } = client()
|
const { createInstanceBackupJob } = client()
|
||||||
createInstanceBackupJob($instance.id)
|
createInstanceBackupJob(instance.id)
|
||||||
}
|
}
|
||||||
|
|
||||||
let sourceBackupId = ''
|
let sourceBackupId = ''
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
import type { InstancesRecord } from '@pockethost/common'
|
import type { InstancesRecord } from '@pockethost/common'
|
||||||
import { writable } from 'svelte/store'
|
import { writable } from 'svelte/store'
|
||||||
|
|
||||||
export const instance = writable<InstancesRecord>()
|
export const instance = writable<InstancesRecord | undefined>()
|
||||||
|
@ -136,6 +136,7 @@ open https://pockethost.io
|
|||||||
|
|
||||||
**next**
|
**next**
|
||||||
|
|
||||||
|
- [x] fix: incorrect instance information displaying on dashboard details
|
||||||
- [x] fix: more helpful error message when backup fails for nonexistent instance
|
- [x] fix: more helpful error message when backup fails for nonexistent instance
|
||||||
- [x] chore: move version number to base package.json
|
- [x] chore: move version number to base package.json
|
||||||
- [ ] chore: refactor logging and async helpers
|
- [ ] chore: refactor logging and async helpers
|
||||||
|
Loading…
x
Reference in New Issue
Block a user