svghmi/widget_tooglebutton.ysl2
author Edouard Tisserant <edouard.tisserant@gmail.com>
Tue, 04 Aug 2020 11:53:39 +0200
branchsvghmi
changeset 3004 705e34c6fe93
parent 2977 82f062408e70
child 3011 601c6dbc1da7
permissions -rw-r--r--
SVGHMI: More JS code refactoring : change_hmi_value and apply_hmi_value now methods of widget class.
// widget_tooglebutton.ysl2

template "widget[@type='ToggleButton']", mode="widget_defs" {
    param "hmi_element";
    labels("active inactive");
    |     frequency: 5,
    |     state: 0,
    |     dispatch: function(value) {
    |         this.state = value;
    |         if (this.state) {
    |             this.active_elt.setAttribute("style", this.active_style);
    |             this.inactive_elt.setAttribute("style", "display:none");
    |             this.state = 0;
    |         } else {
    |             this.inactive_elt.setAttribute("style", this.inactive_style);
    |             this.active_elt.setAttribute("style", "display:none");
    |             this.state = 1;
    |         }
    |     },
    |     on_click: function(evt) {
    |         this.apply_hmi_value(0, this.state);
    |     },
    |     active_style: undefined,
    |     inactive_style: undefined,
    |     init: function() {
    |         this.active_style = this.active_elt.style.cssText;
    |         this.inactive_style = this.inactive_elt.style.cssText;
    |         this.element.setAttribute("onclick", "hmi_widgets['«$hmi_element/@id»'].on_click(evt)");
    |     },
}