Hooks
Hooks let you listen to Screeb lifecycle events. You can define hooks globally via the plugin config or per-survey/per-message.
Available hooksโ
| Hook Name | Plugin config / init | surveyStart | messageStart |
|---|---|---|---|
onReady | โ | โ | โ |
onSurveyDisplayAllowed | โ | โ | โ |
onMessageDisplayAllowed | โ | โ | โ |
onSurveyShowed | โ | โ | โ |
onSurveyStarted | โ | โ | โ |
onQuestionReplied | โ | โ | โ |
onSurveyCompleted | โ | โ | โ |
onSurveyHidden | โ | โ | โ |
onMessageShowed | โ | โ | โ |
onMessageStarted | โ | โ | โ |
onMessageCompleted | โ | โ | โ |
onMessageHidden | โ | โ | โ |
Global hooks (plugin config)โ
Define hooks once in main.ts:
createApp(App)
.use(ScreebPlugin, {
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);
},
},
})
.mount("#app");
Per-survey hooksโ
Pass hooks to surveyStart():
<script setup lang="ts">
import { useScreeb } from "@screeb/sdk-vue";
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 setup lang="ts">
import { useScreeb } from "@screeb/sdk-vue";
const { messageStart } = useScreeb();
await messageStart("<message-id>", true, {}, {
version: "1.0.0",
onMessageCompleted: (payload) => {
console.log("Message completed", payload);
},
});
</script>