svghmi/widget_button.ysl2
author usveticic
Wed, 05 Aug 2020 15:04:53 +0200
branchsvghmi
changeset 3009 7c6960f09881
parent 3004 705e34c6fe93
child 3018 22b969b409b0
permissions -rw-r--r--
Reworked button widget so it uses classes.
// widget_button.ysl2

template "widget[@type='Button']", mode="widget_class"
    ||
    class ButtonWidget extends Widget{
        frequency = 5;
        state = 0;
        active_style = undefined;
        inactive_style = undefined;

         on_mouse_down(evt) {
             if (this.active_style && this.inactive_style) {
                 this.active_elt.setAttribute("style", this.active_style);
                 this.inactive_elt.setAttribute("style", "display:none");
             }
             change_hmi_value(this.indexes[0], "=1");
         }

         on_mouse_up(evt) {
             if (this.active_style && this.inactive_style) {
                 this.active_elt.setAttribute("style", "display:none");
                 this.inactive_elt.setAttribute("style", this.inactive_style);
             }
             change_hmi_value(this.indexes[0], "=0");
         }

         init() {
            this.active_style = this.active_elt ? this.active_elt.style.cssText : undefined;
            this.inactive_style = this.inactive_elt ? this.inactive_elt.style.cssText : undefined;

            if (this.active_style && this.inactive_style) {
                this.active_elt.setAttribute("style", "display:none");
                this.inactive_elt.setAttribute("style", this.inactive_style);
            }

            this.element.setAttribute("onmousedown", "hmi_widgets['«$hmi_element/@id»'].on_mouse_down(evt)");
            this.element.setAttribute("onmouseup", "hmi_widgets['«$hmi_element/@id»'].on_mouse_up(evt)");
         }
    }
    ||


template "widget[@type='Button']", mode="widget_defs" {
    param "hmi_element";
    optional_labels("active inactive");
    |,
}