Skip to end of metadata
Go to start of metadata

You are viewing an old version of this page. View the current version.

Compare with Current View Page History

« Previous Version 29 Next »

Introduction

In the Regent Smart Form Manager Tool, schools with a Regent Rund or Regent Review License can update an existing Smart Form, import an existing Smart Form from a different environment (e.g. QA to Prod), and create a new Smart Form.

Schools should not update Regent maintained Smart Forms, such as the Verification Worksheet. If changes are needed, schools should continue to submit a Customer Zone ticket.

If a school elects to update a Regent maintained Smart Form and data clean-up efforts are needed by Regent, a Statement of Work may be requested for a cost. If updates are made, the school should use extreme caution by first making a copy and updating the Document configuration Smart Form Type/Code to use the school created Smart Form. Any changes made directly to a Regent maintained Smart Form will be overridden upon a new release if enhancements or changes are made. Regent will not make changes to or maintain a ‘copy of’ a Regent maintained Smart Form.

Overview

The Smart Form Manager Tool is available in the Regent Tools menu for users with the permission enabled to view or edit the ‘Smart Form Manager Tool’

The Document Assignment Tool is comprised of a top section with selection options for Institution Name and Query Name and a bottom section for the selection of Documents to be assigned.

NOTE: This tool is designed to be used at the Institution level. Only one Campus per Institution should be configured.

Getting Started

Schools will need to:

  1. Be on or upgrade to the Regent Award 6.5.0.0 Release or a subsequent Release

  2. Update Enterprise Permission

  3. Create Smart Form

  4. Update Document Tracking Setup

Smart Form Manager Tool

A tree-view menu displays on the left-hand side of the Smart Form Manager tab on the Smart Form Manager screen.

The following options are available in the tree-view menu:

  • + Create Smart Form

    • Used to begin the creation of a new smart form.

  • + Import Smart Form

    • Used to import/load a Smart Form from one environment to another.

  • → Active Smart Forms

    • Used to access an existing 'Active Smart Form. A Smart Form is considered ‘Active’ if today’s date falls within the effective Start Date and End Date defined on the Smart Form Information tab.

  • → Inactive Smart Forms

    • Used to access an existing ‘Inactive’ Smart Form. A Smart Form is considered ‘Inactive’ if today’s date does not fall within the effective Start and End Date defined on the Smart Form Information tab.

Creation or Editing of a Smart Form

Information

The Information tab provides basic Smart Form setup information, including the Smart Form Name, Federal Award Year, and valid Effective Start and End Dates.

 Information Tab Fields

Section Field Name

Section Description

Required/Optional

Section Field Type

Section Field Options

Name

The text entered in this field is displayed as the Smart Form name at the top of the Smart Form in the Student Portal.

Required

Textbox

Federal Award Year

The selection here will be used when creating or updating the Smart Form document requirement, if the document is configured as a FAY scope, by ensuring only the Smart Form document requirement with the associated FAY is created or updated upon completion.

If a document is configured as student scope, the Smart Form FAY is ignored when creating the Smart Form document requirement or updating upon completion.

Required

Dropdown

  • 2010-2011 through 2049-2050

Start Date

The date entered here will be used as the effective begin date to allow students to access the Smart Form within the portal.

Required

Calendar Date

End Date

The date entered here will be used as the effective end date to allow students to access the Smart Form within the portal.

Required

Calendar Date

Smart Form Type

The Smart Form type is used to link a Document to an Active Smart Form to make it available via the Student Portal.

Required

Checkbox

  • Use Smart Form Code

  • Lists all existing Smart Form Types

Code

The text entered here will be used as a short name to identify the Smart Form in the Smart Form Manager.

Required

Textbox

Allows alpha-numeric characters without spaces

Make Regent Data Available

Demographic Information

When this option is selected, the student’s Demographic information is made available to pull into the Smart Form.

Optional

Checkbox

  • Selected

  • Not Selected (Default)

ISIR Information

When this option is selected, the student’s ISIR Information is made available to pull into the Smart Form.

Optional

Checkbox

  • Selected

  • Not Selected (Default)

Student Portal Authorizations

When this option is selected, the student’s Portal Authorizations are made available to pull into the Smart Form.

Optional

Checkbox

  • Selected

  • Not Selected (Default)

UDF Information

When this option is selected, the student’s UDF Information is made available to pull into the Smart Form.

Optional

Checkbox

  • Selected

  • Not Selected (Default)

Regent Access

When this option is selected, the student’s Regent Access information is made available to pull into the Smart Form.

Optional

Checkbox

  • Selected

  • Not Selected (Default)

Fund Information

When this option is selected, the student’s Fund information is made available to pull into the Smart Form.

Optional

Checkbox

  • Selected

  • Not Selected (Default)

Section Additional Information and Advanced Settings

Smart Form Id

A system-generated ID is created and associated when creating a new Smart Form.

Textbox (Read-only)

Created At

This is the date upon which a new Smart Form is created.

Textbox (Read-only)

Modified At

This is the last date upon which a Smart Form was modified.

Textbox (Read-only)

Document Persistence

