Package Exports
- executable_html
- executable_html/dist/e2e/choose-in-sequence-with-screen.html
- executable_html/dist/e2e/choose-in-sequence-without-screen.html
- executable_html/dist/e2e/jump-backwards.html
- executable_html/dist/e2e/jump-forwards.html
- executable_html/dist/e2e/likert-choose-branch.html
- executable_html/dist/e2e/linear-sequence.html
- executable_html/dist/e2e/multiple-choice-routing.html
- executable_html/dist/e2e/multiple-matching-whens.html
- executable_html/dist/e2e/nested-sequences.html
- executable_html/dist/e2e/no-match-no-otherwise.html
- executable_html/dist/e2e/self-removal.html
- executable_html/dist/e2e/slider-submit-advance.html
- executable_html/dist/e2e/stop-mid-run.html
- executable_html/dist/e2e/text-answer-validation.html
- executable_html/dist/e2e/text-node-passthrough.html
- executable_html/dist/e2e/variable-branch-false-otherwise.html
- executable_html/dist/e2e/variable-branch-true.html
- executable_html/dist/e2e/write-into-target.html
- executable_html/dist/index.js
- executable_html/dist/vite.svg
- executable_html/types/customElements/aa-affect-grid/aa-affect-grid.d.ts
- executable_html/types/customElements/aa-base-element/aa-base-element.d.ts
- executable_html/types/customElements/aa-checkboxes/aa-checkboxes.backup.d.ts
- executable_html/types/customElements/aa-checkboxes/aa-checkboxes.d.ts
- executable_html/types/customElements/aa-choice-item/aa-choice-item.d.ts
- executable_html/types/customElements/aa-choose/aa-choose.d.ts
- executable_html/types/customElements/aa-choose/aa-otherwise/aa-otherwise.d.ts
- executable_html/types/customElements/aa-choose/aa-when/aa-when.d.ts
- executable_html/types/customElements/aa-function/aa-function-random.d.ts
- executable_html/types/customElements/aa-geolocation/aa-geolocation.d.ts
- executable_html/types/customElements/aa-label/aa-label.d.ts
- executable_html/types/customElements/aa-likert-scale/aa-likert-scale.d.ts
- executable_html/types/customElements/aa-memory/aa-memory.d.ts
- executable_html/types/customElements/aa-multiple-choice/aa-multiple-choice.backup.d.ts
- executable_html/types/customElements/aa-multiple-choice/aa-multiple-choice.d.ts
- executable_html/types/customElements/aa-screen/aa-screen.d.ts
- executable_html/types/customElements/aa-sequence/aa-jump/aa-jump.d.ts
- executable_html/types/customElements/aa-sequence/aa-sequence.d.ts
- executable_html/types/customElements/aa-session/aa-session.d.ts
- executable_html/types/customElements/aa-slider/aa-slider.d.ts
- executable_html/types/customElements/aa-text-answer/aa-text-answer.d.ts
- executable_html/types/customElements/aa-variable/aa-variable.d.ts
- executable_html/types/index.d.ts
- executable_html/types/lib/html2jsl/html2jsl.d.ts
- executable_html/types/lib/js-yaml-browserify.d.ts
- executable_html/types/lib/jsep/jsep.d.ts
- executable_html/types/lib/jsl/jsl2.1.d.ts
- executable_html/types/lib/mySVG/mySVG.d.ts
- executable_html/types/lib/regenerator-runtime/path.d.ts
- executable_html/types/lib/regenerator-runtime/runtime.d.ts
- executable_html/types/lib/svg/svg.d.ts
- executable_html/types/lib/yaml/js-yaml.d.ts
- executable_html/types/lib/yaml/yaml.d.ts
- executable_html/types/my-element.d.ts
- executable_html/types/src/customElements/aa-affect-grid/aa-affect-grid.d.ts
- executable_html/types/src/customElements/aa-base-element/aa-base-element.d.ts
- executable_html/types/src/customElements/aa-camera/aa-camera.d.ts
- executable_html/types/src/customElements/aa-checkboxes/aa-checkboxes.backup.d.ts
- executable_html/types/src/customElements/aa-checkboxes/aa-checkboxes.d.ts
- executable_html/types/src/customElements/aa-choice-item/aa-choice-item.d.ts
- executable_html/types/src/customElements/aa-choose/aa-choose.d.ts
- executable_html/types/src/customElements/aa-choose/aa-otherwise/aa-otherwise.d.ts
- executable_html/types/src/customElements/aa-choose/aa-when/aa-when.d.ts
- executable_html/types/src/customElements/aa-function/aa-function-random.d.ts
- executable_html/types/src/customElements/aa-geolocation/aa-geolocation.d.ts
- executable_html/types/src/customElements/aa-label/aa-label.d.ts
- executable_html/types/src/customElements/aa-likert-scale/aa-likert-scale.d.ts
- executable_html/types/src/customElements/aa-memory/aa-memory.d.ts
- executable_html/types/src/customElements/aa-multiple-choice/aa-multiple-choice.backup.d.ts
- executable_html/types/src/customElements/aa-multiple-choice/aa-multiple-choice.d.ts
- executable_html/types/src/customElements/aa-schedule-calendar/aa-schedule-calendar.d.ts
- executable_html/types/src/customElements/aa-schedule-calendar/aa-schedule-day-column.d.ts
- executable_html/types/src/customElements/aa-schedule-calendar/aa-schedule-signal-list.d.ts
- executable_html/types/src/customElements/aa-schedule-calendar/aa-schedule-stats.d.ts
- executable_html/types/src/customElements/aa-schedule-calendar/aa-schedule-warnings.d.ts
- executable_html/types/src/customElements/aa-schedule-calendar/aa-schedule-week-grid.d.ts
- executable_html/types/src/customElements/aa-schedule-calendar/helpers.d.ts
- executable_html/types/src/customElements/aa-screen/aa-screen.d.ts
- executable_html/types/src/customElements/aa-sequence/aa-jump/aa-jump.d.ts
- executable_html/types/src/customElements/aa-sequence/aa-sequence.d.ts
- executable_html/types/src/customElements/aa-session/aa-session.d.ts
- executable_html/types/src/customElements/aa-signal-protocol/aa-signal-protocol.d.ts
- executable_html/types/src/customElements/aa-slider/aa-slider.d.ts
- executable_html/types/src/customElements/aa-text-answer/aa-text-answer.d.ts
- executable_html/types/src/customElements/aa-variable/aa-variable.d.ts
- executable_html/types/src/index.d.ts
- executable_html/types/src/lib/html2jsl/html2jsl.d.ts
- executable_html/types/src/lib/js-yaml-browserify.d.ts
- executable_html/types/src/lib/jsep/jsep.d.ts
- executable_html/types/src/lib/jsl/jsl2.1.d.ts
- executable_html/types/src/lib/mySVG/mySVG.d.ts
- executable_html/types/src/lib/regenerator-runtime/path.d.ts
- executable_html/types/src/lib/regenerator-runtime/runtime.d.ts
- executable_html/types/src/lib/svg/svg.d.ts
- executable_html/types/src/lib/yaml/js-yaml.d.ts
- executable_html/types/src/lib/yaml/yaml.d.ts
- executable_html/types/tests/aa-affect-grid.test.d.ts
- executable_html/types/tests/aa-checkboxes.test.d.ts
- executable_html/types/tests/aa-choice-item.test.d.ts
- executable_html/types/tests/aa-choose.test.d.ts
- executable_html/types/tests/aa-function-random.test.d.ts
- executable_html/types/tests/aa-geolocation.test.d.ts
- executable_html/types/tests/aa-label.test.d.ts
- executable_html/types/tests/aa-likert-scale.test.d.ts
- executable_html/types/tests/aa-memory.test.d.ts
- executable_html/types/tests/aa-multiple-choice.test.d.ts
- executable_html/types/tests/aa-screen.test.d.ts
- executable_html/types/tests/aa-sequence.test.d.ts
- executable_html/types/tests/aa-session.test.d.ts
- executable_html/types/tests/aa-signal-protocol.test.d.ts
- executable_html/types/tests/aa-slider.test.d.ts
- executable_html/types/tests/aa-text-answer.test.d.ts
- executable_html/types/tests/aa-variable.test.d.ts
- executable_html/types/tests/base-element.test.d.ts
- executable_html/types/tests/test_mySVG.d.ts
Readme
Executable HTML
Build interactive surveys, questionnaires, and experiments using just HTML.
Executable HTML is a library of custom web components that turn static markup into interactive, sequential experiences. Instead of writing JavaScript to manage state, control flow, and data collection, you describe your entire application declaratively with HTML tags.
Live Documentation & Examples | npm | GitHub
Why?
Building surveys and experiments typically requires wiring up JavaScript for page flow, branching logic, data collection, and storage. Executable HTML replaces all of that with a declarative HTML vocabulary:
- No JavaScript required for standard survey flows
- Branching and conditionals via
<aa-choose>/<aa-when>/<aa-otherwise> - Automatic data collection through
<aa-session>and localStorage - Rich form controls — sliders, Likert scales, multiple choice, text input, affect grids
- Progressive enhancement — enhanced UI when Web Awesome is loaded, native fallbacks otherwise
Quick example
<aa-session name="my-survey">
<aa-sequence>
<aa-screen submit-button-text="Next">
<aa-label>How are you feeling?</aa-label>
<aa-slider name="mood" min="0" max="100"
min-label="Bad" max-label="Great">
</aa-slider>
</aa-screen>
<aa-screen submit-button-text="Done">
<aa-label>Thank you!</aa-label>
</aa-screen>
</aa-sequence>
</aa-session>Installation
npm install executable_htmlimport "executable_html";All custom elements are automatically registered. Just write HTML.
Components
Session & data
aa-session— Top-level container that manages memory and data collectionaa-variable— Declares a named variable with a valueaa-memory— Underlying storage layer (localStorage)
Control flow
aa-sequence— Executes child elements one after anotheraa-choose/aa-when/aa-otherwise— Conditional branching based on expressionsaa-jump— Jump to a named step within a sequence
User interface
aa-screen— A page/step with a submit button that collects valuesaa-label— Display textaa-slider— Numeric slider inputaa-multiple-choice/aa-choice-item— Single-select choiceaa-checkboxes— Multi-select checkboxesaa-text-answer— Free text inputaa-likert-scale— Likert scale ratingaa-affect-grid— 2D affect/emotion grid
Utilities
aa-function-random— Generate random valuesaa-geolocation— Capture device location
Styling
Components are styled using CSS custom properties and ::part() selectors:
/* Override the default font */
:root {
--aa-font-family: "Inter", sans-serif;
}
/* Style the submit button */
aa-screen::part(button) {
background: #4f46e5;
border-radius: 8px;
}See the Storybook documentation for the full list of CSS custom properties per component.
TypeScript
Types are exported for all public classes and event detail interfaces:
import type { AASession, AASessionInput } from "executable_html";Browser support
Requires browsers with support for:
- Custom Elements v1 (all modern browsers)
- ES2020 (Chrome 80+, Firefox 80+, Safari 14+, Edge 80+)
No polyfills are included or required for modern browsers.
Development
npm run dev # Vite dev server with getting-started example
npm run storybook # Storybook documentation and playground
npm test # Unit tests (web-test-runner)
npm run test:e2e # End-to-end tests (Playwright)See CONTRIBUTING.md for more details.