Read / Write finished

This commit is contained in:
Rory Powell 2021-12-14 16:46:31 +00:00
parent 5551dbbc1e
commit 4c649e60c7
2 changed files with 59 additions and 45 deletions

View File

@ -96,6 +96,7 @@
{#each fields as field, idx} {#each fields as field, idx}
<Input <Input
placeholder={keyPlaceholder} placeholder={keyPlaceholder}
readonly={readOnly}
bind:value={field.name} bind:value={field.name}
on:change={changed} on:change={changed}
/> />
@ -104,6 +105,7 @@
{:else} {:else}
<Input <Input
placeholder={valuePlaceholder} placeholder={valuePlaceholder}
readonly={readOnly}
bind:value={field.value} bind:value={field.value}
on:change={changed} on:change={changed}
/> />
@ -114,7 +116,7 @@
{#if !readOnly} {#if !readOnly}
<Icon hoverable name="Close" on:click={() => deleteEntry(idx)} /> <Icon hoverable name="Close" on:click={() => deleteEntry(idx)} />
{/if} {/if}
{#if menuItems?.length > 0} {#if menuItems?.length > 0 && !readOnly}
<ActionMenu> <ActionMenu>
<div slot="control" class="icon"> <div slot="control" class="icon">
<Icon size="S" hoverable name="MoreSmallList" /> <Icon size="S" hoverable name="MoreSmallList" />

View File

@ -59,10 +59,11 @@
$: queryConfig = integrationInfo?.query $: queryConfig = integrationInfo?.query
$: url = buildUrl(url, breakQs) $: url = buildUrl(url, breakQs)
$: checkQueryName(url) $: checkQueryName(url)
$: responseSuccess = $: responseSuccess = response?.info?.code >= 200 && response?.info?.code < 400
response?.info?.code >= 200 && response?.info?.code <= 206
$: authConfigs = buildAuthConfigs(datasource) $: authConfigs = buildAuthConfigs(datasource)
$: dynamicVariables = buildDynamicVariables(datasource) $: schemaReadOnly = !responseSuccess
$: variablesReadOnly = !responseSuccess
$: showVariablesTab = shouldShowVariables(dynamicVariables, variablesReadOnly)
function getSelectedQuery() { function getSelectedQuery() {
return cloneDeep( return cloneDeep(
@ -133,7 +134,7 @@
notifications.success(`Request saved successfully.`) notifications.success(`Request saved successfully.`)
if (dynamicVariables) { if (dynamicVariables) {
const dynamicVars = mapDynamicVariables(saveId) const dynamicVars = rebuildVariables(saveId)
datasource.config.dynamicVariables = dynamicVars datasource.config.dynamicVariables = dynamicVars
await datasources.save(datasource) await datasources.save(datasource)
} }
@ -173,6 +174,53 @@
return id return id
} }
// convert dynamic variables list to simple key/val object
const variablesToObject = datasource => {
const variablesList = datasource?.config?.dynamicVariables
if (variablesList && variablesList.length > 0) {
return variablesList.reduce(
(acc, next) => ({ ...acc, [next.name]: next.value }),
{}
)
}
return {}
}
// convert dynamic variables object back to a list, enrich with query id
const rebuildVariables = queryId => {
let variables = []
if (dynamicVariables) {
variables = Object.entries(dynamicVariables).map(entry => {
return {
name: entry[0],
value: entry[1],
queryId,
}
})
}
return variables
}
const shouldShowVariables = (dynamicVariables, variablesReadOnly) => {
if (
dynamicVariables &&
// show when editable or when read only and not empty
(!variablesReadOnly || Object.keys(dynamicVariables).length > 0)
) {
return true
}
return false
}
const schemaMenuItems = [
{
text: "Create dynamic variable",
onClick: () => {
console.log("create variable")
},
},
]
onMount(async () => { onMount(async () => {
query = getSelectedQuery() query = getSelectedQuery()
// clear any unsaved changes to the datasource // clear any unsaved changes to the datasource
@ -210,46 +258,8 @@
if (query && !query.fields.bodyType) { if (query && !query.fields.bodyType) {
query.fields.bodyType = "none" query.fields.bodyType = "none"
} }
dynamicVariables = variablesToObject(datasource)
}) })
/**
* Convert the dynamic variables list to a simple name / value object
*/
const buildDynamicVariables = datasource => {
const variablesList = datasource?.config?.dynamicVariables
let variables = {}
if (variablesList) {
variables = variablesList.reduce(
(acc, next) => ({ ...acc, [next.name]: next.value }),
{}
)
}
return variables
}
/**
* Convert the dynamic variables object back to a list
*/
const mapDynamicVariables = queryId => {
let variables = []
if (dynamicVariables) {
variables = Object.values(dynamicVariables).map((name, value) => ({
name,
value,
queryId,
}))
}
return variables
}
const schemaMenuItems = [
{
text: "Create dynamic variable",
onClick: () => {
console.log("create variable")
},
},
]
</script> </script>
{#if query && queryConfig} {#if query && queryConfig}
@ -388,6 +398,7 @@
headings headings
options={SchemaTypeOptions} options={SchemaTypeOptions}
menuItems={schemaMenuItems} menuItems={schemaMenuItems}
readOnly={schemaReadOnly}
/> />
</Tab> </Tab>
{/if} {/if}
@ -412,7 +423,7 @@
</div> </div>
</Tab> </Tab>
{/if} {/if}
{#if dynamicVariables || response} {#if showVariablesTab}
<Tab title="Dynamic Variables"> <Tab title="Dynamic Variables">
<Layout noPadding gap="S"> <Layout noPadding gap="S">
<Body size="S" <Body size="S"
@ -425,6 +436,7 @@
keyPlaceholder="Name" keyPlaceholder="Name"
valuePlaceholder={`e.g. {{ headers.cookie }}`} valuePlaceholder={`e.g. {{ headers.cookie }}`}
valueHeading={`Value`} valueHeading={`Value`}
readOnly={variablesReadOnly}
/> />
</Layout> </Layout>
</Tab> </Tab>