Yuck includes a small expression language that can be used to run several operations on your data. This can be used to show different values depending on certain conditions, do mathematic operations, and even access values withing JSON-structures.
These expressions can be placed anywhere within your configuration inside { ... }
,
as well as within strings, inside string-interpolation blocks ("foo ${ ... } bar"
).
(box
"Some math: ${12 + foo * 10}"
(button :class {button_active ? "active" : "inactive"}
:onclick "toggle_thing"
{button_active ? "disable" : "enable"}))
Supported currently are the following features:
- simple mathematical operations (
+
,-
,*
,/
,%
) - comparisons (
==
,!=
,>
,<
,<=
,>=
) - boolean operations (
||
,&&
,!
) - regex match operator (
=~
) - elvis operator (
?:
)- if the left side is
""
or a JSONnull
, then returns the right side, otherwise evaluates to the left side.
- if the left side is
- Safe Access operator (
?.
) or (?.[index]
)- if the left side is
""
or a JSONnull
, then returnnull
. Otherwise, attempt to index. - This can still cause an error to occur if the left hand side exists but is
not an object.
(
Number
orString
).
- if the left side is
- conditionals (
condition ? 'value' : 'other value'
) - numbers, strings, booleans and variable references (
12
,'hi'
,true
,some_variable
) - json access (
object.field
,array[12]
,object["field"]
)- for this, the object/array value needs to refer to a variable that contains a valid json string.
- some function calls:
round(number, decimal_digits)
: Round a number to the given amount of decimalsreplace(string, regex, replacement)
: Replace matches of a given regex in a stringsearch(string, regex)
: Search for a given regex in a string (returns array)matches(string, regex)
: check if a given string matches a given regex (returns bool)captures(string, regex)
: Get the captures of a given regex in a string (returns array)strlength(value)
: Gets the length of the stringarraylength(value)
: Gets the length of the arrayobjectlength(value)
: Gets the amount of entries in the objectjq(value, jq_filter_string)
: run a jq style command on a json value. (Uses jaq internally).