Files
espurna/code/html
Maxim Prokhorov b41a20aa86 webui(build): support type=...;base64
in case there are any unquotable or binary sources

SCRIPT is an odd one per the spec, ignore type=...
as it is describing how minification & bundling is done
2025-04-15 20:43:01 +03:00
..
2025-04-14 04:56:15 +03:00
2025-04-14 01:14:13 +03:00
2025-04-14 01:14:13 +03:00
2025-04-14 05:18:25 +03:00

Builder script is using Gulp

Additional tools used

All commands must be called from code/

$ pwd
/home/dev/espurna/code

When gulp command is not available globally

$ ./node_modules/.bin/gulp

Files

  • code/espurna/static/ - .html.ipp, used in the firmware code
  • code/gulpfile.mjs - builder script entrypoint
  • code/vite.config.mjs - (experimental) vite dev server configuration
  • code/html/index.html - main entrypoint, index.html template
  • code/html/build - intermediate build results
  • code/html/preset - build configurations
  • code/html/spec - vitest 'spec' files
  • code/html/src - source .mjs, .html, etc.
  • code/node_modules - build dependencies
  • code/package{,-lock}.json - build dependencies metadata

Installation

(recommended) Install exact dependencies listed in the package-lock.json, from the time the builder code was last updated

$ npm ci

(optional) Install dependencies listed in the package.json, possibly updating packages listed in the package-lock.json

$ npm install

Building

Run tests and build every .html.ipp (default task)

$ gulp

Build only (does not run tests)

$ gulp build

Build specific flavour (preset tasks)

$ gulp build --preset small

List all available tasks

$ gulp --tasks

Development

Launches development server on port 8080 with the resulting .html bundle. No minification or compression, using dev preset as base

$ gulp dev

Only the default task depends on the test and lint tasks, call them manually

$ gulp test
$ gulp eslint html-validate vitest
$ gulp eslint
$ gulp html-validate
$ gulp vitest

Gulp usually does not allow any task arguments, run these tools manually to select specific files or change command line arguments

$ npm exec --no -- eslint gulpfile.mjs html/src/*.mjs html/spec/*.mjs
$ npm exec --no -- html-validate html/src/*.html
$ npm exec --no -- vitest --environment jsdom --dir html/spec --run

Experimental support of Vite dev server is also included. Every preset is supported, but only --mode dev is expected to work locally

$ vite --mode dev