beremiz

SVGHMI: JsonTable now use intermediate variables again to address JSON data without duplicating code or referencing. Using intermediate variables also alows to check for availability of data and stop evaluating early if data is missing. Finally added complete roundtrip example to illustrate use of JSonTable to display "alarms" collected in python from changes on PLC boolean variables.
// widget_circularbar.ysl2
template "widget[@type='CircularBar']", mode="widget_defs" {
param "hmi_element";
| frequency: 10,
labels("path");
optional_labels("value min max");
| dispatch: function(value) {
| if(this.value_elt)
| this.value_elt.textContent = String(value);
| let [min,max,start,end] = this.range;
| let [cx,cy] = this.center;
| let [rx,ry] = this.proportions;
| let tip = start + (end-start)*Number(value)/(max-min);
| let size = 0;
| if (tip-start > Math.PI) {
| size = 1;
| } else {
| size = 0;
| }
| this.path_elt.setAttribute('d', "M "+(cx+rx*Math.cos(start))+","+(cy+ry*Math.sin(start))+" A "+rx+","+ry+" 0 "+size+" 1 "+(cx+rx*Math.cos(tip))+","+(cy+ry*Math.sin(tip)));
| },
| range: undefined,
| init: function() {
| let start = Number(this.path_elt.getAttribute('sodipodi:start'));
| let end = Number(this.path_elt.getAttribute('sodipodi:end'));
| let cx = Number(this.path_elt.getAttribute('sodipodi:cx'));
| let cy = Number(this.path_elt.getAttribute('sodipodi:cy'));
| let rx = Number(this.path_elt.getAttribute('sodipodi:rx'));
| let ry = Number(this.path_elt.getAttribute('sodipodi:ry'));
| if (ry == 0) {
| ry = rx;
| }
| if (start > end) {
| end = end + 2*Math.PI;
| }
| let min = this.min_elt ?
| Number(this.min_elt.textContent) :
| this.args.length >= 1 ? this.args[0] : 0;
| let max = this.max_elt ?
| Number(this.max_elt.textContent) :
| this.args.length >= 2 ? this.args[1] : 100;
| this.range = [min, max, start, end];
| this.center = [cx, cy];
| this.proportions = [rx, ry];
| },
}