diff --git a/hosting/single/nginx/nginx-default-site.conf b/hosting/single/nginx/nginx-default-site.conf
index 3903c0647d..d2f8e229c6 100644
--- a/hosting/single/nginx/nginx-default-site.conf
+++ b/hosting/single/nginx/nginx-default-site.conf
@@ -22,6 +22,16 @@ server {
proxy_pass http://127.0.0.1:4001;
}
+ location /embed {
+ rewrite /embed/(.*) /app/$1 break;
+ proxy_pass http://127.0.0.1:4001;
+ proxy_redirect off;
+ proxy_set_header Host $host;
+ proxy_set_header x-budibase-embed "true";
+ add_header x-budibase-embed "true";
+ add_header Content-Security-Policy "frame-ancestors *";
+ }
+
location = / {
proxy_pass http://127.0.0.1:4001;
}
diff --git a/lerna.json b/lerna.json
index 37914856b9..4d129626b6 100644
--- a/lerna.json
+++ b/lerna.json
@@ -1,5 +1,5 @@
{
- "version": "2.8.3-alpha.3",
+ "version": "2.8.6-alpha.0",
"npmClient": "yarn",
"packages": [
"packages/*"
diff --git a/packages/builder/src/pages/builder/app/[application]/data/datasource/[datasourceId]/_components/panels/Queries/RestImportButton.svelte b/packages/builder/src/pages/builder/app/[application]/data/datasource/[datasourceId]/_components/panels/Queries/RestImportButton.svelte
index 682284adca..7f179d18b4 100644
--- a/packages/builder/src/pages/builder/app/[application]/data/datasource/[datasourceId]/_components/panels/Queries/RestImportButton.svelte
+++ b/packages/builder/src/pages/builder/app/[application]/data/datasource/[datasourceId]/_components/panels/Queries/RestImportButton.svelte
@@ -2,11 +2,12 @@
import { Button, Modal } from "@budibase/bbui"
import ImportQueriesModal from "./RestImportQueriesModal.svelte"
+ export let datasourceId
let importQueriesModal
-
+
diff --git a/packages/client/manifest.json b/packages/client/manifest.json
index 8784339971..ab8d61eebd 100644
--- a/packages/client/manifest.json
+++ b/packages/client/manifest.json
@@ -3223,6 +3223,46 @@
"key": "allowManualEntry",
"defaultValue": false
},
+ {
+ "type": "boolean",
+ "label": "Play sound on scan",
+ "key": "beepOnScan",
+ "defaultValue": false
+ },
+ {
+ "type": "select",
+ "label": "Sound pitch",
+ "key": "beepFrequency",
+ "dependsOn": "beepOnScan",
+ "defaultValue": 2637,
+ "options": [
+ {
+ "label": "Low",
+ "value": 2096
+ },
+ {
+ "label": "Regular",
+ "value": 2637
+ },
+ {
+ "label": "High",
+ "value": 3136
+ },
+ { "label": "Custom", "value": "custom" }
+ ]
+ },
+ {
+ "type": "number",
+ "label": "Sound frequency (Hz)",
+ "key": "customFrequency",
+ "defaultValue": 1046,
+ "min": 20,
+ "max": 8000,
+ "dependsOn": {
+ "setting": "beepFrequency",
+ "value": "custom"
+ }
+ },
{
"type": "validation/string",
"label": "Validation",
diff --git a/packages/client/src/components/app/forms/CodeScanner.svelte b/packages/client/src/components/app/forms/CodeScanner.svelte
index 5dff3a96fa..9895413446 100644
--- a/packages/client/src/components/app/forms/CodeScanner.svelte
+++ b/packages/client/src/components/app/forms/CodeScanner.svelte
@@ -8,6 +8,10 @@
export let disabled = false
export let allowManualEntry = false
export let scanButtonText = "Scan code"
+ export let beepOnScan = false
+ export let beepFrequency = 2637
+ export let customFrequency = 1046
+
const dispatch = createEventDispatcher()
let videoEle
@@ -21,8 +25,13 @@
fps: 25,
qrbox: { width: 250, height: 250 },
}
+ const audioCtx = new (window.AudioContext || window.webkitAudioContext)()
+
const onScanSuccess = decodedText => {
if (value != decodedText) {
+ if (beepOnScan) {
+ beep()
+ }
dispatch("change", decodedText)
}
}
@@ -84,6 +93,27 @@
}
camModal.hide()
}
+
+ const beep = () => {
+ const oscillator = audioCtx.createOscillator()
+ const gainNode = audioCtx.createGain()
+
+ oscillator.connect(gainNode)
+ gainNode.connect(audioCtx.destination)
+
+ const frequency =
+ beepFrequency === "custom" ? customFrequency : beepFrequency
+ oscillator.frequency.value = frequency
+ oscillator.type = "square"
+
+ const duration = 420
+ const endTime = audioCtx.currentTime + duration / 1000
+ gainNode.gain.setValueAtTime(1, audioCtx.currentTime)
+ gainNode.gain.exponentialRampToValueAtTime(0.001, endTime)
+
+ oscillator.start()
+ oscillator.stop(endTime)
+ }
diff --git a/packages/client/src/components/app/forms/CodeScannerField.svelte b/packages/client/src/components/app/forms/CodeScannerField.svelte
index 7e020aa9c7..c408f78d7c 100644
--- a/packages/client/src/components/app/forms/CodeScannerField.svelte
+++ b/packages/client/src/components/app/forms/CodeScannerField.svelte
@@ -11,6 +11,9 @@
export let onChange
export let allowManualEntry
export let scanButtonText
+ export let beepOnScan
+ export let beepFrequency
+ export let customFrequency
let fieldState
let fieldApi
@@ -42,6 +45,9 @@
disabled={fieldState.disabled}
{allowManualEntry}
scanButtonText={scanText}
+ {beepOnScan}
+ {beepFrequency}
+ {customFrequency}
/>
{/if}