--- a/svghmi/gen_index_xhtml.xslt Sun Apr 19 22:01:12 2020 +0200
+++ b/svghmi/gen_index_xhtml.xslt Sun Apr 19 22:44:41 2020 +0200
@@ -1544,6 +1544,115 @@
<xsl:text> apply_cache: foreach_apply_cache,
+ <xsl:template match="epilogue:foreach"> + <xsl:text>function foreach_unsubscribe(){ + <xsl:text> for(let item of this.items){ + <xsl:text> for(let widget of item) { + <xsl:text> unsubscribe.call(widget); + <xsl:text> this.offset = 0; + <xsl:text>function foreach_widgets_do(new_offset, todo){ + <xsl:text> this.offset = new_offset; + <xsl:text> for(let i = 0; i < this.items.length; i++) { + <xsl:text> let item = this.items[i]; + <xsl:text> let orig_item_index = this.index_pool[i]; + <xsl:text> let item_index = this.index_pool[i+this.item_offset]; + <xsl:text> let item_index_offset = item_index - orig_item_index; + <xsl:text> for(let widget of item) { + <xsl:text> todo.call(widget, new_offset + item_index_offset); + <xsl:text>function foreach_subscribe(new_offset=0){ + <xsl:text> foreach_widgets_do.call(this, new_offset, subscribe); + <xsl:text>function foreach_apply_cache() { + <xsl:text> foreach_widgets_do.call(this, this.offset, widget_apply_cache); + <xsl:text>function foreach_onclick(opstr, evt) { + <xsl:text> new_item_offset = eval(String(this.item_offset)+opstr) + <xsl:text> if(new_item_offset + this.items.length > this.index_pool.length) { + <xsl:text> if(this.item_offset + this.items.length == this.index_pool.length) + <xsl:text> new_item_offset = 0; + <xsl:text> new_item_offset = this.index_pool.length - this.items.length; + <xsl:text> } else if(new_item_offset < 0) { + <xsl:text> if(this.item_offset == 0) + <xsl:text> new_item_offset = this.index_pool.length - this.items.length; + <xsl:text> new_item_offset = 0; + <xsl:text> this.item_offset = new_item_offset; + <xsl:text> off = this.offset; + <xsl:text> foreach_unsubscribe.call(this); + <xsl:text> foreach_subscribe.call(this,off); + <xsl:text> update_subscriptions(); + <xsl:text> need_cache_apply.push(this); + <xsl:text> jumps_need_update = true; + <xsl:text> requestHMIAnimation(); <xsl:template mode="widget_defs" match="widget[@type='Input']">
<xsl:param name="hmi_element"/>
<xsl:variable name="value_elt">
@@ -1847,6 +1956,25 @@
+ <xsl:template match="epilogue:jump"> + <xsl:text>var jumps_need_update = false; + <xsl:text>var jump_history = [[default_page, undefined]]; + <xsl:text>function update_jumps() { + <xsl:text> page_desc[current_visible_page].jumps.map(w=>w.notify_page_change(current_visible_page,current_page_index)); + <xsl:text> jumps_need_update = false; <xsl:template match="epilogue:keypad">
@@ -2225,10 +2353,6 @@
<xsl:text>var need_cache_apply = [];
- <xsl:text>var jumps_need_update = false;
- <xsl:text>var jump_history = [[default_page, undefined]];
<xsl:text>function dispatch_value_to_widget(widget, index, value, oldval) {
@@ -2921,58 +3045,6 @@
- <xsl:text>function foreach_unsubscribe(){
- <xsl:text> for(let item of this.items){
- <xsl:text> for(let widget of item) {
- <xsl:text> unsubscribe.call(widget);
- <xsl:text> this.offset = 0;
- <xsl:text>function foreach_widgets_do(new_offset, todo){
- <xsl:text> this.offset = new_offset;
- <xsl:text> for(let i = 0; i < this.items.length; i++) {
- <xsl:text> let item = this.items[i];
- <xsl:text> let orig_item_index = this.index_pool[i];
- <xsl:text> let item_index = this.index_pool[i+this.item_offset];
- <xsl:text> let item_index_offset = item_index - orig_item_index;
- <xsl:text> for(let widget of item) {
- <xsl:text> todo.call(widget, new_offset + item_index_offset);
- <xsl:text>function foreach_subscribe(new_offset=0){
- <xsl:text> foreach_widgets_do.call(this, new_offset, subscribe);
<xsl:text>function widget_apply_cache() {
<xsl:text> for(let index of this.indexes){
@@ -2993,62 +3065,6 @@
- <xsl:text>function foreach_apply_cache() {
- <xsl:text> foreach_widgets_do.call(this, this.offset, widget_apply_cache);
- <xsl:text>function foreach_onclick(opstr, evt) {
- <xsl:text> new_item_offset = eval(String(this.item_offset)+opstr)
- <xsl:text> if(new_item_offset + this.items.length > this.index_pool.length) {
- <xsl:text> if(this.item_offset + this.items.length == this.index_pool.length)
- <xsl:text> new_item_offset = 0;
- <xsl:text> new_item_offset = this.index_pool.length - this.items.length;
- <xsl:text> } else if(new_item_offset < 0) {
- <xsl:text> if(this.item_offset == 0)
- <xsl:text> new_item_offset = this.index_pool.length - this.items.length;
- <xsl:text> new_item_offset = 0;
- <xsl:text> this.item_offset = new_item_offset;
- <xsl:text> off = this.offset;
- <xsl:text> foreach_unsubscribe.call(this);
- <xsl:text> foreach_subscribe.call(this,off);
- <xsl:text> update_subscriptions();
- <xsl:text> need_cache_apply.push(this);
- <xsl:text> jumps_need_update = true;
- <xsl:text> requestHMIAnimation();
<xsl:text>function switch_visible_page(page_name) {
@@ -3107,18 +3123,6 @@
- <xsl:text>function update_jumps() {
- <xsl:text> page_desc[current_visible_page].jumps.map(w=>w.notify_page_change(current_visible_page,current_page_index));
- <xsl:text> jumps_need_update = false;
<xsl:text>// Once connection established
<xsl:text>ws.onopen = function (evt) {
--- a/svghmi/svghmi.js Sun Apr 19 22:01:12 2020 +0200
+++ b/svghmi/svghmi.js Sun Apr 19 22:44:41 2020 +0200
@@ -3,8 +3,6 @@
var cache = hmitree_types.map(_ignored => undefined);
var need_cache_apply = [];
-var jumps_need_update = false;
-var jump_history = [[default_page, undefined]];
function dispatch_value_to_widget(widget, index, value, oldval) {
@@ -351,32 +349,6 @@
need_cache_apply.push(this);
-function foreach_unsubscribe(){
- for(let item of this.items){
- for(let widget of item) {
- unsubscribe.call(widget);
-function foreach_widgets_do(new_offset, todo){
- this.offset = new_offset;
- for(let i = 0; i < this.items.length; i++) {
- let item = this.items[i];
- let orig_item_index = this.index_pool[i];
- let item_index = this.index_pool[i+this.item_offset];
- let item_index_offset = item_index - orig_item_index;
- for(let widget of item) {
- todo.call(widget, new_offset + item_index_offset);
-function foreach_subscribe(new_offset=0){
- foreach_widgets_do.call(this, new_offset, subscribe);
function widget_apply_cache() {
for(let index of this.indexes){
/* dispatch current cache in newly opened page widgets */
@@ -387,34 +359,6 @@
-function foreach_apply_cache() {
- foreach_widgets_do.call(this, this.offset, widget_apply_cache);
-function foreach_onclick(opstr, evt) {
- new_item_offset = eval(String(this.item_offset)+opstr)
- if(new_item_offset + this.items.length > this.index_pool.length) {
- if(this.item_offset + this.items.length == this.index_pool.length)
- new_item_offset = this.index_pool.length - this.items.length;
- } else if(new_item_offset < 0) {
- if(this.item_offset == 0)
- new_item_offset = this.index_pool.length - this.items.length;
- this.item_offset = new_item_offset;
- foreach_unsubscribe.call(this);
- foreach_subscribe.call(this,off);
- update_subscriptions();
- need_cache_apply.push(this);
- jumps_need_update = true;
function switch_visible_page(page_name) {
let old_desc = page_desc[current_visible_page];
@@ -444,12 +388,6 @@
current_visible_page = page_name;
-function update_jumps() {
- page_desc[current_visible_page].jumps.map(w=>w.notify_page_change(current_visible_page,current_page_index));
- jumps_need_update = false;
// Once connection established
ws.onopen = function (evt) {
--- a/svghmi/widget_foreach.ysl2 Sun Apr 19 22:01:12 2020 +0200
+++ b/svghmi/widget_foreach.ysl2 Sun Apr 19 22:44:41 2020 +0200
@@ -55,3 +55,59 @@
| apply_cache: foreach_apply_cache,
+function foreach_unsubscribe(){ + for(let item of this.items){ + for(let widget of item) { + unsubscribe.call(widget); +function foreach_widgets_do(new_offset, todo){ + this.offset = new_offset; + for(let i = 0; i < this.items.length; i++) { + let item = this.items[i]; + let orig_item_index = this.index_pool[i]; + let item_index = this.index_pool[i+this.item_offset]; + let item_index_offset = item_index - orig_item_index; + for(let widget of item) { + todo.call(widget, new_offset + item_index_offset); +function foreach_subscribe(new_offset=0){ + foreach_widgets_do.call(this, new_offset, subscribe); +function foreach_apply_cache() { + foreach_widgets_do.call(this, this.offset, widget_apply_cache); +function foreach_onclick(opstr, evt) { + new_item_offset = eval(String(this.item_offset)+opstr) + if(new_item_offset + this.items.length > this.index_pool.length) { + if(this.item_offset + this.items.length == this.index_pool.length) + new_item_offset = this.index_pool.length - this.items.length; + } else if(new_item_offset < 0) { + if(this.item_offset == 0) + new_item_offset = this.index_pool.length - this.items.length; + this.item_offset = new_item_offset; + foreach_unsubscribe.call(this); + foreach_subscribe.call(this,off); + update_subscriptions(); + need_cache_apply.push(this); + jumps_need_update = true; --- a/svghmi/widget_jump.ysl2 Sun Apr 19 22:01:12 2020 +0200
+++ b/svghmi/widget_jump.ysl2 Sun Apr 19 22:44:41 2020 +0200
@@ -126,3 +126,16 @@
error > Jump id="«@id»" to page "«$target_page_name»" with incompatible path "«path[1]/@value» (must be same class as "«$target_page_path»")
+var jumps_need_update = false; +var jump_history = [[default_page, undefined]]; +function update_jumps() { + page_desc[current_visible_page].jumps.map(w=>w.notify_page_change(current_visible_page,current_page_index)); + jumps_need_update = false;