ability to delete databases

This commit is contained in:
Martin McKeaveney 2020-03-31 17:53:34 +01:00
parent ff0fe2cba5
commit c0bd5f2fbb
3 changed files with 53 additions and 0 deletions

View File

@ -0,0 +1,35 @@
<script>
import Modal from "../../../common/Modal.svelte"
import { store } from "../../../builderStore"
import ActionButton from "../../../common/ActionButton.svelte"
import * as api from "../api"
export let onClosed
let databaseName
// async function deleteDatabase() {
// const response = await api.deleteDatabase($)
// store.createDatabaseForApp(response)
// onClosed()
// }
</script>
<section>
Are you sure you want to delete {database}?
<footer>
<ActionButton disabled={!databaseName} on:click={deleteDatabase}>
Delete
</ActionButton>
</section>
<style>
footer {
position: absolute;
padding: 20px;
width: 100%;
bottom: 0;
left: 0;
background: #fafafa;
}
</style>

View File

@ -4,3 +4,4 @@ export { default as CreateEditModelModal } from "./CreateEditModel.svelte"
export { default as CreateEditViewModal } from "./CreateEditView.svelte" export { default as CreateEditViewModal } from "./CreateEditView.svelte"
export { default as CreateDatabaseModal } from "./CreateDatabase.svelte" export { default as CreateDatabaseModal } from "./CreateDatabase.svelte"
export { default as CreateUserModal } from "./CreateUser.svelte" export { default as CreateUserModal } from "./CreateUser.svelte"
export { default as DeleteDatabaseModal } from "./DeleteDatabase.svelte"

View File

@ -1,6 +1,7 @@
<script> <script>
import { tick } from "svelte" import { tick } from "svelte"
import { store, backendUiStore } from "../builderStore" import { store, backendUiStore } from "../builderStore"
import api from "../builderStore/api"
import getIcon from "../common/icon" import getIcon from "../common/icon"
import { CheckIcon } from "../common/Icons" import { CheckIcon } from "../common/Icons"
@ -13,6 +14,17 @@
backendUiStore.actions.views.select(views[0]) backendUiStore.actions.views.select(views[0])
backendUiStore.actions.database.select(database) backendUiStore.actions.database.select(database)
} }
async function deleteDatabase(database) {
const DELETE_DATABASE_URL = `/_builder/instance/_master/0/api/record/applications/${$store.appId}/instances/${database.id}`
const response = await api.delete(DELETE_DATABASE_URL)
store.update(state => {
state.appInstances = state.appInstances.filter(
db => db.id !== database.id
)
return state
})
}
</script> </script>
<div class="root"> <div class="root">
@ -30,6 +42,9 @@
on:click={() => selectDatabase(database)}> on:click={() => selectDatabase(database)}>
{database.name} {database.name}
</button> </button>
<i
class="ri-close-line hoverable uk-margin-small-left"
on:click={() => deleteDatabase(database)} />
</li> </li>
{/each} {/each}
</ul> </ul>
@ -53,6 +68,8 @@
li { li {
margin: 0.5rem 0; margin: 0.5rem 0;
display: flex;
align-items: center;
} }
button { button {