update ssl ux

This commit is contained in:
Peter Clement 2021-09-29 13:02:30 +01:00
parent ebd26cb42e
commit 42e38ad876
3 changed files with 21 additions and 5 deletions

View File

@ -1,20 +1,28 @@
<script> <script>
import { Label, Input, Layout, Toggle } from "@budibase/bbui" import { Label, Input, Layout, Toggle, Button } from "@budibase/bbui"
import KeyValueBuilder from "components/integration/KeyValueBuilder.svelte" import KeyValueBuilder from "components/integration/KeyValueBuilder.svelte"
import { capitalise } from "helpers" import { capitalise } from "helpers"
export let integration export let integration
export let schema export let schema
let addButton
</script> </script>
<form> <form>
<Layout gap="S"> <Layout gap="S">
{#each Object.keys(schema) as configKey} {#each Object.keys(schema) as configKey}
{#if schema[configKey].type === "object"} {#if schema[configKey].type === "object"}
<Label>{capitalise(configKey)}</Label> <div class="form-row ssl">
<Label>{capitalise(configKey)}</Label>
<Button secondary thin outline on:click={addButton.addEntry()}
>Add</Button
>
</div>
<KeyValueBuilder <KeyValueBuilder
bind:this={addButton}
defaults={schema[configKey].default} defaults={schema[configKey].default}
bind:object={integration[configKey]} bind:object={integration[configKey]}
noAddButton={true}
/> />
{:else if schema[configKey].type === "boolean"} {:else if schema[configKey].type === "boolean"}
<div class="form-row"> <div class="form-row">
@ -42,4 +50,11 @@
grid-gap: var(--spacing-l); grid-gap: var(--spacing-l);
align-items: center; align-items: center;
} }
.form-row.ssl {
display: grid;
grid-template-columns: 20% 20%;
grid-gap: var(--spacing-l);
align-items: center;
}
</style> </style>

View File

@ -4,6 +4,7 @@
export let defaults export let defaults
export let object = defaults || {} export let object = defaults || {}
export let readOnly export let readOnly
export let noAddButton
let fields = Object.entries(object).map(([name, value]) => ({ name, value })) let fields = Object.entries(object).map(([name, value]) => ({ name, value }))
@ -12,7 +13,7 @@
{} {}
) )
function addEntry() { export function addEntry() {
fields = [...fields, {}] fields = [...fields, {}]
} }
@ -32,7 +33,7 @@
{/if} {/if}
{/each} {/each}
</div> </div>
{#if !readOnly} {#if !readOnly && !noAddButton}
<div> <div>
<Button secondary thin outline on:click={addEntry}>Add</Button> <Button secondary thin outline on:click={addEntry}>Add</Button>
</div> </div>

View File

@ -84,7 +84,7 @@ module MySQLModule {
required: true, required: true,
}, },
ssl: { ssl: {
type: DatasourceFieldTypes.BOOLEAN, type: DatasourceFieldTypes.OBJECT,
required: false, required: false,
}, },
}, },