diff --git a/hosting/envoy.dev.yaml.hbs b/hosting/envoy.dev.yaml.hbs
index 080311ee49..76417b3e0d 100644
--- a/hosting/envoy.dev.yaml.hbs
+++ b/hosting/envoy.dev.yaml.hbs
@@ -38,6 +38,11 @@ static_resources:
route:
cluster: server-dev
+ - match: { prefix: "/app/" }
+ route:
+ cluster: server-dev
+ prefix_rewrite: "/"
+
# the below three cases are needed to make sure
# all traffic prefixed for the builder is passed through
# correctly.
diff --git a/packages/bbui/src/Table/StringRenderer.svelte b/packages/bbui/src/Table/StringRenderer.svelte
index 2756839616..6fd731f5ec 100644
--- a/packages/bbui/src/Table/StringRenderer.svelte
+++ b/packages/bbui/src/Table/StringRenderer.svelte
@@ -2,7 +2,7 @@
export let value
-
{value}
+{typeof value === "object" ? JSON.stringify(value) : value}
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/packages/builder/src/components/backend/DatasourceNavigator/icons/index.js b/packages/builder/src/components/backend/DatasourceNavigator/icons/index.js
index 6d469e0904..e251595934 100644
--- a/packages/builder/src/components/backend/DatasourceNavigator/icons/index.js
+++ b/packages/builder/src/components/backend/DatasourceNavigator/icons/index.js
@@ -9,8 +9,10 @@ import SqlServer from "./SQLServer.svelte"
import MySQL from "./MySQL.svelte"
import ArangoDB from "./ArangoDB.svelte"
import Rest from "./Rest.svelte"
+import Budibase from "./Budibase.svelte"
export default {
+ BUDIBASE: Budibase,
POSTGRES: Postgres,
DYNAMODB: DynamoDB,
MONGODB: MongoDB,
diff --git a/packages/builder/src/components/backend/DatasourceNavigator/modals/CreateDatasourceModal.svelte b/packages/builder/src/components/backend/DatasourceNavigator/modals/CreateDatasourceModal.svelte
index a03f07e746..180d03f7ff 100644
--- a/packages/builder/src/components/backend/DatasourceNavigator/modals/CreateDatasourceModal.svelte
+++ b/packages/builder/src/components/backend/DatasourceNavigator/modals/CreateDatasourceModal.svelte
@@ -23,16 +23,17 @@
}
async function saveDatasource() {
- const { type, ...config } = integration
+ const { type, plus, ...config } = integration
// Create datasource
const response = await datasources.save({
name,
source: type,
config,
+ plus,
})
notifications.success(`Datasource ${name} created successfully.`)
- analytics.captureEvent("Datasource Created", { name })
+ analytics.captureEvent("Datasource Created", { name, type })
// Navigate to new datasource
$goto(`./datasource/${response._id}`)
diff --git a/packages/builder/src/components/backend/TableNavigator/TableNavigator.svelte b/packages/builder/src/components/backend/TableNavigator/TableNavigator.svelte
index fa8733a8b3..4291738d3d 100644
--- a/packages/builder/src/components/backend/TableNavigator/TableNavigator.svelte
+++ b/packages/builder/src/components/backend/TableNavigator/TableNavigator.svelte
@@ -6,6 +6,8 @@
import EditViewPopover from "./popovers/EditViewPopover.svelte"
import NavItem from "components/common/NavItem.svelte"
+ export let sourceId
+
$: selectedView = $views.selected && $views.selected.name
function selectTable(table) {
@@ -31,12 +33,13 @@
{#if $database?._id}
- {#each $tables.list as table, idx}
+ {#each $tables.list.filter(table => table.sourceId === sourceId) as table, idx}
0}
icon={table._id === TableNames.USERS ? "UserGroup" : "Table"}
text={table.name}
- selected={selectedView === `all_${table._id}`}
+ selected={$tables.selected?._id === table._id}
on:click={() => selectTable(table)}
>
{#if table._id !== TableNames.USERS}
@@ -45,7 +48,7 @@
{#each Object.keys(table.views || {}) as viewName, idx (idx)}
diff --git a/packages/builder/src/components/backend/TableNavigator/popovers/EditTablePopover.svelte b/packages/builder/src/components/backend/TableNavigator/popovers/EditTablePopover.svelte
index 17d5aa2046..2513c6c7e5 100644
--- a/packages/builder/src/components/backend/TableNavigator/popovers/EditTablePopover.svelte
+++ b/packages/builder/src/components/backend/TableNavigator/popovers/EditTablePopover.svelte
@@ -1,15 +1,15 @@
+
+
+
+
+
+
diff --git a/packages/builder/src/components/deploy/DeployModal.svelte b/packages/builder/src/components/deploy/DeployModal.svelte
index bade2605d9..6e1b5f76e9 100644
--- a/packages/builder/src/components/deploy/DeployModal.svelte
+++ b/packages/builder/src/components/deploy/DeployModal.svelte
@@ -1,10 +1,10 @@
+
+
+ This action doesn't require any additional settings.
+
+
+
diff --git a/packages/builder/src/components/design/PropertiesPanel/PropertyControls/EventsEditor/actions/index.js b/packages/builder/src/components/design/PropertiesPanel/PropertyControls/EventsEditor/actions/index.js
index a3e43cb045..b8114461f9 100644
--- a/packages/builder/src/components/design/PropertiesPanel/PropertyControls/EventsEditor/actions/index.js
+++ b/packages/builder/src/components/design/PropertiesPanel/PropertyControls/EventsEditor/actions/index.js
@@ -4,6 +4,7 @@ import DeleteRow from "./DeleteRow.svelte"
import ExecuteQuery from "./ExecuteQuery.svelte"
import TriggerAutomation from "./TriggerAutomation.svelte"
import ValidateForm from "./ValidateForm.svelte"
+import LogOut from "./LogOut.svelte"
// Defines which actions are available to configure in the front end.
// Unfortunately the "name" property is used as the identifier so please don't
@@ -37,4 +38,8 @@ export default [
name: "Validate Form",
component: ValidateForm,
},
+ {
+ name: "Log Out",
+ component: LogOut,
+ },
]
diff --git a/packages/builder/src/constants/index.js b/packages/builder/src/constants/index.js
index 8a0e8fd60e..aefc1fab0e 100644
--- a/packages/builder/src/constants/index.js
+++ b/packages/builder/src/constants/index.js
@@ -31,3 +31,5 @@ export const LAYOUT_NAMES = {
PUBLIC: "layout_private_master",
},
}
+
+export const BUDIBASE_INTERNAL_DB = "bb_internal"
diff --git a/packages/builder/src/pages/builder/app/[application]/data/_layout.svelte b/packages/builder/src/pages/builder/app/[application]/data/_layout.svelte
index 6910d3e925..6ce765d424 100644
--- a/packages/builder/src/pages/builder/app/[application]/data/_layout.svelte
+++ b/packages/builder/src/pages/builder/app/[application]/data/_layout.svelte
@@ -1,49 +1,27 @@
-
-
-
-
-
+
+
@@ -54,7 +32,7 @@
diff --git a/packages/builder/src/pages/builder/app/[application]/data/datasource/[selectedDatasource]/[query]/_layout.svelte b/packages/builder/src/pages/builder/app/[application]/data/datasource/[selectedDatasource]/[query]/_layout.svelte
index 4d6acc22ae..4fa864ce7a 100644
--- a/packages/builder/src/pages/builder/app/[application]/data/datasource/[selectedDatasource]/[query]/_layout.svelte
+++ b/packages/builder/src/pages/builder/app/[application]/data/datasource/[selectedDatasource]/[query]/_layout.svelte
@@ -1,13 +1 @@
-
-
diff --git a/packages/builder/src/pages/builder/app/[application]/data/datasource/[selectedDatasource]/index.svelte b/packages/builder/src/pages/builder/app/[application]/data/datasource/[selectedDatasource]/index.svelte
index 98379607c9..f805a5724f 100644
--- a/packages/builder/src/pages/builder/app/[application]/data/datasource/[selectedDatasource]/index.svelte
+++ b/packages/builder/src/pages/builder/app/[application]/data/datasource/[selectedDatasource]/index.svelte
@@ -1,7 +1,7 @@
-{#if datasource}
+{#if datasource && integration}
@@ -66,6 +86,34 @@
on:change={setUnsaved}
/>
+ {#if datasource.plus}
+
+
+
+ This datasource can determine tables automatically. Budibase can fetch
+ your tables directly from the database and you can use them without
+ having to write any queries at all.
+
+
+ {#if datasource.entities}
+ {#each Object.keys(datasource.entities) as entity}
+
onClickTable(datasource.entities[entity])}
+ >
+
{entity}
+
Primary Key: {datasource.entities[entity].primary}
+
→
+
+ {/each}
+ {/if}
+
+ {/if}