Conditional Formatting Built into Formula Field
I have a formula field that calculates ending inventory balance. [units on hand] - [units to distribute]
I'd like to add in a conditional formula in the field background based on final balance. I've tried a number of attempts using the color() function and the styled() function. But I can't quite get it to work. I either get the value or the color, but not both. Here is my latest attempt.
What am I doing wrong?
let xBal := sum('UN On Hand' - 'UN to Distrib');
if xBal = 0 then
styled(text(xBal), "green")
else if
xBal > 0 and xBal < 5 then
styled(text(xBal), "yellow")
else if xBal > 5 then
styled(text(xBal), "red")
end
end
end
10 replies
-
Try it this way:
let xBal := sum('UN On Hand' - 'UN to Distrib');
styled(text(xBal), if xBal = 0 then
"green"
else
if xBal > 0 and xBal < 5 then
"yellow"
else
if xBal > 5 then "red" end
end
end) -
Sorry, I'm stumped! I can get the styled and color functions to work in form view but not in table view. All it shows is an unformatted 0. Is this correct?
BTW your formula above doesn't check for the number 5 use xBal <= 5 to include in the yellow set or xBal >= 5 to include it in the red set
Regards John
-
-
Hi Nick
That's wierd. I took a random table in my sandpit database and added a number and formula field, it displayed OK in form view but I had no joy whatsoever in table view. Created a new table and added the same fields and bingo it all worked.
Thanks for that.
Regards John
-
Hi John,
...outside the earth or its atmosphere
-
These two formula fields have the same formula!
-
You are both awesome in your help. I got it to work with your coaching. Thank you. And good catch on including the '5'. thanks.
-
Hi All
When it comes to colouring a field according to its valuse I thought I would put something together that is more re-useable and have come up with the following
let numberField := Number;
let upperBounds := [0, 4, 10];
let colourRange := ["red", "orange", "green", "blue"];
if numberField = null then
styled(text(numberField), "")
else
let colour := item(colourRange, 0);
let i := 1;
for a in upperBounds do
if numberField > a then
colour := item(colourRange, i)
end;
i := i + 1
end;
styled(text(numberField), colour)
endYou only have to amend the first three lines to accommodate your own needs.
Line 1 - amend this to make numberField take the value of your own number field
Line 2 - fill in the upper boundaries that you wish to use. These are inclusive boundaries so for my example its up to and including 0, up to and including 4, etc.
Line 3 - fill in the colours you wish to use. Again the first one will be used up to and including the first upperBound. There is one more colour than upperBound and this is used for everything above that last upperBound
Hope that makes sense.
Regards John
-
Thanks for sharing John.
-
Thanks John
Content aside
- 3 yrs agoLast active
- 10Replies
- 1126Views