Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

check tool: update 'errors' page design & content #640

Merged
merged 30 commits into from
Dec 4, 2024

Conversation

rosado
Copy link
Collaborator

@rosado rosado commented Nov 8, 2024

What type of PR is this?

  • Feature

Description

Update content & design elements of the check tool's "you've got errors" page.

Related Tickets & Documents

QA Instructions, Screenshots, Recordings

For cases where the LPA name is not available (e.g. we have not arrived via deep link) the text at the bottom defaults to "How to improve the data".

image

But when the accessing the check tool via a deep link we can see the LPA's name:

image

Added/updated tests?

We encourage you to keep the code coverage percentage at 80% and above.

  • Yes

Summary by CodeRabbit

Release Notes

  • New Features

    • Enhanced error summary presentation with a structured format, improving clarity for users.
    • Updated button text from "Upload a new version" to "Check your data" to better reflect functionality.
    • Introduced guidance for users on improving data quality with actionable steps.
    • Added a back navigation option on the status page for improved user experience.
    • Implemented functionality to track the last page visited by users.
    • Added a new back link on the confirmation page for easier navigation.
    • Streamlined map display in the no-errors template for clearer information presentation.
    • Improved readability of dataset names in the dataset banner.
  • Bug Fixes

    • Improved error message handling to ensure accurate display and processing of error summaries.
  • Documentation

    • Added JSDoc comments for methods to clarify functionality and expected outputs.
  • Tests

    • Refined test cases to validate the new error summary structure and ensure robust error handling.
    • Updated tests to reflect changes in error handling and template structure.

This comment was marked as resolved.

Copy link

github-actions bot commented Nov 8, 2024

Coverage Report

Status Category Percentage Covered / Total
🔵 Lines 70.19% 5109 / 7278
🔵 Statements 70.19% 5109 / 7278
🔵 Functions 66.99% 203 / 303
🔵 Branches 83.22% 650 / 781
File Coverage
File Stmts Branches Functions Lines Uncovered Lines
Changed Files
src/content/statusPage.js 100% 100% 100% 100%
src/controllers/resultsController.js 88.29% 95.23% 100% 88.29% 45-53, 80-81
src/controllers/statusController.js 78.04% 50% 100% 78.04% 15-20, 32-34
src/models/requestData.js 100% 100% 100% 100%
Generated in workflow #429 for commit d1f8aa5 by the Vitest Coverage Report Action

@rosado rosado marked this pull request as ready for review November 12, 2024 09:43
Copy link
Contributor

@coderabbitai coderabbitai bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Actionable comments posted: 2

🧹 Outside diff range and nitpick comments (4)
src/views/check/results/errors.html (1)

70-79: Clear and well-structured guidance section!

The conditional heading and step-by-step instructions are clear. Consider adding a brief explanation of what the specifications contain to help users understand why they're useful.

 <ol class="govuk-list govuk-list--number">
-      <li>Fix the errors indicated. You should use the <a href="/guidance/specifications/">data specifications</a> to help you do this.</li>
+      <li>Fix the errors indicated. Use the <a href="/guidance/specifications/">data specifications</a> (which contain detailed rules and examples) to help you do this.</li>
       <li>Check your updated data to make sure it meets the specifications.</li>
 </ol>
src/models/requestData.js (1)

Line range hint 35-83: Consider refactoring error handling for better maintainability

The class currently has multiple methods handling different aspects of errors (getErrorSummary, hasErrors, getError), each with its own null checks and logging. This could be simplified and made more maintainable.

Consider:

  1. Creating a central error handling utility
  2. Using TypeScript or JSDoc types more extensively for better type safety
  3. Implementing a consistent pattern for null checks and logging

Here's a suggested approach:

/**
 * @typedef {Object} ErrorState
 * @property {boolean} hasErrors
 * @property {string[]} summary
 * @property {Object} details
 */

/**
 * Centralised error handling
 * @returns {ErrorState}
 */
getErrorState() {
  if (!this.response?.data) {
    logger.warn('No response data available', { requestId: this.id });
    return {
      hasErrors: true,
      summary: [],
      details: { message: 'An unknown error occurred.' }
    };
  }

  return {
    hasErrors: Array.isArray(this.response.data['error-summary']) && 
               this.response.data['error-summary'].length > 0,
    summary: this.response.data['error-summary'] || [],
    details: this.response.error || {}
  };
}
src/controllers/resultsController.js (1)

Line range hint 1-95: Consider architectural improvements for error handling

The error handling flow could benefit from the following improvements:

  1. Document the different error states and their implications
  2. Consider extracting the error processing logic into a dedicated service
  3. Add TypeScript or JSDoc type definitions for error structures

