SVGHMI: Check that explicit relative page jump path is consistant with destination page reference path.
// widget_jump.ysl2
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
| 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()
*/
| this.element.setAttribute("onclick", "hmi_widgets['«$hmi_element/@id»'].on_click(evt)");
| },
}