Merge pull request #15221 from Budibase/firestore-improvements

allow users to select firestore databases other than the default
This commit is contained in:
Andrew Thompson 2024-12-19 16:39:33 +00:00 committed by GitHub
commit 45f2ec39f8
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
8 changed files with 23 additions and 2 deletions

View File

@ -12,6 +12,7 @@
export let name
export let config
export let showModal = () => {}
export let placeholder
const selectComponent = type => {
if (type === "object") {
@ -40,6 +41,7 @@
{name}
{config}
{showModal}
{placeholder}
on:blur
on:change
/>

View File

@ -5,11 +5,12 @@
export let name
export let value
export let error
export let placeholder
</script>
<div class="form-row">
<Label>{name}</Label>
<TextArea on:blur on:change {type} {value} {error} />
<TextArea on:blur on:change {type} {value} {error} {placeholder} />
</div>
<style>

View File

@ -6,6 +6,7 @@
export let value
export let error
export let config
export let placeholder
</script>
<div class="form-row">
@ -17,6 +18,7 @@
{type}
value={value || undefined}
{error}
{placeholder}
/>
</div>

View File

@ -6,6 +6,7 @@
export let name
export let value
export let error
export let placeholder
export let showModal = () => {}
async function handleUpgradePanel() {
@ -22,6 +23,7 @@
type={type === "port" ? "string" : type}
{value}
{error}
{placeholder}
variables={$environment.variables}
environmentVariablesEnabled={$licensing.environmentVariablesEnabled}
{showModal}

View File

@ -85,7 +85,7 @@
/>
{/if}
{#each $configStore.validatedConfig as { type, key, value, error, name, hidden, config }}
{#each $configStore.validatedConfig as { type, key, value, error, name, hidden, config, placeholder }}
{#if hidden === undefined || !eval(processStringSync(hidden, $configStore.config))}
<ConfigInput
{type}
@ -93,6 +93,7 @@
{error}
{name}
{config}
{placeholder}
showModal={() =>
showModal(newValue => configStore.updateFieldValue(key, newValue))}
on:blur={() => configStore.markFieldActive(key)}

View File

@ -114,6 +114,7 @@ export const createValidatedConfigStore = (integration, config) => {
value: getValue(),
error: $errorsStore[key],
name: capitalise(properties.display || key),
placeholder: properties.placeholder,
type: properties.type,
hidden: properties.hidden,
config: properties.config,

View File

@ -12,6 +12,7 @@ interface FirebaseConfig {
email: string
privateKey: string
projectId: string
databaseId?: string
}
const SCHEMA: Integration = {
@ -30,12 +31,21 @@ const SCHEMA: Integration = {
},
privateKey: {
type: DatasourceFieldType.STRING,
display: "Private Key",
required: true,
},
projectId: {
type: DatasourceFieldType.STRING,
display: "Project ID",
required: true,
},
databaseId: {
type: DatasourceFieldType.STRING,
display: "Database ID",
required: false,
default: "(default)",
placeholder: "(default)",
},
},
query: {
create: {
@ -97,6 +107,7 @@ class FirebaseIntegration implements IntegrationBase {
this.config = config
this.client = new Firestore({
projectId: config.projectId,
databaseId: config.databaseId || "(default)",
credentials: {
client_email: config.email,
private_key: config.privateKey?.replace(/\\n/g, "\n"),

View File

@ -119,6 +119,7 @@ interface DatasourceBasicFieldConfig {
default?: any
deprecated?: boolean
hidden?: string
placeholder?: string
}
interface DatasourceSelectFieldConfig extends DatasourceBasicFieldConfig {