a!urlForSite( sitePage, urlParameters )
Returns a URL for a site page. If the page uses an Interface for the Type, you can optionally use URL parameters to pass values into it. These can be configured in the site object.
See Use URL Parameters to Link to a Site or Portal for more information about URL parameters and how to use them to link to site pages.
Keyword | Type | Description |
---|---|---|
|
Site Page |
A reference to a site page, configured using the site! domain. The structure of the site reference is |
|
Map |
When linking to a page that uses an Interface for the Type, optionally use this parameter to pass values to rule inputs in the interface. Use a!map() to provide up to 10 key-value pairs made of the URL parameter names and their associated values. For example: a!map(state: "Virginia", priority: 4). You can view the URL parameter names by clicking the page reference in the sitePage parameter. |
Text
This function makes it easy to link directly to site pages in other environments without hardcoding a link, which is fragile, or using constants, which is cumbersome.
The function automatically uses the domain from the environment from where the link is accessed.
For example, in a development environment, a link created with a!urlForSite()
might look like https://dot-dev.appiancloud.com/projectsite/page/project-dashboard. But when you access the link from a production site, it would look something like https://dot.appiancloud.com/projectsite/page/project-dashboard.
The sitePage parameter takes a reference to a site page that is constructed using the site!
domain. See Reference a Site Page for more information on how to construct a site page reference.
To create a list of the URL parameter names and values for the urlParameters parameter, use the a!map() function to create a list of the URL parameters as key-value pairs. Use the URL parameter name configured in the Rule Input Configurations grid as the key in the key-value pair.
Note that you can also use a dictionary.
Tip: Click the site page reference to view the URL parameter names. They are listed in the expression documentation pane under Enabled URL Parameter(s).
For example:
1
2
3
4
5
6
urlParameters: a!map(
/*URL parameter name = county, URL parameter value = "Fairfax"*/
county: "Fairfax",
/*URL parameter name = active, URL parameter value = true*/
active: true
)
This example is for illustrative purposes only. It won't work if you copy and paste it into an expression.
This table outlines scenarios that could cause a link to error. To avoid broken links, we've implemented certain error handling. This error handling behaves differently depending on if you use a!urlForSite()
or construct the links manually using plaintext URL parameters.
Additionally, if someone changes or deletes a character in an encrypted URL parameter string, all URL parameters that don't have a default value will be ignored.
If the following is used in a link... | Behavior in manually constructed links | Behavior in a!urlForSite |
---|---|---|
A URL parameter name that isn't in the Rule Input Configuration grid for the site page, such as when the URL parameter name is misspelled. | The URL parameter is ignored. The default value will be used for any rule inputs that have it configured. |
Expression evaluation error. |
A plaintext URL parameter that doesn't have Enable in URL selected. | The URL parameter is ignored. | |
A URL parameter value that contains more than 100 characters. | The URL parameter is ignored, unless it has a default value configured. | |
More than 10 URL parameters. | All URL parameters are ignored, unless they have a default value configured. |
The structure for the generated URL is:
https://[site-domain]/[site web address ID]/page/[page web address ID]?[encrypted or plaintext URL parameters]
For example, a URL with plaintext URL parameters might look something like:
https://statedot.appiancloud.com/projectsite/page/project-dashboard?county=Fairfax&active=true
.
If the page was within a page group, the URL would display as:
https://statedot.appiancloud.com/projectsite/group/transportation/page/project-dashboard?county=Fairfax&active=true
Note: If your site has only one page, /page/[page web address ID]
won't display in the URL. However, if you manually add /page/
followed by the web address identifier, the link will still work.
By default, URL parameters are encrypted in the generated URL. If Encrypt URL parameters is turned off for the site page, the URL parameters will display in plaintext.
Site object and record type references are specific to each environment. If you copy and paste these examples into an interface or expression rule, they will not evaluate. Use them for reference only.
1
2
3
4
5
6
7
8
a!urlForSite(
/*Replace the site page and URL parameters with valid references from your environment*/
sitePage: site!DOT Project Site.pages.project-grid,
urlParameters: a!map(
county: "Fairfax",
active: true
)
)
If Encrypt URL parameters is turned on for the page, returns something like:
https://statedot.appiancloud.com/projectsite/page/project-grid?$sp=AAAAAQAAAAAAAAABAAAAEJipwSTzHzI679DzFIjKqeml6sPuuyAWuAnrDIgMG7D5YVbpCLs1Aq5dZHWqbmLw2Z7wpMI6t6lnbmhP6yg7_4WSE_nNUi8WrhryW08
The encrypted characters for the URL parameter will change each time a!urlForSite()
is executed.
If Encrypt URL parameters is not turned on for the page, returns:
https://statedot.appiancloud.com/projectsite/page/project-grid?county=Fairfax&active=true
You can link to a site page using any component that a!safeLink can be used in. For example, to link to a site page using a link component:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
a!linkField(
labelPosition: "COLLAPSED",
links: {
a!safeLink(
label: "Active Projects in Fairfax County",
uri: a!urlForSite(
/*Replace the site page and URL parameters with valid references from your environment*/
sitePage: site!DOT Project Site.pages.project-grid,
urlParameters: a!map(
county: "Fairfax",
active: true
)
)
)
}
)
This returns a link with label "Active Projects in Fairfax County" that uses the encrypted or plaintext link from the Link to a site page example.
Your users may find it useful to bookmark filtered data or share their filtered data with other users. When you use URL parameters to set the value of filters, you can add a copy link button to your interfaces that will update with the value of the selected filters.
Note: Rule inputs can't pass data into user filters. To filter data using URL parameters and rule inputs, create the filters manually.
In order for this example to work, after creating the interface with rule inputs, set up a site page to use URL parameters.
Site and record type references are specific to each environment. This example is for reference only and will not function if you copy and paste it into your environment.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
a!localVariables(
local!county: a!queryRecordType(
recordType: 'recordType!{0c73286d-3e6f-4e42-9343-cc79fa5b0845}DOT County',
pagingInfo: a!pagingInfo(startIndex: 1, batchSize: 30)
).data,
local!selectedCounty: ri!county,
local!isActive: ri!isActive,
local!url: a!urlForSite(
sitePage: 'site!{d70fd713-30e0-45ea-b645-61550a5f163e}Dept of Transportation.pages.{bb0f2448-f8bb-49a1-8883-3a3d17f392cb}projects',
urlParameters: a!map(
county: local!selectedCounty,
isActive: local!isActive
)
),
{
a!richTextDisplayField(
labelPosition: "COLLAPSED",
value: {
a!richTextItem(
text: {a!richTextIcon(icon: "link")," Copy link"},
link: a!safeLink(
uri: local!url
),
linkStyle: "STANDALONE"
)
},
tooltip: "Copy link with selected filters",
align: "RIGHT"
),
a!columnsLayout(
columns: {
a!columnLayout(
contents: {
a!dropdownField(
choiceLabels: local!county['recordType!{0c73286d-3e6f-4e42-9343-cc79fa5b0845}DOT County.fields.{9564c6a0-2c1d-47d2-96e4-3ef3617012c6}value'],
choiceValues: local!county['recordType!{0c73286d-3e6f-4e42-9343-cc79fa5b0845}DOT County.fields.{85610b86-86b8-4884-8bbd-53e8a65c0e77}id'],
label: "COUNTY",
placeholder: "Select a county",
value: local!selectedCounty,
saveInto: local!selectedCounty
)
}
),
a!columnLayout(
contents: {
a!dropdownField(
choiceLabels: {"Active", "Inactive"},
choiceValues: {true, false},
label: "Project Status",
placeholder: "Select a status",
value: local!isActive,
saveInto: local!isActive
)
}
)
}
),
a!gridField(
labelPosition: "COLLAPSED",
data: a!recordData(
recordType: 'recordType!{e73c189c-20a3-44f5-9726-36164b32af15}DOT Project',
filters: a!queryLogicalExpression(
operator: "AND",
filters: {
a!queryFilter(
field: 'recordType!{e73c189c-20a3-44f5-9726-36164b32af15}DOT Project.relationships.{fe28647c-a05a-49c0-9374-cab19f0191ea}county.fields.{85610b86-86b8-4884-8bbd-53e8a65c0e77}id',
operator: "=",
value: local!selectedCounty
),
a!queryFilter(
field: 'recordType!{e73c189c-20a3-44f5-9726-36164b32af15}DOT Project.fields.{d7b7da46-2d1b-4851-a93d-b4e996af5a79}isActive',
operator: "=",
value: local!isActive
)
},
ignoreFiltersWithEmptyValues: true
)
),
columns: {
a!gridColumn(
label: "Project Name",
sortField: 'recordType!{e73c189c-20a3-44f5-9726-36164b32af15}DOT Project.fields.{7e740413-1d8a-4dba-8d9f-d188a773103a}projectName',
value: fv!row['recordType!{e73c189c-20a3-44f5-9726-36164b32af15}DOT Project.fields.{7e740413-1d8a-4dba-8d9f-d188a773103a}projectName']
),
a!gridColumn(
label: "County",
sortField: 'recordType!{e73c189c-20a3-44f5-9726-36164b32af15}DOT Project.relationships.{fe28647c-a05a-49c0-9374-cab19f0191ea}county.fields.{9564c6a0-2c1d-47d2-96e4-3ef3617012c6}value',
value: fv!row['recordType!{e73c189c-20a3-44f5-9726-36164b32af15}DOT Project.relationships.{fe28647c-a05a-49c0-9374-cab19f0191ea}county.fields.{9564c6a0-2c1d-47d2-96e4-3ef3617012c6}value'],
align: "START"
),
a!gridColumn(
label: "Active?",
sortField: 'recordType!{e73c189c-20a3-44f5-9726-36164b32af15}DOT Project.fields.{d7b7da46-2d1b-4851-a93d-b4e996af5a79}isActive',
value: if(
fv!row['recordType!{e73c189c-20a3-44f5-9726-36164b32af15}DOT Project.fields.{d7b7da46-2d1b-4851-a93d-b4e996af5a79}isActive'],
"Yes",
"No"
)
)
}
)
}
)
Feature | Compatibility | Note |
---|---|---|
Portals | Partially compatible | Can be used with Appian Portals if it is connected using an integration and web API. |
Offline Mobile | Incompatible | |
Sync-Time Custom Record Fields | Incompatible | |
Real-Time Custom Record Fields | Incompatible | Custom record fields that evaluate in real time must be configured using one or more Custom Field functions. |
Process Reports | Incompatible | Cannot be used to configure a process report. |
Process Events | Incompatible | Cannot be used to configure a process event node, such as a start event or timer event. |
a!urlForSite() Function