budibase/packages/builder/src/components/design/NavigationPanel/ScreenDetailsModal.svelte

65 lines
1.5 KiB
Svelte
Raw Normal View History

2021-11-10 17:04:27 +01:00
<script>
2021-11-23 21:14:28 +01:00
import { ModalContent, Input, ProgressCircle } from "@budibase/bbui"
import sanitizeUrl from "builderStore/store/screenTemplates/utils/sanitizeUrl"
import { selectedAccessRole, allScreens } from "builderStore"
2021-11-10 17:04:27 +01:00
2021-11-11 13:09:36 +01:00
export let screenName
export let url
2021-11-17 11:24:14 +01:00
export let chooseModal
2021-11-23 10:01:12 +01:00
export let save
2021-11-23 21:14:28 +01:00
export let showProgressCircle = false
let routeError
let roleId = $selectedAccessRole || "BASIC"
const routeChanged = event => {
if (!event.detail.startsWith("/")) {
url = "/" + event.detail
}
url = sanitizeUrl(url)
if (routeExists(url, roleId)) {
routeError = "This URL is already taken for this access role"
} else {
routeError = ""
}
}
const routeExists = (url, roleId) => {
return $allScreens.some(
screen =>
screen.routing.route.toLowerCase() === url.toLowerCase() &&
screen.routing.roleId === roleId
)
}
2021-11-10 17:04:27 +01:00
</script>
<ModalContent
size="M"
2021-11-16 13:18:13 +01:00
title={"Enter details"}
2021-11-10 17:04:27 +01:00
confirmText={"Continue"}
2021-11-17 11:24:14 +01:00
onCancel={() => chooseModal(0)}
2021-11-23 10:01:12 +01:00
onConfirm={() => save()}
2021-11-10 17:04:27 +01:00
cancelText={"Back"}
disabled={!screenName || !url || routeError}
2021-11-10 17:04:27 +01:00
>
2021-11-11 13:09:36 +01:00
<Input label="Name" bind:value={screenName} />
<Input
label="URL"
error={routeError}
bind:value={url}
on:change={routeChanged}
/>
2021-11-23 21:14:28 +01:00
<div slot="footer">
{#if showProgressCircle}
<div class="footer-progress"><ProgressCircle size="S" /></div>
{/if}
</div>
2021-11-10 17:04:27 +01:00
</ModalContent>
2021-11-23 21:14:28 +01:00
<style>
.footer-progress {
margin-top: var(--spacing-s);
}
</style>