Adding a way to see the deployed webhook URLs to the deployment page.
This commit is contained in:
parent
533e502143
commit
91d0222a5b
|
@ -10,7 +10,6 @@
|
||||||
|
|
||||||
let modal
|
let modal
|
||||||
|
|
||||||
$: blockDefinitions = $automationStore.blockDefinitions
|
|
||||||
$: instanceId = $backendUiStore.selectedDatabase._id
|
$: instanceId = $backendUiStore.selectedDatabase._id
|
||||||
$: automation = $automationStore.selectedAutomation?.automation
|
$: automation = $automationStore.selectedAutomation?.automation
|
||||||
|
|
||||||
|
@ -21,7 +20,7 @@
|
||||||
stepId,
|
stepId,
|
||||||
type: blockType,
|
type: blockType,
|
||||||
})
|
})
|
||||||
if (stepId === blockDefinitions.TRIGGER["WEBHOOK"].stepId) {
|
if (stepId === "WEBHOOK") {
|
||||||
modal.show()
|
modal.show()
|
||||||
}
|
}
|
||||||
analytics.captureEvent("Added Automation Block", {
|
analytics.captureEvent("Added Automation Block", {
|
||||||
|
|
|
@ -1,12 +1,20 @@
|
||||||
<script>
|
<script>
|
||||||
import { notifier } from "builderStore/store/notifications"
|
import { notifier } from "builderStore/store/notifications"
|
||||||
import { Input } from "@budibase/bbui"
|
import { Input } from "@budibase/bbui"
|
||||||
|
import { store } from "../../../builderStore"
|
||||||
|
|
||||||
export let value
|
export let value
|
||||||
|
export let production = false
|
||||||
|
|
||||||
|
$: appId = $store.appId
|
||||||
|
|
||||||
function fullWebhookURL(uri) {
|
function fullWebhookURL(uri) {
|
||||||
|
if (production) {
|
||||||
|
return `https://${appId}.app.budi.live/${uri}`
|
||||||
|
} else {
|
||||||
return `http://localhost:4001/${uri}`
|
return `http://localhost:4001/${uri}`
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
function copyToClipboard() {
|
function copyToClipboard() {
|
||||||
const dummy = document.createElement("textarea")
|
const dummy = document.createElement("textarea")
|
||||||
|
|
|
@ -0,0 +1,73 @@
|
||||||
|
<script>
|
||||||
|
import { automationStore } from "builderStore"
|
||||||
|
import { ModalContent } from "@budibase/bbui"
|
||||||
|
import { onMount } from "svelte"
|
||||||
|
import WebhookDisplay from "../automation/Shared/WebhookDisplay.svelte"
|
||||||
|
import analytics from "analytics"
|
||||||
|
|
||||||
|
let webhookUrls = []
|
||||||
|
|
||||||
|
$: automations = $automationStore.automations
|
||||||
|
|
||||||
|
onMount(() => {
|
||||||
|
webhookUrls = automations.map(automation => {
|
||||||
|
const trigger = automation.definition.trigger
|
||||||
|
if (trigger?.stepId === "WEBHOOK" && trigger.inputs) {
|
||||||
|
return {type: "Automation", name: automation.name, url: trigger.inputs.triggerUrl}
|
||||||
|
}
|
||||||
|
})
|
||||||
|
})
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<ModalContent
|
||||||
|
title="Webhook Endpoints"
|
||||||
|
confirmText="Done">
|
||||||
|
<p>
|
||||||
|
See below the list of deployed webhook URLs.
|
||||||
|
</p>
|
||||||
|
{#each webhookUrls as webhookUrl}
|
||||||
|
<div>
|
||||||
|
<h5>{webhookUrl.type} - {webhookUrl.name}</h5>
|
||||||
|
<WebhookDisplay value={webhookUrl.url} production={true} />
|
||||||
|
</div>
|
||||||
|
{/each}
|
||||||
|
<div slot="footer">
|
||||||
|
<a target="_blank" href="https://docs.budibase.com/automate/steps/triggers">
|
||||||
|
<i class="ri-information-line" />
|
||||||
|
<span>Learn about webhooks</span>
|
||||||
|
</a>
|
||||||
|
</div>
|
||||||
|
</ModalContent>
|
||||||
|
|
||||||
|
<style>
|
||||||
|
a {
|
||||||
|
color: var(--ink);
|
||||||
|
font-size: 14px;
|
||||||
|
vertical-align: middle;
|
||||||
|
display: flex;
|
||||||
|
align-items: center;
|
||||||
|
text-decoration: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
a span {
|
||||||
|
text-decoration: underline;
|
||||||
|
}
|
||||||
|
|
||||||
|
i {
|
||||||
|
font-size: 20px;
|
||||||
|
margin-right: var(--spacing-m);
|
||||||
|
text-decoration: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
p {
|
||||||
|
margin-top: 0;
|
||||||
|
margin-bottom: 0;
|
||||||
|
padding-top: 0;
|
||||||
|
text-align: justify;
|
||||||
|
}
|
||||||
|
|
||||||
|
h5 {
|
||||||
|
margin-top: 0;
|
||||||
|
padding-top: 0;
|
||||||
|
}
|
||||||
|
</style>
|
|
@ -2,9 +2,10 @@
|
||||||
import { onMount, onDestroy } from "svelte"
|
import { onMount, onDestroy } from "svelte"
|
||||||
import Spinner from "components/common/Spinner.svelte"
|
import Spinner from "components/common/Spinner.svelte"
|
||||||
import { slide } from "svelte/transition"
|
import { slide } from "svelte/transition"
|
||||||
import { Heading, Body } from "@budibase/bbui"
|
import { Heading, Body, Button, Modal } from "@budibase/bbui"
|
||||||
import api from "builderStore/api"
|
import api from "builderStore/api"
|
||||||
import { notifier } from "builderStore/store/notifications"
|
import { notifier } from "builderStore/store/notifications"
|
||||||
|
import CreateWebhookDeploymentModal from "./CreateWebhookDeploymentModal.svelte"
|
||||||
|
|
||||||
const DATE_OPTIONS = {
|
const DATE_OPTIONS = {
|
||||||
fullDate: {
|
fullDate: {
|
||||||
|
@ -23,6 +24,7 @@
|
||||||
|
|
||||||
export let appId
|
export let appId
|
||||||
|
|
||||||
|
let modal
|
||||||
let poll
|
let poll
|
||||||
let deployments = []
|
let deployments = []
|
||||||
let deploymentUrl = `https://${appId}.app.budi.live/${appId}`
|
let deploymentUrl = `https://${appId}.app.budi.live/${appId}`
|
||||||
|
@ -52,9 +54,14 @@
|
||||||
<section class="deployment-history" in:slide>
|
<section class="deployment-history" in:slide>
|
||||||
<header>
|
<header>
|
||||||
<h4>Deployment History</h4>
|
<h4>Deployment History</h4>
|
||||||
|
<div class="deploy-div">
|
||||||
<a target="_blank" href={`https://${appId}.app.budi.live/${appId}`}>
|
<a target="_blank" href={`https://${appId}.app.budi.live/${appId}`}>
|
||||||
View Your Deployed App →
|
View Your Deployed App →
|
||||||
</a>
|
</a>
|
||||||
|
<Button primary on:click={() => modal.show()}>
|
||||||
|
View webhooks
|
||||||
|
</Button>
|
||||||
|
</div>
|
||||||
</header>
|
</header>
|
||||||
<div class="deployment-list">
|
<div class="deployment-list">
|
||||||
{#each deployments as deployment}
|
{#each deployments as deployment}
|
||||||
|
@ -80,6 +87,9 @@
|
||||||
</div>
|
</div>
|
||||||
</section>
|
</section>
|
||||||
{/if}
|
{/if}
|
||||||
|
<Modal bind:this={modal} width="30%">
|
||||||
|
<CreateWebhookDeploymentModal />
|
||||||
|
</Modal>
|
||||||
|
|
||||||
<style>
|
<style>
|
||||||
.deployment:nth-child(odd) {
|
.deployment:nth-child(odd) {
|
||||||
|
@ -99,6 +109,13 @@
|
||||||
header {
|
header {
|
||||||
margin-left: var(--spacing-l);
|
margin-left: var(--spacing-l);
|
||||||
margin-bottom: var(--spacing-xl);
|
margin-bottom: var(--spacing-xl);
|
||||||
|
margin-right: var(--spacing-l);
|
||||||
|
}
|
||||||
|
|
||||||
|
.deploy-div {
|
||||||
|
display: flex;
|
||||||
|
justify-content: space-between;
|
||||||
|
align-items: center;
|
||||||
}
|
}
|
||||||
|
|
||||||
.deployment-history {
|
.deployment-history {
|
||||||
|
|
Loading…
Reference in New Issue