2022-05-31 09:59:34 +02:00
---
2023-12-22 09:13:53 +01:00
title: HTML & Javascript
2022-05-31 09:59:34 +02:00
---
## Standard
You can get the standard HTML and Javascript code by clicking on the "HTML & Javascript" button in the "Share" tab of your typebot.
There, you can change the container dimensions. Here is a code example:
```html
2023-02-21 16:22:25 +01:00
<script type="module">
2023-10-06 10:14:26 +02:00
import Typebot from 'https://cdn.jsdelivr.net/npm/@typebot.io/js@0.2/dist/web.js'
2023-02-21 16:22:25 +01:00
2023-02-21 15:25:14 +01:00
Typebot.initStandard({
typebot: 'my-typebot',
2022-05-31 09:59:34 +02:00
})
</script>
2023-02-21 16:22:25 +01:00
<typebot-standard style="width: 100%; height: 600px; "></typebot-standard>
2022-05-31 09:59:34 +02:00
```
This code is creating a container with a 100% width (will match parent width) and 600px height.
2023-06-01 10:29:02 +02:00
### Multiple bots
If you have different bots on the same page you will have to make them distinct with an additional `id` prop:
```html
<script type="module">
2023-10-06 10:14:26 +02:00
import Typebot from 'https://cdn.jsdelivr.net/npm/@typebot.io/js@0.2/dist/web.js'
2023-06-01 10:29:02 +02:00
Typebot.initStandard({
id: 'bot1'
typebot: 'my-typebot',
})
Typebot.initStandard({
id: 'bot2'
typebot: 'my-typebot-2',
})
</script>
<typebot-standard
id="bot1"
style="width: 100%; height: 600px; "
></typebot-standard>
...
<typebot-standard
id="bot2"
style="width: 100%; height: 600px; "
></typebot-standard>
```
2023-12-22 09:13:53 +01:00
## Popup
You can get the popup HTML and Javascript code by clicking on the "HTML & Javascript" button in the "Share" tab of your typebot.
Here is an example:
```html
<script type="module">
import Typebot from 'https://cdn.jsdelivr.net/npm/@typebot.io/js@0.2/dist/web.js'
Typebot.initPopup({
typebot: 'my-typebot',
apiHost: 'http://localhost:3001',
autoShowDelay: 3000,
})
</script>
```
This code will automatically trigger the popup window after 3 seconds.
2022-05-31 09:59:34 +02:00
## Bubble
You can get the bubble HTML and Javascript code by clicking on the "HTML & Javascript" button in the "Share" tab of your typebot.
Here is an example:
```html
2023-02-21 16:22:25 +01:00
<script type="module">
2023-10-06 10:14:26 +02:00
import Typebot from 'https://cdn.jsdelivr.net/npm/@typebot.io/js@0.2/dist/web.js'
2023-02-21 16:22:25 +01:00
2023-02-21 15:25:14 +01:00
Typebot.initBubble({
typebot: 'my-typebot',
2023-02-21 16:22:25 +01:00
previewMessage: {
message: 'I have a question for you!',
autoShowDelay: 5000,
avatarUrl: 'https://avatars.githubusercontent.com/u/16015833?v=4',
},
theme: {
button: { backgroundColor: '#0042DA', iconColor: '#FFFFFF' },
previewMessage: { backgroundColor: '#ffffff', textColor: 'black' },
2023-11-14 08:25:32 +01:00
chatWindow: { backgroundColor: '#ffffff', maxWidth: '100%' },
2023-02-21 16:22:25 +01:00
},
2022-05-31 09:59:34 +02:00
})
</script>
```
2023-02-21 16:22:25 +01:00
This code will show the bubble and let a preview message appear after 5 seconds.
2022-05-31 09:59:34 +02:00
2023-05-05 11:10:10 -04:00
### Custom button position
You can move the button with some custom CSS on your website. For example, you can place the bubble button higher with the following CSS:
```css
typebot-bubble::part(button) {
bottom: 60px;
}
typebot-bubble::part(bot) {
bottom: 140px;
2023-08-25 14:35:15 +02:00
height: calc(100% - 140px)
2023-05-05 11:10:10 -04:00
}
```
If you have a preview message, you'll also have to manually position it:
```css
typebot-bubble::part(preview-message) {
bottom: 140px;
}
```
2023-12-22 09:13:53 +01:00
## Commands
Here are the commands you can use to trigger your embedded typebot:
- `Typebot.open()`: Open popup or bubble
- `Typebot.close()`: Close popup or bubble
- `Typebot.toggle()`: Toggle the bubble or popup open/close state,
- `Typebot.showPreviewMessage()`: Show preview message from the bubble,
- `Typebot.hidePreviewMessage()`: Hide preview message from the bubble,
- `Typebot.setPrefilledVariables(...)`: Set prefilled variables.
Example:
```js
Typebot.setPrefilledVariables({
Name: 'Jhon',
Email: 'john@gmail.com',
})
```
For more information, check out [Additional configuration](#additional-configuration).
- `Typebot.setInputValue(...)`: Set the value in the currently displayed input.
You can bind these commands on a button element, for example:
```html
<button onclick="Typebot.open()">Contact us</button>
```
2023-06-28 10:29:58 +02:00
## Callbacks
If you need to trigger events on your parent website when the user interact with the bot, you can use the following callbacks:
```js
Typebot.initStandard({
typebot: 'my-typebot',
onNewInputBlock: (inputBlock) => {
console.log('New input block displayed', inputBlock.id)
},
onAnswer: (answer) => {
console.log('Answer received', answer.message, answer.blockId)
},
onInit: () => {
console.log('Bot initialized')
},
onEnd: () => {
console.log('Bot ended')
},
})
```
2022-05-31 09:59:34 +02:00
## Additional configuration
2023-02-21 15:25:14 +01:00
You can prefill the bot variable values in your embed code by adding the `prefilledVariables` option. Here is an example:
2022-05-31 09:59:34 +02:00
```js
2023-02-21 15:25:14 +01:00
Typebot.initStandard({
typebot: 'my-typebot',
prefilledVariables: {
2022-12-08 14:28:40 +01:00
'Current URL': 'https://my-site/account',
2022-05-31 09:59:34 +02:00
'User name': 'John Doe',
},
})
```
2022-12-08 14:28:40 +01:00
It will prefill the `Current URL` variable with "https://my-site/account" and the `User name` variable with "John Doe". More info about variables: [here](/editor/variables).
2022-11-28 08:27:11 +01:00
2022-12-08 14:28:40 +01:00
Note that if your site URL contains query params (i.e. https://typebot.io?User%20name=John%20Doe), the variables will automatically be injected to the typebot. So you don't need to manually transfer query params to the bot embed configuration.