2021-11-10 17:04:27 +01:00
|
|
|
<script>
|
|
|
|
import { ModalContent, Input } from "@budibase/bbui"
|
2021-11-15 12:03:09 +01:00
|
|
|
import sanitizeUrl from "builderStore/store/screenTemplates/utils/sanitizeUrl"
|
|
|
|
import { selectedAccessRole, allScreens } from "builderStore"
|
2021-11-10 17:04:27 +01:00
|
|
|
|
|
|
|
export let modal
|
|
|
|
export let navigationSelectionModal
|
2021-11-11 13:09:36 +01:00
|
|
|
export let screenName
|
2021-11-15 12:03:09 +01:00
|
|
|
export let url
|
|
|
|
|
|
|
|
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"}
|
|
|
|
onCancel={() => modal.show()}
|
|
|
|
onConfirm={() => navigationSelectionModal.show()}
|
|
|
|
cancelText={"Back"}
|
2021-11-15 12:03:09 +01:00
|
|
|
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} />
|
2021-11-15 12:03:09 +01:00
|
|
|
<Input
|
|
|
|
label="URL"
|
|
|
|
error={routeError}
|
|
|
|
bind:value={url}
|
|
|
|
on:change={routeChanged}
|
|
|
|
/>
|
2021-11-10 17:04:27 +01:00
|
|
|
</ModalContent>
|