From e7e41a174301aa9efe9ec0e45820439030a5ff82 Mon Sep 17 00:00:00 2001 From: Martin McKeaveney Date: Thu, 25 Nov 2021 12:20:20 +0100 Subject: [PATCH] allow type editing on custom query datasource schemas --- .../components/integration/QueryViewer.svelte | 43 ++++++++++++------- 1 file changed, 27 insertions(+), 16 deletions(-) diff --git a/packages/builder/src/components/integration/QueryViewer.svelte b/packages/builder/src/components/integration/QueryViewer.svelte index 54e455b92f..550da98d6b 100644 --- a/packages/builder/src/components/integration/QueryViewer.svelte +++ b/packages/builder/src/components/integration/QueryViewer.svelte @@ -32,31 +32,22 @@ import { onMount } from "svelte" export let query - export let fields = [] + let fields = query.schema ? schemaToFields(query.schema) : [] let parameters let data = [] let roleId const transformerDocs = "https://docs.budibase.com/building-apps/data/transformers" const typeOptions = [ - { label: "Text", value: "STRING" }, - { label: "Number", value: "NUMBER" }, - { label: "Boolean", value: "BOOLEAN" }, - { label: "Datetime", value: "DATETIME" }, + { label: "Text", value: "string" }, + { label: "Number", value: "number" }, + { label: "Boolean", value: "boolean" }, + { label: "Datetime", value: "datetime" }, ] $: datasource = $datasources.list.find(ds => ds._id === query.datasourceId) - $: query.schema = fields.reduce( - (acc, next) => ({ - ...acc, - [next.name]: { - name: next.name, - type: "string", - }, - }), - {} - ) + $: query.schema = fieldsToSchema(fields) $: datasourceType = datasource?.source $: integrationInfo = $integrations[datasourceType] $: queryConfig = integrationInfo?.query @@ -135,7 +126,7 @@ // unique fields returned by the server fields = json.schemaFields.map(field => ({ name: field, - type: "STRING", + type: "string", })) } catch (err) { notifications.error(`Query Error: ${err.message}`) @@ -155,6 +146,26 @@ } } + function schemaToFields(schema) { + return Object.keys(schema).map(key => ({ + name: key, + type: query.schema[key].type, + })) + } + + function fieldsToSchema(fieldsToConvert) { + return fieldsToConvert.reduce( + (acc, next) => ({ + ...acc, + [next.name]: { + name: next.name, + type: next.type, + }, + }), + {} + ) + } + onMount(async () => { if (!query || !query._id) { roleId = Roles.BASIC