# HG changeset patch
# User dgaberscek
# Date 1590483541 -7200
# Node ID 82f062408e709fc5ed624a64fef13f35e8dceda9
# Parent 99c4521bb8446c75becbb76d2c9e00d6d6125c30
SVGHMI: Added widget toggleButton.
diff -r 99c4521bb844 -r 82f062408e70 svghmi/gen_index_xhtml.xslt
--- a/svghmi/gen_index_xhtml.xslt Tue May 26 10:53:02 2020 +0200
+++ b/svghmi/gen_index_xhtml.xslt Tue May 26 10:59:01 2020 +0200
@@ -2729,6 +2729,65 @@
],
+
+
+
+
+
+ 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) {
+
+ change_hmi_value(this.indexes[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['
+
+ '].on_click(evt)");
+
+ },
+
+
Made with SVGHMI. https://beremiz.org
diff -r 99c4521bb844 -r 82f062408e70 svghmi/widget_tooglebutton.ysl2
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/svghmi/widget_tooglebutton.ysl2 Tue May 26 10:59:01 2020 +0200
@@ -0,0 +1,30 @@
+// 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) {
+ | change_hmi_value(this.indexes[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)");
+ | },
+}
\ No newline at end of file