Skip to main content
Version: Vue SDK

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 NamePlugin config / initsurveyStartmessageStart
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>