From 10792c0593b368dafc090e9c46a912e3ca10a742 Mon Sep 17 00:00:00 2001 From: Laurent Garnier Date: Sat, 16 Dec 2023 11:21:51 +0100 Subject: [PATCH 1/2] Sitemap: extended syntax for icon to define conditional rules Related to openhab/openhab-core#3820 Signed-off-by: Laurent Garnier --- ui/sitemaps.md | 47 ++++++++++++++++++++++++++++++++++++++++++----- 1 file changed, 42 insertions(+), 5 deletions(-) diff --git a/ui/sitemaps.md b/ui/sitemaps.md index 103e9b023b..8a27fd663a 100644 --- a/ui/sitemaps.md +++ b/ui/sitemaps.md @@ -631,7 +631,7 @@ Colors can be used to emphasize an items label or its value based on conditions. Colors may be assigned to either the label or the value associated with an Item. The icon may be tinted depending on the state as well. -**Label and Value Color Syntax:** +**Label, Value and Icon Color Syntax:** ```java labelcolor=[item_name operator value = "color", item_name operator value AND item_name operator value = "color", ... ] @@ -721,12 +721,49 @@ There are also the following keywords that can be used as colors: ### Icons openHAB allows a set of icons to be assigned to the different states of an Item and therefore to be presented in a Sitemap. +This first way of proceeding only considers the current state of the linked item and requires the use of icons provided by openHAB and a particular syntax of icon names. Please refer to the documentation on [Item configuration]({{base}}/configuration/items.html#icons) for details. -![battery-0](/iconsets/classic/battery-0.png "battery-0") -![battery-30](/iconsets/classic/battery-30.png "battery-30") -![battery-60](/iconsets/classic/battery-60.png "battery-60") -![battery-100](/iconsets/classic/battery-100.png "battery-100") +![battery-0](/iconsets/classic/battery-0.svg "battery-0") +![battery-30](/iconsets/classic/battery-30.svg "battery-30") +![battery-60](/iconsets/classic/battery-60.svg "battery-60") +![battery-100](/iconsets/classic/battery-100.svg "battery-100") + +There is also a more powerful way to define a dynamic icon based on the states of different items and allowing you to attach any type of icon regardless of its source (not restricted to icons provided by openbHAB). + +The `icon` parameter can be used to provide conditional rules. + +Extended icon syntax: + +```java +icon=[item_name operator value = icon, item_name operator value AND item_name operator value = icon, ... ] +``` + +You can set as many conditions as you want, along with a reference to an icon for each condition. + +A condition can be a single comparison or a combination of several comparisons all separated by the AND operator. +A condition including the AND operator will be considered as true if all individual comparisons are considered as true. +Of course, it is possible to reference a different item in each comparison. + +Note that `item_name` and `operator` are both optional. +If `item_name` is not provided, the Item name will default to the current Item. +If an operator is not specified, the operator will default to `==`. + +Conditions are evaluated from left to right; the first matching condition determines the icon. +If only a reference to an icon is specified, that condition is considered as true and that icon will be used. +It can be used as a last condition to set a default icon that will be used in case any of the other previous conditions is true. + +The comparison operators are the same as for the visibility parameter. + +**Examples:** + +The following three lines are equivalent. + +```java +Text item=TemperatureTrend icon=["UP"=f7:arrowtriangle_up, "DOWN"=f7:arrowtriangle_down, f7:arrowtriangle_right] +Text item=TemperatureTrend icon=[=="UP"=f7:arrowtriangle_up, =="DOWN"=f7:arrowtriangle_down, f7:arrowtriangle_right] +Text item=TemperatureTrend icon=[TemperatureTrend=="UP"=f7:arrowtriangle_up, TemperatureTrend=="DOWN"=f7:arrowtriangle_down, f7:arrowtriangle_right] +``` ## Full Example From 0dc76d1083ca03ac3c450576435358bd2a5b812b Mon Sep 17 00:00:00 2001 From: Laurent Garnier Date: Sat, 16 Dec 2023 17:16:33 +0100 Subject: [PATCH 2/2] Considers review comments Signed-off-by: Laurent Garnier --- ui/sitemaps.md | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/ui/sitemaps.md b/ui/sitemaps.md index 8a27fd663a..ad5f1ba03f 100644 --- a/ui/sitemaps.md +++ b/ui/sitemaps.md @@ -650,7 +650,7 @@ If `item_name` is not provided, the Item name will default to the current Item. If an operator is not specified, the operator will default to `==`. If only a color is specified, that condition is considered as true and that color will be used. -It can be used as a last condition to set a default color that will be used in case any of the other previous conditions is true. +Providing only a color can be used as a last condition to set a default color that will be used in case any of the other previous conditions is true. The comparison operators for `labelcolor`, `valuecolor` and `iconcolor` are the same as for the visibility parameter. @@ -729,7 +729,7 @@ Please refer to the documentation on [Item configuration]({{base}}/configuration ![battery-60](/iconsets/classic/battery-60.svg "battery-60") ![battery-100](/iconsets/classic/battery-100.svg "battery-100") -There is also a more powerful way to define a dynamic icon based on the states of different items and allowing you to attach any type of icon regardless of its source (not restricted to icons provided by openbHAB). +There is also a more powerful way to define a dynamic icon based on the states of different items and allowing you to attach any type of icon regardless of its source (not restricted to icons provided by openHAB). The `icon` parameter can be used to provide conditional rules. @@ -751,7 +751,7 @@ If an operator is not specified, the operator will default to `==`. Conditions are evaluated from left to right; the first matching condition determines the icon. If only a reference to an icon is specified, that condition is considered as true and that icon will be used. -It can be used as a last condition to set a default icon that will be used in case any of the other previous conditions is true. +Providing only a reference to an icon can be used as a last condition to set a default icon that will be used in case any of the other previous conditions is true. The comparison operators are the same as for the visibility parameter.