From e8b8e6b9130cc76264ffaecb7467956551926a3b Mon Sep 17 00:00:00 2001 From: Remko Date: Mon, 23 Oct 2023 12:56:26 +0200 Subject: [PATCH 1/5] updated template to accommodate mobile use --- pwa/package.json | 2 +- .../ResultsDisplaySwitch.module.css | 17 ++ .../landing/LandingTemplate.module.css | 18 ++ .../CardsResultsTemplate.module.css | 13 + .../filters/FiltersTemplate.module.css | 25 ++ .../footer/FooterTemplate.module.css | 30 +- .../WOOItemDetailTemplate.tsx | 284 +++++++++--------- 7 files changed, 248 insertions(+), 141 deletions(-) diff --git a/pwa/package.json b/pwa/package.json index 6d6751db..3c012350 100644 --- a/pwa/package.json +++ b/pwa/package.json @@ -25,7 +25,7 @@ }, "dependencies": { "@conduction/components": "2.2.18", - "@conduction/theme": "1.0.50", + "@conduction/theme": "1.0.51", "@fortawesome/fontawesome-svg-core": "^6.1.1", "@fortawesome/free-solid-svg-icons": "^6.4.0", "@fortawesome/react-fontawesome": "^0.1.18", diff --git a/pwa/src/components/resultsDisplaySwitch/ResultsDisplaySwitch.module.css b/pwa/src/components/resultsDisplaySwitch/ResultsDisplaySwitch.module.css index db3cb651..6ac3abe6 100644 --- a/pwa/src/components/resultsDisplaySwitch/ResultsDisplaySwitch.module.css +++ b/pwa/src/components/resultsDisplaySwitch/ResultsDisplaySwitch.module.css @@ -7,3 +7,20 @@ .button:hover { cursor: pointer; } + +@media only screen and (max-width: 992px) { + /* Tablet */ + .container { + margin-inline-start: unset; + display: flex; + } +} + +@media only screen and (max-width: 576px) { + /* Mobile */ + .container { + margin-inline-start: unset; + justify-content: center; + display: flex; + } +} diff --git a/pwa/src/templates/landing/LandingTemplate.module.css b/pwa/src/templates/landing/LandingTemplate.module.css index ddb02a7a..587afc40 100644 --- a/pwa/src/templates/landing/LandingTemplate.module.css +++ b/pwa/src/templates/landing/LandingTemplate.module.css @@ -10,3 +10,21 @@ display: flex; justify-content: space-between; } + +@media only screen and (max-width: 576px) { + /* Mobile */ + .container { + margin-block-start: unset; + } + + .container > *:not(:last-child) { + margin-block-end: var(--utrecht-space-block-2xl); + } + + .pagination { + display: grid; + justify-content: unset; + justify-items: center; + margin-block-start: var(--utrecht-space-block-lg); + } +} diff --git a/pwa/src/templates/templateParts/cardsResultsTemplate/CardsResultsTemplate.module.css b/pwa/src/templates/templateParts/cardsResultsTemplate/CardsResultsTemplate.module.css index 5b12176b..23365624 100644 --- a/pwa/src/templates/templateParts/cardsResultsTemplate/CardsResultsTemplate.module.css +++ b/pwa/src/templates/templateParts/cardsResultsTemplate/CardsResultsTemplate.module.css @@ -25,3 +25,16 @@ .description { color: var(--conduction-card-wrapper-color) !important; } + +@media only screen and (max-width: 992px) { + /* Tablet */ + .componentsGrid { + grid-template-columns: repeat(2, minmax(0, 1fr)); + } +} +@media only screen and (max-width: 576px) { + /* Mobile */ + .componentsGrid { + grid-template-columns: repeat(1, minmax(0, 1fr)); + } +} diff --git a/pwa/src/templates/templateParts/filters/FiltersTemplate.module.css b/pwa/src/templates/templateParts/filters/FiltersTemplate.module.css index a0850fda..66258cd7 100644 --- a/pwa/src/templates/templateParts/filters/FiltersTemplate.module.css +++ b/pwa/src/templates/templateParts/filters/FiltersTemplate.module.css @@ -33,3 +33,28 @@ transform: rotate(360deg); } } + +@media only screen and (max-width: 992px) { + /* Tablet */ + .container { + display: grid; + justify-content: unset; + } + + .form { + margin-block-end: 12px; + } +} + +@media only screen and (max-width: 576px) { + /* Mobile */ + .container { + display: grid; + justify-content: unset; + } + + .form { + display: grid; + margin-block-end: 12px; + } +} diff --git a/pwa/src/templates/templateParts/footer/FooterTemplate.module.css b/pwa/src/templates/templateParts/footer/FooterTemplate.module.css index d5e22e04..4315112c 100644 --- a/pwa/src/templates/templateParts/footer/FooterTemplate.module.css +++ b/pwa/src/templates/templateParts/footer/FooterTemplate.module.css @@ -56,7 +56,7 @@ .contentGrid { gap: 28px; display: grid; - grid-template-columns: 1fr 1fr 1fr; + grid-template-columns: repeat(3, minmax(0, 1fr)); } .dynamicSectionTitle { @@ -76,3 +76,31 @@ justify-content: space-between; align-items: flex-end; } + +@media only screen and (max-width: 992px) { + /* Tablet */ + .contentGrid { + grid-template-columns: repeat(2, minmax(0, 1fr)); + } +} + +@media only screen and (max-width: 576px) { + /* Mobile */ + .footer { + background-position: var( + --utrecht-page-footer-mobile-background-position, + var(--utrecht-page-footer-background-position) + ); + } + .contentGrid { + grid-template-columns: repeat(1, minmax(0, 1fr)); + } + + .imageContainer { + margin-block-end: 15px; + } + + .logoAndConduction { + display: block; + } +} diff --git a/pwa/src/templates/wooItemDetailTemplate/WOOItemDetailTemplate.tsx b/pwa/src/templates/wooItemDetailTemplate/WOOItemDetailTemplate.tsx index 3b618a5d..fc17014a 100644 --- a/pwa/src/templates/wooItemDetailTemplate/WOOItemDetailTemplate.tsx +++ b/pwa/src/templates/wooItemDetailTemplate/WOOItemDetailTemplate.tsx @@ -11,7 +11,6 @@ import { UnorderedList, UnorderedListItem, Link, - Icon, } from "@utrecht/component-library-react/dist/css-module"; import { translateDate } from "../../services/dateFormat"; import { useTranslation } from "react-i18next"; @@ -23,7 +22,7 @@ import { useOpenWoo } from "../../hooks/openWoo"; import Skeleton from "react-loading-skeleton"; import { getPDFName } from "../../services/getPDFName"; import { isUUID } from "../../services/isUUID"; -import { getBijlageTitleFromURL } from "../../services/getNameFromBijlageArray"; +import { HorizontalOverflowWrapper } from "@conduction/components"; interface WOOItemDetailTemplateProps { wooItemId: string; @@ -50,144 +49,151 @@ export const WOOItemDetailTemplate: React.FC = ({ wo {getItems.data.Titel !== "" ? getItems.data.Titel : t("No title available")} - - - {getItems.data.ID && ( - - {t("Feature")} - {isUUID(getItems.data.ID) ? getItems.data.Object_ID : getItems.data.ID} - - )} - - {getItems.data.Titel && ( - - {t("Category")} - {getItems.data.Categorie ?? "-"} - - )} - - {getItems.data.Samenvatting && ( - - {t("Summary")} - {getItems.data.Samenvatting} - - )} - {getItems.data.Beschrijving && ( - - {t("Description")} - {getItems.data.Beschrijving} - - )} - - {getItems.data.Termijnoverschrijding && ( - - {t("Exceeding the term")} - {getItems.data.Termijnoverschrijding} - - )} - - {getItems.data.Publicatiedatum && ( - - {t("Publication date")} - - {getItems.data.Publicatiedatum - ? translateDate(i18n.language, getItems.data.Publicatiedatum) - : "-"} - - - )} - - {getItems.data.Ontvangstdatum && ( - - {t("Registration date")} - - {translateDate(i18n.language, getItems.data.Ontvangstdatum) ?? "-"} - - )} - - {getItems.data.Besluitdatum && ( - - {t("Decision date")} - {translateDate(i18n.language, getItems.data.Besluitdatum) ?? "-"} - - )} - - {getItems.data?.embedded?.Themas && ( - - {t("Themes")} - - {getItems.data?.embedded?.Themas.map((thema: any, idx: number) => ( - - {thema.Hoofdthema + (idx !== getItems.data?.embedded?.Themas.length - 1 ? ", " : "")} - - ))} - - - )} - - {getItems.data?.embedded?.informatieverzoek && ( - - {t("Information request")} - - - {getItems.data?.embedded?.informatieverzoek?.Titel_Bijlage} - - - - )} - - {(getItems.data.Besluit || (getItems.data?.embedded?.besluit ?? getItems.data.URL_besluit)) && ( - - {t("Decision")} - - {getItems.data.Besluit} - {getItems.data.Besluit && - (getItems.data?.embedded?.besluit ?? getItems.data.URL_besluit) && - ","}{" "} - {(getItems.data?.embedded?.besluit ?? getItems.data.URL_besluit) && ( - - {getItems.data?.embedded?.besluit?.Titel_Bijlage ?? getPDFName(getItems.data.URL_besluit)} - - )} - - - )} - - {getItems.data?.embedded?.inventarisatielijst && ( - - {t("Inventory list")} - - - {getItems.data?.embedded?.inventarisatielijst?.Titel_Bijlage} - - - - )} - - {getItems.data?.embedded?.Bijlagen && ( - - {t("Attachments")} - - - {getItems.data?.embedded?.Bijlagen.map((bijlage: any, idx: number) => ( - - - {bijlage.Titel_Bijlage} - - + +
+ + {getItems.data.ID && ( + + {t("Feature")} + {isUUID(getItems.data.ID) ? getItems.data.Object_ID : getItems.data.ID} + + )} + + {getItems.data.Titel && ( + + {t("Category")} + {getItems.data.Categorie ?? "-"} + + )} + + {getItems.data.Samenvatting && ( + + {t("Summary")} + {getItems.data.Samenvatting} + + )} + {getItems.data.Beschrijving && ( + + {t("Description")} + {getItems.data.Beschrijving} + + )} + + {getItems.data.Termijnoverschrijding && ( + + {t("Exceeding the term")} + {getItems.data.Termijnoverschrijding} + + )} + + {getItems.data.Publicatiedatum && ( + + {t("Publication date")} + + {getItems.data.Publicatiedatum + ? translateDate(i18n.language, getItems.data.Publicatiedatum) + : "-"} + + + )} + + {getItems.data.Ontvangstdatum && ( + + {t("Registration date")} + + {translateDate(i18n.language, getItems.data.Ontvangstdatum) ?? "-"} + + )} + + {getItems.data.Besluitdatum && ( + + {t("Decision date")} + {translateDate(i18n.language, getItems.data.Besluitdatum) ?? "-"} + + )} + + {getItems.data?.embedded?.Themas && ( + + {t("Themes")} + + {getItems.data?.embedded?.Themas.map((thema: any, idx: number) => ( + + {thema.Hoofdthema + (idx !== getItems.data?.embedded?.Themas.length - 1 ? ", " : "")} + ))} - - - - )} - -
+ + + )} + + {getItems.data?.embedded?.informatieverzoek && ( + + {t("Information request")} + + + {getItems.data?.embedded?.informatieverzoek?.Titel_Bijlage} + + + + )} + + {(getItems.data.Besluit || (getItems.data?.embedded?.besluit ?? getItems.data.URL_besluit)) && ( + + {t("Decision")} + + {getItems.data.Besluit} + {getItems.data.Besluit && + (getItems.data?.embedded?.besluit ?? getItems.data.URL_besluit) && + ","}{" "} + {(getItems.data?.embedded?.besluit ?? getItems.data.URL_besluit) && ( + + {getItems.data?.embedded?.besluit?.Titel_Bijlage ?? getPDFName(getItems.data.URL_besluit)} + + )} + + + )} + + {getItems.data?.embedded?.inventarisatielijst && ( + + {t("Inventory list")} + + + {getItems.data?.embedded?.inventarisatielijst?.Titel_Bijlage} + + + + )} + + {getItems.data?.embedded?.Bijlagen && ( + + {t("Attachments")} + + + {getItems.data?.embedded?.Bijlagen.map((bijlage: any, idx: number) => ( + + + {bijlage.Titel_Bijlage} + + + ))} + + + + )} + + + )} {getItems.isLoading && } From f885579e521ce0d0106edf12ec494a53db33b447 Mon Sep 17 00:00:00 2001 From: Remko Date: Mon, 23 Oct 2023 13:39:22 +0200 Subject: [PATCH 2/5] updated version of conduction-theme --- pwa/package-lock.json | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/pwa/package-lock.json b/pwa/package-lock.json index b5b625ed..900f2005 100644 --- a/pwa/package-lock.json +++ b/pwa/package-lock.json @@ -9,7 +9,7 @@ "version": "1.0.0", "dependencies": { "@conduction/components": "2.2.18", - "@conduction/theme": "1.0.50", + "@conduction/theme": "1.0.51", "@fortawesome/fontawesome-svg-core": "^6.1.1", "@fortawesome/free-solid-svg-icons": "^6.4.0", "@fortawesome/react-fontawesome": "^0.1.18", @@ -2112,9 +2112,9 @@ } }, "node_modules/@conduction/theme": { - "version": "1.0.50", - "resolved": "https://registry.npmjs.org/@conduction/theme/-/theme-1.0.50.tgz", - "integrity": "sha512-VdkN12+r12WORjVtl2W1kSLMaeZLtqRdrwtHJKuuUFGZmUnqDoxrdjPnX9c5in+MROLgIbBN1Xp/8/Ucy/Y6Lg==", + "version": "1.0.51", + "resolved": "https://registry.npmjs.org/@conduction/theme/-/theme-1.0.51.tgz", + "integrity": "sha512-rRp8SMHYU7EYrgXNR/z5+X6/rB6XNrXrJ3WnmBEu+jYLKJqpbhluPUPhHvWEJmRAYNDo1rEYyYK27JljgGe89w==", "dependencies": { "@nl-design-system-unstable/rotterdam-design-tokens": "^1.0.0-alpha.100" } From b9176f0c06e3e3ee6d0b3da525c03e79f481d4b7 Mon Sep 17 00:00:00 2001 From: Remko Date: Mon, 23 Oct 2023 14:21:27 +0200 Subject: [PATCH 3/5] fixed filters to close to jumbotron --- pwa/src/templates/landing/LandingTemplate.module.css | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/pwa/src/templates/landing/LandingTemplate.module.css b/pwa/src/templates/landing/LandingTemplate.module.css index 587afc40..342d9a5b 100644 --- a/pwa/src/templates/landing/LandingTemplate.module.css +++ b/pwa/src/templates/landing/LandingTemplate.module.css @@ -14,7 +14,7 @@ @media only screen and (max-width: 576px) { /* Mobile */ .container { - margin-block-start: unset; + margin-block-start: var(--utrecht-space-block-lg) !important; } .container > *:not(:last-child) { From 8c16738b8f61c5763cb9335ec2d17b26b9a1488b Mon Sep 17 00:00:00 2001 From: Remko Date: Tue, 24 Oct 2023 11:18:39 +0200 Subject: [PATCH 4/5] simplified year param --- pwa/src/services/filtersToQueryParams.ts | 12 ++++++++++++ .../templateParts/filters/FiltersTemplate.tsx | 2 +- 2 files changed, 13 insertions(+), 1 deletion(-) diff --git a/pwa/src/services/filtersToQueryParams.ts b/pwa/src/services/filtersToQueryParams.ts index 8a15c6f3..0ed45f21 100644 --- a/pwa/src/services/filtersToQueryParams.ts +++ b/pwa/src/services/filtersToQueryParams.ts @@ -1,3 +1,5 @@ +import { generateYearsArray } from "../data/years"; + export const filtersToQueryParams = (filters: any): string => { const cleanedFilters = Object.fromEntries( Object.entries(filters).filter(([key]) => !filterKeysToRemove.includes(key)), @@ -20,6 +22,9 @@ export const filtersToQueryParams = (filters: any): string => { }; export const filtersToUrlQueryParams = (filters: Record): string => { + const today = new Date(); + const currentYear = today.getFullYear(); + const cleanedFilters = Object.fromEntries( Object.entries(filters).filter(([key]) => !filterKeysToRemove.includes(key)), ); @@ -32,6 +37,13 @@ export const filtersToUrlQueryParams = (filters: Record): string => ? value.map((v: string) => v.replace(/\s+/g, "_")).join(`&${key}[]=`) : (value as string).replace(/\s+/g, "_"); + if (key == "Publicatiedatum[after]") return; + if (key == "Publicatiedatum[before]") + return `year=${ + generateYearsArray(currentYear - 1995).find((year: any) => { + return year.before === value; + })?.value + }`; return `${Array.isArray(value) ? `${key}[]` : key}=${formattedValue}`; }) .filter(Boolean) diff --git a/pwa/src/templates/templateParts/filters/FiltersTemplate.tsx b/pwa/src/templates/templateParts/filters/FiltersTemplate.tsx index 34dcc340..2fbcf381 100644 --- a/pwa/src/templates/templateParts/filters/FiltersTemplate.tsx +++ b/pwa/src/templates/templateParts/filters/FiltersTemplate.tsx @@ -52,7 +52,7 @@ export const FiltersTemplate: React.FC = ({ isLoading }) = setValue( "year", generateYearsArray(currentYear - 1995).find((year: any) => { - return year.after === params.Publicatiedatum?.after && year.before === params.Publicatiedatum?.before; + return year.value === params.year; }), ); From ec91d362906885ede7e7105560eb7ef1a077568c Mon Sep 17 00:00:00 2001 From: Remko Date: Tue, 24 Oct 2023 13:07:16 +0200 Subject: [PATCH 5/5] hotfix filters --- pwa/src/services/filtersToQueryParams.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/pwa/src/services/filtersToQueryParams.ts b/pwa/src/services/filtersToQueryParams.ts index 8a15c6f3..ec2df5f6 100644 --- a/pwa/src/services/filtersToQueryParams.ts +++ b/pwa/src/services/filtersToQueryParams.ts @@ -9,7 +9,7 @@ export const filtersToQueryParams = (filters: any): string => { const formattedValue = Array.isArray(value) ? value.map((v: string) => v.replace(/\s+/g, "_")).join(`&${key}[]=`) - : (value as string).replace(/\s+/g, "_"); + : (value as string); return `${Array.isArray(value) ? `${key}[]` : key}=${formattedValue}`; })