--- a/svghmi/gen_index_xhtml.xslt Fri Mar 12 15:12:38 2021 +0100
+++ b/svghmi/gen_index_xhtml.xslt Mon Mar 15 11:25:24 2021 +0100
@@ -4422,9 +4422,15 @@
- <xsl:text> overshot(new_val, max) {
- <xsl:text> this.last_display = "max: "+max;
+ <xsl:text> is_inhibited = false; + <xsl:text> this.is_inhibited = true; + <xsl:text> this.display = msg; + <xsl:text> setTimeout(() => this.stopalert(), 1000); <xsl:text> this.request_animate();
@@ -4432,11 +4438,29 @@
+ <xsl:text> stopalert(){ + <xsl:text> this.is_inhibited = false; + <xsl:text> this.display = this.last_value; + <xsl:text> this.request_animate(); + <xsl:text> overshot(new_val, max) { + <xsl:text> this.alert("max"); <xsl:text> undershot(new_val, min) {
- <xsl:text> this.last_display = "min: "+min;
- <xsl:text> this.request_animate();
+ <xsl:text> this.alert("min"); @@ -4480,19 +4504,25 @@
<xsl:if test="$have_value or $have_edit">
<xsl:when test="count(arg) = 1">
- <xsl:text> this.last_display = vsprintf("</xsl:text>
+ <xsl:text> this.last_value = vsprintf("</xsl:text> <xsl:value-of select="arg[1]/@value"/>
- <xsl:text> this.last_display = value;
+ <xsl:text> this.last_value = value;
- <xsl:if test="$have_value">
- <xsl:text> this.request_animate();
+ <xsl:text> if(!this.is_inhibited){ + <xsl:text> this.display = this.last_value; + <xsl:if test="$have_value"> + <xsl:text> this.request_animate(); @@ -4500,7 +4530,7 @@
<xsl:if test="$have_value">
<xsl:text> animate: function(){
- <xsl:text> this.value_elt.textContent = String(this.last_display);
+ <xsl:text> this.value_elt.textContent = String(this.display); @@ -4512,7 +4542,7 @@
<xsl:value-of select="path/@value"/>
<xsl:text>", "</xsl:text>
<xsl:value-of select="path/@type"/>
- <xsl:text>", this, this.last_display);
+ <xsl:text>", this, this.last_value); <xsl:if test="$have_value">
<xsl:text> this.value_elt.style.pointerEvents = "none";
--- a/svghmi/widget_input.ysl2 Fri Mar 12 15:12:38 2021 +0100
+++ b/svghmi/widget_input.ysl2 Mon Mar 15 11:25:24 2021 +0100
@@ -10,14 +10,26 @@
this.apply_hmi_value(0, new_val);
- overshot(new_val, max) {
- this.last_display = "max: "+max;
+ this.is_inhibited = true; + setTimeout(() => this.stopalert(), 1000); + this.is_inhibited = false; + this.display = this.last_value; + this.request_animate(); + overshot(new_val, max) { undershot(new_val, min) {
- this.last_display = "min: "+min;
- this.request_animate();
@@ -45,28 +57,31 @@
if "$have_value or $have_edit" {
- | this.last_display = vsprintf("«arg[1]/@value»", [value]);
+ | this.last_value = vsprintf("«arg[1]/@value»", [value]); - | this.last_display = value;
+ | this.last_value = value;
+ | if(!this.is_inhibited){ + | this.display = this.last_value; - | this.request_animate();
+ | this.request_animate(); - | this.value_elt.textContent = String(this.last_display);
+ | this.value_elt.textContent = String(this.display); - | this.edit_elt.onclick = () => edit_value("«path/@value»", "«path/@type»", this, this.last_display);
+ | this.edit_elt.onclick = () => edit_value("«path/@value»", "«path/@type»", this, this.last_value); | this.value_elt.style.pointerEvents = "none";