Adding a way to see the deployed webhook URLs to the deployment page.

This commit is contained in:
mike12345567 2020-10-26 17:46:20 +00:00
parent 533e502143
commit 91d0222a5b
4 changed files with 104 additions and 7 deletions

View File

@ -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", {

View File

@ -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")

View File

@ -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>

View File

@ -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 {