This is a JavaScript library for rendering Yamcs Operator Interfaces (OPI) in a web browser.
An OPI is a file in XML format that describes a synoptic display for the monitoring and control of systems.
This library is a side project of Yamcs Mission Control for use in its web interface. Operators can upload and monitor synoptic displays where widgets are connected to telemetry delivered by Yamcs.
Compared to the Yamcs Studio desktop software, this library has these limitations:
- No edit support
- No Python scripts (use JavaScript instead)
- No access to Java code from within scripts
- Scripts cannot access the local file system
And as this library is in incubation phase, many widgets are not or not fully supported.
Ticked widgets are at least partially implemented.
- Action Button
- Boolean Button
- Boolean Switch
- Check Box
- Choice Button
- Combo
- Image Boolean Button
- Knob
- Menu Button
- Native Button
- Radio Box
- Scrollbar
- Spinner
- Scaled Slider
- Text Input
- Thumb Wheel
- Arc
- Ellipse
- Image
- Label
- Polygon
- Polyline
- Rectangle
- Rounded Rectangle
- Byte Monitor
- Gauge
- Image Boolean Indicator
- Intensity Graph
- LED
- Meter
- Progress Bar
- Tank
- Text Update
- Thermometer
- XY Graph
- Array
- Connection
- Display
- Grid Layout
- Grouping Container
- Linking Container
- Sash Container
- Tabbed Container
- Table
- Web Browser
npm install --save @yamcs/opi
<div id="mydisplay" style="display: inline-block"></div>
import { Display } from "@yamcs/opi";
const targetEl = document.getElementById("mydisplay");
const display = new Display(targetEl);
display.setSource("/static/my-display.opi");
The OPI display format originates from Control System Studio, an Eclipse RCP product. The implementation in this repository ports many of their routines.
Note that compatibility with Control System Studio is not an objective of this library. Instead we follow the display format of Yamcs Studio -- a fork of Control System Studio.
MIT License
This product includes 3rd party software under different terms. For details see LICENSE.