Example type definitions:

/**
 * @typedef {Object} ErrorSummaryItem
 * @property {string} text - The error message
 * @property {string} href - Link to the error location
 */

/**
 * @typedef {Object} ErrorResponse
 * @property {ErrorSummaryItem[]} errorSummary
 * @property {Object} tableParams
 * @property {Object} mappings
 */
test/integration/test_recieving_results.playwright.test.js (1)

Line range hint 63-67: Fix incorrect array iteration syntax

The current implementation has two issues:

  1. Using for...in with arrays is incorrect as it iterates over all enumerable properties
  2. The destructuring syntax with for...in is invalid

Apply this fix to correctly iterate over the array with indices:

- for (const [index, issuesForRow] in issues) {
-   for (const issue in issuesForRow) {
-     await expect(page.locator('.govuk-table').locator('tr').nth(parseInt(index) + 1)).toContainText(prettifyColumnName(issue))
-   }
- }
+ for (const [index, issuesForRow] of issues.entries()) {
+   for (const issue of issuesForRow) {
+     await expect(page.locator('.govuk-table').locator('tr').nth(index + 1)).toContainText(prettifyColumnName(issue))
+   }
+ }

This change:

  • Uses for...of with entries() for proper array iteration
  • Removes unnecessary parseInt as index is already a number
  • Correctly iterates over the issues array
📜 Review details

Configuration used: CodeRabbit UI
Review profile: CHILL

📥 Commits

Reviewing files that changed from the base of the PR and between 2e993a7 and e67e730.

📒 Files selected for processing (7)
  • src/controllers/resultsController.js (1 hunks)
  • src/models/requestData.js (1 hunks)
  • src/views/check/results/errors.html (3 hunks)
  • test/PageObjectModels/resultsPage.js (1 hunks)
  • test/integration/test_recieving_results.playwright.test.js (1 hunks)
  • test/unit/errorsPage.test.js (3 hunks)
  • test/unit/resultsController.test.js (1 hunks)
🔇 Additional comments (10)
src/views/check/results/errors.html (2)

7-7: Good addition of the GOV.UK error summary component!

This import enables the use of the standardised error summary component, which improves accessibility and maintains consistency with GOV.UK design patterns.


82-82: Good improvement to the button text!

The new text "Check your data" is more accurate and better describes the next action in the user journey.

src/models/requestData.js (1)

35-38: Review return type documentation for consistency

The JSDoc comment indicates that getErrorSummary returns string[], but according to the AI summary, these error summaries are being transformed into objects with text and href properties in the ResultsController. This suggests a potential disconnect between the documented return type and how the data is actually being used.

Consider either:

  1. Updating the return type documentation to reflect the actual structure needed by consumers
  2. Or documenting that the strings returned by this method require transformation before use

Let's verify how this method is used:

src/controllers/resultsController.js (2)

67-72: 🛠️ Refactor suggestion

Consider implementing proper href values for error summary links

The empty href values might affect accessibility and user navigation. Each error summary item should ideally link to the corresponding error location on the page.

Consider this implementation:

 req.form.options.errorSummary = requestData.getErrorSummary().map(message => {
   return {
     text: message,
-    href: ''
+    href: `#error-${message.toLowerCase().replace(/\s+/g, '-')}`
   }
 })

Let's verify the error summary structure and its usage:


Line range hint 1-95: Verify integration with LPA name display functionality

The PR objectives mention LPA name display variations. Ensure this controller properly handles both scenarios:

  1. Default text when LPA name is unavailable
  2. LPA name display when accessed via deep link

Let's verify the LPA name handling:

✅ Verification successful

LPA name handling is correctly implemented through deep link context

The verification shows that:

  • LPA name (organisation name) is properly handled in both error and no-error templates (src/views/check/results/errors.html and src/views/check/results/no-errors.html)
  • The deep link context is correctly passed through PageController which sets options.deepLink containing the organisation name
  • The templates appropriately handle both scenarios:
    • Show default text when LPA name is unavailable
    • Display LPA name when provided via deep link

The implementation in ResultsController inherits this functionality from PageController and doesn't need additional LPA name handling logic.

🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Check how LPA name is processed across the codebase
rg -A 5 'getLpaName|lpaName' src/

# Check for deep link handling
rg -A 5 'isDeepLink|deepLink' src/

Length of output: 4204


Script:

#!/bin/bash
# Check for LPA name handling in the request data model
ast-grep --pattern 'class $_ {
  $$$
  getLpaName() {
    $$$
  }
  $$$
}'

# Check for LPA name handling in templates
rg -l 'lpa.*name|orgName' src/views/

