NOTE: You can replace the contents of this README with text that describes your UI.
A template that just Vue v3 or above with no build step even though it includes a Vue custom component module. There is no need to install any dev dependencies to get this going.
Note that Vue v3 is called from an Internet CDN so that you don't have to have it installed via uibuilder's library manager. However, you may want to install it if you continue to use Vue v3 to save a dependency on the Internet being up.
Included are a few elements that demonstrate Vue's rectivity and demonstrates how to get data from and to Node-RED via uibuilder.
It uses the ESM version of the modern client library. So the uibuilder and other libraries are loaded in index.js
.
VueJS and similar advanced front-end frameworks require UI components and structure to be pre-defined before the DOM is created. So you cannot dynamically insert further Vue elements easily.
You can still dynamically insert HTML elements but they will not be responsive Vue elements.
Dynamic and late-loading of components and new responsive elements is an advanced Vue topic.
The root folder contains this file. It can be used for other things but it will not be served up in the Node-RED web server. Either the src
or the dist
folder are served up (along with all of their sub-folders). So the root and any other root sub-folders can be used mostly however you like.
One reserved item in the root folder however will be a package.json
file. This will be used in the future to help with build/compile steps. You can still use it yourself, just bear in mind that a future version of uibuilder will make use it as well. If you need to have any development packages installed to build your UI, don't forget to tell npm
to save them as development dependencies not normal dependencies.
Two sub-folders are included.
The template only has files in the src
folder. That folder is the default used by uibuilder to serve up files to clients.
The dist
folder should be used if you have a build step to convert your source code to something that browsers understand. So if you are using a build (compile) step to produce your production code, ensure that it is configured to use the dist
folder as the output folder and that it creates at least an index.html
file.
You can switch between the src
and dist
folders using the matching setting in the Editor. See uibuilder's advanced settings tab.
Also note that you can use linked folders and files in this folder structure. This can be handy if you want to maintain your code in a different folder somewhere or if your default build process needs to use sub-folders other than src
and dist
. (Though as of v6, you can specify any sub-folder to be served)
package.json
: Defines the basic structure, name, description of the project and defines any local development dependencies if any.README.md
: This file.src/index.html
: Contains your basic HTML and will be the file loaded and displayed in the browser when going to the uibuilder defined URL.src/index.js
: Contains all of the logic for your UI. It must be linked to in the html file.src/mycomponent.js
: Contains a simple Vue v3 component, loaded as a JavaScript module. The module shows how you can still interact with Node-RED.src/index.css
: Contains your custom CSS for styling. It must be linked to in the html file.
Note that only the package.json
and index.html
files are actually required. uibuilder will not function as expected without them.
It is possible to use the index.html file simply as a link to other files but it must be present.
The other files are all optional. However, you will need to change the index.html file accordingly if you rename or remove them.
uibuilder will happily serve up any number of web pages from a single instance. It will also make use of sub-folders. However, each folder should have an index.html
file so that a URL that ends with the folder name will still work without error.
Note that each html file is a separate page and requires its own JavaScript and uibuilder library reference. When moving between pages, remember that every page is stand-alone, a new environment.
However, if multiple pages are connected to the same uibuilder instance, they will all get the same broadcast messages from Node-RED. So if you want to handle different messages on different pages, remember to filter them in your front-end JavaScript in uibuilder.onChange('msg', ....)
function.