UNPKG

node-red-contrib-uibuilder

Version:

Easily create data-driven web UI's for Node-RED. Single- & Multi-page. Multiple UI's. Work with existing web development workflows or mix and match with no-code/low-code features.

110 lines (64 loc) 5.7 kB
--- title: Front-End Build Steps and Tools description: | Describes how to use a build step to transpile and optimise your front-end code. created: 2021-04-22 09:53:00 updated: 2024-06-14 20:18:33 --- A build step is simply a way to take things that your browser wont understand directly (like .vue, .jsx files) and convert them to somthing that they can understand. Along the way, it will try to optimise everything to give the best possible performance. - [Why have a build step (and why not)](#why-have-a-build-step-and-why-not) - [Things to watch out for](#things-to-watch-out-for) - [Using a build development server](#using-a-build-development-server) - [Tools](#tools) ## Why have a build step (and why not) If you want to make most use of the more complex features of a front-end library or if you want to write using the latest language features but still need to support older browsers, then a build step will almost certainly be needed. A build step may also be desirable if you need to squeeze more performance out or reduce the size of your web app. Otherwise, you may wish to try and avoid the complexity of setting up your build environment, running dev servers and so on. One of the reasons that UIBUILDER used to use VueJS as its default template was that it was one of the best front-end libraries for avoiding build steps. It even has a dynamic loader (3rd party extension) and an in-browser compiler. ## Things to watch out for * The tooling is likely to have its own desired folder structure. You will most likely have to change the configuration to make it use the folders for UIBUILDER on the Node-RED server. * If using the build-tool's development server, you will need to change some code. See the next section for details. The Svelte development server is the only known exception to this as it "just works" with Node-red/UIBUILDER. ## Using a build development server Many build tools and some front-end frameworks have "live servers" to support development. These automatically reload the page being developed whenever something changes. At present, only the Svelte development server will work correctly without you making some temporary changes to your front-end code. (However, see also [Live-reload dev servers](how-to/live-reload-dev-server)). For all other development servers, you will need to make the following changes: 1. In `index.html` - replace the default `./xxxx` and `../uibuilder/xxxx` URL's with ones that start with the correct Node-RED/uibuilder server. e.g. `http://localhost:1880/xxxx`. 2. In `index.js` - replace the `uibuilder.start()` with `uibuilder.start('http://localhost:1880/aa')` (old client example) or `uibuilder.start({ioNamespace:'http://localhost:1880/aa'})` (new client example) where the protocol, server name and port are your Node-RED/uibuilder server as above and `/aa` is the `uibuilder` node instances URL with a leading `/`. That is the Socket.io namespace. Note that if you have set the `httpNodeRoot` in Node-RED and you are not using UIBUILDER's custom ExpressJS server, you **must** also include the second parameter which overrides the Socket.IO path such that it includes the httpNodeRoot. Example: if httpNodeRoot='nr', the path parameter must be `/nr/uibuilder/vendor/socket.io`. Don't forget to change these back when you are putting your code live. Though your live code will still work, it would be more fragile and would break if you change the server details. It is also possible that you could automate these changes using the build tool. Using environment variables to tell the tool which url's to use. If not, you could automate the whole process using a tool such as [GulpJS](https://gulpjs.com/). ## Tools There are many options when it comes to tooling for your build step, here are some of the main ones and some of the latest tools that are a LOT simpler than the earlier ones ### Snowpack [Snowpack](https://www.snowpack.dev/) is: > "a lightning-fast frontend build tool, designed for the modern web" See the [How-to configure and use a front-end build step using Snowpack](front-end-build-snowpack.md) page for more details. Snowpack works well with UIBUILDER. ### ESbuild [ESbuild](https://esbuild.github.io/) Unlike the other tools listed here, esbuild _only_ does a build. It does not attempt to provide a development server or do clever transpilation (converting from a newer version of JavaScript to an older one). And that may well be all that you need since Node-RED is providing a web server and modern browsers are less likely to require transpilation. Julia Evans is a well-known blogger and has written a [simple guide to using esbuild with VueJS](https://jvns.ca/blog/2021/11/15/esbuild-vue/). ESbuild is used to produce the IIFE and ESM builds of the uibuilder client library and other front-end libraries because it is able to output different versions constrained to specific JavaScript versions and module types. It can also compress JavaScript source and create map files for ease of debugging. ### Webpack [Webpack](https://webpack.js.org/) TBC ### Parcel [Parcel](https://parceljs.org/) TBC ### Rollup [Rollup](https://rollupjs.org/) TBC ### Vite [Vite](https://vitejs.dev/) (by VueJS author Evan You): > "an opinionated web dev build tool that serves your code via native ES Module imports during development and bundles it with Rollup for production." While Vite was written by the author of VueJS, it is certainly not only for Vue projects. Out of the box, it supports REACT, JSX as well as various CSS pre-processors and templates. It uses ESBuild under the skin. It uses native browser ES imports to make everything fast.