# Check for deep link data structure in the request model
ast-grep --pattern 'class $_ {
  $$$
  getDeepLinkData() {
    $$$
  }
  $$$
}'

Length of output: 272

test/unit/errorsPage.test.js (2)

55-55: Well-structured error summary implementation

The transformation of error messages into objects with text and href properties is cleanly implemented. The test properly validates the new structure whilst maintaining existing functionality.

Also applies to: 74-74


40-45: Query: Should href be empty?

The summaryItem function creates objects with an empty href property. Consider whether these error messages should link to specific sections of the form or documentation.

✅ Verification successful

Empty href is correct in error summary items

The empty href in the summaryItem function is the correct implementation. The GOV.UK error summary component is being used across multiple templates (src/views/**/*.html), and these templates import the error summary macro without requiring href values. The error summary is used to display validation messages at the top of the page without needing to link to specific form sections.

🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Check if hrefs are used in the error templates
rg -g '*.html' -A 5 'govuk-error-summary__list'

Length of output: 47


Script:

#!/bin/bash
# Let's check for error summary implementations in views and templates with different extensions
rg -t html -t njk -t nunjucks -A 5 'govuk-error-summary'

# Also check the controller/page implementation to understand the href usage
ast-grep --pattern 'summaryItem = $_'

Length of output: 124


Script:

#!/bin/bash
# Search for error summary implementations in views directory
rg -g '*.{html,nunjucks}' -A 5 'error-summary'

# Check the controller implementation for error handling
rg -g '*.js' -A 5 'summaryItem'

# Look for any error-related templates
fd . -e html -e nunjucks --exec grep -l "error"

Length of output: 8249

test/integration/test_recieving_results.playwright.test.js (1)

44-44: Good improvement to selector specificity!

The change to use ul.govuk-list instead of a general text locator makes the test more robust and less prone to false positives.

test/unit/resultsController.test.js (2)

Line range hint 1-214: Test coverage looks comprehensive

The test suite thoroughly covers various scenarios:

  • Error and no-error states
  • Failed file and URL requests
  • Request completion status
  • Error handling (404, 500)
  • Template selection logic
  • Data transformation

Well structured and maintainable test cases.


139-139: Verify error summary href implementation

The test shows that href is always set to an empty string. If this is intentional, consider adding a test case that explicitly verifies this behaviour. If not, we might need tests for scenarios where href should contain a value.

✅ Verification successful

Let me search for more context about error summary implementation.


Empty href in error summary is correct implementation

The empty href is intentional and aligns with the implementation in resultsController.js. The controller explicitly sets empty hrefs when mapping error messages:

errorSummary = requestData.getErrorSummary().map(message => {
  return {
    text: message,
    href: ''
  }
})

This is used with the GOV.UK Design System's error summary component, which allows optional hrefs for cases where error messages don't need to link to specific form fields.

🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Search for href usage in error summaries across the codebase
rg -A 3 'errorSummary.*href'

# Check if there are any error summary components that might expect href values
ast-grep --pattern 'errorSummary.*href'

Length of output: 391


Script:

#!/bin/bash
# Search for error summary usage and structure in the codebase
rg -g '!test/**' 'errorSummary' -A 3

# Look for error summary component or type definitions
fd -e ts -e js -e jsx -e tsx . | xargs rg 'interface.*ErrorSummary|type.*ErrorSummary|class.*ErrorSummary'

# Search for GDS error summary component imports or usage
rg "import.*ErrorSummary|require.*ErrorSummary"

Length of output: 2496

test/PageObjectModels/resultsPage.js Show resolved Hide resolved
src/views/check/results/errors.html Show resolved Hide resolved
@alextea
Copy link
Contributor

alextea commented Nov 13, 2024

The error summary table should use the error messages from this file: https://github.com/digital-land/submit/blob/main/src/content/fieldIssueMessages.csv

Can we any numerical or date columns use the govuk-table__cell--numeric class (George implemented this on the dataset table view)

@rosado
Copy link
Collaborator Author

rosado commented Nov 13, 2024

The error summary table should use the error messages from this file: https://github.com/digital-land/submit/blob/main/src/content/fieldIssueMessages.csv

Those messages come from external service in the form of those strings. We can't look them up in the mentioned table.

Copy link
Contributor

@DilwoarH DilwoarH left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Code looks good - have design and product signed off?

@eveleighoj eveleighoj temporarily deployed to submit-pr-640 December 4, 2024 13:33 Inactive
@rosado
Copy link
Collaborator Author

rosado commented Dec 4, 2024

Code looks good - have design and product signed off?

Thank. And yep, via slack thread.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants