add paging and add more custom table renderers
This commit is contained in:
parent
f19e44a341
commit
5732c80a8a
|
@ -21,5 +21,6 @@
|
||||||
flex-direction: row;
|
flex-direction: row;
|
||||||
gap: var(--spacing-m);
|
gap: var(--spacing-m);
|
||||||
align-items: center;
|
align-items: center;
|
||||||
|
margin-left: auto;
|
||||||
}
|
}
|
||||||
</style>
|
</style>
|
||||||
|
|
|
@ -2,12 +2,11 @@
|
||||||
import { Icon } from "@budibase/bbui"
|
import { Icon } from "@budibase/bbui"
|
||||||
|
|
||||||
export let value
|
export let value
|
||||||
$: console.log(value)
|
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<div class="cell">
|
<div class="cell">
|
||||||
<Icon name="JourneyVoyager" />
|
<Icon name="JourneyVoyager" />
|
||||||
<div>{value.length}</div>
|
<div>{value?.length}</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<style>
|
<style>
|
||||||
|
|
|
@ -3,6 +3,7 @@
|
||||||
ActionButton,
|
ActionButton,
|
||||||
DatePicker,
|
DatePicker,
|
||||||
Layout,
|
Layout,
|
||||||
|
notifications,
|
||||||
Pagination,
|
Pagination,
|
||||||
Select,
|
Select,
|
||||||
Table,
|
Table,
|
||||||
|
@ -10,16 +11,26 @@
|
||||||
} from "@budibase/bbui"
|
} from "@budibase/bbui"
|
||||||
import { onMount } from "svelte"
|
import { onMount } from "svelte"
|
||||||
import { backups } from "stores/portal"
|
import { backups } from "stores/portal"
|
||||||
|
import { createPaginationStore } from "helpers/pagination"
|
||||||
import DatasourceRenderer from "./DatasourceRenderer.svelte"
|
import DatasourceRenderer from "./DatasourceRenderer.svelte"
|
||||||
import ScreensRenderer from "./ScreensRenderer.svelte"
|
import ScreensRenderer from "./ScreensRenderer.svelte"
|
||||||
import AutomationsRenderer from "./AutomationsRenderer.svelte"
|
import AutomationsRenderer from "./AutomationsRenderer.svelte"
|
||||||
import CreateBackupModal from "./CreateBackupModal.svelte"
|
import CreateBackupModal from "./CreateBackupModal.svelte"
|
||||||
import TriggerRenderer from "./TriggerRenderer.svelte"
|
import TriggerRenderer from "./TriggerRenderer.svelte"
|
||||||
import ActionsRenderer from "./ActionsRenderer.svelte"
|
import ActionsRenderer from "./ActionsRenderer.svelte"
|
||||||
|
import DateRenderer from "./DateRenderer.svelte"
|
||||||
|
import DaysRenderer from "./DaysRenderer.svelte"
|
||||||
|
|
||||||
export let app
|
export let app
|
||||||
|
|
||||||
let backupData = null
|
let backupData = null
|
||||||
let modal
|
let modal
|
||||||
|
let trigger = null
|
||||||
|
let pageInfo = createPaginationStore()
|
||||||
|
$: page = $pageInfo.page
|
||||||
|
$: console.log(page)
|
||||||
|
|
||||||
|
$: fetchBackups(app.instance._id, trigger, page)
|
||||||
|
|
||||||
const triggers = {
|
const triggers = {
|
||||||
PUBLISH: "Publish",
|
PUBLISH: "Publish",
|
||||||
|
@ -31,10 +42,14 @@
|
||||||
trigger: {
|
trigger: {
|
||||||
displayName: "Trigger",
|
displayName: "Trigger",
|
||||||
},
|
},
|
||||||
|
days: {
|
||||||
|
displayName: null,
|
||||||
|
},
|
||||||
|
|
||||||
name: {
|
name: {
|
||||||
displayName: "Name",
|
displayName: "Name",
|
||||||
},
|
},
|
||||||
date: {
|
createdAt: {
|
||||||
displayName: "Date",
|
displayName: "Date",
|
||||||
},
|
},
|
||||||
datasources: {
|
datasources: {
|
||||||
|
@ -60,33 +75,52 @@
|
||||||
{ column: "automations", component: AutomationsRenderer },
|
{ column: "automations", component: AutomationsRenderer },
|
||||||
{ column: "trigger", component: TriggerRenderer },
|
{ column: "trigger", component: TriggerRenderer },
|
||||||
{ column: "actions", component: ActionsRenderer },
|
{ column: "actions", component: ActionsRenderer },
|
||||||
|
{ column: "createdAt", component: DateRenderer },
|
||||||
|
{ column: "days", component: DaysRenderer },
|
||||||
]
|
]
|
||||||
|
|
||||||
async function fetchBackups() {
|
function flattenBackups(backups) {
|
||||||
backups.load()
|
let flattened = backups.map(backup => {
|
||||||
backupData = enrichBackupData($backups)
|
|
||||||
}
|
|
||||||
|
|
||||||
function enrichBackupData(backups) {
|
|
||||||
let enrichedBackups = backups.map(backup => {
|
|
||||||
return {
|
return {
|
||||||
...backup,
|
...backup,
|
||||||
...Object.assign(...backup.contents),
|
days: getDaysBetween(backup.createdAt),
|
||||||
|
//...Object.assign(...backup?.contents),
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
return enrichedBackups
|
return flattened
|
||||||
}
|
}
|
||||||
|
|
||||||
function createManualBackup(name) {
|
function getDaysBetween(date) {
|
||||||
backups.createManualBackup({ appId: app.appId, name })
|
const now = new Date()
|
||||||
|
const backupDate = new Date(date)
|
||||||
|
backupDate.setDate(backupDate.getDate() - 1)
|
||||||
|
console.log(backupDate)
|
||||||
|
const oneDay = 24 * 60 * 60 * 1000
|
||||||
|
return now > backupDate
|
||||||
|
? Math.round(Math.abs((now - backupDate) / oneDay))
|
||||||
|
: 0
|
||||||
}
|
}
|
||||||
|
|
||||||
onMount(async () => {
|
async function fetchBackups(appId, trigger, page) {
|
||||||
console.log(await backups.searchBackups(app.appId))
|
const response = await backups.searchBackups(appId, trigger, page)
|
||||||
|
pageInfo.fetched(response.hasNextPage, response.nextPage)
|
||||||
|
|
||||||
await fetchBackups()
|
// flatten so we have an easier structure to use for the table schema
|
||||||
})
|
backupData = flattenBackups(response.data)
|
||||||
|
}
|
||||||
|
|
||||||
|
async function createManualBackup(name) {
|
||||||
|
try {
|
||||||
|
let response = await backups.createManualBackup({
|
||||||
|
appId: app.instance._id,
|
||||||
|
name,
|
||||||
|
})
|
||||||
|
notifications.success(response.message)
|
||||||
|
} catch {
|
||||||
|
notifications.error("Unable to create backup")
|
||||||
|
}
|
||||||
|
}
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<div class="root">
|
<div class="root">
|
||||||
|
@ -122,7 +156,13 @@
|
||||||
border={false}
|
border={false}
|
||||||
/>
|
/>
|
||||||
<div class="pagination">
|
<div class="pagination">
|
||||||
<Pagination page={1} />
|
<Pagination
|
||||||
|
page={$pageInfo.pageNumber}
|
||||||
|
hasPrevPage={$pageInfo.loading ? false : $pageInfo.hasPrevPage}
|
||||||
|
hasNextPage={$pageInfo.loading ? false : $pageInfo.hasNextPage}
|
||||||
|
goToPrevPage={pageInfo.prevPage}
|
||||||
|
goToNextPage={pageInfo.nextPage}
|
||||||
|
/>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
{/if}
|
{/if}
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
|
|
||||||
<div class="cell">
|
<div class="cell">
|
||||||
<Icon name="Data" />
|
<Icon name="Data" />
|
||||||
<div>{value.length}</div>
|
<div>{value?.length}</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<style>
|
<style>
|
||||||
|
|
|
@ -0,0 +1,17 @@
|
||||||
|
<script>
|
||||||
|
import DateTimeRenderer from "components/common/renderers/DateTimeRenderer.svelte"
|
||||||
|
export let value
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<div class="cell">
|
||||||
|
<DateTimeRenderer {value} />
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<style>
|
||||||
|
.cell {
|
||||||
|
display: flex;
|
||||||
|
flex-direction: row;
|
||||||
|
gap: var(--spacing-m);
|
||||||
|
align-items: center;
|
||||||
|
}
|
||||||
|
</style>
|
|
@ -0,0 +1,18 @@
|
||||||
|
<script>
|
||||||
|
export let value
|
||||||
|
$: console.log(value)
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<div class="cell">
|
||||||
|
{value}
|
||||||
|
{`day${value == 1 ? "" : "s"} ago`}
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<style>
|
||||||
|
.cell {
|
||||||
|
display: flex;
|
||||||
|
flex-direction: row;
|
||||||
|
gap: var(--spacing-m);
|
||||||
|
align-items: center;
|
||||||
|
}
|
||||||
|
</style>
|
|
@ -6,7 +6,7 @@
|
||||||
|
|
||||||
<div class="cell">
|
<div class="cell">
|
||||||
<Icon name="WebPage" />
|
<Icon name="WebPage" />
|
||||||
<div>{value.length}</div>
|
<div>{value?.length}</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<style>
|
<style>
|
||||||
|
|
|
@ -2,18 +2,20 @@
|
||||||
import { Icon } from "@budibase/bbui"
|
import { Icon } from "@budibase/bbui"
|
||||||
|
|
||||||
export let value
|
export let value
|
||||||
|
|
||||||
|
let trigger = value.charAt(0).toUpperCase() + value.slice(1)
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<div class="cell">
|
<div class="cell">
|
||||||
{#if value === "PUBLISH"}
|
{#if value === "publish"}
|
||||||
<Icon name="GlobeCheck" />
|
<Icon name="GlobeCheck" />
|
||||||
<div>{value}</div>
|
<div>{trigger}</div>
|
||||||
{:else if value === "MANUAL"}
|
{:else if value === "manual"}
|
||||||
<Icon name="Floppy" />
|
<Icon name="SaveFloppy" />
|
||||||
<div>{value}</div>
|
<div>{trigger}</div>
|
||||||
{:else if value === "SCHEDULED"}
|
{:else if value === "scheduled"}
|
||||||
<Icon name="Clock" />
|
<Icon name="Clock" />
|
||||||
<div>{value}</div>
|
<div>{trigger}</div>
|
||||||
{/if}
|
{/if}
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
|
|
@ -20,8 +20,8 @@ export function createBackupsStore() {
|
||||||
])
|
])
|
||||||
}
|
}
|
||||||
|
|
||||||
async function searchBackups(appId) {
|
async function searchBackups(appId, trigger, page) {
|
||||||
return API.searchBackups(appId)
|
return API.searchBackups({appId, trigger, page})
|
||||||
}
|
}
|
||||||
|
|
||||||
async function createManualBackup(appId, name) {
|
async function createManualBackup(appId, name) {
|
||||||
|
|
|
@ -2,12 +2,13 @@ export const buildBackupsEndpoints = API => ({
|
||||||
/**
|
/**
|
||||||
* Gets a list of users in the current tenant.
|
* Gets a list of users in the current tenant.
|
||||||
*/
|
*/
|
||||||
searchBackups: async appId => {
|
searchBackups: async ({appId, trigger, page}) => {
|
||||||
|
console.log(page)
|
||||||
return await API.post({
|
return await API.post({
|
||||||
url: `/api/apps/${appId}/backups/search`,
|
url: `/api/apps/${appId}/backups/search`,
|
||||||
body: {
|
body: {
|
||||||
trigger: "MANUAL",
|
page,
|
||||||
},
|
}
|
||||||
})
|
})
|
||||||
},
|
},
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue