- 06 May 2025
- 13 minute read
- Print
- DarkLight
- PDF
Creating a Custom Portal
- Updated 06 May 2025
- 13 minute read
- Print
- DarkLight
- PDF
Before you dive in to creating a custom portal:
- Check the list of example portals that you can import into your database—we may have what you need. 
- Make sure you’re comfortable with basic Slate functionality, specifically: 
Without further ado, let’s make a custom portal!
Step 1: Creating the portal
Click Database in the Slate navigation bar and click the Portals link in the Portals section.
Click New Portal when creating a portal (or clicking the "edit" button for an existing portal), the following settings can be configured:
Status: If the portal is Active, it can be visited at a URL formed from
/portal/followed by the portal key. Inactive portals can be viewed and/or impersonated by Slate users with the relevant permissions.
Name: A descriptive name you can give your portal for your own reference (it won't be seen by the public).
Key: A simple name used in the public URL for the portal, which should be unique for each portal created. For example, you might have a portal with a name of "My Awesome Portal" with a key of
awesome. The URL would then be:https://apply.slateuniversity.edu/portal/awesome
Folder: If you have a number of portals, you may want to organize them into folders for your own reference.
Default View: The view that defines the portal layout when the portal is initially loaded. When creating a new portal, there will be no available views to select, as these have not yet been created. The default view can be set later as soon as at least one view is created.
Scope: The scope of information being displayed in the portal. For constituent-facing portals, this will align with the Security setting.
Security: The method you want to use to authenticate who can enter your portal. This will allow you to control access to the portal, and also allow you to identify a portal user so that you can show them content that is specific to them (e.g., an alumni interviewer would see their own interview assignments).
Secure Link: Portal access can be provided via login or a secure link. The secure link will look something like:
https://apply.slateuniversity.edu/portal/alumni?key= be930235-707b-4405-b0ca-04cf64aceec7
Secure links are only available for portals with person or dataset security. If any personally-identifiable information will be displayed on the portal, we recommend requiring a login and discourage using the "Secure Link" setting.
Use SSO: This setting is used for dataset portals, which can leverage an institutional SSO for authentication.
Restrict Access: Add filters to indicate who should have access to your portal. For example, in a User portal, you can restrict to certain roles or permissions. In an Application portal, you might restrict based on round or decision.
Authorization Fail Custom Message: This message will appear if the filters prevent access.
Inactive Message: This message will appear if the portal is set to an inactive state.
Description: A longer description of the portal for your own reference.
Custom CSS Rules: Allows you to add CSS rules that apply to the entire portal, without needing to modify your existing institutional branding.
XML Configuration: Allows you to define custom variables that will be available in portal methods as well as in views to store information that is needed throughout the portal. For example, if the queries should reference certain rounds, or the portal should link to a certain form, you might want to define that in a variable here so that you can update it in one central location. You can add a variable in XML by adding something like
var id="review_form">84bf4da7-ce29-4151-ac47-2edad7b84691
where the enclosed value is the GUID of a form. In the portal editor, you can then reference that variable in SQL as@review_form.
Step 2: Adding portal methods
Each portal method can run one or more Slate queries to look up or update Slate data. Each portal method should correspond to a given "page" of the portal.
Each method can have an action attribute that determines when it will run (no action means it will run for the default portal page; otherwise it will run for URLs of the form ?cmd=action).
A portal method is also meant to represent a page or endpoint for the portal -- for example, in the portal method you indicate whether the page should include your branding.
Status: Portal methods that are set to "inactive" will not run even if they would otherwise be called.
Name: A descriptive name of the method for your own reference.
Type: All modern portals use the GET method type, which is designed to be given request parameters and look up and return information; for example, to get information about the current user, to get a list of applicants to display, etc.
POST methods are a deprecated way to receive passed-in data and perform an update. Portals with POST methods should be updated to use Slate forms instead.
Output Type: The data that has been returned from the query can be treated in several ways.
Default Branding: The associated view creates an HTML web page, which would be displayed using your institution's default Slate branding.
Framework + No Branding: Use the associated view to create an HTML web page, which should be displayed as is (no added branding) but with the built-in Slate framework code included. This should be used if you want your portal to have a different branding than your default Slate branding (and the portal branding should then be included in the view).
AJAX Popup/No Branding: Use the associated view to create an HTML web page which should be displayed as is. This is typically used when the portal method is creating the contents of a pop-up or is just meant to render a section of a page which will be inserted by an AJAX call (i.e., where the page doesn't get reloaded but JavaScript replaces part of the page contents dynamically).
JSON: Output the results in JSON (JavaScript Object Notation) format, useful for AJAX calls that are then using the data to do an update themselves.
JSONP: Output the results in JSONP format, a version of JSON in which the results are formatted in a way that allows the calling code to avoid cross-domain security restrictions. This would be used if you were creating a portal in order to support some sort of integration with an outside system.
XML: Output the results in XML format. The results from the portal method will be returned as an XML element, with each column as an XML attribute.
Raw: Output the results with no formatting or markup. This could be useful for troubleshooting or for a situation where you're doing your formatting within the SQL.
Excel Spreadsheet: Output the result as an Excel spreadsheet which will be queued for download in the web browser. The Excel spreadsheet will automatically inherit the portal key as its filename. However, you can specify the filename by appending a query string parameter to the download link. This filename can use merge fields so the name may be dynamic as needed.
/portal/key?cmd=method-action&filename={{merge-field}}_spreadsheet.xlsx
Redirect: Typically used in situations in which a logged-in person will need to be redirected to a particular page.
Page Title: Display a custom page title for the method.
Action: For the initial "home" page of the portal no action should be entered. For other pages, popups, or updates, the value entered under "action" will determine when the method should be called.
If the URL that loaded the current page or pop-up includes
cmd=doThis, and the action value for this portal method isdoThis, then this portal method will be called.
View: Select the view associated with this method.
Step 3: Creating portal queries
The core of the functionality for a portal method is a query (or queries) that will run when the method is called. Queries will either get the data from your database and display it according to how the portal view is set up, or update data back in the database.
Queries can be reused across methods within a portal, and each portal method can also be linked with multiple queries.
Adding a new query
Configure queries using various bases to dynamically display data on the dashboard.
Give the query a Name, for your own reference. Give your portal queries names that are easily understandable and distinguishable from one another.
Select a Base. If the query is only querying for data of a given type (e.g., applicants), selecting the corresponding population allows you to set up your query using the standard Slate query interface.
The data returned by the query will be available as merge fields that can be used in Liquid markup with your views.
The export parts should be edited to use lowercase names that do not include spaces or punctuation other than underscores or dashes. (For example, change "First Name" to first or first_name).
Query parameters
If you need to pass data into a portal method query, you will create parameters. This might be data that you are using to refine the data you are retrieving (for example, retrieve applicant data for a particular applicant by passing in the applicant ID).
Click Edit Parameters.
Add XML tags, once for each parameter, following the format below:
<param id="person" type="uniqueidentifier" /> <param id="term" type="string" />
In the query, you would use the parameters in direct filters or formula subqueries.
Output nodes
The node controls how the data in the query is delivered to a view. Typically, when a query delivers data for a list of objects each with their own attributes, the output node is used to designate the name given to this "container" of objects.
In the view editor, the node can then be referenced in Liquid markup for data inside an object - that is, with Liquid looping where each object needs to be iterated over.
The node will only be needed when looping through a list of results. If the query is returning a single set of data (e.g., information about the currently logged-in person), then the node should be blank.
Common uses for the output node include: displaying checklist data (example node name: checklist), displaying a list of alumni interviewers within a table that generates one row per interviewer (example node name: interviewers).
Linking queries to methods
In each portal method, a list of queries linked to that method is displayed. Click "Edit Linked Queries" to specify which portal queries should be associated with the method.
Step 4 (Optional): Creating portal reports
Portals have their own report builder functionality. Example use cases for a report in a portal might include:
- Athletics: Show coaches aggregate data about their athletes. 
- Volunteers or Alumni Interviewers: Let volunteers view prospective students with whom they’ve interacted and which events those prospects have attended. 
- Gift officers: Present giving history and totals within particular portfolios. 
📖 Further reading: Reports
📝 Reports created outside of a portal (that is, in Queries / Reports) cannot be accessed from within the portal.
To create a new report in a portal:
Select New Report.
Configure the following settings:
Name: Name the report.
Realm (Optional): Add the report to a Realm.
Orientation: Select Portrait or Landscape for the orientation.
Colors (Optional): Customize the color palette that will be used in your report.
Parameters (Optional): Insert Parameters for the report.
Select Save.
Create additional reports as desired.
In the next section, we’ll create views to present these reports and the queries we created earlier.
Step 5: Creating portal views
A view controls how the content of the portal is displayed. A view may consist of static HTML content (which could contain merge fields that display data from a portal query) or content widgets such as forms, reports, checklist sections, decision sections, etc.
Each view represents a single "page" of the portal. There is typically one "Default" view with additional views linked to portal methods that render other pages, popups, or sections of pages that will be loaded on the fly.
Create a new view
- Status: The portal can use a view when it is set to Active. 
- Name: The name will be visible when editing the portal, so it is recommended that the name makes it clear which section the view represents. 
- Layout: The page can be set up with the Layout Editor (selected by default) to build a customized view using a drag-and-drop methodology, or it can be set up by using one of a collection of pre-defined layouts. 
Using the Layout Editor
In the Views section, select the New View link. The Edit View popup appears.
Configure the following settings:
Status: Active
Name: Enter an appropriate name for the view
Layout: Dynamic Layout Editor (default)
Click Save. The layout editor appears.
Click New Row on the right side of the page. The Select Row Layout popup appears.
Select the desired layout for the row. The new row appears on the layout.
From the parts shown on the right side of the page, drag the desired view parts into the row. The Edit Part popup appears.
Add additional rows and parts as needed.
When finished adding all rows and parts click the portal name link in the breadcrumb on the top of the page to return to the portal summary page.
Using a Standard Layout
In the Views section, select the New View link. The Edit View popup appears.
Clear the Use Layout Editor option. A drop-down list appears.
Select the desired page layout.
Click Save. The view layout appears.
Add content to the view by dragging the desired view parts from the palette on the right.
Removing view parts
Modify an existing view
Select the desired view to modify.
If the view was created with the fixed (legacy) portal process, it can be converted to use the dynamic layout editor.
Click Edit. The Edit View popup appears.
Select Convert To Use Layout Editor. A confirmation opens to inform you that Slate will attempt to reconstruct the view as closely as possible, and also to suggest testing this conversion prior to using it in your production environment.
Click OK.
Click Save.
Refer to the procedures described in the Creating a New View section above for information on editing the view with the layout editor.
Converting all views to use the layout editor
If a portal was created using the legacy portal process, all views within the portal can be converted to use the dynamic layout editor.
📝 Note: This option is only available when copying a portal. This prevents auto-conversion of items that might result in a change in the portal appearance.
On the Portal page, select the desired portal.
Under View Layout, click the Copy this portal to switch to the dynamic Layout Editor link. The Copy Portal popup appears.
Enter the desired values in the popup fields, and make sure that Convert Views to Dynamic Layout Editor is selected.
Click Copy. The portal summary page for the new (copied) portal appears.
All views in the portal now use the dynamic layout editor.
🔔 ImportantKeep in mind that Slate attempts to convert the views as accurately as possible, but the conversion process may result in changes to the portal display (portals with fixed-layout views are rendered using HTML tables, but dynamic-layout views are rendered using a CSS grid). Confirm the appearance of the portal in the test environment prior to converting in the production environment.
Portal widget palette
When building a view, use the Portal Widget Palette to drag in the type of content to be added. The palette changes depending on the Scope and Security settings. The Portal Widgets article describes each option in detail.

Step 6: Testing and activation
Like all Slate configurations, portals should be built in your Production environment but tested prior to going live. Depending on the type of portal, your testing steps may be different. For Anonymous/Guest portals, you can perform testing in Production - simply leave your portal with a Status of Inactive, and view the portal URL. As long as you’re logged in to Slate administratively, you can view and interact with the portal.
If your portal can access and/or modify record information, we recommend the following steps instead:
- Build the portal in Production, making sure the Status is Inactive. 
- As you build, perform any impersonations only with test records. 
- When you’re ready to perform testing of the finalized portal, refresh your Test environment. 
- In Test, use actual records to perform the impersonation. 
- After completing these steps, set the Status to Active in Production. 
Testing existing portals
If you’re modifying an existing portal, you may want to test changes without affecting existing end-users. This can be done by filtering your new portal widget using the Current User join. For example, adding the following subquery filter will only display the portal widget when the portal is being viewed when logged in as a Slate user:





.png?sv=2022-11-02&spr=https&st=2025-10-25T17%3A29%3A44Z&se=2025-10-25T17%3A39%3A44Z&sr=c&sp=r&sig=zVba3q4JnXue%2FruSN7OJmSmcb07aUfhM5gSknn49luo%3D)


