Skip to content

Commit

Permalink
feat: add search by region & add sidebar anchors for finance and mand…
Browse files Browse the repository at this point in the history
…ataires
  • Loading branch information
ImenOuidou committed Jan 22, 2024
1 parent 3e04971 commit 5d6814d
Show file tree
Hide file tree
Showing 9 changed files with 225 additions and 84 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -42,12 +42,47 @@ const EnterpriseInfos = ({ enterprise: baseEntreprise }) => {
const location = useLocation();
useEffect(() => {
const hash = window.location.hash;
if (location.pathname.includes("enterprise") && hash === "#mandataires") {

const checkAndScroll = (elementId) => {
const element = document.getElementById(elementId);
const headerOffset = document.getElementById("header")?.offsetHeight || 0;
if (element) {
const position = element.offsetTop - headerOffset;
window.scrollTo({
behavior: "smooth",
top: position,
});
return true;
}
return false;
};

const setupScroll = (targetId) => {
if (!checkAndScroll(targetId)) {
const interval = setInterval(() => {
if (checkAndScroll(targetId)) {
clearInterval(interval);
}
}, 100);
}
window.addEventListener("resize", () => checkAndScroll(targetId));
return () =>
window.removeEventListener("resize", () => checkAndScroll(targetId));
};

if (location.pathname.includes("enterprise")) {
if (hash === "#mandataires") {
return setupScroll("mandataires");
}
if (hash === "#finance-data") {
return setupScroll("finance-data");
}
}
if (location.pathname.includes("enterprise") && hash === "#finance-data") {
const checkAndScroll = () => {
const element = document.getElementById("mandataires");
const element = document.getElementById("finance-data");
const headerOffset =
document.getElementById("header")?.offsetHeight || 0; // Dynamic header height
console.log(document.getElementById("header"));
if (element) {
const position = element.offsetTop - headerOffset; // Subtract header height
window.scrollTo({
Expand All @@ -59,20 +94,16 @@ const EnterpriseInfos = ({ enterprise: baseEntreprise }) => {
return false;
};

// Check if element is available and scroll to it
if (!checkAndScroll()) {
// If element is not available, set an interval to check again
const interval = setInterval(() => {
if (checkAndScroll()) {
clearInterval(interval); // Clear interval once the element is found
clearInterval(interval);
}
}, 100); // Check every 100ms
}, 100);
}

// Add resize event listener
window.addEventListener("resize", checkAndScroll);

// Clean up interval and remove event listener on component unmount
return () => {
window.removeEventListener("resize", checkAndScroll);
};
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -139,7 +139,7 @@ const Finances = ({ siret, siren }) => {
});
}
return (
<>
<div id="finance-data">
{hasBilan_K && (
<span className="text">
Cette entreprise déclare un bilan consolidé, voir sur{" "}
Expand Down Expand Up @@ -222,7 +222,7 @@ const Finances = ({ siret, siren }) => {
Non disponible
</p>
)}
</>
</div>
);
};

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -4,9 +4,9 @@ import { pipe } from "lodash/fp";
import { BCE_CLIENT } from "../../../../../services/GraphQL/GraphQL";
import { mapQueryResult } from "../../../../../utils/graphql/graphql";
import {
normalizeInteractions3E,
normalizeInteractions3ESRC,
normalizeInteractionsC,
// normalizeInteractions3E,
// normalizeInteractions3ESRC,
// normalizeInteractionsC,
normalizeInteractionsT,
} from "../../../../../utils/interactions/interactions";

Expand All @@ -20,43 +20,43 @@ const controlesQuery = gql`
denominationusuelleetablissement
}
}
fce_interactions_pole_t(where: { siret: { _eq: $siret } }) {
date
intervenant
action_sur
realise_pour
siret
}
fce_interactions_pole_3e(where: { siret: { _eq: $siret } }) {
inspecteurs
date_visite
type_suivi
region
siret
}
fce_interactions_pole_3e_src(where: { siret: { _eq: $siret } }) {
date
libelle_region
siret
type_controle
nature_controle
cible_controle
clos
}
# fce_interactions_pole_t(where: { siret: { _eq: $siret } }) {
# date
# intervenant
# action_sur
# realise_pour
# siret
# }
# fce_interactions_pole_3e(where: { siret: { _eq: $siret } }) {
# inspecteurs
# date_visite
# type_suivi
# region
# siret
# }
# fce_interactions_pole_3e_src(where: { siret: { _eq: $siret } }) {
# date
# libelle_region
# siret
# type_controle
# nature_controle
# cible_controle
# clos
# }
}
`;

const normalizeResponsesToInteraction = ({
fce_interactions_pole_3e,
fce_interactions_pole_3e_src,
fce_interactions_pole_c,
// fce_interactions_pole_3e,
// fce_interactions_pole_3e_src,
// fce_interactions_pole_c,
fce_interactions_pole_t,
}) => ({
interactions_pole_3e: normalizeInteractions3E(fce_interactions_pole_3e),
interactions_pole_3e_src: normalizeInteractions3ESRC(
fce_interactions_pole_3e_src
),
interactions_pole_c: normalizeInteractionsC(fce_interactions_pole_c),
// interactions_pole_3e: normalizeInteractions3E(fce_interactions_pole_3e),
// interactions_pole_3e_src: normalizeInteractions3ESRC(
// fce_interactions_pole_3e_src
// ),
// interactions_pole_c: normalizeInteractionsC(fce_interactions_pole_c),
interactions_pole_t: normalizeInteractionsT(fce_interactions_pole_t),
});

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -45,7 +45,7 @@ const Controles = ({ siret }) => {
<div className=" direccte-interactions__title">
<span className="text">
Dernier contrôle ou visite au cours des 24 derniers mois (Pôle
T, Pôle C, Pôle 3E)
T, Pôle C, Pôle ES)
</span>
</div>
<div className="data-sheet--table data-sheet--table-to-left">
Expand Down
37 changes: 37 additions & 0 deletions src/client/src/components/DataSheets/Sidebar/Sidebar.js
Original file line number Diff line number Diff line change
Expand Up @@ -92,6 +92,43 @@ const Sidebar = ({
}}
>
Entreprise
{!isEntrepriseDisplayed && (
<div className="anchors">
<div>
<span className="ellipse-span">
<EllipseIconAside color={"#e3e3fd"} />
</span>
<a
href={`/enterprise/${siren}#finance-data`}
className={"active-anchor"}
>
{"Données financières"}
</a>
</div>
<div>
<span className="ellipse-span">
<EllipseIconAside color={"#e3e3fd"} />
</span>
<a
href={`/enterprise/${siren}#mandataires`}
className={"active-anchor"}
>
{"Mandataires"}
</a>
</div>
<div>
<span className="ellipse-span">
<EllipseIconAside color={"#e3e3fd"} />
</span>
<a
href={`/enterprise/${siren}`}
className={"active-anchor"}
>
{"..."}
</a>
</div>
</div>
)}
</button>
{isEntrepriseDisplayed && (
<div className="anchors">
Expand Down
3 changes: 0 additions & 3 deletions src/client/src/components/DataSheets/Sidebar/sidebar.scss
Original file line number Diff line number Diff line change
Expand Up @@ -183,7 +183,4 @@ $border-color: var(--border-color);
margin-bottom: $spacing-3;
}
}



}
111 changes: 82 additions & 29 deletions src/client/src/components/Search/Filters/LocationFilter.js
Original file line number Diff line number Diff line change
Expand Up @@ -7,13 +7,16 @@ import Config from "../../../services/Config";
import {
searchCommune,
searchDepartement,
searchRegion,
serachDepartementsByRegion,
} from "../../../services/LocationSearch/LocationSearch";
import { selectCustomStyles } from "./customStyles";

const searchLocation = async (query) => {
const [departements, communes] = await Promise.all([
const [departements, communes, regions] = await Promise.all([
searchDepartement(query),
searchCommune(query),
searchRegion(query),
]);
const formattedDepartements = departements.map(({ code, nom }) => ({
label: `${nom} (${code})`,
Expand All @@ -26,10 +29,22 @@ const searchLocation = async (query) => {
type: "commune",
value: code,
}));
const formattedRegions = regions?.map(({ code, nom }) => ({
label: nom,
type: "region",
value: code,
}));

const options = [];

if (formattedDepartements.length > 0) {
if (formattedRegions.length > 0) {
options.push({
label: "REGIONS",
options: formattedRegions,
});
}

options.push({
label: "DÉPARTEMENTS",
options: formattedDepartements,
Expand All @@ -48,34 +63,72 @@ const searchLocation = async (query) => {

const throttledSearch = pDebounce(searchLocation, 300);

const LocationFilter = ({ filters, addFilter, removeFilter }) => (
<div className="control is-expanded select-control-field ">
<AsyncSelect
id="location"
name="location"
placeholder={<div className="select_placeholder">Zone géographique</div>}
isMulti
defaultOptions={[]}
loadOptions={throttledSearch}
onChange={(location) => {
location ? addFilter("location", location) : removeFilter("location");
}}
components={{
IndicatorSeparator: () => null,
}}
loadingMessage={() => "Chargement..."}
noOptionsMessage={(term) =>
term.inputValue.length >= Config.get("advancedSearch").minTerms
? "Aucun résultat"
: `Veuillez saisir au moins ${
Config.get("advancedSearch").minTerms
} caractères`
}
value={filters?.location || []}
styles={selectCustomStyles}
/>
</div>
);
const LocationFilter = ({ filters, addFilter, removeFilter }) => {
const addAddress = (locations) => {
Promise.all(
locations.map(async (loc) => {
const { type, value, label, regions } = loc;

if (type === "region" && !regions) {
try {
const data = await serachDepartementsByRegion(value);
const departementsResult = data.map(({ code, nom }) => ({
label: `${nom} (${code})`,
type: "departement",
value: code,
}));

return {
label: label,
regions: departementsResult,
type: type,
value: value,
};
} catch (error) {
console.error("Error fetching departements:", error);
return loc; // Return the original location in case of an error
}
} else {
return loc; // Return the original location for non-region types
}
})
).then((updatedLocations) => {
// Update the filter with the new array of locations
addFilter("location", updatedLocations);
});
};

return (
<div className="control is-expanded select-control-field ">
<AsyncSelect
id="location"
name="location"
placeholder={
<div className="select_placeholder">Zone géographique</div>
}
isMulti
defaultOptions={[]}
loadOptions={throttledSearch}
onChange={(location) => {
location ? addAddress(location) : removeFilter("location");
}}
components={{
IndicatorSeparator: () => null,
}}
loadingMessage={() => "Chargement..."}
noOptionsMessage={(term) =>
term.inputValue.length >= Config.get("advancedSearch").minTerms
? "Aucun résultat"
: `Veuillez saisir au moins ${
Config.get("advancedSearch").minTerms
} caractères`
}
value={filters?.location || []}
styles={selectCustomStyles}
/>
</div>
);
};

LocationFilter.propTypes = {
addFilter: PropTypes.func.isRequired,
Expand Down
Loading

0 comments on commit 5d6814d

Please sign in to comment.