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

VACMS-19386 Add Checklist template #796

Closed
wants to merge 51 commits into from
Closed
Show file tree
Hide file tree
Changes from 49 commits
Commits
Show all changes
51 commits
Select commit Hold shift + click to select a range
3225a28
VACMS-19386 Checklist template migration
randimays Oct 4, 2024
eb4da29
Adding more types and finishing query for checklist
randimays Oct 7, 2024
aa9c573
Adding imports to get the page to load
randimays Oct 8, 2024
592650c
Removed unused Link custom component; added secondaryButtonGroup for …
randimays Oct 8, 2024
3aa9e8d
Adding secondary button group component for CTAs
randimays Oct 8, 2024
212d3d1
Add optional intro
randimays Oct 9, 2024
c75922c
Trying to get the nested checklist paragraph to work
randimays Oct 10, 2024
b0cca8a
Got checklist data fetching properly
randimays Oct 10, 2024
dac3b6c
Adding more content for checklist page
randimays Oct 10, 2024
8ec1f03
Adding some Medallia code
randimays Oct 14, 2024
cc9d385
Updating design system, fixing tags issues, still working on web comp…
randimays Oct 15, 2024
2eba58d
Adding related information shared component
randimays Oct 15, 2024
133a289
Added benefit hubs links
randimays Oct 15, 2024
20347d4
Tweaks to tags for styling. Add next-template data to all things in t…
randimays Oct 16, 2024
5928f6a
A few more updates for data- attributes
randimays Oct 16, 2024
06c3fe2
Updating responsive behavior in the contentFooter
randimays Oct 16, 2024
d36d584
Adding mock and tests for data query
randimays Oct 16, 2024
926ef0b
One more data query test update
randimays Oct 16, 2024
bb8e37e
Adding tests for checklist item and updating plop test template
randimays Oct 16, 2024
ee16a56
Checklist item test adjustment
randimays Oct 16, 2024
02c55a1
Remove unneeded files
randimays Oct 16, 2024
dcc8ac9
Adding and updating unit tests
randimays Oct 17, 2024
7cf319a
Update unit tests
randimays Oct 17, 2024
ff33e5b
More unit test tweaks
randimays Oct 17, 2024
9e58253
Adding/updating more unit tests
randimays Oct 17, 2024
5b5637c
Removing storybook files
randimays Oct 17, 2024
2bf8399
Fixing type errors
randimays Oct 18, 2024
40157d9
Fixing more type errors
randimays Oct 18, 2024
8ac0798
Adding playwright test
randimays Oct 18, 2024
128b623
Adding back props that were removed in NodeAbstractResource
randimays Oct 18, 2024
5f85b20
Revert Taxonomy Term to former structure (empty)
randimays Oct 18, 2024
f19fe3d
Trying to revert dependency updates
randimays Oct 18, 2024
fa38520
Fixing some typescript issues
randimays Oct 22, 2024
6b2d6bd
More types fixes
randimays Oct 24, 2024
2cb0cca
Updating types
randimays Oct 25, 2024
9366f3f
Fixing types for contact info
randimays Oct 25, 2024
5301629
Refactor related information component to be shared
randimays Oct 25, 2024
daa4ff0
Consolidated shared related links component, fix more types
randimays Oct 28, 2024
24d049a
Consolidated shared related links component, fix more types
randimays Oct 28, 2024
3492e82
Fixing more types in the tests
randimays Oct 28, 2024
03c3d93
Fixed all the types
randimays Oct 29, 2024
0fec3be
Fixing some tests and errors
randimays Oct 29, 2024
800b76e
Reverting API playground
randimays Oct 29, 2024
84c218b
Updating design library dependencies
randimays Oct 29, 2024
661a94f
Fixing some tests
randimays Oct 29, 2024
ff5f227
Prettier formatting
randimays Oct 29, 2024
80aed79
Updating snapshots
randimays Oct 29, 2024
88a7bf1
Fixing test
randimays Oct 29, 2024
af3975a
Remove next component data attributes
randimays Oct 31, 2024
9969f6f
Upgrading design system dependencies again
randimays Nov 13, 2024
615cede
Update Tugboat README
randimays Nov 13, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
925 changes: 925 additions & 0 deletions .yarn/releases/yarn-4.5.0.cjs

