@medic/openrosa-formlist
v1.0.1
Published
Create a valid OpenRosa FormList of xforms see https://bitbucket.org/javarosa/javarosa/wiki/FormListAPI
Downloads
3
Readme
openrosa-formlist
Create a valid JavaRosa FormList of xforms see https://bitbucket.org/javarosa/javarosa/wiki/FormListAPI
defaults(mediaRe, namePath, instancePath)
Default options
Parameters
| parameter | type | description |
| -------------- | ------ | ------------------------------------------------------------------------------------------------------------ |
| mediaRe
| RegExp | RegExp to match any external media referenced in the xForm |
| namePath
| String | xPath style path to the XML tag that contains the xForm name |
| instancePath
| String | xPath style path to XML tag that contains the instance (which has the form id
and version
as attributes) |
createFormList(forms, [options], callback)
Creates a valid FormList XML document according to https://bitbucket.org/javarosa/javarosa/wiki/FormListAPI
Parameters
| parameter | type | description |
| ----------- | -------- | -------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
| forms
| Array | An array of Urls for each form, streams (could be a file read stream or a response stream), or full XML text of the form |
| [options]
| Object | optional: options.downloadUrl
is a template for the url where the form is located, in the format http://example.com/forms/${formId}.xml
. ${formId}
will be replaced by the actual form Id of each form. options.manifestUrl
is the url template for the location of the manifest xml document (only included if external media is referenced in the xForm) |
| callback
| Function | Called with (err, data)
where data
is a valid formListAPI Xml document |
Example
var createFormList = require('openrosa-formlist');
var forms = [
'https://opendatakit.appspot.com/formXml?formId=widgets',
'https://opendatakit.appspot.com/formXml?formId=Birds'
];
createFormList(forms, function(err, data) {
console.log(data) // outputs formList Xml
})
Installation
Requires nodejs.
$ npm install openrosa-formlist
Tests
$ npm test