diff --git a/src/_patterns/help-users-to/stay-informed-of-their-application-status.md b/src/_patterns/help-users-to/stay-informed-of-their-application-status.md index e25f32177..cd6cc0ffd 100644 --- a/src/_patterns/help-users-to/stay-informed-of-their-application-status.md +++ b/src/_patterns/help-users-to/stay-informed-of-their-application-status.md @@ -1,9 +1,9 @@ --- layout: pattern -title: Stay informed of their application status +title: Stay informed of their form submission status permalink: /patterns/help-users-to/stay-informed-of-their-application-status sub-section: help-users-to -intro-text: "Follow this pattern to notify users when their request is submitted, received, and has hit an error. These are required notification touch points." +intro-text: "Follow this pattern to notify people when their online form submission is in progress, when we receive their submitted form, and when a system error has caused the submission to fail. These are required notification touch points." status: use-with-caution-candidate research-title: Help users to stay informed of app status anchors: @@ -17,68 +17,84 @@ anchors: ### When to use this pattern -* **Any application that takes data from a user and submits that data to a back-end system.** This pattern is widely applicable to any application or service that accepts users data and submits that data, synchronously or asynchronously, to a system of record. It is a requirement that we notify the user at critical touch points as their request is processed. - +* **Any online form that takes data from someone and submits that data to a back-end system.** This pattern is widely applicable to any online form that accepts someone's data and submits that data, synchronously or asynchronously, to the system of record. We're required to notify that person at critical touch points in the submission process. ## Examples ### Email notifications -{% include component-example.html alt="Screen shots of 3 email templates." file="/images/patterns/help-users-to/stay-informed-of-their-application-status/email-templates.png" caption="Three templates for email notification touch points sent via VA Notify." class="x2" %} +We'll add examples of these notifications soon. If you need examples now, contact #sitewide-content-accessibility-ia. -### Status in MyVA +### Form submission status in My VA -{% include component-example.html alt="Screen shots of 3 MyVA status cards." file="/images/patterns/help-users-to/stay-informed-of-their-application-status/myva-status-cards.png" caption="Three Card component variations used to convey status of a user's submission in MyVA for Benefits applications." reverse="true" %} +{% include component-example.html alt="Screen shots of 3 My VA status cards." file="/images/patterns/help-users-to/stay-informed-of-their-application-status/myva-status-cards.png" caption="Three Card component variations used to show the status of someone's submission in My VA for Benefits applications." reverse="true" %} ## How to design and build -### Email notification touch points +### Sending email notifications + +#### For synchronous submissions + +If there’s no lag time between when someone submits a form and when we receive it—the form was received in the system of record in time for us to show a success message on the confirmation page—then we consider it a synchronous form. In this case, you need to implement only one email notification: -When a request reaches these 3 touch points the user must be notified via email: +1. **Received**: The notification when we've received a submitted form in the system of record. This means the form is ready for processing. **Only send this status notification when we have confirmation that the request has reached the system of record.** -1. **Submission in progress**: The status immediately after a user clicks "submit" on a form. This is the period between the submission and when that submission reaches a system of record. During this time, data submitted by the user may travel through several systems. - * **Not required for synchronous status.** This touch point is only necessary if the user's data submission is being handled asynchronously. If you can synchronously confirm that the user's data has reached the system of record immediately then you can skip this status notification. -2. **Received**: The status when a request has arrived in the system of record. From there it can be worked on and ultimately completed. **This status notification must not be sent unless we have confirmation that the request has reached the system of record.** -3. **Action needed:** The status which informs the user that their request has failed as it has not reached the system of record. This status may be accompanied by directions for re-submission or directions to call our call center for help. +**Note:** The reason you don't need "Action needed" notifications for synchronous submissions is that you show the person the error message in the form itself. If form submission can fail after the person gets a success message on the form confirmation page, your form has asynchronous submissions and you need to implement 3 email notifications. + +Submit a [VA Notify intake ticket](https://github.com/department-of-Veterans-affairs/va.gov-team/issues/new?assignees=christy-tongty%2C+mjones-oddball%2C+GitSamJennings&labels=vanotify-intake&template=VANotify-Business-Intake.md&title=Business+intake+form+for+%5BBusiness+or+team%5D) to start the process of activating email notifications for your application. + +#### For asynchronous submissions + +If there's a lag time between when someone submits the form and when VA receives it in the system of record, you must implement these 3 email notifications: + +1. **Submission in progress**: The notification we send immediately after someone selects the **Submit** button on an online form. This means that the form submission has successfully started, but it has not yet reached the system of record. During this time, data submitted by the person may travel through several systems. +2. **Received**: The notification we send when we've received a submitted form in the system of record. This means the form is ready for processing. **Only send this status notification when we have confirmation that the request has reached the system of record.** +3. **Action needed:** The error notification we send if a form submission fails to reach the system of record. This means we need the person to resubmit or take another action before we can process their form. This notification must include instructions for the person to recover from the error. Submit a [VA Notify intake ticket](https://github.com/department-of-Veterans-affairs/va.gov-team/issues/new?assignees=christy-tongty%2C+mjones-oddball%2C+GitSamJennings&labels=vanotify-intake&template=VANotify-Business-Intake.md&title=Business+intake+form+for+%5BBusiness+or+team%5D) to start the process of activating email notifications for your application. #### Protecting PII & PHI in notifications -* **Do NOT send PII or PHI in notifications.** It is imperative that notifications not include any PII or PHI. -* **Obfuscate filenames.** File names for evidence and other uploads of documents to the VA can often include personal information. Thus we obfuscate all filenames in notifications. To do this: +* **Do not send personally identifiable information (PII) or protected health information (PHI) in notifications.** It's imperative that notifications do not include any PII or PHI. +* **Hide filenames.** File names for evidence and other uploads of documents to the VA can often include personal information. So we hide all filenames in notifications. To do this: * Replace all but the first 3 and last 2 characters (numbers or letters) of the filename with the "X" character. - * Show the MIME type of the file (e.g. ".png", ".pdf", etc.) + * Show the MIME type of the file (like ".png", ".pdf", etc.) + +### Showing form submission status on the form confirmation page -### Showing status in MyVA for Benefits applications +#### For synchronous submissions -Submissions to the VA made via VA.gov or the mobile app must show the status of a request in MyVA such that authenticated users can see the status of any and all submissions. MyVA includes several sections where status can be conveyed: +If there's no lag time between when someone submits the form and when VA receives it in the system of record, do these 2 things on your form confirmation page: +- Show a success message confirming that the submission was successful and we've received the form, like "You've submitted your form" +- In the **What to expect** section, tell the person about the next notification we'll send (in this case, that should be an email confirming we've received their form) -* Claims and appeals -* Health care -* Outstanding debts -* Benefit payments -* Benefit applications and forms +#### For asynchronous submissions -#### Claims and appeals +If there's a lag time between when someone submits the form and when VA receives it in the system of record, do these 2 things on the form confirmation page: +- Show a success message confirming only that the submission is in progress, like "Your form submission is in progress" — and explain that we'll send an email to confirm when we've received the form and an estimate for how long that will take +- In the **What to expect** section, tell the person about the next notifications we'll send (in this case, an email confirming the submission is in progress and then a second email confirming when we've received their form) -Obtains status from the Claims Status Tool. +### Showing form submission status in My VA -#### Benefit applications and forms +Form submissions on VA.gov or in the mobile app must show the submission status in My VA for people who are authenticated. These statuses appear in the **Benefit applications and forms** section of My VA. This section currently gets statuses from the [Lighthouse Benefits Intake API](https://developer.va.gov/explore/api/benefits-intake) polling mechanism for submissions processed asynchronously. -Currently obtains status from the [Lighthouse Benefits Intake API](https://developer.va.gov/explore/api/benefits-intake) polling mechanism for submissions processed asynchronously. +Some forms also show a "received" status in the **Claims and appeals** section of My VA. If your form appears as a claim, decision review, or appeal in the claim status tool, work with the team that manages that tool to determine how and where you should show form submission status in My VA. + +### Showing form processing status after we receive it in the system of record + +Some forms show processing status after point of receipt in the claim status tool. In the future, all forms should work toward allowing people to track the processing status through to the point of a VA decision or other ultimate end point. ### How this pattern works -Communicating status of a request has three critical phases that all teams must account for in their applications: +Communicating form submission status has 3 critical phases that all teams must account for in their online forms: -1. **Status notification via email or text.** -2. **Status notification in the user interface of VA.gov and the flagship mobile app.** -3. **Providing a clear next step in the event of an error.** +1. **Status notification via email or text** +2. **Status notification in the user interface of VA.gov and the flagship mobile app** +3. **A clear next step in the event of an error** #### How to provide a clear next step in the event of an error -In the event of an error, an application may determine the next logical step a user can take to remedy that error. At the very least users must be notified that they can contact the Call Center in the event of a submission failure. +Every time a form submission error happens, you must notify the person about that error and provide a recovery step. At the very least, tell people to contact the Call Center. ### Components used in this pattern @@ -87,20 +103,6 @@ In the event of an error, an application may determine the next logical step a u ### Page templates available for this pattern -* [Email templates are available in VA Notify](https://notifications.va.gov/information/emails). [VA.gov email templates](https://notifications.va.gov/services/5bda137e-689e-4532-b3d2-2c81c0324331/templates) are available if you have access to that workspace. - * NOTE: You must have a VA Notify account to access these templates. +* [Email templates are available in VA Notify](https://staging.notifications.va.gov/). You'll need a VA Notify account to access the sample templates. Select a service. If you're not assigned to a service contact # va-notify-public. Select **Add template**. Then select **Sample templates**. +* The sample email templates include customizable content you'll need to fill in for your form. Try to use as much of the template content as possible and only adjust where needed. If you have questions or need help adjusting the templates for your form, you can contact #sitewide-content-accessibility-ia * Email templates must be reviewed by a VA Privacy Officer in the appropriate portfolio (VBA or VHA). - -## Examples in production - -### Claim status - -{% include component-example.html alt="An example of the track your claims page." file="/images/patterns/help-users-to/stay-informed-of-their-application-status/track-your-claims.png" caption="The Claim Status Tool uses Cards that provide details on the current step of the process." class="x2" %} - -### Decision letter - -{% include component-example.html alt="An example of a claim status card that shows the ability to download a decision letter" file="/images/patterns/help-users-to/stay-informed-of-their-application-status/decision-letter-status-card.png" caption="This claim Card component provides a status of the claim and indicates that a decision letter is available for download." class="x2" %} - -### Certificate of eligibility - -{% include component-example.html alt="An example of the Certificate of eligibility status page." file="/images/patterns/help-users-to/stay-informed-of-their-application-status/COE-automatic-download-page.png" caption="The Certificate of eligibility uses an Alert component on the confirmation page to show status of a synchronous request." class="x2" %}