extension-libs/
Introduced in v4.2.0
Introduction
Extension libraries are blocks of code that are cached with the CHT web application giving app developers a powerful tool to extend the CHT. This is an advanced feature and requires an app developer with some software development experience.
An example of a use for this feature is to provide a function to calculate a risk score based on a machine learning model. The function can then be called passing in values from app forms and return the result to be stored with the report.
Library
The first step is to create the js file to return the function that will be called by the web application. Create a new file using this template:
module.exports = function(/* parameters */) {
return result;
}
Now populate the function as needed. For complex functions, it is recommended to use third party libraries (such as momentjs, lodash, etc) and use a bundler (eg: webpack) to make it easy to build a single file. It’s recommended to use development best practices such as linting, unit tests, and minification to ensure quality and small download size.
xpath functions
To call the function from within a form the parameters and return value will need to have a very specific structure to work with Enketo xforms.
{
"t": <type>,
"v": <value>
}
Where the type is one of “bool”, “num”, “str”, “date”, or “arr”. For example, to calculate the average of two inputs, you would use:
const getValue = function(obj) {
let val;
if (obj.t === 'arr') {
val = obj.v && obj.v.length && obj.v[0];
} else {
val = obj.v;
}
if (!val) {
return 0;
}
const parsed = parseInt(val.textContent);
return isNaN(parsed) ? 0 : parsed;
};
module.exports = function(first, second) {
const average = (getValue(first) + getValue(second)) / 2;
return {
t: 'num',
v: average
};
}
Uploading to the CHT
Create a folder within the project configuration to contain the libraries, for example:
./extension-libs
average.js
calculate-risk-score.js
Now run the command: cht upload-extension-libs
This will create or update a document to CouchDB with an ID of extension-libs
with each of the configured scripts attached. Once this is created the webapp service worker will be updated so the libraries are cached on the phone ready for use offline.
Invoking the function
CHT API
The function will now be available via the CHT API for tasks, targets, and contact summary configurations.
CHT xPath functions
To execute the function from within an xform use the cht:extension-lib
xpath function.
Advanced usage
Extension libraries are simply JavaScript functions executed in the context of the CHT web application. This means technically they can be used to do things like manipulating the DOM for fine-grained control of how elements are displayed in a form.
Advanced integrations like this are not explicitly supported (they may break in future versions of the CHT). However, they can be a powerful tool for developers looking to extend the CHT without having to fork the entire project.
See this blog post from a community member for more information and inspiration on the kinds of things that can be achieved with extension libs!
Feedback
Was this page helpful?
Glad to hear it! Please tell us how we can improve.
Sorry to hear that. Please tell us how we can improve.