Large diffs are not rendered by default.

4 changes: 3 additions & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -34,7 +34,9 @@ You should set these up before attempting to install the repo.

7. In the `next-build` directory, run `yarn setup` to pull initial built assets from the `vets-website` repo. This will grab a bunch of files from a vets-website S3 bucket and place them into the appropriate `public/` folders.

8. Run `yarn dev`.
8. In your `envs/.env.local` file, uncomment `FEATURE_NEXT_BUILD_CONTENT_ALL=true`.

9. Run `yarn dev`.

You will now have a Next.js development server running at http://localhost:3999, which will refresh with changes to your local environment. (Note: your local port may differ if you changed the value for `PORT` in .env.local).

Expand Down
17 changes: 11 additions & 6 deletions additional.d.ts
Original file line number Diff line number Diff line change
Expand Up @@ -16,20 +16,25 @@ declare module '@department-of-veterans-affairs/component-library/Modal'
declare module '@department-of-veterans-affairs/component-library/Pagination'
declare module '@department-of-veterans-affairs/component-library/ProgressButton'
declare module '@department-of-veterans-affairs/component-library/PromoBanner'
declare module '@department-of-veterans-affairs/component-library/VaRadio'
declare module '@department-of-veterans-affairs/component-library/VaRadioOption'
declare module '@department-of-veterans-affairs/component-library/dist/react-bindings'
declare module 'mq-polyfill'
declare module 'debug'

declare namespace JSX {
interface IntrinsicElements {
'va-alert'
'va-link'
'va-icon'
'va-button'
'va-breadcrumbs'
'va-accordion'
'va-accordion-item'
'va-on-this-page'
'va-alert'
'va-back-to-top'
'va-breadcrumbs'
randimays marked this conversation as resolved.
Show resolved Hide resolved
'va-button'
'va-checkbox'
'va-icon'
'va-link'
'va-link-action'
'va-on-this-page'
'va-telephone'
}
}
1 change: 1 addition & 0 deletions generator-templates/component/test.hbs
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
import React from 'react'
import { render, screen } from '@testing-library/react'
import { {{pascalCase name}} } from './index'

Expand Down
25 changes: 14 additions & 11 deletions generator-templates/query/test.hbs
Original file line number Diff line number Diff line change
@@ -1,25 +1,28 @@
/**
* @jest-environment node
*/

import { {{pascalCase name}} } from '@/types/drupal/node'
import { queries } from '@/data/queries'
import mockData from '@/mocks/{{camelCase name}}.mock.json'

const {{pascalCase name}}Mock: {{pascalCase name}} = mockData

