Formula - XHTML

Formula - XHTML allows you to enhance the appearance of column values by embedding limited HTML markup within TeamDesk’s formula language. This feature enables you to style content by inserting HTML directly into formula results, but with some important constraints.

When using Formula - XHTML:

  1. Embedding Code Points: You can insert formula code points (enclosed within <% ... %> marks) inside attribute values and tag contents, but not as part of the tag structure itself. This ensures that the HTML remains well-formed.

  2. No Dynamic Tag Generation: You cannot generate or alter HTML tags dynamically within the formula. This restriction is designed to maintain the integrity of the HTML structure, preventing issues that could arise from malformed or improperly nested tags.

  3. Safe Encoding: Each formula piece is evaluated, and its result is automatically encoded to ensure it’s safely integrated into the markup without affecting other parts of the page.

This approach guarantees that the output is valid HTML, preserving both the appearance and functionality of the content.

Here are typical usage examples for the formula:

Coloring the Status

Formula-XHTML color status

Color a Status value green if it is "Completed", red if it is "Overdue", otherwise black.

To do this, add a new Formula - XHTML column and name it "Status(Colored)". This column can be added to a Table View instead of the existing "Status" text column, which can be used only for record editing. When the Formula - XHTML column is created, you can enter the following formula:

<font color="<%Case([Status],"Completed","#339900","Overdue","#ff3333","")%>"><%=[Status]%></font>

Contact Name as Email Link

Formula-XHTML E-mail Link

Decorate contact names as e-mail links.

Create a "Contact Person" Formula-XHTML column, where the existing "Name" column is associated with a corresponding e-mail listed in the E-mail column.

Enter the following formula:

<a href="<% Nz("mailto:" & [E-mail]) %>"><% [Name] %></a>

Behind the scenes, Formula - XHTML creates a text formula: a concatenation of markup code and formula results enclosed in an HTML encoding function, such as the code below produced from the example:

"<a href=\"" & Encode(Nz("mailto:" & [E-mail])) & "\">" & Encode([Name]) & "</a>"

Coloring Numeric Values

Formula-XHTML color numbers

Color a value red if it is less than 100.

Create the "Value (Colored)" Formula-XHTML column, where the values should be colored.

Enter the following formula:

<span style="<% If([Value] < 100, "color:red", "") %>">
<%= [Value] %>
</span>

Highlighting Date Background

Formula-XTML highlight date background

Highlight the background of an Expiry Date value in red if it is less than today+60 days and in yellow if a value is less than today+180 days.

Create the "Colored Date" Formula-XHTML column, where the "Expiry Date" column value background should be highlighted.

Enter the following formula:

<span style="background-color:<%If([Expiry Date]<Today()+60d,"red",[Expiry Date]<Today()+180d,"yellow","")%>"><%=[Expiry Date]%></span>

Changing the Font Size

Formula-XTML font size

Increase/decrease the font size.

The Formula XHTML keeps the following formula:

<span style="font-size:300%"><%[Test Column]%></span>  

You can specify the percentage value you need and write a corresponding column name instead of "Test Column".

Be aware of the way concatenation handles NULL values - if one of the parts is NULL, the whole result is also NULL. The first example produces no markup at all when the value of [Name] is blank. While it is useful in some scenarios, enclosing each and every field you want to display in a sort of NULL checks is a cumbersome task. To handle this case, we created a shorthand for code points containing a sole reference to a column, <%= [Column] %>. It creates an Nz() wrapper so that NULL values produce empty strings that can be safely concatenated. Numbers, dates, times, and timestamps are converted to text via locale-aware Format() function, and other types are converted via ToText(). In the second example, <%= [Value] %> produces Encode(Nz(Format([Value]))).

The usage of HTML and Formula - XHTML is somewhat limited due to technical reasons.

  1. Dropdown lists, as dropdowns do not support markup;
  2. Calendar views and Lookup columns with "Display As Link" options checked, as a very limited set of tags can be displayed inside of a link;
  3. Documents as the Word file format has no connection to HTML.