Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/victronenergy/venus-html5-app
HTML5 App including Javascript library that communicates with Venus OS over MQTT websockets
https://github.com/victronenergy/venus-html5-app
Last synced: 2 months ago
JSON representation
HTML5 App including Javascript library that communicates with Venus OS over MQTT websockets
- Host: GitHub
- URL: https://github.com/victronenergy/venus-html5-app
- Owner: victronenergy
- License: mit
- Created: 2018-09-18T19:25:03.000Z (over 6 years ago)
- Default Branch: master
- Last Pushed: 2024-05-22T15:38:53.000Z (8 months ago)
- Last Synced: 2024-05-22T15:56:05.441Z (8 months ago)
- Language: TypeScript
- Size: 19.5 MB
- Stars: 97
- Watchers: 28
- Forks: 30
- Open Issues: 22
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
- awesome-github-star - venus-html5-app
README
![screenshot](/legacy/victron-webapp-screenshot.png?raw=true)
# Venus OS hosted web app
The "app" is a single page application that communicates to the rest of Venus OS via MQTT over websockets.
It uses React with ES6 for the UI layer and also includes a wrapper service for the MQTT interface.Its primary purpose is to be a simple to use and nice looking UI for a Victron system on
marine Multi Functional Displays, such as the ones from Garmin, Simrad and others. This
removes the need for a Victron panel at the helm: less clutter on the dashboard.The secondary purpose is to help OEMs, boat builders and motorhome builders for example,
make their own custom UI.## 0. Contents
Chapters in this readme:
1. Functionality.
2. Development
3. Testing
4. Making a release
5. Device error logging
6. Device debugging## 1. Functionality
### 1.1 Documentation per Box
`Boxes` are the various designed visualisation: there are a Battery box, a Generator box, a Tanks box, and so forth.
How certain devices are visualised/rendered on HTML5, ie. in to what box(es), and what topics are used for what parameter, and more is documented in three places:
- [TOPICS.md](https://github.com/victronenergy/venus-html5-app/blob/master/TOPICS.md)
- [wiki/Translating system components into the HTML5 app](https://github.com/victronenergy/venus-html5-app/wiki/Translating-system-components-into-the-HTML5-app)
- [wiki/Dashboard overview](https://github.com/victronenergy/venus-html5-app/wiki/Dashboard-overview)### 1.2 Handling disconnects
When devices are disconnected from the GX Device, see [this issue](https://github.com/victronenergy/venus-html5-app/issues/49)
for what happens on the D-Bus.On MQTT, this is translated into sending an empty message on the subs which depend on the lost service. Depending on the element we show either -- for the value (in the case of numeric values) or another default state for the component (like disconnected for the active source).
## 2. Development
### 2.1 Initial setup
If it's the first time you run the app:
- make sure to have `node` & `npm` installed on your machine
- run `npm install` in the root folder### 2.2 Setting white label
This repository contains several white-label apps. To work with a specific app, set the correct `APP` environment variable in the `.env.local` file. For example, to build the `Marine2` app, use:
```
REACT_APP_WHITELABEL=Marine2
```You can find the list of available apps in the `.env.local.example` file.
### 2.3 Run app locally
To run the app locally for development, run:
`npm run start`
And then open the app in the browser at `http://localhost:8000`.
This will start the webpack dev server, which will recompile the app on code changes and hot reload the UI.
Note that the app will attempt to connect to MQTT broker served via the same port as the app and path `/websocket-mqtt`, and that will eventually fail.
You will need to change the `host`, `port`, and `path` (defaults to `/websocket-mqtt`) query parameters to connect to a different Venus websocket MQTT host.
To connect to a Venus device with `VENUS_DEVICE_IP` running firmware >= 3.50 use the following URL:
`http://localhost:8000?host=&port=80`
To connect to Venus device with `VENUS_DEVICE_IP` running firmware < 3.50, or to a `venus-docker` simulation, use the following URL:
`http://localhost:8000/app?host=VENUS_DEVICE_IP&port=9001&path=%02%03`
Note: the `port` needs to be overriden to connect directly to `flashmq` provided websocket port.
Note: the `path` URL parameter requires special sequence `%02%03` in order to properly override the default `/websocket-mqtt` path and specify an empty string.
This way you can run the local app against any Venus device that is reachable via your network.
### 2.4 Using Demo mode on Venus device
Every Venus device also has a Demo mode, which allows you to get useful data if you only have the Venus device available, without requiring various Victron devices to be connected to the Venus device. To enable it, navigate to the `Venus Remote Console` -> `Settings` -> `General`.
### 2.5 Running the app with no Venus device available
Use [venus-docker](https://github.com/victronenergy/venus-docker) in demo mode.
You can run multiple `venus-docker` simulations by executing: `echo {a..z} | xargs -n1 ./run.sh -s`. Each container running a simulation will expose MQTT on
an increasing port number starting from `9001`.### 2.6 Metrics available
- Identify the D-bus channel that you want to read [from here](https://github.com/victronenergy/venus/wiki/dbus)
- Create a component using MqttSubscriptions or MqttTopicWildcard and pass the topic as the wrapper topic. See examples in other components### 2.7 Deploying to a device during development
#### 2.7.1 Get the device ip
In order to deploy you need to know the target device's IP. It can be connected to by ethernet, LAN or the device's own WLAN.
Instructions on how to find the IPs can be found [here](https://www.victronenergy.com/media/pg/Venus_GX/en/accessing-the-gx-device.html)
for the Venus GX device.The default device's IP address is `172.24.24.1`
#### 2.7.2 Run deploy script
In the project main folder run `./bin/deploy.sh --build ` where ip is the target device's IP. The script also accepts an additional
`--user|-u` param that defines the user for the deployment connection. This defaults to `root`. You will also need a password to connect to the device. To set the password, navigate to the `Venus Remote Console` -> `Settings` -> `General -> Set root password`.The deploy script also bundles the app if `--build` or `-b` . Note that the script assumes that it's run from the root folder of the application.
#### 2.7.3 Deploying on multiple devices
To deploy the app on multiple devices, use `./bin/deploy-multiple.sh` script. This script uses a list of WiFi access points defined in `network.csv` file.
#### 2.7.4 Deploying using a USB stick
Since Venus OS 2.80, placing the build of the app in `/data/www/app` allows for serving a different version of the app than the one bundled with Venus OS at `/var/www/venus/app`. When the `/data/www/app` is present, it'll be server at `venus.local/app` and the original application at `venus.local/default/app`.
By creating an archive named `venus-data.zip` that contains the build files from the `dist` inside an `www/app/` folder will ensure that the `/data/www/app` folder will be created and the content of the archived extracted when the GX device is rebooted.
The content of the `/data` partition is persistent across firmware updates.
To create the archive, run `./bin/pack.sh` from the root folder of the application. This will create a `venus-data.zip` file. Place this file on a USB stick and insert it into the GX device, then reboot the device.
### 2.8 Translations
#### 2.8.1 Syncronizing the translations files with the POEditor Project
[POEditor](https://poeditor.com/) is used as localization management platform for this project. In order to sync the translations using the scripts from the `poeditor` folder, an API key has to be placed in the `.env.local` according to the `.env.local.example` file.
#### 2.8.2 Pushing the local translation files to POEditor
```
npm run poeditor:push
```Running the command will trigger the following actions:
1. Add the terms of the main language file (default: en)
1. Add new languges to the POEditor project if they are available locally but missing in POEditor
1. Add the local translations for all the languages
1. Mark translations as fuzzy if there are changes in the translation of the main language```
npm run poeditor:push -f
```Running the comamnd with the `-f` flag will delete the terms from POEditor that are not present in the local file.
Please use with caution. If wrong data is sent, existing terms and their translations might be irreversibly lost.#### 2.8.3 Pulling the POEditor translations locally
```
npm run poeditor:pull
```## 3. Testing
### 3.1 Venus OS Release test plan
In the Venus OS release test plan there is a tab containing all tests.
### 3.2 Enzyme
Most components have Enzyme unit tests. Run all of these tests with `npm run test:unit`
### 3.3 Cypress
Cypress is used to run integration tests on the compiled ui to make sure it opens and operated correctly in different
display sizes. To run cypress you need to run the live server and an instance of venus docker in the Venus GX demo mode (z):(in html5 app repo): `npm run start`
(in venus docker repo): `./run.sh -s z`
Then you can run the cypress UI interactively with `npm run cy:open`.
To run the ui tests in CI-style use `npm run test:e2e`
### 3.4 Simulating/Debugging MFD UI locally
MFDs ship web browsers based on `AppleWebKit/537` or `AppleWebKit/601`.
Partially Simulating the MFD web browser can be achieved by running any browser using the same engine.
Google Chrome 49 runs `AppleWebKit/537`, so contains all the same CSS/JS limitations, and can be use to simulate/debug CSS issues faster.
## 4. Making a release
Whenever a new tag is created, GitHub Actions will build the app, archive the built files and upload them as `venus-html5-app.tar.gz` to the Github Release associated with the tag.
The app can then be downloaded from `https://github.com/victronenergy/venus-html5-app/releases/download//venus-html5-app.tar.gz`.
The build script expects the tags to follow semantic versioning (e.g. `1.2.3`, `1.2`, etc.) and will not trigger for tags that don't follow this convention (e.g. `v1.0`, `test`).To include the HTML5 app in the next Venus OS version:
1. Increment the version number in `package.json`. Create and push a commit.
2. Create & push a tag for the version (do not use `v` in the version name, just the number).
3. Edit the generated release, add the changelog, change title (see previous releases) and set checkbox "Set as pre-release" to true.
4. Update the [todo](https://github.com/victronenergy/venus-private/wiki/todo) page for the build.You should add a note under `Done - waiting for recipe / venus maintainer`, containing the tag name and the changes included:
```md
html5-app -```
For example:
```md
html5-app - 0.2 \
* Reworked the UI
```If you need any changes to the how the app is included inside Venus, please specify in the TODO file as well what changes need to be made to the recipe.
All Venus recipes are found [here](https://github.com/victronenergy/meta-victronenergy/tree/master/meta-ve-software/recipes-ve).
A sample recipe for the HTML5 app is [here](https://github.com/victronenergy/meta-victronenergy/tree/master/meta-ve-software/recipes-ve)## 5. Device error logging
When the app is hosted from a Venus device, there is no convenient way to see the errors in the js console.
To make troubleshooting easier the app can send the error messages through websocket port 7890 to the device.
To enable this debugging mode, setup https://github.com/vi/websocat on your Venus device, uncomment the debug code in `index.html`, and deploy to the device.## 6. Device debugging
By adding `debug=true` to the query params you can enable some convenience features for debugging on actual devices:
- "Reload page" button - refreshes the page
- "Browser info" button - links to page containing basic information about the browser in which the app is running
- A debug log element, which redirects all console messages to a visible element in the uiTo enable this this debugging mode on a MFD device, uncommend the debug code in `index.html`, override the `debug=true` check, and deploy to the device.