2021-11-10 17:04:27 +01:00
|
|
|
<script>
|
2022-04-22 13:22:21 +02:00
|
|
|
import { ModalContent, Input } from "@budibase/bbui"
|
2023-10-30 13:46:44 +01:00
|
|
|
import sanitizeUrl from "builder/store/screenTemplates/utils/sanitizeUrl"
|
2022-03-02 20:10:18 +01:00
|
|
|
import { get } from "svelte/store"
|
2023-10-30 13:46:44 +01:00
|
|
|
import { screenStore } from "stores/frontend"
|
2021-11-10 17:04:27 +01:00
|
|
|
|
2022-03-02 20:10:18 +01:00
|
|
|
export let onConfirm
|
|
|
|
export let onCancel
|
2022-03-02 20:26:43 +01:00
|
|
|
export let screenUrl
|
2022-05-11 09:47:24 +02:00
|
|
|
export let screenRole
|
2022-03-07 11:41:52 +01:00
|
|
|
export let confirmText = "Continue"
|
2021-11-23 21:14:28 +01:00
|
|
|
|
2022-04-22 19:23:16 +02:00
|
|
|
const appPrefix = "/app"
|
2022-05-11 09:47:24 +02:00
|
|
|
let touched = false
|
|
|
|
let error
|
2022-04-22 19:23:16 +02:00
|
|
|
|
|
|
|
$: appUrl = screenUrl
|
|
|
|
? `${window.location.origin}${appPrefix}${screenUrl}`
|
|
|
|
: `${window.location.origin}${appPrefix}`
|
|
|
|
|
2021-11-15 12:03:09 +01:00
|
|
|
const routeChanged = event => {
|
|
|
|
if (!event.detail.startsWith("/")) {
|
2022-03-02 20:10:18 +01:00
|
|
|
screenUrl = "/" + event.detail
|
2021-11-15 12:03:09 +01:00
|
|
|
}
|
2022-03-02 20:26:43 +01:00
|
|
|
touched = true
|
2022-03-02 20:10:18 +01:00
|
|
|
screenUrl = sanitizeUrl(screenUrl)
|
|
|
|
if (routeExists(screenUrl)) {
|
2022-05-11 09:47:24 +02:00
|
|
|
error = "This URL is already taken for this access role"
|
2021-11-15 12:03:09 +01:00
|
|
|
} else {
|
2022-05-11 09:47:24 +02:00
|
|
|
error = null
|
2021-11-15 12:03:09 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-03-02 20:10:18 +01:00
|
|
|
const routeExists = url => {
|
2022-05-11 09:47:24 +02:00
|
|
|
if (!screenRole) {
|
|
|
|
return false
|
|
|
|
}
|
2023-10-30 13:46:44 +01:00
|
|
|
return get(screenStore).screens.some(
|
2021-11-15 12:03:09 +01:00
|
|
|
screen =>
|
|
|
|
screen.routing.route.toLowerCase() === url.toLowerCase() &&
|
2022-05-11 09:47:24 +02:00
|
|
|
screen.routing.roleId === screenRole
|
2021-11-15 12:03:09 +01:00
|
|
|
)
|
|
|
|
}
|
2021-11-29 12:53:46 +01:00
|
|
|
|
2022-03-02 20:10:18 +01:00
|
|
|
const confirmScreenDetails = async () => {
|
|
|
|
await onConfirm({
|
|
|
|
screenUrl,
|
|
|
|
})
|
|
|
|
}
|
2021-11-10 17:04:27 +01:00
|
|
|
</script>
|
|
|
|
|
|
|
|
<ModalContent
|
|
|
|
size="M"
|
2022-05-11 09:47:24 +02:00
|
|
|
title={"Screen details"}
|
2022-03-07 11:41:52 +01:00
|
|
|
{confirmText}
|
2022-03-02 20:10:18 +01:00
|
|
|
onConfirm={confirmScreenDetails}
|
|
|
|
{onCancel}
|
2021-11-10 17:04:27 +01:00
|
|
|
cancelText={"Back"}
|
2022-05-11 09:47:24 +02:00
|
|
|
disabled={!screenUrl || error || !touched}
|
2021-11-10 17:04:27 +01:00
|
|
|
>
|
2021-11-15 12:03:09 +01:00
|
|
|
<Input
|
2022-04-22 13:22:21 +02:00
|
|
|
label="Enter a URL for the new screen"
|
2022-05-11 09:47:24 +02:00
|
|
|
{error}
|
2022-03-02 20:10:18 +01:00
|
|
|
bind:value={screenUrl}
|
2021-11-15 12:03:09 +01:00
|
|
|
on:change={routeChanged}
|
|
|
|
/>
|
2022-04-22 19:23:16 +02:00
|
|
|
<div class="app-server" title={appUrl}>
|
|
|
|
{appUrl}
|
|
|
|
</div>
|
2021-11-10 17:04:27 +01:00
|
|
|
</ModalContent>
|
2022-04-22 19:23:16 +02:00
|
|
|
|
|
|
|
<style>
|
|
|
|
.app-server {
|
|
|
|
color: var(--spectrum-global-color-gray-600);
|
|
|
|
width: 320px;
|
|
|
|
white-space: nowrap;
|
|
|
|
overflow: hidden;
|
|
|
|
text-overflow: ellipsis;
|
|
|
|
}
|
|
|
|
</style>
|