SVGHMI: Add TODOs in Button widgets. svghmi
authorEdouard Tisserant
Wed, 26 Aug 2020 11:34:06 +0200 (2020-08-26)
branchsvghmi
changeset 3039 5ca37a7b89e2
parent 3038 92101729f7b7
child 3040 acecaeadf20d
SVGHMI: Add TODOs in Button widgets.
svghmi/widget_button.ysl2
--- a/svghmi/widget_button.ysl2	Wed Aug 26 11:26:45 2020 +0200
+++ b/svghmi/widget_button.ysl2	Wed Aug 26 11:34:06 2020 +0200
@@ -8,34 +8,42 @@
         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");
-             }
-             this.apply_hmi_value(0, 1);
-         }
+        // TODO decouple update of DOM from event (i.e use animate())
 
-         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);
-             }
-             this.apply_hmi_value(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;
+        // TODO State of the button should distinguish UI feedbak from current PLC value
 
+        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");
+            }
+            this.apply_hmi_value(0, 1);
+            // TODO inhibit all mouse/touch events except mouse up (in other word grab cursor)
+        }
+
+        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);
             }
+            this.apply_hmi_value(0, 0);
+            // TODO release inhibited events 
+        }
 
-            this.element.setAttribute("onmousedown", "hmi_widgets[\""+this.element_id+"\"].on_mouse_down(evt)");
-            this.element.setAttribute("onmouseup", "hmi_widgets[\""+this.element_id+"\"].on_mouse_up(evt)");
-         }
+        init() {
+           // TODO : move to widget_defs so that we can have generated string literals directly
+           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[\""+this.element_id+"\"].on_mouse_down(evt)");
+           this.element.setAttribute("onmouseup", "hmi_widgets[\""+this.element_id+"\"].on_mouse_up(evt)");
+        }
     }
     ||
 }