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

[UICAL-268, UICAL-228, UICAL-269, UICAL-220, UICAL-270] Convert to react-final-form-arrays, stripes-types, react 18 #491

Closed
wants to merge 35 commits into from
Closed
Show file tree
Hide file tree
Changes from 20 commits
Commits
Show all changes
35 commits
Select commit Hold shift + click to select a range
2cd5cba
Convert to react-final-form-arrays and stripes-types
ncovercash May 3, 2023
f25f200
Revert migration to stripes-types
ncovercash May 3, 2023
ee3515c
Fix linting nitpick
ncovercash May 3, 2023
b695968
Merge branch 'master' into uical-268
ncovercash May 3, 2023
ab07b9a
Test converting back to stripes-types
ncovercash May 3, 2023
50bb18e
change git protocol
ncovercash May 3, 2023
6743e52
Test resolution
ncovercash May 3, 2023
e8cd0f6
Fix missing await in exception field test
ncovercash May 3, 2023
aaf3cef
Fully remove submitAttempted prop
ncovercash May 3, 2023
d84b384
Use query for testing exception row deletion
ncovercash May 3, 2023
3e9a67c
Sonar fixes
ncovercash May 3, 2023
0ebb03b
Fix onSubmit return for sonar
ncovercash May 3, 2023
884d3ce
More sonar fixes, yay!
ncovercash May 3, 2023
a429c47
sonar pls
ncovercash May 3, 2023
d1380a5
uical-220: create tests for MCLRowFormatter
ncovercash May 3, 2023
3fa5998
Fix onSubmit usage
ncovercash May 3, 2023
4de6f0f
Make calendar form wrapper test more involved
ncovercash May 3, 2023
658dbc1
this is ridiculous
ncovercash May 3, 2023
3f05637
sonar: please
ncovercash May 3, 2023
5de5c45
maybe?
ncovercash May 3, 2023
e6adfa7
Remove testing code
ncovercash May 9, 2023
1df09ee
Update package.json
ncovercash May 24, 2023
df57a75
Update Node.js to v18 in GitHub Actions
danetsao Sep 14, 2023
88a5d90
Update package.json
ncovercash Sep 14, 2023
5e18187
Merge branch 'master' into uical-268
ncovercash Sep 20, 2023
39c80af
Merge remote-tracking branch 'origin/UICAL-271' into uical-268
ncovercash Sep 20, 2023
9b99191
Merge remote-tracking branch 'origin/uical-268' into uical-268
ncovercash Sep 20, 2023
d390e7f
Merge branch 'master' into uical-268
ncovercash Sep 22, 2023
258a6f2
Update deps
ncovercash Sep 22, 2023
3b16700
Fix bad merge
ncovercash Sep 22, 2023
33f6cea
Fix lint errors
ncovercash Sep 22, 2023
226f11a
Package, test cleanup
ncovercash Sep 22, 2023
60a0b03
Update typings for forms/etc
ncovercash Oct 9, 2023
a9a4091
Test fix
ncovercash Oct 9, 2023
746eea3
Merge branch 'master' into uical-268
ncovercash Oct 11, 2023
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
10 changes: 9 additions & 1 deletion package.json
Original file line number Diff line number Diff line change
Expand Up @@ -111,7 +111,7 @@
},
"devDependencies": {
"@folio/eslint-config-stripes": "^6.3.0",
"@folio/stripes": "^8.0.0",
"@folio/stripes": "https://github.com/ualibweb/stripes.git#stripes-859",
"@folio/stripes-cli": "^2.6.0",
"@folio/stripes-components": "^11.0.0",
"@folio/stripes-core": "^9.0.0",
Expand Down Expand Up @@ -153,14 +153,22 @@
"dayjs": "^1.11.2",
"dom-helpers": "^5.2.1",
"dotenv": "^16.0.3",
"final-form": "^4.20.9",
"final-form-arrays": "^3.1.0",
"fuzzysort": "^2.0.1",
"history": "^4.9.0",
"ky": "^0.31.1",
"memoizee": "^0.4.15",
"react-final-form": "^6.5.9",
"react-final-form-arrays": "^3.1.4",
"utility-types": "^3.10.0"
},
"resolutions": {
"@types/react": "^17.0.2"
},
"peerDependencies": {
"@folio/stripes": "^8.0.0",
"@types/react": "^17.0.2",
"final-form": "^4.20.7",
"react": "^17.0.2",
"react-dom": "^17.0.2",
Expand Down
2 changes: 1 addition & 1 deletion src/components/Calendar.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -59,7 +59,7 @@ export default function Calendar(props: Props) {
className={css.calendar}
style={
{
'--num-main-cal-rows': displayDates.length / 7
'--num-main-cal-rows': displayDates.length / 7,
} as CSSPropertiesWithVars
}
>
Expand Down
281 changes: 110 additions & 171 deletions src/components/fields/ExceptionField.test.tsx
Original file line number Diff line number Diff line change
@@ -1,247 +1,186 @@
import { render, screen } from '@testing-library/react';
import userEvent from '@testing-library/user-event';
import arrayMutators from 'final-form-arrays';
import React from 'react';
import { Form } from 'react-final-form';
import { FieldArray } from 'react-final-form-arrays';
import { FormValues } from '../../forms/CalendarForm/types';
import withIntlConfiguration from '../../test/util/withIntlConfiguration';
import ExceptionField from './ExceptionField';
import { ExceptionRowState } from './ExceptionFieldTypes';
import RowType from './RowType';

describe('ExceptionField', () => {
it('Renders successfully', () => {
it('Empty field renders successfully', () => {
render(
withIntlConfiguration(
<ExceptionField
fieldRefs={{ startDate: {}, startTime: {}, endDate: {}, endTime: {} }}
error={undefined}
localeTimeFormat="HH:mm a"
submitAttempted={false}
input={{
name: 'exception-field',
onBlur: jest.fn(),
onChange: jest.fn(),
onFocus: jest.fn(),
value: []
<Form
mutators={{
...arrayMutators,
}}
meta={{ touched: true }}
/>
onSubmit={() => ({})}
>
{() => (
<FieldArray<ExceptionRowState> name="exceptions">
{({ fields: values }) => <ExceptionField values={values} />}
</FieldArray>
)}
</Form>
)
);

// header and add row button
expect(screen.getAllByRole('row')).toHaveLength(2);
});

it('Renders successfully with rows', () => {
it('Rows add successfully', async () => {
render(
withIntlConfiguration(
<ExceptionField
fieldRefs={{ startDate: {}, startTime: {}, endDate: {}, endTime: {} }}
error={undefined}
localeTimeFormat="HH:mm a"
submitAttempted={false}
input={{
name: 'exception-field',
onBlur: jest.fn(),
onChange: jest.fn(),
onFocus: jest.fn(),
value: [
{
i: 0,
type: RowType.Open,
name: 'Foo',
lastRowI: 1,
rows: [
{
i: 0,
startDate: '2000-01-01',
startTime: '00:00',
endDate: '2000-01-05',
endTime: '03:00'
},
{
i: 1,
startDate: '2000-01-06',
startTime: '00:00',
endDate: '2000-01-08',
endTime: '03:00'
}
]
},
{
i: 1,
type: RowType.Closed,
name: 'Sample closure',
lastRowI: 0,
rows: [
{
i: 0,
startDate: '2000-01-01',
startTime: undefined,
endDate: '2000-01-05',
endTime: undefined
}
]
}
]
<Form
mutators={{
...arrayMutators,
}}
meta={{ touched: true }}
/>
onSubmit={() => ({})}
>
{() => (
<FieldArray<ExceptionRowState> name="exceptions">
{({ fields: values }) => <ExceptionField values={values} />}
</FieldArray>
)}
</Form>
)
);

// header and add row button
expect(screen.getAllByRole('row')).toHaveLength(4);
expect(screen.getAllByRole('row')).toHaveLength(2);
await userEvent.click(screen.getByRole('button', { name: 'Add row' }));
expect(screen.getAllByRole('row')).toHaveLength(3);
});

it('Adds rows on button click', async () => {
it('Field with values renders successfully', () => {
render(
withIntlConfiguration(
<ExceptionField
fieldRefs={{ startDate: {}, startTime: {}, endDate: {}, endTime: {} }}
error={undefined}
localeTimeFormat="HH:mm a"
submitAttempted={false}
input={{
name: 'exception-field',
onBlur: jest.fn(),
onChange: jest.fn(),
onFocus: jest.fn(),
value: []
<Form<FormValues>
mutators={{
...arrayMutators,
}}
onSubmit={() => ({})}
initialValues={{
exceptions: [
{
name: 'test',
type: RowType.Open,
rows: [
{
startDate: '2000-01-01',
startTime: '00:00',
endDate: '2000-01-01',
endTime: '00:00',
},
],
},
],
}}
meta={{ touched: true }}
/>
>
{() => (
<FieldArray<ExceptionRowState> name="exceptions">
{({ fields: values }) => <ExceptionField values={values} />}
</FieldArray>
)}
</Form>
)
);

// header and add row button
expect(screen.getAllByRole('row')).toHaveLength(2);
await userEvent.click(screen.getByRole('button', { name: 'Add row' }));
expect(screen.getAllByRole('row')).toHaveLength(3);
});

it('Removes row on button click', async () => {
it('Adding and deleting rows works successfully', async () => {
render(
withIntlConfiguration(
<ExceptionField
fieldRefs={{ startDate: {}, startTime: {}, endDate: {}, endTime: {} }}
error={undefined}
localeTimeFormat="HH:mm a"
submitAttempted={false}
input={{
name: 'exception-field',
onBlur: jest.fn(),
onChange: jest.fn(),
onFocus: jest.fn(),
value: [
<Form<FormValues>
mutators={{
...arrayMutators,
}}
onSubmit={() => ({})}
initialValues={{
exceptions: [
{
i: 0,
name: 'test',
type: RowType.Open,
name: 'Foo',
lastRowI: 1,
rows: [
{
i: 0,
startDate: '2000-01-01',
startTime: '00:00',
endDate: '2000-01-05',
endTime: '03:00'
endDate: '2000-01-01',
endTime: '00:00',
},
{
i: 1,
startDate: '2000-01-06',
startTime: '00:00',
endDate: '2000-01-08',
endTime: '03:00'
}
]
],
},
{
i: 1,
type: RowType.Closed,
name: 'Sample closure',
lastRowI: 0,
rows: [
{
i: 0,
startDate: '2000-01-01',
startTime: undefined,
endDate: '2000-01-05',
endTime: undefined
}
]
}
]
],
}}
meta={{ touched: true }}
/>
>
{() => (
<FieldArray<ExceptionRowState> name="exceptions">
{({ fields: values }) => <ExceptionField values={values} />}
</FieldArray>
)}
</Form>
)
);

// header and add row button
expect(screen.getAllByRole('row')).toHaveLength(4);
// 9 from open and 3 from closed
expect(screen.getAllByRole('textbox')).toHaveLength(12);
expect(screen.getAllByRole('row')).toHaveLength(3);
expect(screen.getAllByRole('textbox')).toHaveLength(5);

// delete open row
await userEvent.click(screen.getAllByRole('button', { name: 'trash' })[0]);
await userEvent.click(screen.getByRole('button', { name: 'plus-sign' }));
expect(screen.getAllByRole('row')).toHaveLength(3);
expect(screen.getAllByRole('textbox')).toHaveLength(3);
expect(screen.getAllByRole('textbox')).toHaveLength(9);

// delete closed row
await userEvent.click(screen.getAllByRole('button', { name: 'trash' })[0]);
await userEvent.click(screen.getByRole('button', { name: 'trash' }));
expect(screen.getAllByRole('row')).toHaveLength(2);
expect(screen.queryAllByRole('textbox')).toHaveLength(0);
});

it('Adds inner row on button click', async () => {
it('Adding to closed rows is a no-op', async () => {
render(
withIntlConfiguration(
<ExceptionField
fieldRefs={{ startDate: {}, startTime: {}, endDate: {}, endTime: {} }}
error={undefined}
localeTimeFormat="HH:mm a"
submitAttempted={false}
input={{
name: 'exception-field',
onBlur: jest.fn(),
onChange: jest.fn(),
onFocus: jest.fn(),
value: [
<Form<FormValues>
mutators={{
...arrayMutators,
}}
onSubmit={() => ({})}
initialValues={{
exceptions: [
{
i: 0,
type: RowType.Open,
name: 'Foo',
lastRowI: 1,
name: 'test',
type: RowType.Closed,
rows: [
{
i: 0,
startDate: '2000-01-01',
startTime: '00:00',
endDate: '2000-01-05',
endTime: '03:00'
startTime: undefined,
endDate: '2000-01-01',
endTime: undefined,
},
{
i: 1,
startDate: '2000-01-06',
startTime: '00:00',
endDate: '2000-01-08',
endTime: '03:00'
}
]
}
]
],
},
],
}}
meta={{ touched: true }}
/>
>
{() => (
<FieldArray<ExceptionRowState> name="exceptions">
{({ fields: values }) => <ExceptionField values={values} />}
</FieldArray>
)}
</Form>
)
);

// header and add row button
expect(screen.getAllByRole('row')).toHaveLength(3);
expect(screen.getAllByRole('textbox')).toHaveLength(9);
expect(screen.getAllByRole('textbox')).toHaveLength(3);

// create additional inner row (four more textboxes)
await userEvent.click(screen.getByRole('button', { name: 'plus-sign' }));
expect(screen.getAllByRole('row')).toHaveLength(3);
expect(screen.getAllByRole('textbox')).toHaveLength(13);
expect(screen.getAllByRole('textbox')).toHaveLength(3);
});
});
Loading