This is a set of custom elements to provide piecemeal insertion of HTML into the DOM tree, in either sequential or conditional fashion, effectively rendering said HTML executable.
For a demo, see https://b3008.github.io/
executable HTML is a set of custom elements which help the author of HTML content determine the way pieces of HTML are inserted into the document, without necessitating the use of JavaScript by the author.
Normally an HTML script is parsed and rendered by the browser as a whole, when loaded. The only way to modify the content of the page is either by having hidden parts that are displayed to the user on some event, or by manipulating the DOM with JavaScript.
There are use cases where simple logic is needed, and the move into the domain of JavaScript can be daunting for users. One such is the creation of questionnaires for clinical psychology.
Please refer to this paper for a detailed exposition of the problem this collection of custom elements solves.
The ultimate aim is to produce a single representation of a data collection protocol that is both human-readable and computer executable.ss
Raise a server at localhost, e.g using
live-server and load /tests/test.html
Run npm run test
. It will run the browser tests and also produce a coverate report for headless Chrome and Firefox under ./coverage
.
Make sure you have webpack
and webpack-cli
installed. Run webpack at the root directory to compile all modules under ./src
into a production-mode single source, stored under ./dist/aaCustomElements.js
Alternatively, run npm run build
Develop a new component by inheriting from BaseElement
import BaseElement from './../aa-baseElement/baseElement.js';
export default class NewComponent extends BaseElement {
}
The properties
getter describes the attributes for the element e.g.
myAttribute:{
type : <String, Nubmer, Boolean, etc>
userDefined : <true | false> is it a property that can be set by the user? (knowing this can be used in building an editor for the element)
value : does it have a default value?
}
acceptsElements
is an array of the tags that can be nested inside this element. knowing this can be used in building an editor for the element.
To get the new component built into the release package, import it in to ./src/index.js
This codebase uses slightly modified versions of jsep and js-yaml, to be able to import them (e.g, with the addition of export default
)