Skip to content

Commit

Permalink
Merge branch 'creation-formulaire-candidature-structure' of https://g…
Browse files Browse the repository at this point in the history
…ithub.com/anct-cnum/site-vitrine into creation-formulaire-candidature-structure
  • Loading branch information
Ornella452 committed Jul 30, 2024
2 parents 4e7e725 + 46f7a3e commit 37c9b5e
Show file tree
Hide file tree
Showing 5 changed files with 170 additions and 6 deletions.
3 changes: 2 additions & 1 deletion src/views/candidature-structure/CandidatureStructure.jsx
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
import React, { useState } from 'react';
import SommaireStructure from './SommaireStructure';
import InformationsDeContact from './InformationsDeContact';
import InformationsDeStructure from './InformationsDeStructure';
import BesoinEnConseillerNumerique from './BesoinEnConseillerNumerique';
import Motivation from './Motivation';
import { useScrollToSection } from '../../hooks/useScrollToSection';
Expand Down Expand Up @@ -30,7 +31,7 @@ export default function CandidatureStructure() {
<h1 className="cc-titre fr-mb-5w">Je souhaite engager un conseiller numérique</h1>
<p className="fr-text--sm fr-hint-text">Les champs avec <span className="cc-obligatoire">*</span> sont obligatoires.</p>
<form aria-label="Candidature structure" >
{/* TODO : Vos informations de structure */}
<InformationsDeStructure />
<InformationsDeContact />
<BesoinEnConseillerNumerique setDateAccueilConseillerNumerique={setDateAccueilConseillerNumerique} />
<Motivation />
Expand Down
59 changes: 54 additions & 5 deletions src/views/candidature-structure/CandidatureStructure.test.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -14,10 +14,7 @@ describe('candidature structure', () => {
render(<CandidatureStructure />);

// THEN
const titre = screen.getByRole('heading', {
level: 1,
name: textMatcher('Je souhaite engager un conseiller numérique'),
});
const titre = screen.getByRole('heading', { level: 1, name: textMatcher('Je souhaite engager un conseiller numérique') });
expect(titre).toBeInTheDocument();

const champsObligatoires = screen.getByText(textMatcher('Les champs avec * sont obligatoires.'), { selector: 'p' });
Expand All @@ -41,7 +38,58 @@ describe('candidature structure', () => {
});
});

it.todo('quand j’affiche le formulaire alors l’étape "Vos informations de structure" est affiché');
it('quand j’affiche le formulaire alors l’étape "Vos informations de structure" est affiché', () => {
// WHEN
render(<CandidatureStructure />);

// THEN
const formulaire = screen.getByRole('form', { name: 'Candidature structure' });
const etapeInformationsDeStructure = within(formulaire).getByRole('group', { name: 'Vos informations de structure' });
expect(etapeInformationsDeStructure).toHaveAttribute('id', 'informations-de-structure');

const siretOuRidet = within(etapeInformationsDeStructure).getByPlaceholderText('N° SIRET / RIDET');

Check failure on line 50 in src/views/candidature-structure/CandidatureStructure.test.jsx

View workflow job for this annotation

GitHub Actions / tests

src/views/candidature-structure/CandidatureStructure.test.jsx > candidature structure > quand j’affiche le formulaire alors l’étape "Vos informations de structure" est affiché

TestingLibraryElementError: Unable to find an element with the placeholder text of: N° SIRET / RIDET Ignored nodes: comments, script, style <fieldset class="fr-border cc-section fr-p-3w fr-mb-3w" id="informations-de-structure" > <legend class="fr-h5" > Vos informations de structure </legend> <hr /> <div class="fr-fieldset__element" > <div class="fr-input-group" > <label class="fr-label" for="siretEntreprise" /> <input class="fr-input" id="siretEntreprise" type="text" /> </div> </div> <div class="fr-fieldset__element" > <div class="fr-input-group" > <label class="fr-label" for="denomination" > Dénomination <span class="cc-obligatoire" > * </span> </label> <input class="fr-input" id="denomination" required="" type="text" /> </div> </div> <div class="fr-fieldset__element" > <div class="fr-input-group" > <label class="fr-label" for="adresse" > Adresse <span class="cc-obligatoire" > * </span> </label> <input class="fr-input" id="adresse" required="" type="text" /> </div> </div> <p class="fr-mb-3w cc-bold" > Votre structure est <span class="cc-obligatoire" > * </span> </p> <div class="fr-grid-row" > <div class="fr-fieldset__element" > <div class="fr-radio-group" > <input id="commune" name="typeStructure" required="" type="radio" /> <label class="fr-label" for="commune" > Une commune </label> </div> </div> <div class="fr-fieldset__element" > <div class="fr-radio-group" > <input id="intercommunalite" name="typeStructure" required="" type="radio" /> <label class="fr-label" for="intercommunalite" > Un département </label> </div> </div> <div class="fr-fieldset__element" > <div class="fr-radio-group" > <input id="region" name="typeStructure" required="" type="radio" /> <label class="fr-label" for="region" > Une région </label> </div> </div> <div class="fr-fieldset__element" > <div class="fr-radio-group" > <input id="etablissement" name="typeStructure" required="" type="radio" /> <label class="fr-label" for="etablissement" > Un établissement public de coopération intercommunale </label> </div> </div> <div class="fr-fieldset__element" > <div class="fr-radio-group" > <input id="collectivite" name="typeStructure" required="" type="radio" /> <label class="fr-label" for="collectivite" > Une collectivité à statut particulier </label> </div> </div> <div class="fr-fieldset__element" > <div class="fr-radio-group" > <input id="gip" name="typeStructure" required="" type="radio" /> <label class="fr-label" for="gip" > Un GIP </label> </div> </div> <div class="fr-fieldset__element" > <div class="fr-radio-group" > <input id="structurePrivee" name="typeStructure" required="" type="radio"
expect(siretOuRidet).toHaveAttribute('id', 'siretEntreprise');
expect(siretOuRidet).toBeRequired();

const denomination = within(etapeInformationsDeStructure).getByLabelText('Dénomination *');
expect(denomination).toHaveAttribute('type', 'text');
expect(denomination).toBeRequired();

const adresse = within(etapeInformationsDeStructure).getByLabelText('Adresse *');
expect(adresse).toHaveAttribute('type', 'text');
expect(adresse).toBeRequired();

const questionTypeDeStructure = within(etapeInformationsDeStructure).getByText(textMatcher('Votre structure est *'), { selector: 'p' });
expect(questionTypeDeStructure).toBeInTheDocument();

const _uneCommune = screen.getByRole('radio', { name: 'Une commune' });
expect(_uneCommune).toBeRequired();
expect(_uneCommune).toHaveAttribute('name', 'typeStructure');

const _unDepartement = screen.getByRole('radio', { name: 'Un département' });
expect(_unDepartement).toBeRequired();
expect(_unDepartement).toHaveAttribute('name', 'typeStructure');

const _uneRegion = screen.getByRole('radio', { name: 'Une région' });
expect(_uneRegion).toBeRequired();
expect(_uneRegion).toHaveAttribute('name', 'typeStructure');

const _unEtablissemntPublic = screen.getByRole('radio', { name: 'Un établissement public de coopération intercommunale' });
expect(_unEtablissemntPublic).toBeRequired();
expect(_unEtablissemntPublic).toHaveAttribute('name', 'typeStructure');

const _uneCollectivite = screen.getByRole('radio', { name: 'Une collectivité à statut particulier' });
expect(_uneCollectivite).toBeRequired();
expect(_uneCollectivite).toHaveAttribute('name', 'typeStructure');

const _unGIP = screen.getByRole('radio', { name: 'Un GIP' });
expect(_unGIP).toBeRequired();
expect(_unGIP).toHaveAttribute('name', 'typeStructure');

// const _uneStructurePrivee = screen.getByRole('radio', { name: 'Une structure privée (association, entreprise de l’ESS, fondations)' });
// expect(_uneStructurePrivee).toBeRequired();
// expect(_uneStructurePrivee).toHaveAttribute('name', 'typeStructure');
});

it('quand j’affiche le formulaire alors l’étape "Vos informations de contact" est affiché', () => {
// WHEN
Expand Down Expand Up @@ -140,3 +188,4 @@ describe('candidature structure', () => {
});
it.todo('quand j’affiche le formulaire alors l’encart des engagements est affiché');
});

20 changes: 20 additions & 0 deletions src/views/candidature-structure/CompanyFinder.jsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
import React from 'react';
import Input from '../../components/commun/Input';
import { useSiretApi } from './useSiretApi';
import { debounce } from '../candidature-conseiller/debounce';

export default function CompanyFinder() {
const { search, entreprise } = useSiretApi();

return (
<>
<Input
id="siretEntreprise"
isRequired={false}
onChange={debounce(event => search(event.target.value))}
placeholder="N° SIRET / RIDET"
/>
{entreprise}
</>
);
}
53 changes: 53 additions & 0 deletions src/views/candidature-structure/InformationsDeStructure.jsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,53 @@
import React from 'react';
import Input from '../../components/commun/Input';
import CompanyFinder from './CompanyFinder';
import BoutonRadio from '../../components/commun/BoutonRadio';

export default function InformationsDeContact() {
return (
<fieldset
className="fr-border cc-section fr-p-3w fr-mb-3w"
id="informations-de-structure"
>
<legend className="fr-h5">Vos informations de structure</legend>
<hr />
<CompanyFinder />
<Input
id="denomination"
>
Dénomination <span className="cc-obligatoire">*</span>
</Input>
<Input
id="adresse"
>
Adresse <span className="cc-obligatoire">*</span>
</Input>
<p className="fr-mb-3w cc-bold">
Votre structure est <span className="cc-obligatoire">*</span>
</p>
<div className="fr-grid-row">
<BoutonRadio id="commune" nomGroupe="typeStructure">
Une commune
</BoutonRadio>
<BoutonRadio id="intercommunalite" nomGroupe="typeStructure">
Un département
</BoutonRadio>
<BoutonRadio id="region" nomGroupe="typeStructure">
Une région
</BoutonRadio>
<BoutonRadio id="etablissement" nomGroupe="typeStructure">
Un établissement public de coopération intercommunale
</BoutonRadio>
<BoutonRadio id="collectivite" nomGroupe="typeStructure">
Une collectivité à statut particulier
</BoutonRadio>
<BoutonRadio id="gip" nomGroupe="typeStructure">
Un GIP
</BoutonRadio>
<BoutonRadio id="structurePrivee" nomGroupe="typeStructure">
Une structure privée (association, entreprise de l’ESS, fondations)
</BoutonRadio>
</div>
</fieldset>
);
}
41 changes: 41 additions & 0 deletions src/views/candidature-structure/useSiretApi.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,41 @@
import { useState } from 'react';

const getUrlEntrepriseApiV3 = (sirenOuSiret, type) => {
let params = '?context=cnum&object=checkSiret&recipient=13002603200016';
let url = 'https://entreprise.api.gouv.fr/v3/';
let service = '';
switch (type) {
case 'siret':
service = 'insee/sirene/etablissements/' + sirenOuSiret;
break;
case 'siren':
service = 'insee/sirene/unites_legales/' + sirenOuSiret + '/siege_social/';
break;
default:
break;
}
return url + service + params;
};

export const useSiretApi = () => {
const [entreprise, setEntreprise] = useState(null);
const [error, setError] = useState(null);

const search = async (sirenOuSiret, type) => {
try {
const url = getUrlEntrepriseApiV3(sirenOuSiret, type);
const response = await fetch(url);
if (!response.ok) {
throw new Error(`Error fetching data: ${response.statusText}`);
}
const result = await response.json();
setEntreprise(result);
setError(null);
} catch (err) {
setError(err.message);
setEntreprise(null);
}
};

return { search, entreprise, error };
};

Check warning on line 41 in src/views/candidature-structure/useSiretApi.js

View workflow job for this annotation

GitHub Actions / lint

Newline required at end of file but not found

0 comments on commit 37c9b5e

Please sign in to comment.