Merge branch 'feature/automation-redesign' of github.com:Budibase/budibase into feature/automation-query

This commit is contained in:
mike12345567 2021-09-15 14:21:29 +01:00
commit 6232fa40ba
10 changed files with 101 additions and 72 deletions

View File

@ -1,7 +1,7 @@
<?xml version="1.0" encoding="utf-8"?> <?xml version="1.0" encoding="utf-8"?>
<!-- Generator: Adobe Illustrator 23.0.1, SVG Export Plug-In . SVG Version: 6.00 Build 0) --> <!-- Generator: Adobe Illustrator 25.4.1, SVG Export Plug-In . SVG Version: 6.00 Build 0) -->
<svg version="1.1" id="Layer_1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px" <svg version="1.1" id="Layer_1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px"
viewBox="0 0 270 270" style="enable-background:new 0 0 270 270;" xml:space="preserve"> viewBox="0 0 132 132" style="enable-background:new 0 0 132 132;" xml:space="preserve">
<style type="text/css"> <style type="text/css">
.st0{fill:#E01E5A;} .st0{fill:#E01E5A;}
.st1{fill:#36C5F0;} .st1{fill:#36C5F0;}
@ -10,24 +10,24 @@
</style> </style>
<g> <g>
<g> <g>
<path class="st0" d="M99.4,151.2c0,7.1-5.8,12.9-12.9,12.9c-7.1,0-12.9-5.8-12.9-12.9c0-7.1,5.8-12.9,12.9-12.9h12.9V151.2z"/> <path class="st0" d="M30.4,82.2c0,7.1-5.8,12.9-12.9,12.9S4.6,89.3,4.6,82.2c0-7.1,5.8-12.9,12.9-12.9h12.9V82.2z"/>
<path class="st0" d="M105.9,151.2c0-7.1,5.8-12.9,12.9-12.9s12.9,5.8,12.9,12.9v32.3c0,7.1-5.8,12.9-12.9,12.9 <path class="st0" d="M36.9,82.2c0-7.1,5.8-12.9,12.9-12.9s12.9,5.8,12.9,12.9v32.3c0,7.1-5.8,12.9-12.9,12.9s-12.9-5.8-12.9-12.9
s-12.9-5.8-12.9-12.9V151.2z"/> C36.9,114.5,36.9,82.2,36.9,82.2z"/>
</g> </g>
<g> <g>
<path class="st1" d="M118.8,99.4c-7.1,0-12.9-5.8-12.9-12.9c0-7.1,5.8-12.9,12.9-12.9s12.9,5.8,12.9,12.9v12.9H118.8z"/> <path class="st1" d="M49.8,30.4c-7.1,0-12.9-5.8-12.9-12.9S42.7,4.6,49.8,4.6s12.9,5.8,12.9,12.9v12.9H49.8z"/>
<path class="st1" d="M118.8,105.9c7.1,0,12.9,5.8,12.9,12.9s-5.8,12.9-12.9,12.9H86.5c-7.1,0-12.9-5.8-12.9-12.9 <path class="st1" d="M49.8,36.9c7.1,0,12.9,5.8,12.9,12.9s-5.8,12.9-12.9,12.9H17.5c-7.1,0-12.9-5.8-12.9-12.9s5.8-12.9,12.9-12.9
s5.8-12.9,12.9-12.9H118.8z"/> C17.5,36.9,49.8,36.9,49.8,36.9z"/>
</g> </g>
<g> <g>
<path class="st2" d="M170.6,118.8c0-7.1,5.8-12.9,12.9-12.9c7.1,0,12.9,5.8,12.9,12.9s-5.8,12.9-12.9,12.9h-12.9V118.8z"/> <path class="st2" d="M101.6,49.8c0-7.1,5.8-12.9,12.9-12.9c7.1,0,12.9,5.8,12.9,12.9s-5.8,12.9-12.9,12.9h-12.9V49.8z"/>
<path class="st2" d="M164.1,118.8c0,7.1-5.8,12.9-12.9,12.9c-7.1,0-12.9-5.8-12.9-12.9V86.5c0-7.1,5.8-12.9,12.9-12.9 <path class="st2" d="M95.1,49.8c0,7.1-5.8,12.9-12.9,12.9c-7.1,0-12.9-5.8-12.9-12.9V17.5c0-7.1,5.8-12.9,12.9-12.9
c7.1,0,12.9,5.8,12.9,12.9V118.8z"/> c7.1,0,12.9,5.8,12.9,12.9V49.8z"/>
</g> </g>
<g> <g>
<path class="st3" d="M151.2,170.6c7.1,0,12.9,5.8,12.9,12.9c0,7.1-5.8,12.9-12.9,12.9c-7.1,0-12.9-5.8-12.9-12.9v-12.9H151.2z"/> <path class="st3" d="M82.2,101.6c7.1,0,12.9,5.8,12.9,12.9c0,7.1-5.8,12.9-12.9,12.9c-7.1,0-12.9-5.8-12.9-12.9v-12.9H82.2z"/>
<path class="st3" d="M151.2,164.1c-7.1,0-12.9-5.8-12.9-12.9c0-7.1,5.8-12.9,12.9-12.9h32.3c7.1,0,12.9,5.8,12.9,12.9 <path class="st3" d="M82.2,95.1c-7.1,0-12.9-5.8-12.9-12.9c0-7.1,5.8-12.9,12.9-12.9h32.3c7.1,0,12.9,5.8,12.9,12.9
c0,7.1-5.8,12.9-12.9,12.9H151.2z"/> c0,7.1-5.8,12.9-12.9,12.9H82.2z"/>
</g> </g>
</g> </g>
</svg> </svg>

Before

Width:  |  Height:  |  Size: 1.6 KiB

After

Width:  |  Height:  |  Size: 1.6 KiB

View File

@ -1,39 +1,26 @@
<script> <script>
import { ModalContent, Layout, Detail, Body, Icon } from "@budibase/bbui" import { ModalContent, Layout, Detail, Body, Icon } from "@budibase/bbui"
import { automationStore } from "builderStore" import { automationStore } from "builderStore"
import DiscordLogo from "assets/discord.svg"
import ZapierLogo from "assets/zapier.png"
import IntegromatLogo from "assets/integromat.png"
import SlackLogo from "assets/slack.svg"
import n8nlogo from "assets/n8n.png"
import { database } from "stores/backend" import { database } from "stores/backend"
import { externalActions } from "./ExternalActions"
$: instanceId = $database._id $: instanceId = $database._id
let selectedAction let selectedAction
let actionVal let actionVal
let actions = Object.entries($automationStore.blockDefinitions.ACTION)
export let blockComplete export let blockComplete
let externalActionsPredicate = [ const external = actions.reduce((acc, elm) => {
{ name: "zapier", logo: ZapierLogo },
{ name: "discord", logo: DiscordLogo },
{ name: "slack", logo: SlackLogo },
{ name: "integromat", logo: IntegromatLogo },
{ name: "n8n", logo: n8nlogo },
]
let actions = Object.entries($automationStore.blockDefinitions.ACTION)
const externalActions = actions.reduce((acc, elm) => {
const [k, v] = elm const [k, v] = elm
if (externalActionsPredicate.some(pred => pred.name === k)) { if (!v.internal) {
acc[k] = v acc[k] = v
} }
return acc return acc
}, {}) }, {})
const internalActions = actions.reduce((acc, elm) => { const internal = actions.reduce((acc, elm) => {
const [k, v] = elm const [k, v] = elm
if (!externalActionsPredicate.some(pred => pred.name === k)) { if (v.internal) {
acc[k] = v acc[k] = v
} }
return acc return acc
@ -73,7 +60,7 @@
<Body size="S">Apps</Body> <Body size="S">Apps</Body>
<div class="item-list"> <div class="item-list">
{#each Object.entries(externalActions) as [idx, action]} {#each Object.entries(external) as [idx, action]}
<div <div
class="item" class="item"
class:selected={selectedAction === action.name} class:selected={selectedAction === action.name}
@ -83,7 +70,7 @@
<img <img
width="20" width="20"
height="20" height="20"
src={externalActionsPredicate.find(val => val.name === idx).logo} src={externalActions[action.stepId].icon}
alt="zapier" alt="zapier"
/> />
<span class="icon-spacing"> <span class="icon-spacing">
@ -98,7 +85,7 @@
<Detail size="S">Actions</Detail> <Detail size="S">Actions</Detail>
<div class="item-list"> <div class="item-list">
{#each Object.entries(internalActions) as [idx, action]} {#each Object.entries(internal) as [idx, action]}
<div <div
class="item" class="item"
class:selected={selectedAction === action.name} class:selected={selectedAction === action.name}

View File

@ -2,12 +2,10 @@ import DiscordLogo from "assets/discord.svg"
import ZapierLogo from "assets/zapier.png" import ZapierLogo from "assets/zapier.png"
import IntegromatLogo from "assets/integromat.png" import IntegromatLogo from "assets/integromat.png"
import SlackLogo from "assets/slack.svg" import SlackLogo from "assets/slack.svg"
import n8nlogo from "assets/n8n.png"
export const externalActions = { export const externalActions = {
zapier: { name: "zapier", icon: ZapierLogo }, zapier: { name: "zapier", icon: ZapierLogo },
discord: { name: "discord", icon: DiscordLogo }, discord: { name: "discord", icon: DiscordLogo },
slack: { name: "slack", icon: SlackLogo }, slack: { name: "slack", icon: SlackLogo },
integromat: { name: "integromat", icon: IntegromatLogo }, integromat: { name: "integromat", icon: IntegromatLogo },
n8n: { name: "n8n", icon: n8nlogo },
} }

View File

@ -73,18 +73,18 @@
}} }}
class="splitHeader" class="splitHeader"
> >
<div style="display: flex;"> <div class="center-items">
{#if externalActions[block.stepId]} {#if externalActions[block.stepId]}
<img <img
alt={externalActions[block.stepId].name} alt={externalActions[block.stepId].name}
width="35px" width="28px"
height="35px" height="28px"
src={externalActions[block.stepId].icon} src={externalActions[block.stepId].icon}
/> />
{:else} {:else}
<svg <svg
width="35px" width="28px"
height="35px" height="28px"
class="spectrum-Icon" class="spectrum-Icon"
style="color:grey;" style="color:grey;"
focusable="false" focusable="false"
@ -118,7 +118,7 @@
on:click|stopPropagation={() => { on:click|stopPropagation={() => {
setupToggled = !setupToggled setupToggled = !setupToggled
}} }}
class="toggle" class="center-items"
> >
{#if setupToggled} {#if setupToggled}
<Icon size="M" name="ChevronDown" /> <Icon size="M" name="ChevronDown" />
@ -142,7 +142,7 @@
/> />
{#if lastStep} {#if lastStep}
<Button on:click={() => testDataModal.show()} cta <Button on:click={() => testDataModal.show()} cta
>Continue and test automation</Button >Finish and test automation</Button
> >
{/if} {/if}
<Button <Button
@ -173,7 +173,7 @@
</div> </div>
<style> <style>
.toggle { .center-items {
display: flex; display: flex;
align-items: center; align-items: center;
} }

View File

@ -1,5 +1,5 @@
<script> <script>
import { ModalContent, Icon, Detail, Badge, TextArea } from "@budibase/bbui" import { ModalContent, Icon, Detail, TextArea } from "@budibase/bbui"
export let testResult export let testResult
export let isTrigger export let isTrigger
@ -16,9 +16,13 @@
<div slot="header"> <div slot="header">
<div style="float: right;"> <div style="float: right;">
{#if isTrigger || testResult[0].outputs.success} {#if isTrigger || testResult[0].outputs.success}
<Badge green><Icon size="S" name="CheckmarkCircle" /></Badge> <div class="iconSuccess">
<Icon size="S" name="CheckmarkCircle" />
</div>
{:else} {:else}
<Badge red><Icon size="S" name="CloseCircle" /></Badge> <div class="iconFailure">
<Icon size="S" name="CloseCircle" />
</div>
{/if} {/if}
</div> </div>
</div> </div>
@ -45,7 +49,12 @@
</div> </div>
</div> </div>
{#if inputToggled} {#if inputToggled}
<TextArea disabled value={JSON.stringify(testResult[0].inputs, null, 2)} /> <div class="text-area-container">
<TextArea
disabled
value={JSON.stringify(testResult[0].inputs, null, 2)}
/>
</div>
{/if} {/if}
<div <div
@ -70,11 +79,24 @@
</div> </div>
</div> </div>
{#if outputToggled} {#if outputToggled}
<TextArea disabled value={JSON.stringify(testResult[0].outputs, null, 2)} /> <div class="text-area-container">
<TextArea
disabled
value={JSON.stringify(testResult[0].outputs, null, 2)}
/>
</div>
{/if} {/if}
</ModalContent> </ModalContent>
<style> <style>
.iconSuccess {
color: var(--spectrum-global-color-green-600);
}
.iconFailure {
color: var(--spectrum-global-color-red-600);
}
.splitHeader { .splitHeader {
cursor: pointer; cursor: pointer;
display: flex; display: flex;
@ -85,4 +107,8 @@
display: flex; display: flex;
align-items: center; align-items: center;
} }
.text-area-container :global(textarea) {
height: 150px;
}
</style> </style>

View File

@ -9,13 +9,13 @@
let trigger = cloneDeep( let trigger = cloneDeep(
$automationStore.selectedAutomation.automation.definition.trigger $automationStore.selectedAutomation.automation.definition.trigger
) )
let schemaProperties = Object.entries(trigger.schema.outputs.properties || {})
if (!$automationStore.selectedAutomation.automation.testData) { if (!$automationStore.selectedAutomation.automation.testData) {
$automationStore.selectedAutomation.automation.testData = {} $automationStore.selectedAutomation.automation.testData = {}
} }
// get the outputs so we can define the fields // get the outputs so we can define the fields
let schemaProperties = Object.entries(trigger.schema.outputs.properties || {})
// check to see if there is existing test data in the store // check to see if there is existing test data in the store
$: testData = $automationStore.selectedAutomation.automation.testData $: testData = $automationStore.selectedAutomation.automation.testData
@ -48,23 +48,41 @@
cancelText="Cancel" cancelText="Cancel"
> >
<Tabs selected="Form" quiet <Tabs selected="Form" quiet
><Tab icon="Form" title="Form" ><Tab icon="Form" title="Form">
><AutomationBlockSetup <div class="tab-content-padding">
bind:testData <AutomationBlockSetup
{schemaProperties} bind:testData
block={trigger} {schemaProperties}
/></Tab block={trigger}
/>
</div></Tab
> >
<Tab icon="FileJson" title="JSON"> <Tab icon="FileJson" title="JSON">
<Label>JSON</Label><TextArea <div class="tab-content-padding">
value={JSON.stringify( <Label>JSON</Label>
$automationStore.selectedAutomation.automation.testData, <div class="text-area-container">
null, <TextArea
2 value={JSON.stringify(
)} $automationStore.selectedAutomation.automation.testData,
error={failedParse} null,
on:change={e => parseTestJSON(e)} 2
/> )}
error={failedParse}
on:change={e => parseTestJSON(e)}
/>
</div>
</div>
</Tab> </Tab>
</Tabs> </Tabs>
</ModalContent> </ModalContent>
<style>
.text-area-container :global(textarea) {
min-height: 200px;
height: 200px;
}
.tab-content-padding {
padding: 0 var(--spacing-xl);
}
</style>

View File

@ -6,7 +6,7 @@ const usage = require("../../utilities/usageQuota")
exports.definition = { exports.definition = {
name: "Create Row", name: "Create Row",
tagline: "Create a {{inputs.enriched.table.name}} row", tagline: "Create a {{inputs.enriched.table.name}} row",
icon: "SaveFloppy", icon: "TableRowAddBottom",
description: "Add a row to your database", description: "Add a row to your database",
type: "ACTION", type: "ACTION",
internal: true, internal: true,

View File

@ -4,7 +4,7 @@ const usage = require("../../utilities/usageQuota")
exports.definition = { exports.definition = {
description: "Delete a row from your database", description: "Delete a row from your database",
icon: "DeleteOutline", icon: "TableRowRemoveCenter",
name: "Delete Row", name: "Delete Row",
tagline: "Delete a {{inputs.enriched.table.name}} row", tagline: "Delete a {{inputs.enriched.table.name}} row",
type: "ACTION", type: "ACTION",

View File

@ -1,7 +1,7 @@
exports.definition = { exports.definition = {
name: "Row Deleted", name: "Row Deleted",
event: "row:delete", event: "row:delete",
icon: "Delete", icon: "TableRowRemoveCenter",
tagline: "Row is deleted from {{inputs.enriched.table.name}}", tagline: "Row is deleted from {{inputs.enriched.table.name}}",
description: "Fired when a row is deleted from your database", description: "Fired when a row is deleted from your database",
stepId: "ROW_DELETED", stepId: "ROW_DELETED",

View File

@ -1,7 +1,7 @@
exports.definition = { exports.definition = {
name: "Row Created", name: "Row Created",
event: "row:save", event: "row:save",
icon: "SaveFloppy", icon: "TableRowAddBottom",
tagline: "Row is added to {{inputs.enriched.table.name}}", tagline: "Row is added to {{inputs.enriched.table.name}}",
description: "Fired when a row is added to your database", description: "Fired when a row is added to your database",
stepId: "ROW_SAVED", stepId: "ROW_SAVED",