Support navigate to link in new tab (#9800)
* Support navigate to link in new tab * Add dropdown for Navigate To type * lint * Remove labels
This commit is contained in:
parent
6fdc328cd9
commit
6a6bbb38c4
|
@ -1,22 +1,66 @@
|
||||||
<script>
|
<script>
|
||||||
import { Label, Checkbox } from "@budibase/bbui"
|
import { store } from "builderStore"
|
||||||
|
import { onMount } from "svelte"
|
||||||
|
import { Label, Checkbox, Select } from "@budibase/bbui"
|
||||||
import DrawerBindableInput from "components/common/bindings/DrawerBindableInput.svelte"
|
import DrawerBindableInput from "components/common/bindings/DrawerBindableInput.svelte"
|
||||||
|
import DrawerBindableCombobox from "components/common/bindings/DrawerBindableCombobox.svelte"
|
||||||
|
|
||||||
export let parameters
|
export let parameters
|
||||||
export let bindings = []
|
export let bindings = []
|
||||||
|
|
||||||
|
$: urlOptions = $store.screens
|
||||||
|
.map(screen => screen.routing?.route)
|
||||||
|
.filter(x => x != null)
|
||||||
|
|
||||||
|
const typeOptions = [
|
||||||
|
{
|
||||||
|
label: "Screen",
|
||||||
|
value: "screen",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
label: "URL",
|
||||||
|
value: "url",
|
||||||
|
},
|
||||||
|
]
|
||||||
|
|
||||||
|
onMount(() => {
|
||||||
|
if (!parameters.type) {
|
||||||
|
parameters.type = "screen"
|
||||||
|
}
|
||||||
|
})
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<div class="root">
|
<div class="root">
|
||||||
<Label small>Screen</Label>
|
<Label small>Destination</Label>
|
||||||
<DrawerBindableInput
|
<Select
|
||||||
title="Destination URL"
|
placeholder={null}
|
||||||
|
bind:value={parameters.type}
|
||||||
|
options={typeOptions}
|
||||||
|
on:change={() => (parameters.url = "")}
|
||||||
|
/>
|
||||||
|
{#if parameters.type === "screen"}
|
||||||
|
<DrawerBindableCombobox
|
||||||
|
title="Destination"
|
||||||
placeholder="/screen"
|
placeholder="/screen"
|
||||||
value={parameters.url}
|
value={parameters.url}
|
||||||
on:change={value => (parameters.url = value.detail)}
|
on:change={value => (parameters.url = value.detail)}
|
||||||
{bindings}
|
{bindings}
|
||||||
|
options={urlOptions}
|
||||||
|
appendBindingsAsOptions={false}
|
||||||
|
/>
|
||||||
|
<div />
|
||||||
|
<Checkbox text="Open screen in modal" bind:value={parameters.peek} />
|
||||||
|
{:else}
|
||||||
|
<DrawerBindableInput
|
||||||
|
title="Destination"
|
||||||
|
placeholder="/url"
|
||||||
|
value={parameters.url}
|
||||||
|
on:change={value => (parameters.url = value.detail)}
|
||||||
|
{bindings}
|
||||||
/>
|
/>
|
||||||
<div />
|
<div />
|
||||||
<Checkbox text="Open screen in modal" bind:value={parameters.peek} />
|
<Checkbox text="New Tab" bind:value={parameters.externalNewTab} />
|
||||||
|
{/if}
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<style>
|
<style>
|
||||||
|
@ -24,7 +68,7 @@
|
||||||
display: grid;
|
display: grid;
|
||||||
align-items: center;
|
align-items: center;
|
||||||
gap: var(--spacing-m);
|
gap: var(--spacing-m);
|
||||||
grid-template-columns: auto 1fr;
|
grid-template-columns: auto;
|
||||||
max-width: 400px;
|
max-width: 400px;
|
||||||
margin: 0 auto;
|
margin: 0 auto;
|
||||||
}
|
}
|
||||||
|
|
|
@ -66,25 +66,30 @@ const createRouteStore = () => {
|
||||||
return state
|
return state
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
const navigate = (url, peek) => {
|
const navigate = (url, peek, externalNewTab) => {
|
||||||
if (get(builderStore).inBuilder) {
|
if (get(builderStore).inBuilder) {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
if (url) {
|
if (url) {
|
||||||
// If we're already peeking, don't peek again
|
// If we're already peeking, don't peek again
|
||||||
const isPeeking = get(store).queryParams?.peek
|
const isPeeking = get(store).queryParams?.peek
|
||||||
if (peek && !isPeeking) {
|
|
||||||
peekStore.actions.showPeek(url)
|
|
||||||
} else {
|
|
||||||
const external = !url.startsWith("/")
|
const external = !url.startsWith("/")
|
||||||
if (external) {
|
if (peek && !isPeeking && !external) {
|
||||||
|
peekStore.actions.showPeek(url)
|
||||||
|
} else if (external) {
|
||||||
|
if (url.startsWith("www")) {
|
||||||
|
url = `https://${url}`
|
||||||
|
}
|
||||||
|
if (externalNewTab) {
|
||||||
|
window.open(url, "_blank")
|
||||||
|
} else {
|
||||||
window.location.href = url
|
window.location.href = url
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
push(url)
|
push(url)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
const setRouterLoaded = () => {
|
const setRouterLoaded = () => {
|
||||||
store.update(state => ({ ...state, routerLoaded: true }))
|
store.update(state => ({ ...state, routerLoaded: true }))
|
||||||
}
|
}
|
||||||
|
|
|
@ -140,8 +140,8 @@ const triggerAutomationHandler = async action => {
|
||||||
}
|
}
|
||||||
|
|
||||||
const navigationHandler = action => {
|
const navigationHandler = action => {
|
||||||
const { url, peek } = action.parameters
|
const { url, peek, externalNewTab } = action.parameters
|
||||||
routeStore.actions.navigate(url, peek)
|
routeStore.actions.navigate(url, peek, externalNewTab)
|
||||||
}
|
}
|
||||||
|
|
||||||
const queryExecutionHandler = async action => {
|
const queryExecutionHandler = async action => {
|
||||||
|
|
Loading…
Reference in New Issue