From d6fb5273f6bb79f303e048c7266d52d2c5c0a8af Mon Sep 17 00:00:00 2001 From: Dylan Decrulle <81740200+ddecrulle@users.noreply.github.com> Date: Thu, 21 Mar 2024 10:02:07 +0100 Subject: [PATCH] update document title and change filename of downloaded data --- .../Orchestrator/CustomPages/EndPage.tsx | 4 ++-- src/components/Orchestrator/Orchestrator.tsx | 12 ++++++++---- src/components/Orchestrator/slotComponents.tsx | 16 ++++++++++++++++ src/hooks/useDocumentTitle.ts | 17 ++++++++++++++++- src/pages/Accessibility/route.ts | 3 ++- src/pages/Legals/route.ts | 3 ++- src/pages/NavigationAssistance/route.ts | 3 ++- src/pages/Security/route.ts | 3 ++- src/pages/SiteMap/route.ts | 3 ++- src/pages/Visualize/route.ts | 3 ++- 10 files changed, 54 insertions(+), 13 deletions(-) create mode 100644 src/components/Orchestrator/slotComponents.tsx diff --git a/src/components/Orchestrator/CustomPages/EndPage.tsx b/src/components/Orchestrator/CustomPages/EndPage.tsx index f13c0da1..17cb2b37 100644 --- a/src/components/Orchestrator/CustomPages/EndPage.tsx +++ b/src/components/Orchestrator/CustomPages/EndPage.tsx @@ -1,5 +1,5 @@ -export function EndPage(props: { date: number }) { - const { date } = props +export function EndPage(props: { date: number | undefined }) { + const { date = Date.now() } = props const formatedData = new Date(date).toLocaleString() return ( <> diff --git a/src/components/Orchestrator/Orchestrator.tsx b/src/components/Orchestrator/Orchestrator.tsx index 0a91b080..e998c758 100644 --- a/src/components/Orchestrator/Orchestrator.tsx +++ b/src/components/Orchestrator/Orchestrator.tsx @@ -4,7 +4,6 @@ import { type LunaticSource, type LunaticError, } from '@inseefr/lunatic' -import { slotComponents } from '@inseefr/lunatic-dsfr' import { fr } from '@codegouvfr/react-dsfr' import { downloadAsJson } from 'utils/downloadAsJson' import { useNavigate } from '@tanstack/react-router' @@ -19,6 +18,7 @@ import { assert } from 'tsafe/assert' import type { SurveyUnitData } from 'model/SurveyUnitData' import type { StateData } from 'model/StateData' import { isBlockingError, isSameErrors } from './utils/controls' +import { slotComponents } from './slotComponents' export function Orchestrator(props: { source: LunaticSource @@ -95,7 +95,7 @@ export function Orchestrator(props: { }, }) - const getStateData = (): StateData => { + const getCurrentStateData = (): StateData => { switch (currentPage) { case 'endPage': return { date: Date.now(), currentPage, state: 'VALIDATED' } @@ -115,9 +115,11 @@ export function Orchestrator(props: { downloadAsJson({ dataToDownload: { data: getData(false), - stateData: getStateData(), + stateData: getCurrentStateData(), personalization: surveyUnitData?.personalization, }, + //The label of source is not dynamic + filename: `${source.label.value}-${new Date().toLocaleDateString()}`, }) } @@ -158,7 +160,9 @@ export function Orchestrator(props: { /> )} {currentPage === 'validationPage' && } - {currentPage === 'endPage' && } + {currentPage === 'endPage' && ( + + )} diff --git a/src/components/Orchestrator/slotComponents.tsx b/src/components/Orchestrator/slotComponents.tsx new file mode 100644 index 00000000..eafe8a5f --- /dev/null +++ b/src/components/Orchestrator/slotComponents.tsx @@ -0,0 +1,16 @@ +import type { LunaticSlotComponents } from '@inseefr/lunatic' +import { slotComponents as dsfrSlotsComponents } from '@inseefr/lunatic-dsfr' +import { useSequenceTitle } from 'hooks/useDocumentTitle' +import { assert } from 'tsafe/assert' + +const Sequence: LunaticSlotComponents['Sequence'] = (props) => { + const DsfrSequence = dsfrSlotsComponents['Sequence'] + + assert(DsfrSequence !== undefined) + + useSequenceTitle(props.label) + + return +} + +export const slotComponents = { ...dsfrSlotsComponents, Sequence } diff --git a/src/hooks/useDocumentTitle.ts b/src/hooks/useDocumentTitle.ts index 133118bc..8c8ab848 100644 --- a/src/hooks/useDocumentTitle.ts +++ b/src/hooks/useDocumentTitle.ts @@ -1,11 +1,26 @@ -import { useEffect } from 'react' +import { useEffect, type ReactNode } from 'react' +import { renderToString } from 'react-dom/server' export function useDocumentTitle(title: string) { useEffect(() => { + const prevTitle = document.title + document.title = title + return () => { document.title = prevTitle } }) } + +export function useSequenceTitle(sequenceLabel: ReactNode) { + //TODO get the name of the site (in metadata.json I hope) + /** + * This is a dirty, sequenceLabel is today a LabelType VTL|MD, + * it will be replaced by VTL only so we will be able to just sequenceLabel.toString() + */ + return useDocumentTitle( + `${renderToString(sequenceLabel)} | Filière d'Enquête` + ) +} diff --git a/src/pages/Accessibility/route.ts b/src/pages/Accessibility/route.ts index 0f4fa34f..c2d7b93c 100644 --- a/src/pages/Accessibility/route.ts +++ b/src/pages/Accessibility/route.ts @@ -7,6 +7,7 @@ export const accessibilityRoute = createRoute({ path: 'accessibilite', component: AccessibilityPage, loader: () => { - document.title = 'Accessibilité' + //TODO get name (Filière d'Enquête) in metadata + document.title = "Accessibilité | Filière d'Enquête" }, }) diff --git a/src/pages/Legals/route.ts b/src/pages/Legals/route.ts index 59aa8ccd..5937e314 100644 --- a/src/pages/Legals/route.ts +++ b/src/pages/Legals/route.ts @@ -7,6 +7,7 @@ export const legalsRoute = createRoute({ path: 'mentions-legales', component: LegalPage, loader: () => { - document.title = 'Mentions Légales' + //TODO get name (Filière d'Enquête) in metadata + document.title = "Mentions Légales | Filière d'Enquête" }, }) diff --git a/src/pages/NavigationAssistance/route.ts b/src/pages/NavigationAssistance/route.ts index 63b08843..13ecd3f0 100644 --- a/src/pages/NavigationAssistance/route.ts +++ b/src/pages/NavigationAssistance/route.ts @@ -7,6 +7,7 @@ export const navigationAssistanceRoute = createRoute({ path: 'aide-a-la-navigation', component: NavigationAssistancePage, loader: () => { - document.title = 'Aide à la navigation' + //TODO get name (Filière d'Enquête) in metadata + document.title = "Aide à la navigation | Filière d'Enquête" }, }) diff --git a/src/pages/Security/route.ts b/src/pages/Security/route.ts index 0fb85701..e007ad90 100644 --- a/src/pages/Security/route.ts +++ b/src/pages/Security/route.ts @@ -7,6 +7,7 @@ export const securityRoute = createRoute({ path: 'securite', component: SecurityPage, loader: () => { - document.title = 'Sécurité' + //TODO get name (Filière d'Enquête) in metadata + document.title = "Sécurité | Filière d'Enquête" }, }) diff --git a/src/pages/SiteMap/route.ts b/src/pages/SiteMap/route.ts index 210c57e4..2d9ac519 100644 --- a/src/pages/SiteMap/route.ts +++ b/src/pages/SiteMap/route.ts @@ -7,6 +7,7 @@ export const siteMapRoute = createRoute({ path: 'plan-du-site', component: SiteMapPage, loader: () => { - document.title = 'Plan du site' + //TODO get name (Filière d'Enquête) in metadata + document.title = "Plan du site | Filière d'Enquête" }, }) diff --git a/src/pages/Visualize/route.ts b/src/pages/Visualize/route.ts index d6e90305..d0b96719 100644 --- a/src/pages/Visualize/route.ts +++ b/src/pages/Visualize/route.ts @@ -29,7 +29,8 @@ export const visualizeRoute = createRoute({ context: { queryClient }, deps: { sourceUrl, surveyUnitDataUrl, metadataUrl, nomenclature }, }) => { - document.title = 'Visualisation' + //TODO get name (Filière d'Enquête) in metadata + document.title = "Visualisation | Filière d'Enquête" if (!sourceUrl) { return