Svelte context and hooks
Hooks let you listen to Screeb lifecycle events. You can define hooks globally via the provider config or per-survey/per-message.
Available hooksโ
| Hook Name | Provider config / init | surveyStart | messageStart |
|---|---|---|---|
onReady | โ | โ | โ |
onSurveyDisplayAllowed | โ | โ | โ |
onMessageDisplayAllowed | โ | โ | โ |
onSurveyShowed | โ | โ | โ |
onSurveyStarted | โ | โ | โ |
onQuestionReplied | โ | โ | โ |
onSurveyCompleted | โ | โ | โ |
onSurveyHidden | โ | โ | โ |
onMessageShowed | โ | โ | โ |
onMessageStarted | โ | โ | โ |
onMessageCompleted | โ | โ | โ |
onMessageHidden | โ | โ | โ |
Global hooks (provider config)โ
Define hooks once in your root component:
<script lang="ts">
import { setScreebContext } from "@screeb/sdk-svelte";
setScreebContext({
websiteId: "<YOUR-CHANNEL-ID>",
autoInit: true,
hooks: {
version: "1.0.0",
onReady: (payload) => {
console.log("Screeb ready", payload);
},
onSurveyShowed: (payload) => {
console.log("Survey showed", payload);
},
onSurveyCompleted: (payload) => {
console.log("Survey completed", payload);
},
},
});
</script>
Per-survey hooksโ
Pass hooks to surveyStart():
<script lang="ts">
import { useScreeb } from "@screeb/sdk-svelte";
const { surveyStart } = useScreeb();
await surveyStart("<survey-id>", undefined, false, {}, {
version: "1.0.0",
onSurveyCompleted: (payload) => {
console.log("Survey completed", payload);
},
});
</script>
Per-message hooksโ
Pass hooks to messageStart():
<script lang="ts">
import { useScreeb } from "@screeb/sdk-svelte";
const { messageStart } = useScreeb();
await messageStart("<message-id>", true, {}, {
version: "1.0.0",
onMessageCompleted: (payload) => {
console.log("Message completed", payload);
},
});
</script>