-
Notifications
You must be signed in to change notification settings - Fork 42
user elements variables logic
This guide covers the translation variables and logic you can use in a Definition. There is a lot of duplication from the manual. Translation variables are specially formatted blocks of text that are translated before rendering to display something else (much like a reference to a column).
The following translation functions and logic apply to all types of Elements. The samples below show Text Element output. As with everything be sure to see the manual.
##x;y;z#
This will translate as follows: x + (current card index * y) with left padded 0's numbering z
- The card index is a 0 based value. This can be a bit confusing but is critical to the use of the y value.
##1;1;0#
-- Just a basic counter starting at card index 1
Card 1 Result: 1
Card 33 Result: 33
Card 100 Result: 100
##5;1;3#
-- Counter starting at 5, with left padding.
Card 1 Result: 005
Card 33 Result: 037
Card 100 Result: 104
##2;2;0#
-- Counter starting at 2, and adding 2 per card index.
Card 1 Result: 2
Card 33 Result: 66
Card 100 Result: 200
#(if x [logical statement] y then a)#
OR
#(if x [logical statement] y then a else b)#
This will translate based on the success/failure of the logic statement. There are a number of possible logical operators detailed in the manual.
#(if 1 == 1 then good news!)#
Result: good news!
#(if 1 == 2 then bad news!)#
Result: (There is no result because 1 does not equal 2.)
++#(if 1 == 2 then bad news!)#++
Result: ++++
The logical statement will result in nothing but the existing text wrapped around it will appear as normal.
++#(if 1 == 2 then bad news! else good news!)#++
Result: ++good news!++
++#(if 1 == then bad news! else good news!)#++
Result: ++good news!++
This logical statement is comparing 1 to an empty string. As they are not equal this will fail to the else value. The #empty
(empty string) functionality can make this a little easier to read:
++#(if 1 == #empty then bad news! else good news!)#++
If this were the definition of a Text element it would display the value from the @[skill] reference. If that reference value is 15 then the opacity of the element will be set to 50. This uses the inline override functionality.
@[skill]#(if @[skill] == 15 then $[opacity:50])#
If the comparison or results contain the key words: else
or then
you might run into trouble. Yikes!
If you need to do something that really requires that kind of output I recommend investigating the
override functionality overriding the variable
.
#(if [x;y;z] [logical statement] [a;b;c] then m)#
OR
#(if [x;y;z] [logical statement] [a;b;c] then m else n)#
This will translate based on the success/failure of the logic statement based on the existence of x, y, or z in the set of a, b, and c. Only one of the values in the first set must exist in the second set to pass. Both sets are unbounded on size. Only the == and != logical operators are supported for this logic. This is a reasonably complex statement to use and is only recommended if you really need it!
#(if [1;2] == [5;2;6] then good news! else bad news!)#
Result: good news!
#(if [1;2] == [5;6;7] then good news! else bad news!)#
Result: bad news!
++#(if [1;2] == [5;6;7] then good news!)#++
Result: ++++
#(switch;key;keytocheck1;value1(unbounded repeat: ;keytoCheck;value))#
This will translate to the value associated when the key matches a keytocheck value.
Optionally you may specify #default to indicate that if nothing passes to use the value specified with default.
#(switch;1;1;good news!;2;bad news!)#
Result: good news!
#(switch;2;1;good news!;2;bad news!)#
Result: bad news!
++#(switch;54;1;good news!;2;bad news!)#++
Result: ++#(switch;54;1;good news!;2;bad news!)#++
Unlike the if statements the result of an nonexistent item is the raw text (might be something to consider changing in the application!).
#(switch;3;1;good news!;2;bad news!;#default;confused!)#
Result: confused!