# HG changeset patch # User Edouard Tisserant # Date 1591183915 -7200 # Node ID 9442f6a6449ed19a5e2c4d318faf55f1fd29c859 # Parent 8e8812f13d9d291be0274f2ba49b644690a04ff3# Parent 67c6783f221c1f83028430604114b8c9e8a39e80 merge diff -r 8e8812f13d9d -r 9442f6a6449e svghmi/gen_index_xhtml.xslt --- a/svghmi/gen_index_xhtml.xslt Tue Jun 02 13:37:34 2020 +0200 +++ b/svghmi/gen_index_xhtml.xslt Wed Jun 03 13:31:55 2020 +0200 @@ -1,6 +1,6 @@ - - + + @@ -1152,40 +1152,72 @@ } - - class ButtonWidget extends Widget{ - - frequency = 5; - - init() { - - // TODO : use attributes to allow interaction through svg:use - - // TODO : deal with dragging - - this.element.addEventListener( - - "mousedown", - - evt => { - - change_hmi_value(this.indexes[0], "=1"); - - }); - - this.element.addEventListener( - - "mouseup", - - evt => { - - change_hmi_value(this.indexes[0], "=0"); - - }); + + + + + + active inactive + + + + frequency: 5, + + on_mouse_down: function(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: function(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"); + + }, + + active_style: undefined, + + inactive_style: undefined, + + init: function() { + + 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[' + + '].on_mouse_down(evt)"); + + this.element.setAttribute("onmouseup", "hmi_widgets[' + + '].on_mouse_up(evt)"); + + }, @@ -2697,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 @@ -2704,7 +2795,7 @@ - + @@ -3271,8 +3362,6 @@ } - console.log(opstr, given_val); - let old_val = cache[index]; let new_val; diff -r 8e8812f13d9d -r 9442f6a6449e svghmi/widget_button.ysl2 --- a/svghmi/widget_button.ysl2 Tue Jun 02 13:37:34 2020 +0200 +++ b/svghmi/widget_button.ysl2 Wed Jun 03 13:31:55 2020 +0200 @@ -1,20 +1,33 @@ // widget_button.ysl2 -template "widget[@type='Button']", mode="widget_class" - || - class ButtonWidget extends Widget{ - frequency = 5; - init() { - this.element.addEventListener( - "mousedown", - evt => { - change_hmi_value(this.indexes[0], "=1"); - }); - this.element.addEventListener( - "mouseup", - evt => { - change_hmi_value(this.indexes[0], "=0"); - }); - } - } - || +template "widget[@type='Button']", mode="widget_defs" { + param "hmi_element"; + optional_labels("active inactive"); + | frequency: 5, + | on_mouse_down: function(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: function(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"); + | }, + | active_style: undefined, + | inactive_style: undefined, + | init: function() { + | 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)"); + | }, +} \ No newline at end of file diff -r 8e8812f13d9d -r 9442f6a6449e svghmi/widget_tooglebutton.ysl2 --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/svghmi/widget_tooglebutton.ysl2 Wed Jun 03 13:31:55 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