wis2box-ui is the user interface for the wis2box
Please direct all issues to the main wis2box issue tracker
The UI has a series of environment variables that can be used to configure the application. If you are using npm locally, these can be set in the .env file.
If you are using Docker, when you run the associated Dockerfile, the environment variables will be loaded in and override the values in the .env file.
| Environment Variable | Description | Required to be set | 
|---|---|---|
| WIS2BOX_URL | The base URL for the wis2boxapplication. | ✅ | 
| WIS2BOX_API_URL | The backend URL for the wis2boxAPI. | ✅ | 
| WIS2BOX_BASEMAP_URL | The URL pattern for fetching map tiles (default: OpenStreetMap URL). | ❌ | 
| WIS2BOX_BASEMAP_ATTRIBUTION | Attribution text for the map tiles (default: OpenStreetMap link). | ❌ | 
| WIS2BOX_UI_CLUSTER | Boolean flag to enable or disable clustering of stations on the map (default: 'false'). | ❌ | 
| WIS2BOX_UI_LANG | The language to use when translating with i18n (default: 'en'). | ❌ | 
| WIS2BOX_UI_LOGO | The URL of a custom logo to display in the application. | ❌ | 
| WIS2BOX_UI_BANNER_COLOR | The background color of the banner (can be set to a hex color code). | ❌ | 
| WIS2BOX_UI_DISABLE_SEPARATOR_IMAGE | Boolean flag to enable or disable the footer separator image (default: 'false'). | ❌ | 
| Command | Description | 
|---|---|
| npm install | Install project dependencies. | 
| docker compose -f docker/Docker-compose-test.yml up | Build and start the UI with Docker. By default it will accessible on localhost:5174 | 
| npm run dev | Compiles and hot-reloads for development. | 
| npm run build | Compiles and minifies for production. | 
| npm run preview | Preview production build. | 
| npm run test:unit | Run unit tests. | 
| npm run lintnpm run format | Lints and fixes files. | 
wis2box-ui has multilingual support via vue i18n.
To add a supported locale to wis2box-ui, create a branch of wis2box-ui and navigate to wis2box-ui/src/locales/. From there, create a copy of _template.json with the name of the new locale as the name of the file (i.e. en.json, en-US.json, etc...). Create entries for the empty double quoted fields and submit a pull request back into the main branch. The default language of wis2box-ui is English (en).
git clone https://github.com/World-Meteorological-Organization/wis2box-ui.git
cd ./src/locales
cp _template.json de.json
At this point, you can cross reference language support with a command like:
cat en.json
Then to edit the german locale:
vi de.json
# create release (x.y.z is the release version)
vi package.json  # update "version"
vi package-lock.json  # update 'version' and 'packages."".version
git commit -am 'update release version x.y.z'
git push origin main
git tag -a x.y.z -m 'tagging release version x.y.z'
git push --tags
# publish release on GitHub (https://github.com/World-Meteorological-Organization/wis2box-ui/releases/new)