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

DNM: Integration form engine 2 #2273

Draft
wants to merge 21 commits into
base: main
Choose a base branch
from
Draft
Show file tree
Hide file tree
Changes from 3 commits
Commits
Show all changes
21 commits
Select commit Hold shift + click to select a range
01edd06
VATEAM-87714: Add KISS configuration for Digital Forms (#2213)
derekhouck Aug 6, 2024
fd22547
VATEAM-88634: Create a normalization layer for Digital Forms (#2215)
derekhouck Aug 10, 2024
49ce1af
Add OMB info to Digital Form GraphQL query
derekhouck Aug 29, 2024
0cec642
Normalize OMB info
derekhouck Aug 29, 2024
4d7dc20
Remove Date object from formatDate
derekhouck Sep 6, 2024
52edb57
VATEAM-90733: Normalize OMB info fields (#2252)
derekhouck Sep 12, 2024
b64c733
Add Identification Information fragment
derekhouck Sep 16, 2024
62fdaab
Import identificationInformation fragment into digitalForm fragment
derekhouck Sep 16, 2024
ee1a69f
Extract Identification Information fields
derekhouck Sep 16, 2024
9a6014e
Fix imports
derekhouck Sep 16, 2024
66f5048
VATEAM-87714: Add KISS configuration for Digital Forms (#2213)
derekhouck Aug 6, 2024
e3d84e6
VATEAM-88634: Create a normalization layer for Digital Forms (#2215)
derekhouck Aug 10, 2024
a314931
Merge branch 'main' into integration-form-engine-2
derekhouck Oct 2, 2024
3633329
Merge branch '90733-normalize-omb-info-section' into integration-form…
derekhouck Oct 2, 2024
628f6cb
Merge branch '91741-normalize-identification-information' into integr…
derekhouck Oct 2, 2024
0166a12
VATEAM-92265: Normalize Address Digital Form pattern output (#2301)
derekhouck Oct 4, 2024
02d5d12
VATEAM-94290: Remove "Digital Form:" from content-build output (#2304)
derekhouck Oct 9, 2024
1d80dde
Merge branch 'main' into integration-form-engine-2
derekhouck Oct 16, 2024
a0310be
VATEAM-93401: Normalize Phone and Email Digital Form pattern output (…
derekhouck Oct 16, 2024
00433c4
VATEAM-94709: Normalize Your Personal Information chapter (#2338)
derekhouck Nov 4, 2024
56aee27
VATEAM-93614: Normalize List and Loop pattern output (#2350)
derekhouck Nov 12, 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
12 changes: 12 additions & 0 deletions src/site/stages/build/drupal/static-data-files/config.js
Original file line number Diff line number Diff line change
@@ -1,3 +1,8 @@
const {
query: queryDigitalForms,
postProcess: postProcessDigitalForm,
} = require('./digitalForm');

const {
query: queryVamcEhrSystem,
postProcess: postProcessVamcEhrSystem,
Expand Down Expand Up @@ -35,6 +40,13 @@ const DATA_FILE_PATH = 'data/cms';
* }
*/
const DATA_FILES = [
{
description: 'Digital Forms',
filename: 'digital-forms.json',
query: queryDigitalForms,
queryType: 'graphql',
postProcess: postProcessDigitalForm,
},
{
description: 'VAMC EHR System',
filename: 'vamc-ehr.json',
Expand Down
15 changes: 15 additions & 0 deletions src/site/stages/build/drupal/static-data-files/config.unit.spec.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
/* eslint-disable @department-of-veterans-affairs/axe-check-required */
Copy link
Collaborator

Choose a reason for hiding this comment

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

ESLint disabled here


import { expect } from 'chai';
import { DATA_FILES } from './config';

describe('config', () => {
describe('DATA_FILES', () => {
it('includes Digital Forms', () => {
expect(
DATA_FILES.filter(dataFile => dataFile.description === 'Digital Forms')
.length,
).to.eq(1);
});
});
});
Original file line number Diff line number Diff line change
@@ -0,0 +1,33 @@
const nameAndDateOfBirth = require('./nameAndDateOfBirth.graphql');

/*
*
* The "Digital Form" Content Type in the VA.gov CMS
*
*/
module.exports = `
${nameAndDateOfBirth}

fragment digitalForm on NodeDigitalForm {
nid
entityLabel
fieldVaFormNumber
fieldOmbNumber
fieldRespondentBurden
fieldExpirationDate {
value
}
fieldChapters {
entity {
entityId
type {
entity {
entityId
entityLabel
}
}
...nameAndDateOfBirth
}
}
}
`;
Original file line number Diff line number Diff line change
@@ -0,0 +1,26 @@
/* eslint-disable @department-of-veterans-affairs/axe-check-required */
Copy link
Collaborator

Choose a reason for hiding this comment

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

ESLint disabled here


import { expect } from 'chai';
import digitalForm from './digitalForm.graphql';

describe('digitalForm fragment', () => {
it('includes form fields', () => {
expect(digitalForm).to.have.string('nid');
expect(digitalForm).to.have.string('entityLabel');
expect(digitalForm).to.have.string('fieldVaFormNumber');
expect(digitalForm).to.have.string('fieldChapters');
});

it('include OMB info', () => {
expect(digitalForm).to.have.string('fieldOmbNumber');
expect(digitalForm).to.have.string('fieldRespondentBurden');
expect(digitalForm).to.have.string('fieldExpirationDate');
});

describe('chapter fragments', () => {
it('imports the nameAndDateOfBirth fragment', () => {
expect(digitalForm).to.have.string('fragment nameAndDateOfBirth');
expect(digitalForm).to.have.string('...nameAndDateOfBirth');
});
});
});
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
/*
*
* The "Name and Date of Birth" Digital Form pattern.
*
* Pattern documentation:
* https://design.va.gov/patterns/ask-users-for/names
*
*/
module.exports = `
fragment nameAndDateOfBirth on ParagraphDigitalFormNameAndDateOfBi {
fieldTitle
fieldIncludeDateOfBirth
}
`;
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
/* eslint-disable @department-of-veterans-affairs/axe-check-required */
Copy link
Collaborator

Choose a reason for hiding this comment

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

ESLint disabled here


import { expect } from 'chai';
import nameAndDateOfBirth from './nameAndDateOfBirth.graphql';

describe('nameAndDateOfBirth fragment', () => {
it('includes fieldTitle', () => {
expect(nameAndDateOfBirth).to.have.string('fieldTitle');
});

it('includes fieldIncludeDateOfBirth', () => {
expect(nameAndDateOfBirth).to.have.string('fieldIncludeDateOfBirth');
});
});
Original file line number Diff line number Diff line change
@@ -0,0 +1,26 @@
const digitalForm = require('./fragments/digitalForm.graphql');
const { postProcessDigitalForm } = require('./postProcessDigitalForm');

const query = `
${digitalForm}

query ($onlyPublishedContent: Boolean!) {
nodeQuery(
filter: {
conditions: [
{ field: "status", value: "1", enabled: $onlyPublishedContent },
{ field: "type", value: "digital_form" }
]
}
) {
entities {
... digitalForm
}
}
}
`;

module.exports = {
query,
postProcess: postProcessDigitalForm,
};
Original file line number Diff line number Diff line change
@@ -0,0 +1,52 @@
/* eslint-disable @department-of-veterans-affairs/axe-check-required */
Copy link
Collaborator

Choose a reason for hiding this comment

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

ESLint disabled here


import { expect } from 'chai';
import { query, postProcess } from './index';

describe('digitalForm', () => {
describe('query', () => {
it('returns digital_form entities', () => {
expect(query).to.have.string('digital_form');
});
it('imports the digitalForm fragment', () => {
expect(query).to.have.string('fragment digitalForm');
expect(query).to.have.string('... digitalForm');
});
});

describe('postProcess', () => {
it('imports postProcessDigitalForm', () => {
const queryResult = {
data: {
nodeQuery: {
entities: [
{
nid: 71002,
entityLabel: 'Form with One Step',
fieldVaFormNumber: '11111',
fieldOmbNumber: '1111-1111',
fieldChapters: [
{
entity: {
entityId: '157904',
type: {
entity: {
entityId: 'digital_form_name_and_date_of_bi',
entityLabel: 'Name and Date of Birth',
},
},
fieldTitle: 'The Only Step',
fieldIncludeDateOfBirth: true,
},
},
],
},
],
},
},
};

expect(() => postProcess(queryResult)).to.not.throw();
});
});
});
Original file line number Diff line number Diff line change
@@ -0,0 +1,62 @@
const { logDrupal } = require('../../utilities-drupal');

const extractAdditionalFields = entity => {
const additionalFields = {};

if (entity.type.entity.entityId === 'digital_form_name_and_date_of_bi') {
additionalFields.includeDateOfBirth = entity.fieldIncludeDateOfBirth;
}

return additionalFields;
};
const extractForms = resultObject => resultObject?.data?.nodeQuery?.entities;

const formatDate = dateString => {
const removeLeadingZero = s => s.replace(/^0+/, '');
const [year, month, day] = dateString.split('-');
return `${removeLeadingZero(month)}/${removeLeadingZero(day)}/${year}`;
};

const normalizeChapter = ({ entity }) => {
return {
id: parseInt(entity.entityId, 10),
chapterTitle: entity.fieldTitle,
type: entity.type.entity.entityId,
pageTitle: entity.type.entity.entityLabel,
additionalFields: extractAdditionalFields(entity),
};
};

const normalizeForm = (form, logger = logDrupal) => {
try {
return {
cmsId: form.nid,
formId: form.fieldVaFormNumber,
title: form.entityLabel,
ombInfo: {
expDate: formatDate(form.fieldExpirationDate.value),
ombNumber: form.fieldOmbNumber,
resBurden: form.fieldRespondentBurden,
},
chapters: form.fieldChapters.map(normalizeChapter),
};
} catch (error) {
logger(`There was an error with this form: ${error}`);
return {};
}
};

const postProcessDigitalForm = (queryResult, logger = logDrupal) => {
// queryResult was already parsed by graphQLApiClient
const forms = extractForms(queryResult);

// will be turned into JSON by writeProcessedDataFilesToCache
if (forms) {
return forms.map(form => normalizeForm(form, logger));
}

logger(`Malformed result query: ${queryResult}`);
return [];
};

module.exports.postProcessDigitalForm = postProcessDigitalForm;
Loading
Loading