Document Persistence allows school users to create rules using regular expressions (see https://www.geeksforgeeks.org/javascript-regexpregular-expression/) to add or update a student document requirement in Regent. Document Requirements are added and updated upon the completion, including signature(s), of the Smart Form. The document requirement is only added or updated if the expression results are true. For example, if a student indicates, ‘I was married at the time of FAFSA completion but am no longer married’ on a Smart Form question response, Document Persistence can be created to add a Divorce Decree document requirement with a status of ‘Needed’ to collect the additional documentation required.

Document Setup must be considered when adding Document Persistence. For example, if a document is configured to ‘Enforce Scope Uniqueness’, a new document will not be added if it already exists, however, the status of an existing document can be updated. Alternatively, if documents are configured to be added automatically via another process (e.g. ISIR Import), the Document Persistence can be used to update the Document Status on an existing document(s).

 Document Requirement Persistence Fields

DRP Field Name

Required/Optional

DRP Field Description

DRP Field Type

Question Field Options

Document Name

Required

This is the name of the document configured in Regent to update or create based on the persistence logic.

When configuring a Document Persistence, the ‘Name’ must match the name of the document configured in Document Setup. Use caution when Document Names have special characters such as an apostrophe or dash that it is using the identical Document Name and has not been updated by the editor. If no match is found to an existing Document Name configured when executing the DRP expression, an error message is displayed, ‘Document name of <Document Name> is not found'.

Textbox

Scope

Required

This is the document scope associated with the document requirement to update or create.

Dropdown

  • Student

  • Federal Award Year

  • Student and Reason

  • Federal Award Year and Reason

Note: Payment Period and Academic Year scopes are not available options.

Default Status

Required

This is the status the document requirement is set to upon the completion of the Smart Form.

Although required, this status is only used when the Smart Form is not configured for electronic signatures.

Dropdown

  • Static

  • Velocity

Activity Log Entry Status

Required

This is the Activity Type for the
Activity Log Entry in Regent logging status changes and new document requirements.

Dropdown

Esigned Status

Required

This is the status the document requirement is set to upon the completion of the Smart Form.

Although required, this status is only used when the Smart Form is configured for electronic signatures.

Textbox

Condition Expression

Required

A Boolean Expression is defined using logical operator such as, AND (&&) and OR (||), which can be used in combination with built-in expressions (see XXX), to result in a TRUE or FALSE. Question responses are wrapped in braces (curly brackets) within the expression.the question code in curly braces. If an expression did not evaluate to true or false, that means the expression is not valid and contains syntax errors. If the expression is invalid, persistence actions for this document requirement will be ignored.

Textbox

Create on No Match

Optional

If checked, the DRP will be create in REM even if the smart form document can not be found for the specified create statuses. The document will be created based on the "Attachment Type" field selection.

Checkbox

  • Selected

  • Unselected (Default)

For Transfer

Optional

This is a legacy setting and is no longer used.

Checkbox

  • Selected

  • Unselected (Default)

REM Linked Document

Optional

If selected, the Document Persistence associates the document being created or updated to a Document in Regent Enterprise Management (REM).

An unselected REM Linked Document field is legacy code that is no longer supported.

Checkbox

  • Selected (Default)

  • Unselected

Document Reason

Optional

If added, the Document Reason, which is defined as an expression will be added to the ‘reason’ field on the associated Document Requirement when creating or updating the document in Regent.

Textbox

Update Statuses

Optional

A Document Requirement is updated in Regent to the Default Status or Esigned Status if a Document Requirement in Regent has one of the statuses listed in this column upon completion of the Smart Form.

Drag-and-Drop, Multi-selection

  • Selected Document Statuses from the Available Statuses

Available Statuses

Optional

The list of available document requirement statuses to select the ‘update’ or ‘create’ statuses from.

Drag-and-Drop, Multi- selection

Create Statuses

Optional

A Document Requirement is created in Regent if a Document Requirement does not exist with one of the statuses listed in this column upon completion of the Smart Form.

Drag-and-Drop, Multi- selection

Document Persistence Additional Information & Advanced Settings

File Name

Optional

This is a legacy setting and is no longer used.

Textbox

Template Name

Required

This is a legacy setting and is no longer used.

Textbox

Attachment Type

This is a legacy setting and is no longer used.

Dropdown

  • Pdf Template

  • FAFSA

Student Persistence

Student Persistence updates the Student Portal Authorization fields in Regent based on the Smart Form question response(s). Student Persistence is added and updated upon the completion of the Smart Form, including all required signature(s).

 Student Persistence Fields

DRP Field Name

Required/Optional

DRP Field Description

DRP Field Type

Question Field Options

Credit Balance Option

Optional

This field is associated to the Portal Credit Balance Option in Regent and the Smart Form response from the question code selected is persisted to the associated field.

Dropdown

  • All question codes in sequential order within the Smart Form

Hold Excess Title4

Optional

This field is associated to the Hold Excess Title IV in Regent and the Smart Form response from the question code selected is persisted to the associated field.

Dropdown

  • All question codes in sequential order within the Smart Form

Pay Prior Year Minor Charges

Optional

This field is associated to the Pay Prior Year Minor Charges in Regent and the Smart Form response from the question code selected is persisted to the associated field..

Dropdown

  • All question codes in sequential order within the Smart Form

Pay Non Institutional Charges

Optional

This field is associated to the Pay Non-Institutional Charges in Regent and the Smart Form response from the question code selected is persisted to the associated field.

Dropdown

  • All question codes in sequential order within the Smart Form

Parent/Spouse Persistence

Parent/Spouse Persistence updates the Parent/Spouse Reference fields in Regent based on the Smart Form question response(s). Parent/Spouse Persistence is added and updated upon the completion of the Smart Form, including all required signature(s).

 Student Persistence Fields

DRP Field Name

Required/Optional

DRP Field Description

DRP Field Type

Question Field Options

Credit Balance Option

Optional

This field is associated to the Portal Credit Balance Option in Regent and the Smart Form response from the question code selected is persisted to the associated field.

Dropdown

  • All question codes in sequential order within the Smart Form

Hold Excess Title4

Optional

This field is associated to the Hold Excess Title IV in Regent and the Smart Form response from the question code selected is persisted to the associated field.

Dropdown

  • All question codes in sequential order within the Smart Form

Pay Prior Year Minor Charges

Optional

This field is associated to the Pay Prior Year Minor Charges in Regent and the Smart Form response from the question code selected is persisted to the associated field..

Dropdown

  • All question codes in sequential order within the Smart Form

Pay Non Institutional Charges

Optional

This field is associated to the Pay Non-Institutional Charges in Regent and the Smart Form response from the question code selected is persisted to the associated field.

Dropdown

  • All question codes in sequential order within the Smart Form

Sections

Section names are displayed on the Smart Form menu within the Student Portal. Sections are displayed in numerical order from lowest to highest based on the number entered in the Section Sort Order field.

 Section Fields

Section Field Name

Required/Optional

Section Description

Section Field Type

Section Field Options

Template Engine

Required

If static is selected, the field content is displayed in the same manner provided. If velocity is selected, a velocity templating engine is used that will allow for dynamic logic and display (see https://velocity.apache.org/engine/1.7/user-guide.html).

Dropdown

  • Static

  • Velocity

Section Name

Required

The text entered in this field is displayed in the Smart Form menu in the Student Portal as the Menu Section Name.

Textbox

Code

Required

The text entered here will be used as a short name to identify the Section in the Smart Form Manager.

Textbox

Allows alpha-numeric characters without spaces

Sort Order

Required

The number entered here will be used to sort Sections in the Smart Form from the lowest Sort Order to the highest Sort Order.

Numeric box

Visible

Optional

If selected, the Section will be visible by default. If unselected, the Section will not be visible by default. Dependency logic can be used to display or hide the Section from its initial default state.

Checkbox

Sections Additional Information & Advanced Settings

Section Id

A system-generated ID is created and associated when creating a new section.

Textbox (Read-only)

Created At

This is the date upon which a new section is created.

Textbox (Read-only)

Modified At

This is the last date upon which a section was modified.

Textbox (Read-only)

Section Title

Optional

The text entered in this field is displayed at the top of the Smart Form page.

Textbox

Section Information

Optional

The text entered in this field is displayed at the top of the Smart Form page beneath the Section Title, if configured

Text Area

Parent Information

Optional

The selection(s) in this section can be used as an identifier or in validation and dependency logic in the Smart Form.

Checkbox

  • Selected

  • Unselected (Default)

Groups

Groups are used within each Section to categorize questions. Each group is comprised of one or more questions. All questions contained within a group are organized beneath the Group name defined and displayed within each Section. Groups display in numerical order from lowest to highest based on the number entered in the Group Sort Order field.

 Group Fields

Group Field Name

Required/Optional

Group Field Description

Group Field Type

Group Field Options

Template Engine

Required

If static is selected, the field content is displayed in the same manner provided. If velocity is selected, a velocity templating engine is used that will allow for dynamic logic and display (see https://velocity.apache.org/engine/1.7/user-guide.html).

Dropdown

  • Static (Default)

  • Velocity

Group Name

Required

The text entered in this field is displayed as a Group Title for a set of one or more questions within the Smart Form in the Student Portal.

Textbox

Group Instructions

Optional

The text entered here is displayed as instructional messaging for the questions within the group.

Textbox

Code

Required

The text entered here will be used as a short name to identify the Group in the Smart Form Manager.

Textbox

Allows alpha-numeric characters without spaces

Sort Order

Required

The number entered here will be used to sort Groups within the Section from the lowest Sort Order to the highest Sort Order.

Numeric

Visible

Optional

If selected, the Group will be visible by default. If unselected, the Group will not be visible by default. Dependency logic can be used to display or hide the Group from its initial default state.

Checkbox

  • Selected

  • Not Selected (Default)

Page Index

Required

Groups can be displayed on different pages within each Section. The number entered here will be used to determine which page the Group is displayed on.

Numeric

Groups Additional Information & Advanced Settings

Group Id

A system-generated ID is created and associated when creating a new group.

Created At

This is the date upon which a new group is created.

Modified At

This is the last date upon which a group was modified.

Questions

Questions are displayed within each Group to categorize questions. Each group is comprised of one or more questions. All questions contained within a group are organized beneath the Group name defined and displayed within each Section. Questions display in numerical order from lowest to highest based within the Group on the number entered in the Question Sort Order field.

 Question Fields

Question Field Name

Required/Optional

Question Field Description

Question Field Type

Question Field Options

Field Type

Required

The selection here will be used to determine the question selection type.

Dropdown

  • Textbox

  • Dropdown

  • RadioButton

  • Date

  • SSN

  • Autosize Dropdown

  • MMDDYYYY Dropdown

  • HyperlinkButton

  • Text Only

  • MMYYYY Dropdown Date

  • Text Area

  • Checkbox

  • Currency - Whole Dollar

  • Phone

Data Type

Required

The Data Type entered here will determine how the value is saved in the database and the available operators in the Regent Query Tool. If this field is not selected, the question is not available as an option in the Regent Query Tool.

Dropdown

  • Text

  • Amount

  • Date

  • Number

Template Engine

Required

If static is selected, the field content is displayed in the same manner provided. If velocity is selected, a velocity templating engine is used that will allow for dynamic logic and display (see https://velocity.apache.org/engine/1.7/user-guide.html).

Dropdown

  • Static (Default)

  • Velocity

Question

Required

The text entered in this field is displayed as the question with the Group and Section on the Smart Form in the Student Portal.

Textbox

Help Text

Optional

The text entered here will display as help text beneath the question in the Smart Form.

Textbox

Code

Required

The text entered here will be used as a short name to identify the question in the Smart Form Manager.

Textbox

Allows alpha-numeric characters without spaces

Sort Order

Required

The number entered here will be used to sort questions within the Group from the lowest Sort Order to the highest Sort Order.

Numeric

Pre-populate Question Response from

Optional

If ‘Prior Smart Form’ is selected, the question response is pre-populated from the most recently completed Smart Form with the same Smart Form Type, regardless of the FAY scope. If ‘Prior Smart Form with same FAY’ is selected, the question response is pre-populated from the most recently completed Smart Form with the same Smart Form Type and the same FAY scope. If ‘None’ is selected, the question response presented in the Smart Form is not pre-populated.

Dropdown

  • None (Default)

  • Prior Smart Form

  • Prior Smart Form with same FAY

Default Question Response

Optional

The text or input value entered here will be used to pre-populate the response for the question in the Smart Form based on predefined Regent data or one of the available options.

Textbox

Maximum Number of Characters Allowed in Response

Optional

The number entered here will be used to as the limit for the number of characters allowed in the user response for this question when completing the Smart Form.

Numeric

Maximum Characters: 10

Required

Optional

When this field is selected, the question requires a response in the Smart Form. If selected, this question is always displayed if the section and group are displayed and takes precedence over the ‘visible’ setting for the question. If dependency logic is desired for the question, the ‘visible’ setting should be used to display or hide the question from its initial default state.

Checkbox

  • Selected

  • Not Selected (Default)

Visible

Optional

If selected, the Question will be visible by default. If unselected, the Question will not be visible by default. Dependency logic can be used to display or hide the Question from its initial default state.

Checkbox

  • Selected

  • Not Selected (Default)

Read Only

Optional

When this selection is selected, no question options will be required or available.

Checkbox

  • Selected

  • Not Selected (Default)

Questions Additional Information and Advanced Settings

Question Id

A system-generated ID is created and associated when creating a new question.

Created At

This is the date upon which a new question is created.

Modified At

This is the last date upon which a question was modified.

Reset Response if Hidden

Optional

When this field is selected, the question response will revert back to the original default response value (e.g. blank, unselected) if the question is subsequently hidden due to smart logic. For example, if a user answers ‘Yes’ to this question then changes a prior question that forces this question to no longer display, the response value is then reverted back to the original default response value.

Checkbox

  • Selected

  • Not Selected (Default)

Reset Response if Restarted

Optional

When this field is selected, the question response will revert back to the original default response value (e.g. blank, unselected) if the question is subsequently displayed after being hidden due to smart logic.

Checkbox

  • Selected

  • Not Selected (Default)

Auto Capitalize

Optional

When this field is selected, the response will be user response in the Smart Form is automatically updated to all capital letters.

Checkbox

  • Selected

  • Not Selected (Default)

Options Expression

Optional

This field allows an expression to be provided by the user when to display an option under the defined conditions. Expressions use JavaScript language (see https://www.geeksforgeeks.org/javascript-regexpregular-expression/) to perform logical and mathematical operations to determine if the expression is true or false.

Textbox

Secure

Optional

This is a legacy setting and is no longer used.

Checkbox

  • Selected

  • Not Selected (Default)

Dependencies

Smart Forms can be designed to use conditional logic to tailor each question to an individual applicant and minimize the number of questions an applicant is required to answer by using Dependency logic. Dependencies use dynamic logic for Sections, Groups, and Questions to make Visible or hide based on responses to Questions within the Smart Form. Dependencies also control if a Question is Required when made Visible or not. For example, a Dependency can be created to Hide a Question, make a Question Visible and Required, or make a Question Visible and Not Required.

A Section, Group, or Question can have one or more Dependency groups. Each Dependency group is comprised of one or more Dependency rules. Each Dependency group uses a selected Operator Type of ‘AND’ or ‘OR' when evaluating if the Dependency rule(s) are 'true’.

Dependency Comparison Operator

  • The "AND" Compare Operator is used to determine if ALL Dependency Rules are true.

  • The "OR" Compare Operator is used to determine if one or more Dependency Rules are true.

Tip: It's recommended that you set a Section/Groups/Questions visibility to a base visibility, and then only create rules which change the visibility. This way you do not have conflicting dependencies or dependency rules (one rule which makes it hidden, and another rule which makes it visible). If both rules evaluate to true, then it can be more complicated to determine which rules visibility applies. For instance, perhaps you set a Section's visibility to hidden, and then only create dependencies/dependency rules that make it visible. See the "Competing Dependencies Example" in Examples section below.

 Dependency Group Fields

Dependency Group Field Name

Required/Optional

Dependency Group Description

Dependency Group Field Type

Dependency Group Options

Description

Required

This field can be used to describe what all of the rules are intended to determine. For example, a Dependency Group Description may be called, ‘Student is Not Married' while the Dependency Rules are made up of each non-married marital status.

Textbox

Type

Required

This field determines the operator type that is used to evaluate the dependency rules. The ‘And’ operator type is used to determine if all Dependency Rules within the Dependency Group are ‘true’. The ‘Or’ operator type is used to determine if one or more Dependency Rules within the Dependency Group are ‘true’.

Dropdown

  • And

  • Or

 Dependency Rule Fields

Dependency Rule Field Name

Required/Optional

Dependency Rule Description

Dependency Rule Field Type

Dependency Rule Options

Rule Type

Required

  • Question Based

  • Expression Based

Dependent Question

Required

Dropdown

  • All question codes in sequential order within the Smart Form

Question Option

Required

Dropdown

  • All question options configured in sequential order for the selected Question.

Expression

Required

Textbox

Comparison Operator

Required

Dropdown

Required

Optional

Checkbox

Visible

Optional

Checkbox

Dependency Rules Additional Information and Advanced Settings

Rule Id

A system-generated ID is created and associated when creating a new question.

Created At

This is the date upon which a new question is created.

Modified At

Dependency Rules

  • Rules can be a two types: question based or expression based

    • Question based rules are the rules that makes target object dependant of the value of another question in the application.

    • Expression based rules are the rules that are evaluated using an expression provided by the user. This expression is based on the javascript language. A single rule expression can be build on one or more dependent questions using various logical and mathematical operations. Question values are referenced by using the following notation {questionCode}

  • The individual rules have the flags for visible and required. When different rules in the same dependency have different values for those flags, the first rule that is evaluated will trigger, and all subsequent rules in the dependency will be ignored.

  • The dependency rules are evaluated in the order they were added to the database.

  • Every rule has the following information:

    • Comparison operator (=, >, <, >=, <=, !, <>, !=)

      • The symbols "<>" and "!=" are interchangeable operators that mean "not equal".

      • The Exclaimation point means logical not.

    • Dependent question option id

    • Expression

    • Required Flag

    • Visible Flag

  • Rules can be a two types: question based or expression based

    • Question based rules are the rules that makes target object dependant of the value of another question in the application.

    • Expression based rules are the rules that are evaluated using an expression provided by the user. This expression is based on the javascript language. A single rule expression can be build on one or more dependent questions using various logical and mathematical operations. Question values are referenced by using the following notation {questionCode}

    • Logical evaluations can be strung together using logical AND (&&) and logical OR (||).  These kind of conditions allow multiple comparisons to determine the ultimate result of the expression.  The words "AND" and "OR" are interchangeable with "&&" and "||", respectively.

      • SnapUtility.EqualOfAny('hi', 'is', 'hi', 'here') && SnapUtility.IsCurrentDateBefore('01/01/2013') - returns false because both conditions must be true for the expression to be true.

      • SnapUtility.IsCurrentDateBefore('01/01/2013') || SnapUtility.EqualOfAny('hi', 'is', 'hi', 'here') - returns true because at least one of the conditions is true.

    • Several Helper functions are provided:

      • UpperCase - returns string - Converts the argument to UPPER CASE. eg: SnapUtility.UpperCase("upper case") returns "UPPER CASE".

      • Trim - returns string - Removes leading and trailing whitespace.  eg: SnapUtility.Trim("   Hello   ") returns "Hello".

      • TrimUpper - returns string - Performs both UpperCase and Trim commands.

      • EqualOfAny - returns boolean - Performs TrimUpper and checks if the first argument is in the list of remaining arguments (this function is case insensitive).  eg: SnapUtility.EqualOfAny("Hi", "Does", "hi", "exist") returns true.

      • IsNumber - returns number - Checks to see if the first argument is a number.  If it is not, the second argument is returned.  eg: SnapUtility.IsNumber("Dog", -1) returns -1.

      • CheckNumber

      • CompareDate - returns number - Checks to see how two dates compare.  If the first date is after the second date, the function will return a positive number.  If the second date is after the first one, the function will return a negative number.  If the dates are the same, the function will return 0.  If the arguments cannot be resolved to dates, the function returns NaN.  eg: SnapUtility.CompareDate('07/19/2013', '08/01/2013') returns -1.

      • IsCurrentDateBetween - returns boolean - Checks to see if the current date falls in a range (non-inclusive).  eg: SnapUtility.IsCurrentDateBetween('01/01/2013', '01/01/3000') returns true.

      • IsCurrentDateAfter - returns boolean - Checks if the current date falls after a specified date.  eg: SnapUtility.IsCurrentDateAfter('01/01/2013') returns true.

      • IsCurrentDateBefore - returns boolean - Checks if the current date falls before a specified date.  eg: SnapUtility.IsCurrentDateBefore('01/01/2013') returns false.

      • AddDaysToDate - returns Date - Adds a specified number of days to the specified date.  eg: SnapUtility.AddDaysToDate('01/01/2013', 9) returns '01/10/2013'.

    • If a dependant question is hidden (visibleFlag = 0) then the dependency rule is not evaluated and always returns false.

    • For the expression based rules, by placing “@” symbol before the question code in expression points the application to evaluate this question even if it is hidden. (@{studentsMaritalStatus})

    • If one of the dependant questions (in case of an expression based rule) is hidden then the whole expression will not be evaluated.

    • Because visibility / required flags are set on the Rule level it is possible to have one rule which sets something to hidden and another rule which sets something to visible in the same dependency.

      • For AND dependencies, the visibility / required flag of the last rule will be used

      • For OR dependencies, the visibility / reguired flag of the first triggered rule (rule with conditions met) will be used. 

  • If there are multiple Dependencies, each with its own set of Dependency Rules then the following evaluation process will take place:

    • All dependencies and its dependency rules are read from the database in the order they were added.

    • Application starts to evaluate dependency rules

    • Application checks the current rule’s dependant question’s status. If a dependant question is hidden then the rule is ignored.

    • In case of an expression based rule, application checks every question’s status that is met in the expression. If one of the questions is hidden and does not have status ignoring symbol then the whole expression is ignored.

Dependency Examples

  1. /wiki/spaces/SNAP/pages/8716538

Validations

https://velocity.apache.org/engine/1.7/user-guide.html

https://www.geeksforgeeks.org/javascript-regexpregular-expression/

Document Requirement Persistence

  1. Condition (expression) -> an optional javascript expression, similar to dependency / complex validator expressions which can be set. If it's set, the doc req will only attempt to persist if the expression results in true. Will handle {questionCode} formatting. No special logic for whether questions are hidden, visible, etc.

Will handle {questionCode} formatting.

Examples

Example 1
  1. Student starts a Verification Worksheet smart form application.

  2. Student indicates No, I have already filed a tax return SNAP smart form questionnaire.

  3. Student completes and signs their Verification Worksheet.

  4. A 2015 Student Filing Extension Granted by the IRS document requirement is created for the student.

  5. Student starts a Verification Worksheet - Change smart form application.

  6. Student indicates No, I have already filed a tax return.

  7. Student completes and signs their Verification Worksheet.

  8. A 2015 Student Filing Extension Granted by the IRS document requirement does not get created for the student.

Example 2

Given:

  1. Verification Worksheet for FAY

    1. W-2 document, scope uniqueness is turned off in REM

    2. Student selects "Will Not File"

    3. Student indicates that they received a W-2 from Employer 1 and provides information for Employer 1

    4. Student indicates that they received a W-2 from Employer 2 and provides information for Employer 2

When:

  1. Student completes and signs the Verification Worksheet - Change smart form for same FAY

    1. Student selects "Will Note File"

    2. Student indicates that they received a W-2 from Employer 1 and provides information for Employer 1 (Employer A)

    3. Student indicates that they received a W-2 from Employer 2 and provides information for Employer 2 (Employer B)

    4. Student indicates that they received a W-2 from Employer 3 and provides information for Employer 3 (Employer C)

Then:

  1. A new, needed, W-2 document is created in REM, with the reason set to the name of Employer 3 (Employer C)

Example 3

Given:

  1. Verification Worksheet for FAY

    1. W-2 document, scope uniqueness is turned off in REM

    2. Student selects "Will Not File"

    3. Student indicates that they received a W-2 from Employer 1 and provides information for Employer 1 (Employer A)

    4. Student indicates that they received a W-2 from Employer 2 and provides information for Employer 2 (Employer B)

When:

  1. Student completes and signs the Verification Worksheet - Change smart form for same FAY

    1. Student selects "Will Note File"

    2. Student updates the information for Employer 1 to Employer B

    3. Student updates the information for Employer 2 to Employer C

    4. Student deletes the information for Employer 3

Then:

  1. The W-2 for Employer A is waived

  2. The W-2 for Employer B remains unchanged

  3. The W-2 for Employer C is created with a needed status

Example 4

Given:

  1. Verification Worksheet for FAY

    1. W-2 document, scope uniqueness is turned off in REM

    2. Student selects "Will Not File"

    3. Student indicates that they received a W-2 from Employer 1 and provides information for Employer 1 (Employer A)

    4. Student indicates that they received a W-2 from Employer 2 and provides information for Employer 2 (Employer B)

When:

  1. User changes W-2 for Employer A to satisfied in REM

  2. Student completes and signs the Verification Worksheet - Change smart form for same FAY

    1. Student selects "Will Note File"

    2. Student updates the information for Employer 1 to Employer B

    3. Student updates the information for Employer 2 to Employer C

    4. Student deletes the information for Employer 3

    5. REM

Then:

  1. The W-2 for Employer A is unchanged

  2. The W-2 for Employer B remains unchanged

  3. The W-2 for Employer C is created with a needed status

Technical Details

  1. Condition (expression) -> an optional javascript expression, similar to dependency / complex validator expressions which can be set. If it's set, the doc req will only attempt to persist if the expression results in true. Will handle {questionCode} formatting. No special logic for whether questions are hidden, visible, etc.

  2. Match configuration - Capability to create, update, or do nothing if a matched document for the student already exists based on the existing doc requirement status. User can select multiple statuses for update vs create. Status selection will be mutually exclusive (a doc status can only exist in one of the following items):

  3. Update On Match Statuses: (selected document statuses)

  4. Create On Match Statuses: (selected document statuses)

  5. Otherwise ignore

  6. Can configure to create the document if there is no match

  7. Scope: STUDENT or FEDERALAWARDYEAR

  8. Status: NEEDED,SATISFIED,UNSATISFIED,RECEIVED,INCOMPLETE,WAIVED

  9. Status doc will be saved as if the questionnaire is not an esign questionnaire, or it is an esign questionnaire but user did not esign (they paper signed instead)

  10. ESignedStatus: NEEDED,SATISFIED,UNSATISFIED,RECEIVED,INCOMPLETE,WAIVED

  11. Document will be created or updated with this status if it's an ESIGN questionnaire and the user did choose to E-sign

  12. FEDERALAWARDYEAR will be set to Federal Award Year of questionnaire

  13. Supported entry types: AddressRelated, AwardRelated, AuditRelated, COARelated, CODRelated, DisbursementRelated, DocumentRelated, EnrollmentRelated, ISIRRelated, NeedRelated, PLUSRelated, PJRelated, QARelated, ResourceRelated, R2T4Related, SAPRelated, SBLLoad, ServiceRelated, VerificationRelated, CommunicationRelated, Other, ESTRelated, WorkStudyRelated

  14. Attachment Type: None, PdfTemplate, FAFSA

  15. None - no attachment stored in REM

  16. PdfTemplate - Indicates a PDF attachment will be created based on the value of Attachment Template

  17. FAFSA - The standard Dept. Of Ed. FAFSA (that matches fed award year of questionnaire) will be pre-populated from the SNAP questionnaire.

10. Attachment File Name: string of file name as stored in REM

11. Attachment Template - string field which will take a named velocity template. Note - this velocity template MUST exist in the theme the questionnaire is processed with, otherwise an "Template 'templatename' does not exist." error will be thrown at time of application processing.

  1. Notes about fields which are not configurable

  2. Letter correspondence date -> ignored by snap

  3. Email correspondence date -> ignored by snap

  4. Activity Source Type - STUDENTACTION always used

  5. Message - will use the message as set up in REM document setup

  6. Reason - will use the reason as set up in REM document setup

  7. Received Date - Will rely on REM services automatically setting to current datetime if existing received date is null (or we are creating doc) and status is RECEIVED or SATISFIED

  8. Reviewed Date - Will rely on REM services automatically setting to current datetime if existing reviewed date is null (or we are creating doc) and status is SATISFIED

  9. This configuration will be included in when a questionnaire is copied, exported, or imported.

  10. EFAFSA:

  11. Will persist as the current EnableEFAFSAPersistence configuration setting dictates (which can be scoped for the whole snap instance, or scoped to questionnaire which takes precedence)

  12. Student demographic fields: These will be handled in another JIRA issue to facilitate testing

  13. Management screens in SNAP admin pages (Persistence link/button on questionnaire detail page).

Related Tickets

SNAP-2899 - SNAP questionnaires can be configured to persist document requirements to REM upon app completion

Student Portal: Create new function for Document Requirement Persistence (DRP) Reason Expression

Expressions

When configuring a DRP, the ‘Name’ must match the name of the document configured in Document Setup. Use caution when Document Names have special characters such as an apostrophe or dash that it is using the identical Document Name and has not been updated by the editor. If no match is found to an existing Document Name configured when executing the DRP expression, an error message is displayed, ‘Document name of <Document Name> is not found'.

Shortkeys:

 Shortkeys

Shortcut Name

Description

  • {fay)

  • Automatically inserts the Federal Award Year of the Smart Form (e.g. 2024-2025).

  • {YearDescription}

Name of smart form

  • {YearCode}

This returns the a special int which is essentially (max year of FAY)-2010. So for 2018-2019 FAY, the year code would be 9.

  • {InstitutionExternalId}

  • {LocationName}

This is legacy shortcut that is no longer used.

  • {LocationExternalId}

This is legacy shortcut that is no longer used.

  • {CampusName}

  • {CampusExternalId}

  • {SiteName}

  • {SiteExternalId}

  • {ProgramName}

  • {ProgramExternalId}

  • {ProgramType}

Helper Functions

  • UpperCase - returns string

  • returns string - Converts the argument to UPPER CASE. eg: SnapUtility.UpperCase("upper case") returns "UPPER CASE".

  • Trim

  • returns string - Removes leading and trailing whitespace.  eg: SnapUtility.Trim("   Hello   ") returns "Hello".

  • EqualOfAny

  • returns boolean - Performs TrimUpper and checks if the first argument is in the list of remaining arguments (this function is case insensitive).  eg: SnapUtility.EqualOfAny("Hi", "Does", "hi", "exist") returns true.

  • IsNumber

  • returns number - Checks to see if the first argument is a number.  If it is not, the second argument is returned.  eg: SnapUtility.IsNumber("Dog", -1) returns -1.

  • CheckNumber

  • CompareDate

  • returns number - Checks to see how two dates compare.  If the first date is after the second date, the function will return a positive number.  If the second date is after the first one, the function will return a negative number.  If the dates are the same, the function will return 0.  If the arguments cannot be resolved to dates, the function returns NaN.  eg: SnapUtility.CompareDate('07/19/2013', '08/01/2013') returns -1.

  • IsCurrentDateBetween

  • returns boolean - Checks to see if the current date falls in a range (non-inclusive).  eg: SnapUtility.IsCurrentDateBetween('01/01/2013', '01/01/3000') returns true.

  • IsCurrentDateBefore

  • returns boolean - Checks if the current date falls before a specified date.  eg: SnapUtility.IsCurrentDateBefore('01/01/2013') returns false.

  • AddDaysToDate

  • - returns Date - Adds a specified number of days to the specified date.  eg: SnapUtility.AddDaysToDate('01/01/2013', 9) returns '01/10/2013'.

When configuring a DRP, the ‘Name’ must match the name of the document configured in Document Setup. Use caution when Document Names have special characters such as an apostrophe or dash that it is using the identical Document Name and has not been updated by the editor. If no match is found to an existing Document Name configured when executing the DRP expression, an error message is displayed, ‘Document name of <Document Name> is not found'.

Logical operators, such as, AND (&&), and OR (||) may be used in combination with built-in expressions, such as, SnapUtility.EqualOfAny, and SnapUtility.ReasonEqualToAny. The SnapUtility.ReasonEqualToAny is a special function that can not be used in combination with other expressions and will perform the requested action on existing, student documents where the document reason matches any of the values provided to the function.

Shortkeys:

 Shortkeys

Shortcut Name

Description

  • {fay)

  • Automatically inserts the Federal Award Year of the Smart Form (e.g. 2024-2025).

  • {YearDescription}

Name of smart form

  • {YearCode}

  • This returns a special int which is essentially (max year of FAY)-2010. So for 2018-2019 FAY, the year code would be 9.

  • {InstitutionExternalId}

  • {LocationName}

legacy

  • {LocationExternalId}

legacy

  • {CampusName}

  • {CampusExternalId}

  • {SiteName}

  • {SiteExternalId}

  • {ProgramName}

  • {ProgramExternalId}

  • {ProgramType}

Helper Functions

  • UpperCase - returns string

  • returns string - Converts the argument to UPPER CASE. eg: SnapUtility.UpperCase("upper case") returns "UPPER CASE".

  • Trim

  • returns string - Removes leading and trailing whitespace.  eg: SnapUtility.Trim("   Hello   ") returns "Hello".

  • EqualOfAny

  • returns boolean - Performs TrimUpper and checks if the first argument is in the list of remaining arguments (this function is case insensitive).  eg: SnapUtility.EqualOfAny("Hi", "Does", "hi", "exist") returns true.

  • IsNumber

  • returns number - Checks to see if the first argument is a number.  If it is not, the second argument is returned.  eg: SnapUtility.IsNumber("Dog", -1) returns -1.

  • CheckNumber

  • CompareDate

  • returns number - Checks to see how two dates compare.  If the first date is after the second date, the function will return a positive number.  If the second date is after the first one, the function will return a negative number.  If the dates are the same, the function will return 0.  If the arguments cannot be resolved to dates, the function returns NaN.  eg: SnapUtility.CompareDate('07/19/2013', '08/01/2013') returns -1.

  • IsCurrentDateBetween

  • returns boolean - Checks to see if the current date falls in a range (non-inclusive).  eg: SnapUtility.IsCurrentDateBetween('01/01/2013', '01/01/3000') returns true.

  • IsCurrentDateBefore

  • returns boolean - Checks if the current date falls before a specified date.  eg: SnapUtility.IsCurrentDateBefore('01/01/2013') returns false.

  • AddDaysToDate

  • - returns Date - Adds a specified number of days to the specified date.  eg: SnapUtility.AddDaysToDate('01/01/2013', 9) returns '01/10/2013'.

  • No labels