# HG changeset patch
# User Edouard Tisserant
# Date 1585226000 -3600
# Node ID 3f5194bba67d179803cad99681b97864da8eae8c
# Parent 3ef217f525ff362d151672e8bc3e4d1fc0c0090a
SVGHMI: Jump widget now make errors if path given for relative jump doesn't match target page reference path class.
diff -r 3ef217f525ff -r 3f5194bba67d svghmi/detachable_pages.ysl2
--- a/svghmi/detachable_pages.ysl2 Thu Mar 26 11:17:34 2020 +0100
+++ b/svghmi/detachable_pages.ysl2 Thu Mar 26 13:33:20 2020 +0100
@@ -102,9 +102,10 @@
const "page_all_elements", "func:all_related_elements($page)";
- const "all_page_widgets","$hmi_elements[@id = $page_all_elements/@id and @id != $page/@id and not(@id=$in_forEach_widget_ids)]";
+ const "all_page_widgets","$hmi_elements[@id = $page_all_elements/@id and @id != $page/@id]";
+ const "page_managed_widgets","$all_page_widgets[not(@id=$in_forEach_widget_ids)]";
const "page_relative_widgets",
- "$all_page_widgets[func:is_descendant_path(func:widget(@id)/path/@value, $desc/path/@value)]";
+ "$page_managed_widgets[func:is_descendant_path(func:widget(@id)/path/@value, $desc/path/@value)]";
// Take closest ancestor in detachable_elements
// since nested detachable elements are filtered out
@@ -126,7 +127,7 @@
}
| ],
| absolute_widgets: [
- foreach "$all_page_widgets[not(@id = $page_relative_widgets/@id)]" {
+ foreach "$page_managed_widgets[not(@id = $page_relative_widgets/@id)]" {
| hmi_widgets["«@id»"]`if "position()!=last()" > ,`
}
| ],
@@ -135,9 +136,14 @@
| "«@id»": detachable_elements["«@id»"]`if "position()!=last()" > ,`
}
| }
+ apply "$parsed_widgets/widget[@id = $all_page_widgets/@id]", mode="per_page_widget_template"{
+ with "page_desc", "$desc";
+ }
| }`if "position()!=last()" > ,`
}
+template "*", mode="per_page_widget_template";
+
function "debug_detachables" {
| DETACHABLES:
foreach "$detachable_elements"{
diff -r 3ef217f525ff -r 3f5194bba67d svghmi/gen_index_xhtml.xslt
--- a/svghmi/gen_index_xhtml.xslt Thu Mar 26 11:17:34 2020 +0100
+++ b/svghmi/gen_index_xhtml.xslt Thu Mar 26 13:33:20 2020 +0100
@@ -147,6 +147,13 @@
+
+
+
+
+
+
+
@@ -332,8 +339,9 @@
-
-
+
+
+
"
@@ -384,7 +392,7 @@
absolute_widgets: [
-
+
hmi_widgets["
"]
@@ -412,6 +420,9 @@
}
+
+
+
}
,
@@ -419,6 +430,7 @@
+
DETACHABLES:
@@ -891,6 +903,44 @@
},
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Jump id="
+
+ " to page "
+
+ " with incompatible path "
+
+ (must be same class as "
+
+ ")
+
+
+
+
frequency: 10,
diff -r 3ef217f525ff -r 3f5194bba67d svghmi/widget_jump.ysl2
--- a/svghmi/widget_jump.ysl2 Thu Mar 26 11:17:34 2020 +0100
+++ b/svghmi/widget_jump.ysl2 Thu Mar 26 13:33:20 2020 +0100
@@ -3,22 +3,12 @@
template "widget[@type='Jump']", mode="widget_defs" {
param "hmi_element";
- /* check that given path is compatible with page's reference path */
- if "count(arg) > 0 and count(path) > 0" {
- const "target_page_name", "arg[1]/@value";
- const "target_page_desc", "$hmi_pages_descs[arg[1]/@value = $target_page_name]";
- const "target_page_path", "$target_page_desc/path[1]/@value";
- if "not(func:same_class_paths($target_page_path, path[1]/@value))"
- warning > Jump id="«@id»" to page "«$target_page_name»" with incompatible path "«path[1]/@value»"
- }
- /* TODO check that path is also matching in case of implicit local jump (no page name given) */
-
| on_click: function(evt) {
| const index = this.indexes.length > 0 ? this.indexes[0] + this.offset : undefined;
| switch_page(this.args[0], index);
| },
| init: function() {
- /* registering event this way doies not "click" through svg:use
+ /* registering event this way does not "click" through svg:use
| this.element.onclick = evt => switch_page(this.args[0]);
event must be registered by adding attribute to element instead
TODO : generalize mouse event handling by global event capture + getElementsAtPoint()
@@ -26,3 +16,22 @@
| this.element.setAttribute("onclick", "hmi_widgets['«$hmi_element/@id»'].on_click(evt)");
| },
}
+
+template "widget[@type='Jump']", mode="per_page_widget_template"{
+ param "page_desc";
+ /* check that given path is compatible with page's reference path */
+ if "path" {
+ /* when no page name provided, check for same page */
+ const "target_page_name" choose {
+ when "arg" value "arg[1]/@value";
+ otherwise value "$page_desc/arg[1]/@value";
+ }
+ const "target_page_path" choose {
+ when "arg" value "$hmi_pages_descs[arg[1]/@value = $target_page_name]/path[1]/@value";
+ otherwise value "$page_desc/path[1]/@value";
+ }
+
+ if "not(func:same_class_paths($target_page_path, path[1]/@value))"
+ error > Jump id="«@id»" to page "«$target_page_name»" with incompatible path "«path[1]/@value» (must be same class as "«$target_page_path»")
+ }
+}