Skip to content

Commit

Permalink
♻️(frontend) replace grommet Select with Cunnigham Select
Browse files Browse the repository at this point in the history
- replace the Grommet Select component with the Cunningham Select
component
  • Loading branch information
AntoLC committed Sep 14, 2023
1 parent a1ce494 commit f44f591
Show file tree
Hide file tree
Showing 42 changed files with 662 additions and 618 deletions.
4 changes: 4 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,10 @@ Versioning](https://semver.org/spec/v2.0.0.html).

- Save license when a video is created

### Changed

- Replace grommet Select by Cunningham Select (#2400)

## [4.4.0] - 2023-09-08

### Added
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -214,7 +214,7 @@ describe('<DashboardInstructor />', () => {
},
);

const fileFilter = screen.getByRole('button', { name: /Filter files/i });
const fileFilter = screen.getByRole('combobox', { name: /Filter files/i });
await userEvent.click(fileFilter);
await userEvent.click(
await screen.findByRole('option', { name: 'Unread' }),
Expand Down
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
import { Box, Heading, Pagination, Paragraph, Select, Text } from 'grommet';
import { Select } from '@openfun/cunningham-react';
import { Box, Heading, Pagination, Paragraph, Text } from 'grommet';
import { Maybe } from 'lib-common';
import { FileDepository, Loader } from 'lib-components';
import React, { FocusEvent, useState } from 'react';
Expand All @@ -10,6 +11,8 @@ import {
useUpdateFileDepository,
} from 'apps/deposit/data/queries';

type SelectProps = React.ComponentPropsWithoutRef<typeof Select>;

const PAGE_SIZE = 10;

const messages = defineMessages({
Expand Down Expand Up @@ -77,7 +80,7 @@ export const DashboardInstructor = ({
const [indices, setIndices] = useState([0, PAGE_SIZE]);
const [readFilter, setReadFilter] = useState<Maybe<string>>(undefined);

const { data, isError, isLoading, refetch } = useDepositedFiles(
const { data, isError, isLoading } = useDepositedFiles(
fileDepository.id,
{
limit: `${PAGE_SIZE}`,
Expand All @@ -103,9 +106,8 @@ export const DashboardInstructor = ({
},
];

const onReadFilterChange = (event: React.ChangeEvent<HTMLSelectElement>) => {
setReadFilter(event.target.value);
refetch();
const onReadFilterChange: SelectProps['onChange'] = (event) => {
setReadFilter(event.target.value as Maybe<string>);
};

const { mutate } = useUpdateFileDepository(fileDepository.id);
Expand Down Expand Up @@ -190,17 +192,11 @@ export const DashboardInstructor = ({
pad="medium"
>
<Select
a11yTitle={intl.formatMessage(messages.readFilterTitle)}
id="readFilterSelect"
name="read"
placeholder={intl.formatMessage(
messages.readFilterPlaceholder,
)}
value={readFilter}
options={readFilterOptions}
labelKey="label"
valueKey={{ key: 'value', reduce: true }}
aria-label={intl.formatMessage(messages.readFilterTitle)}
label={intl.formatMessage(messages.readFilterTitle)}
onChange={onReadFilterChange}
options={readFilterOptions}
value={readFilter}
/>
<Text>
<FormattedMessage
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -111,7 +111,7 @@ describe('MarkdownWizard', () => {
'Mon titre',
);
await userEvent.click(
screen.getByRole('button', { name: /Select language/i }),
screen.getByRole('combobox', { name: /Select language/i }),
);
await userEvent.click(
await screen.findByRole('option', { name: /French/i }),
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -100,12 +100,14 @@ export const MarkdownWizard = ({ markdownDocumentId }: MarkdownWizardProps) => {
maxLength={255}
onChange={(event) => setLocalTitle(event.target.value)}
value={localTitle}
fullWidth
/>
</Box>
<LanguageSelector
currentLanguage={language}
onLanguageChange={setLanguage}
disabled={false}
fullWidth
/>

<Button
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -111,10 +111,13 @@ describe('<VideoCreateForm />', () => {
screen.getByText('Add a video or drag & drop it'),
).toBeInTheDocument();
expect(
await screen.findByRole('button', {
name: 'Select the license under which you want to publish your video; Selected: CC_BY',
await screen.findByRole('combobox', {
name: 'Select the license',
}),
).toBeInTheDocument();
expect(
await screen.findByText('Creative Common By Attribution'),
).toBeInTheDocument();
expect(
screen.getByRole('button', { name: /Add Video/i }),
).toBeInTheDocument();
Expand Down Expand Up @@ -147,10 +150,13 @@ describe('<VideoCreateForm />', () => {
screen.getByText('Add a video or drag & drop it'),
).toBeInTheDocument();
expect(
await screen.findByRole('button', {
name: 'Select the license under which you want to publish your video; Selected: CC_BY',
await screen.findByRole('combobox', {
name: 'Select the license',
}),
).toBeInTheDocument();
expect(
await screen.findByText('Creative Common By Attribution'),
).toBeInTheDocument();
expect(
screen.getByRole('button', { name: /Add Video/i }),
).toBeInTheDocument();
Expand Down Expand Up @@ -254,11 +260,15 @@ describe('<VideoCreateForm />', () => {
).toBeInTheDocument();

expect(
await screen.findByRole('button', {
name: 'Select the license under which you want to publish your video; Selected: CC_BY',
await screen.findByRole('combobox', {
name: 'Select the license',
}),
).toBeInTheDocument();

expect(
screen.getByText('Creative Common By Attribution'),
).toBeInTheDocument();

const hiddenInput = screen.getByTestId('input-video-test-id');

await userEvent.upload(hiddenInput, file);
Expand Down Expand Up @@ -334,11 +344,15 @@ describe('<VideoCreateForm />', () => {
).toBeInTheDocument();

expect(
await screen.findByRole('button', {
name: 'Select the license under which you want to publish your video; Selected: CC_BY',
await screen.findByRole('combobox', {
name: 'Select the license',
}),
).toBeInTheDocument();

expect(
screen.getByText('Creative Common By Attribution'),
).toBeInTheDocument();

const hiddenInput = screen.getByTestId('input-video-test-id');

await userEvent.upload(hiddenInput, file);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -191,19 +191,13 @@ const VideoCreateForm = () => {
videoUploadState={newVideo?.upload_state}
/>

<FormField
label={intl.formatMessage(messages.licenseLabel)}
htmlFor="select-license-id"
name="license"
required
margin={{ vertical: 'small' }}
>
<Field className="mt-s" fullWidth>
<LicenseSelect
onChange={(option) =>
setVideo((_video) => ({ ..._video, license: option.value }))
}
/>
</FormField>
</Field>
</Box>

<ModalButton
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -91,21 +91,17 @@ describe('<CreatePlaylistForm />', () => {

expect(await screen.findByText('Create a playlist')).toBeInTheDocument();

await userEvent.click(
await screen.findByRole('button', { name: 'Open Drop; Selected: id' }),
);
expect(screen.getByText('org')).toBeInTheDocument();

await userEvent.click(
await screen.findByRole('option', { name: 'other-org' }),
screen.getByRole('combobox', {
name: 'Organization',
}),
);
await userEvent.click(screen.getByRole('option', { name: 'other-org' }));

expect(
await screen.findByRole('button', {
name: 'Open Drop; Selected: other-id',
}),
).toBeInTheDocument();
expect(screen.getByDisplayValue('other-org')).toBeInTheDocument();
expect(screen.queryByDisplayValue('org')).not.toBeInTheDocument();
expect(screen.getByText('other-org')).toBeInTheDocument();
expect(screen.queryByText('org')).not.toBeInTheDocument();

await userEvent.type(
screen.getByRole('textbox', { name: 'Name' }),
Expand Down
Loading

0 comments on commit f44f591

Please sign in to comment.