Basic widget installation
<button class="heidi-button" style="display: none;" onclick="openHeidi()">
Open Heidi
</button>
<button class="heidi-button" style="display: none;" onclick="openHeidiWithTemplate()">
Open Heidi with Template
</button>
<button class="heidi-button" style="display: none;" onclick="closeHeidi()">
Close Heidi
</button>
<script>
const templateData = {
content: '...',
responses: [
{
questionId: '...',
question: '...',
answerType: '...',
answerOptions: ['...', '...'],
},
],
};
function openHeidiWithTemplate() {
Heidi.open({ template: templateData });
}
function openHeidi() {
Heidi.open();
}
function closeHeidi() {
Heidi.close();
}
const heidiOptions = {
token: 'VALID_JWT_TOKEN',
target: '#heidi',
onInit: () => {
// Display the UI that will trigger Heidi
document
.querySelectorAll('.heidi-button')
.forEach((button) => (button.style.display = 'block'));
},
onReady: () => {
Heidi.onPushData((data) => {
// data.notesData will contain data generated by Heidi
// if a template was used, it will contain the result
// using the Template structure above
console.log(data);
});
Heidi.onSessionStarted((sessionId) => {
// sessionId is the ID of the current Heidi Session.
});
},
};
(function (s, o) {
const script = document.createElement('script');
script.async = true;
script.src = s;
document.head.append(script);
script.addEventListener('load', () => new Heidi(o));
})('https://registrar.widget.heidihealth.com/staging/widget/heidi.js', heidiOptions);
</script>
TypeScript Support
The widget is fully compatible with TypeScript.
If you are using TypeScript, you can use the @heidihealth/widget-types
package to get the correct types for the widget.
npm install @heidihealth/widget-types --save-dev