describe('{{pascalCase name}} formatData', () => {
let windowSpy

beforeEach(() => {
windowSpy = jest.spyOn(window, 'window', 'get')
})

afterEach(() => {
windowSpy.mockRestore()
// remove if this component does not have a data fetch
describe('DrupalJsonApiParams configuration', () => {
test('params function sets the correct include fields', () => {
// TODO
})
})

describe('{{pascalCase name}} formatData', () => {
test('outputs formatted data', () => {
windowSpy.mockImplementation(() => undefined)

expect(
queries.formatData('node--{{snakeCase name}}', {{pascalCase name}}Mock)
).toMatchSnapshot()
})

test('handles no answers correctly', () => {
// TODO
})
})
6 changes: 3 additions & 3 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -44,9 +44,9 @@
"dependencies": {
"@actions/core": "^1.10.1",
"@actions/github": "^6.0.0",
"@department-of-veterans-affairs/component-library": "^45.0.0",
"@department-of-veterans-affairs/formation": "^11.0.12",
"@department-of-veterans-affairs/web-components": "^11.2.9",
"@department-of-veterans-affairs/component-library": "^47.2.0",
"@department-of-veterans-affairs/formation": "^12.0.0",
"@department-of-veterans-affairs/web-components": "^15.2.0",
"@fortawesome/fontawesome-free": "^5.15.4",
"@octokit/rest": "^21.0.1",
"@storybook/react": "^8.0.5",
Expand Down
25 changes: 25 additions & 0 deletions playwright/tests/checklist.spec.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
import { test, expect } from '../utils/next-test'

test.describe('Checklist', () => {
test('Checklist page renders', async ({ page }) => {
await page.goto(
'/resources/what-to-bring-to-create-your-online-sign-in-account'
)
await expect(page).toHaveURL(
'/resources/what-to-bring-to-create-your-online-sign-in-account'
)
})

test('Should render without a11y errors', async ({
page,
makeAxeBuilder,
}) => {
await page.goto(
'/resources/what-to-bring-to-create-your-online-sign-in-account'
)

const accessibilityScanResults = await makeAxeBuilder().analyze()

expect(accessibilityScanResults.violations).toEqual([])
})
})
25 changes: 19 additions & 6 deletions src/data/queries/audienceTopics.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,3 @@
// Define the query params for fetching node--news_story.
import { ParagraphAudienceTopics } from '@/types/drupal/paragraph'
import { QueryFormatter, QueryParams } from 'next-drupal-query'
import { AudienceTopic, AudienceTopics } from '@/types/formatted/audienceTopics'
Expand All @@ -12,6 +11,18 @@ export const params: QueryParams<null> = () => {
])
}

const formatBeneficiariesData = (beneficiaries) => {
if (!beneficiaries || beneficiaries.length === 0) {
return []
}

if (!Array.isArray(beneficiaries)) {
return [beneficiaries]
}

return beneficiaries
}

export const getTagsList = (
entity: ParagraphAudienceTopics
): AudienceTopic[] | null => {
Expand All @@ -23,17 +34,19 @@ export const getTagsList = (
field_non_beneficiares: fieldNonBeneficiares,
} = entity

const audienceBeneficiaries = formatBeneficiariesData(
fieldAudienceBeneficiares
)
const nonBeneficiaries = formatBeneficiariesData(fieldNonBeneficiares)

const topics = fieldTopics.map((topic) => ({
id: topic.id,
href: topic.path?.alias,
name: topic.name,
categoryLabel: 'Topics',
}))

const audiences = [
...(fieldAudienceBeneficiares || []),
...(fieldNonBeneficiares || []),
]
const audiences = [...audienceBeneficiaries, ...nonBeneficiaries]
.filter((tag) => !!tag)
.map((audience) => ({
id: audience.id,
Expand All @@ -44,7 +57,7 @@ export const getTagsList = (

const tagList = [...topics, ...audiences]

return tagList.sort((a, b) => a.categoryLabel.localeCompare(b.categoryLabel))
return tagList.sort((a, b) => a.name.localeCompare(b.name))
}

/**
Expand Down
13 changes: 5 additions & 8 deletions src/data/queries/benefitsHubLinks.ts
Original file line number Diff line number Diff line change
@@ -1,24 +1,21 @@
import { QueryFormatter, QueryParams } from 'next-drupal-query'
import { NodeLandingPage } from '@/types/drupal/node'
import { BenefitsHubLink } from '@/types/formatted/benefitsHub'
import { RelatedLink } from '@/types/formatted/relatedLinks'
import { DrupalJsonApiParams } from 'drupal-jsonapi-params'

// Define the query params for fetching node--landing_page.
export const params: QueryParams<null> = () => {
return new DrupalJsonApiParams().addInclude(['field_support_services'])
}

// Format NodeLandingPage (Benefits Hub) into link teasers.
export const formatter: QueryFormatter<NodeLandingPage[], BenefitsHubLink[]> = (
export const formatter: QueryFormatter<NodeLandingPage[], RelatedLink[]> = (
entities: NodeLandingPage[]
) => {
return entities.map((entity) => {
return {
id: entity.id,
path: entity.path?.alias,
title: entity.title,
label: entity.field_home_page_hub_label,
teaserText: entity.field_teaser_text,
uri: entity.path?.alias,
title: entity.field_home_page_hub_label,
summary: entity.field_teaser_text,
}
})
}
92 changes: 92 additions & 0 deletions src/data/queries/checklist.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,92 @@
import { QueryData, QueryFormatter, QueryParams } from 'next-drupal-query'
import { DrupalJsonApiParams } from 'drupal-jsonapi-params'
import { queries } from '.'
import { formatParagraph } from '@/lib/drupal/paragraphs'
import {
PARAGRAPH_RESOURCE_TYPES,
RESOURCE_TYPES,
} from '@/lib/constants/resourceTypes'
import { ExpandedStaticPropsContext } from '@/lib/drupal/staticProps'
import {
entityBaseFields,
fetchSingleEntityOrPreview,
} from '@/lib/drupal/query'
import { getNestedIncludes } from '@/lib/utils/queries'

// Types
import { AlertSingle } from '@/types/formatted/alert'
import { AudienceTopics } from '@/types/formatted/audienceTopics'
import { Button } from '@/types/formatted/button'
import { Checklist, ChecklistItem } from '@/types/formatted/checklist'
import { ContactInfo } from '@/types/formatted/contactInfo'
import { NodeChecklist } from '@/types/drupal/node'
import { RelatedLink } from '@/types/formatted/relatedLinks'

export const params: QueryParams<null> = () => {
return new DrupalJsonApiParams().addInclude([
...getNestedIncludes(
'field_alert_single',
PARAGRAPH_RESOURCE_TYPES.ALERT_SINGLE
),
'field_buttons',
'field_checklist.field_checklist_sections',
...getNestedIncludes(
'field_contact_information',
PARAGRAPH_RESOURCE_TYPES.CONTACT_INFORMATION
),
'field_related_benefit_hubs',
'field_related_information',
...getNestedIncludes(
'field_tags',
PARAGRAPH_RESOURCE_TYPES.AUDIENCE_TOPICS
),
])
}

export type ChecklistDataOpts = {
id: string
context?: ExpandedStaticPropsContext
}

export const data: QueryData<ChecklistDataOpts, NodeChecklist> = async (
opts
): Promise<NodeChecklist> => {
const entity = (await fetchSingleEntityOrPreview(
opts,
RESOURCE_TYPES.CHECKLIST,
params
)) as NodeChecklist

return entity
}

export const formatter: QueryFormatter<NodeChecklist, Checklist> = (
entity: NodeChecklist
) => {
const formatRelatedLinks = (links): RelatedLink[] =>
links?.map((link) => ({
uri: link?.field_link?.uri,
title: link?.field_link?.title,
summary: link.field_link_summary,
}))

return {
...entityBaseFields(entity),
alert: formatParagraph(entity.field_alert_single) as AlertSingle,
benefitsHubLinks: queries.formatData(
RESOURCE_TYPES.BENEFITS_HUB,
entity.field_related_benefit_hubs
),
buttons: entity.field_buttons.map?.(formatParagraph) as Button[],
checklist: entity.field_checklist.field_checklist_sections?.map((section) =>
queries.formatData(PARAGRAPH_RESOURCE_TYPES.CHECKLIST, section)
) as ChecklistItem[],
contactInformation: formatParagraph(
entity.field_contact_information
) as ContactInfo,
intro: entity.field_intro_text_limited_html.processed,
relatedInformation: formatRelatedLinks(entity.field_related_information),
repeatButtons: entity.field_buttons_repeat,
tags: formatParagraph(entity.field_tags) as AudienceTopics,
}
}
16 changes: 16 additions & 0 deletions src/data/queries/checklistItem.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
import { QueryFormatter } from 'next-drupal-query'
import { ParagraphChecklistItem } from '@/types/drupal/paragraph'
import { ChecklistItem } from '@/types/formatted/checklist'

export const formatter: QueryFormatter<
ParagraphChecklistItem,
ChecklistItem
> = (entity: ParagraphChecklistItem) => {
return {
type: entity.type as ChecklistItem['type'],
id: entity.id,
items: entity.field_checklist_items,
header: entity.field_section_header,
intro: entity.field_section_intro,
}
}
Loading
Loading