Lifecycle callbacks¶
To create a robust Agentic Interface, you must understand in which state a dialog with the user can be and know how and when the dialog transitions between the states.
Agentic Interface lifecycle¶
Every project you create with Alan AI goes through the following workflow:
- Project is created: The project lifecycle begins when you create and save scripts for the Agentic Interface in Alan AI Studio. At this step, Alan AI loads the scripts in the Alan AI Cloud and builds the project model for the Agentic Interface. - Alan AI reloads scripts and rebuilds the project model every time you update and save scripts in Alan AI Studio. 
- User is connected: When a new user opens an app with the Agentic Interface and starts a conversation, Alan AI connects to the project in the Alan AI Cloud, creates a new dialog for this user and assigns a unique ID to this dialog. For every user interacting with Alan AI, a separate dialog is created. All the communication with Alan AI is performed within this dialog, even if the user stops interaction for a while by clicking or tapping the Agentic Interface button. 
- User is disconnected: When the user stops communicating with the app, he or she gets disconnected, and Alan AI closes the dialog created for the user. The dialog can also be closed in the following cases: - The user is inactive for a 30-minute period. 
- The dialog scripts for the project are reloaded. 
 
Callbacks¶
As the dialog transitions from state to state, you may need to adjust the Agentic Interface behavior. To let you do it, Alan AI offers a set of predefined callbacks. You can use these callbacks to perform necessary tasks and handle significant events in your dialog script:
onCreateProject()¶
This callback is invoked when the project is created and the project model is built. You can perform any initialization activities that may be required for your agent.
onCreateProject(() => {
    project.drinks = "green tea, black tea, oolong";
});
onCreateUser()¶
This callback is invoked when a new user connects to Alan AI and starts the dialog session. Here, for example, you can set user-specific data.
onCreateUser(p => {
    p.userData.name = "John Smith";
});
onUserEvent((p, e) => {
    if (e.event == 'firstClick') {
        p.play(`Hi, ${p.userData.name}, how can I help you today?`);
    }
});
onCleanupUser()¶
This callback is invoked when the user disconnects from Alan AI or the dialog is closed. Here you can perform any cleanup activities or save the user data.
onCleanupUser(p => {
    p.userData.name = "";
});
onVisualState()¶
This callback is invoked when the visual state is sent from the client app.
Setting the visual state in the app:
<script>
  function myFunction() {
    alanBtnInstance.setVisualState({"page": "admittance"});
  }
</script>
Playing a greeting in the dialog script:
onVisualState((p, s) => {
    if (p.visual.page === "admittance") {
        p.play("Hello there! I'm your Agentic Interface, here to guide you through your journey towards academic success.")
    }
});
onUserEvent()¶
This callback invoked when Alan AI emits events driven by users’ interactions with the Agentic Interface.
onCreateUser(p => {
    p.userData.name = "John Smith";
});
onUserEvent((p, e) => {
    if (e.event == 'firstClick') {
        p.play(`Hi, ${p.userData.name}, how can I help you today?`);
    }
});