JSPM

  • Created
  • Published
  • Downloads 24
  • Score
    100M100P100Q75250F
  • License MIT

Build interactive surveys, questionnaires, and experiments using just HTML custom elements.

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_html
import "executable_html";

All custom elements are automatically registered. Just write HTML.

Components

Session & data

  • aa-session — Top-level container that manages memory and data collection
  • aa-variable — Declares a named variable with a value
  • aa-memory — Underlying storage layer (localStorage)

Control flow

  • aa-sequence — Executes child elements one after another
  • aa-choose / aa-when / aa-otherwise — Conditional branching based on expressions
  • aa-jump — Jump to a named step within a sequence

User interface

  • aa-screen — A page/step with a submit button that collects values
  • aa-label — Display text
  • aa-slider — Numeric slider input
  • aa-multiple-choice / aa-choice-item — Single-select choice
  • aa-checkboxes — Multi-select checkboxes
  • aa-text-answer — Free text input
  • aa-likert-scale — Likert scale rating
  • aa-affect-grid — 2D affect/emotion grid

Utilities

  • aa-function-random — Generate random values
  • aa-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.

Further reading

License

MIT