In Portrait, you can define how the data is shown on the users user's frontend and with column types you can define the style and behaviour behavior of the data. Furthermore, you can make use of of Forms and Actions, which lets you integrate "Call To Actions" that fits the situation and gives a more streamlined user-experience.
...
To represent a text in its original form. Use this type if you cannot determine the source definition. Try to avoid this type for of numbers or dates because the sorting functionality will not work properly in such cases.
If a string contains formatting, for instance line breaks, they will be ignored. In case you need formatting features, see the column types:
...
Code Block | ||
---|---|---|
| ||
- label: 'Creator' key: 'creator' type: 'string' hideIfEmpty: true showInTableHeader: true showInDetailList: true |
...
Markup
type: text
In case you need formatting features, you can use this type. The formatting features are activate the allowMarkup
option.
Markdown
The formatting can be based on Markdown (see: https://en.wikipedia.org/wiki/Markdown for details on how to use it). This markup language is used as well-known for its use in documentation software and content management systems like Wikimedia or Atlassian Confluence. The feature set is limited, but therefore especially useful for: Headings, NumberingsNumbering, Highlighting, and so on.
Generally it is not recommended to use using this data type option if the column is shown in the table (showInTableHeader
should be false).
Code Block | ||
---|---|---|
| ||
- label: 'WorklogCreator' key: 'descriptioncreator' type: 'textstring' showInTableHeader: false showInDetailList: true options: allowMarkup: markdown |
HTML
type: html
This type option can be used for advanced formatting and extended functionality inside the UI. Since the Portrait Frontend in itself uses HTML for markup declaration, the risk of interference and therefore a malfunctioning Portrait-App is high. Therefore, it is very important to provide clean and safe data inside this column.
Generally it is not recommended to use using this data type if the column is shown in the table (showInTableHeader
should be false)..
Code Block | ||
---|---|---|
| ||
- label: 'Article' key: 'content' type: 'htmlstring' showInTableHeader: false showInDetailList: true |
Double
type: decimal,2
Use this definition to show the column values as a Floating Point- Number (e.g.: 12,34). In case of the type decimal you must provide a number of digits for the fractional parts. For Typically this would be two digits:
Code Block |
---|
options:
allowMarkup: html |
Preserve Line Breaks
If your text has longer text including line breaks, and you want to preserve them, you can activate the option newline
. In combination with the allowMarkup
option, the rendering of content is very flexible.
Code Block | ||
---|---|---|
| ||
- label: 'Description'
key: 'desc'
type: 'string'
showInTableHeader: false
showInDetailList: true
options:
newline: preserve |
Hide fields if they are empty
You can define, if a field should be hidden in the detail view, if the value is empty.
In this example, the Creator field is hidden, if it is empty:
Code Block | ||
---|---|---|
| ||
- label: 'Creator'
key: 'creator'
type: 'string'
hideIfEmpty: true
showInTableHeader: true
showInDetailList: true |
By default, the field is shown even though, the value is empty.
Pill
type: pill
The pill lets you color highlight specific values (e.g. “To-Do” is blue, “In Progress” is yellow, “Done” is green). The pill can be either used inside the list and inside the detail view.
Code Block | ||
---|---|---|
| ||
- label: ' |
...
Priority' key: ' |
...
Priority' type: ' |
...
pill' options: allowMarkup: markdown defaultColor: "#0022dd" highlight: - value: "1 - Low" color: "#C6DDF0" - value: "2 - Medium" color: "#C99DA3" - value: "3 - High" color: "#996888" showInTableHeader: true showInDetailList: |
...
true |
Number
type: number
This column type is used to declare a natural number. Useful if a number represents an amount or a count.
Code Block | ||
---|---|---|
| ||
- label: 'Amount'
key: 'lineAmount'
type: 'number'
showInTableHeader: false
showInDetailList: true
options:
maximumFractionDigits: 2
currencyCode: USD |
The two options are not mandatory:
maximumFractionDigits
determines the maximum amount of digits after the decimal point.currencyCode
accepts a 3-Letter ISO code, likeEUR
. If set, all other options are ignored and the number will be formatted with the given currency. For Euro, it would be314,14 €
Date
type: date
This column type is used to declare data as date. Make sure that you declare the data backend-wise in the correct format: 2018-02-28
or 2018-02-28 18:33:56.01
. A date-field shown in the User-Frontend will not contain the time-part.
How a date will be presented to the user depends on his used browser language, for example given the above date will look this:
...
Code Block |
---|
- label: 'Created on' key: 'createdon' type: 'date' showInTableHeader: true showInDetailList: true |
Boolean
type: boolean
In
case you want to show the boolean state of a value as either Yes
or No
. Make sure that you declare the data backend-wise in the correct format: True or FalseA boolean represents a true/false value.
Code Block | ||
---|---|---|
| ||
- label: 'Is completed'
key: 'isCompleted'
type: 'boolean'
showInTableHeader: true
showInDetailList: true |
The following values, and their string representations, are considered as false: false
, 0
, null
, ''
, undefined
.
Form
type: form
Allow opening forms directly from a given entry. The form can be opened with given data of the entry when the property forwardFields
is configured.
Code Block |
---|
- label: 'Is ShippedNew Opportunity' type: 'form' key: 'shippedcreateOpportunity' typeicon: 'booleanbriefcase' showInTableHeader: truefalse showInDetailList: true options: forwardFields: - COMPANY_REFERENCE - COMPANY_NAME - SOURCEID |
In this example, the form 'createOpportunity' can be opened via the button 'New Opportunity' inside the detail-view of an entry. The values COMPANY_REFERENCE
, COMPANY_REFERENCE
or SOURCEID
are passed into the form. The button has the icon 'briefcase'.
Info |
---|
The list of possible icons is based on the https://feathericons.com/ library and are open source. |
Action
type: action
Based on backend-data
With this type you can define an action for an entry based on a prediefend predefined backend-value In terms of the frontend, this these actions are also known as "Call To Action". An action could be:
...
As long as the defined action can be used inside an a href-tag (see Chapter href: https://developer.mozilla.org/en-US/docs/Web/HTML/Element/a) it is a valid action. The action itself is therefore declare as value-field in the backend-query: https://maps.google.at/?q=Stephansplatz%201,%20Wien
or mailto://office@treskon.at
.
The icon property defines what glyph is shown in the button. The list of possible icons is based on the https://feathericons.com/ library and are open source. The feather icon site lets you search for icons and use the icon name inside the property (e.g. phone
).
Code Block |
---|
- label: 'Send Request' key: 'requestMailto' type: 'action' icon: 'phone' showInTableHeader: false showInDetailList: true |
Tables
type: table
This type can be used to show a list of objects as a table. In conjunction with a the ELO Maps maps this can represent tables with columns and a given list of lines.
Code Block |
---|
- label: 'Taxes' key: 'map_objekte_TAX_AMOUNT' type: 'table' options: allowMarkup: markdown tableWidth: auto columns: - label: Net Amount field: TAX_AMOUNT_POS_NET - label: VAT in % field: TAX_AMOUNT_IN_PERCENT - label: VAT in € field: TAX_AMOUNT_IN_EUR showInTableHeader: false showInDetailList: true |
Options:
tableWidth
either ‘fixed’ or 'auto'
Download
type: download
This type will show a download button for the linked document (next to possibly defined actions). This type is only effective if the entry is connected to a document (currently only possible for entries coming from ELO sources). For this type the configuration value key
has no effect - – it will therefore be ignored. We recommend to provide a _fileSize
as column well. This actual file size of the downloadable document will be shown whilst hovering over the download button (see example configuration below).
Code Block |
---|
- label: 'Open Invoice'
key: ''
type: 'download'
showInTableHeader: false
showInDetailList: true |
Stacked bar chart
type: stackedBarChart
This type will show a horizontal bar chart to use for visualizing progress or similar data. You can pass a configuration object where you can specify which keys from the entries the chart should use, and their color in the chart.
Info |
---|
The stacked bar chart relies on data fields that are sourced as number. |
...
Code Block |
---|
- label: 'Open InvoiceProgress' key: '' type: 'downloadstackedBarChart' showInTableHeader: false showInDetailList: true options: defaultColor: '#0022dd', stackedBarChart: - label key: 'Remaining' color: 'Filesize#C6DDF0' - key: 'Spent' color: '_fileSize'#C99DA3' - key: 'Excess' type color: 'text'#996888' |
If you have an entry with these data fields:
Code Block |
---|
{ showInTableHeader"Remaining": 5, "Spent": false4, showInDetailList: false"Excess": 1, } |
A stacked bar chart type with the above configuration will create a diagram that shows 50% “Remaining” in color #C6DDF0
, 40% “Spent” in color #C99DA3
and 10% “Excess” in color #996888
.