Skip to content

Commit

Permalink
Merge pull request #1439 from danskernesdigitalebibliotek/develop
Browse files Browse the repository at this point in the history
Release 2024.38.0
  • Loading branch information
kasperg authored Sep 17, 2024
2 parents f2db689 + 3d2fc45 commit 65e8999
Show file tree
Hide file tree
Showing 23 changed files with 564 additions and 122 deletions.
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
{
"id" : "d25c69b9-da31-4c2a-bc7f-41739eb13e40",
"name" : "Opening hours today",
"request": {
"urlPattern": "/api/v1/opening_hours\\?from_date=.*&to_date=.*",
"method": "GET"
},
"response": {
"status": 200,
"body": "[\n {\n \"id\": 12,\n \"category\": {\n \"title\": \"Åbent\",\n \"color\": \"#4986E7\"\n },\n \"date\": \"{{request.query.from_date}}\",\n \"start_time\": \"08:00\",\n \"end_time\": \"17:00\",\n \"branch_id\": 10,\n \"repetition\": {\n \"id\": 12,\n \"type\": \"none\"\n }\n },\n {\n \"id\": 20,\n \"category\": {\n \"title\": \"Borgerservice\",\n \"color\": \"#4986E7\"\n },\n \"date\": \"{{request.query.from_date}}\",\n \"start_time\": \"09:00\",\n \"end_time\": \"12:00\",\n \"branch_id\": 10,\n \"repetition\": {\n \"id\": 20,\n \"type\": \"none\"\n }\n },\n {\n \"id\": 21,\n \"category\": {\n \"title\": \"Selvbetjening\",\n \"color\": \"#4986E7\"\n },\n \"date\": \"{{request.query.from_date}}\",\n \"start_time\": \"06:00\",\n \"end_time\": \"22:00\",\n \"branch_id\": 10,\n \"repetition\": {\n \"id\": 21,\n \"type\": \"none\"\n }\n },\n {\n \"id\": 22,\n \"category\": {\n \"title\": \"Åbent\",\n \"color\": \"#4986E7\"\n },\n \"date\": \"{{request.query.from_date}}\",\n \"start_time\": \"08:00\",\n \"end_time\": \"16:00\",\n \"branch_id\": 12,\n \"repetition\": {\n \"id\": 22,\n \"type\": \"none\"\n }\n },\n {\n \"id\": 23,\n \"category\": {\n \"title\": \"Med betjening\",\n \"color\": \"#4986E7\"\n },\n \"date\": \"{{request.query.from_date}}\",\n \"start_time\": \"12:00\",\n \"end_time\": \"14:30\",\n \"branch_id\": 12,\n \"repetition\": {\n \"id\": 23,\n \"type\": \"none\"\n }\n },\n {\n \"id\": 24,\n \"category\": {\n \"title\": \"Åbent\",\n \"color\": \"#4986E7\"\n },\n \"date\": \"{{request.query.from_date}}\",\n \"start_time\": \"10:00\",\n \"end_time\": \"17:00\",\n \"branch_id\": 18,\n \"repetition\": {\n \"id\": 24,\n \"type\": \"none\"\n }\n }\n]",
"headers": {
"Content-Type": "application/json"
},
"transformers": ["response-template"]
},
"uuid": "eb4b441b-def3-438b-b473-02a068e30d3f",
"persistent": true,
"priority": 5,
"insertionIndex": 2,
"postServeActions": []
}
1 change: 1 addition & 0 deletions docs/request_mocking_wiremock.md
Original file line number Diff line number Diff line change
Expand Up @@ -39,6 +39,7 @@ We use Wiremock through Docker based on the following setup:
```dotenv
PUBLIZON_BASEURL=http://publizon-mock.docker`
FBS_BASEURL=http://fbs-mock.docker`
CMS_BASEURL=http://cms-mock.docker
```

<!-- markdownlint-disable-next-line MD029 -->
Expand Down
18 changes: 9 additions & 9 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -53,7 +53,7 @@
"@babel/preset-typescript": "^7.24.7",
"@csstools/postcss-sass": "^5.1.1",
"@cypress/browserify-preprocessor": "^3.0.2",
"@cypress/code-coverage": "^3.12.47",
"@cypress/code-coverage": "^3.12.48",
"@graphql-codegen/add": "^3.1.1",
"@graphql-codegen/cli": "^2.6.2",
"@graphql-codegen/introspection": "^2.1.1",
Expand Down Expand Up @@ -82,16 +82,16 @@
"@types/react-redux": "^7.1.24",
"@typescript-eslint/eslint-plugin": "^5.23.0",
"@typescript-eslint/parser": "^7.16.0",
"@vitest/coverage-istanbul": "^2.0.5",
"@vitest/coverage-istanbul": "^2.1.1",
"autoprefixer": "^10.4.20",
"babel-loader": "^9.1.3",
"babel-plugin-istanbul": "^7.0.0",
"babel-plugin-lodash": "^3.3.4",
"babel-plugin-transform-react-remove-prop-types": "^0.4.24",
"caniuse-lite": "^1.0.30001658",
"caniuse-lite": "^1.0.30001660",
"change-case-all": "^2.1.0",
"chokidar-cli": "^3.0.0",
"concurrently": "^9.0.0",
"concurrently": "^9.0.1",
"core-js": "^3.38.1",
"css-loader": "^7.1.2",
"cssnano": "^7.0.6",
Expand All @@ -107,7 +107,7 @@
"eslint-plugin-jsx-a11y": "^6.5.1",
"eslint-plugin-no-only-tests": "^3.3.0",
"eslint-plugin-prettier": "^4.0.0",
"eslint-plugin-react": "^7.35.2",
"eslint-plugin-react": "^7.36.1",
"eslint-plugin-react-hooks": "^4.6.2",
"eslint-webpack-plugin": "^4.2.0",
"glob": "^8.0.1",
Expand All @@ -117,7 +117,7 @@
"mutationobserver-shim": "^0.3.7",
"nyc": "^17.0.0",
"orval": "^6.26.0",
"postcss": "^8.4.45",
"postcss": "^8.4.47",
"postcss-cli": "^11.0.0",
"postcss-loader": "^8.1.1",
"postcss-scss": "^4.0.9",
Expand All @@ -130,7 +130,7 @@
"stylelint-config-prettier": "^9.0.5",
"stylelint-config-recommended-scss": "^6.0.0",
"stylelint-prettier": "^2.0.0",
"stylelint-scss": "^6.5.1",
"stylelint-scss": "^6.6.0",
"stylelint-webpack-plugin": "^5.0.1",
"svg-url-loader": "^8.0.0",
"ts-node": "^10.9.2",
Expand All @@ -145,7 +145,7 @@
"prop-types": "Since we use former ddb-react components that depend on prop-types we keep this. Should be removed when usage of prop-types is deprecated."
},
"dependencies": {
"@danskernesdigitalebibliotek/dpl-design-system": "^2024.37.0-d007a043185fe27649dc16ba7d4996eab9ee1caf",
"@danskernesdigitalebibliotek/dpl-design-system": "^2024.38.0-0dbeffee4f1a1dce73311d4744a9bf02acceeeb1",
"@fullcalendar/core": "^6.1.15",
"@fullcalendar/daygrid": "^6.1.15",
"@fullcalendar/interaction": "^6.1.15",
Expand Down Expand Up @@ -176,6 +176,6 @@
"unfetch": "^4.2.0"
},
"peerDependencies": {
"postcss": "^8.4.45"
"postcss": "^8.4.47"
}
}
5 changes: 5 additions & 0 deletions src/apps/advanced-search/AdvancedSearch.dev.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -200,6 +200,11 @@ export default {
defaultValue: "Add row",
control: { type: "text" }
},
advancedSearchRemoveRowText: {
name: "Remove row",
defaultValue: "Remove row @inputNumber",
control: { type: "text" }
},
advancedSearchInputPlaceholderText: {
name: "Advanced search input placeholder",
defaultValue: "Search term",
Expand Down
1 change: 1 addition & 0 deletions src/apps/advanced-search/AdvancedSearch.entry.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -66,6 +66,7 @@ interface AdvancedSearchEntryTextProps {
advancedSearchFilterNonFictionText: string;
advancedSearchFilterHoldingStatusText: string;
advancedSearchInputLabelText: string;
advancedSearchRemoveRowText: string;
}

interface AdvancedSearchEntryConfigProps {
Expand Down
3 changes: 3 additions & 0 deletions src/apps/advanced-search/AdvancedSearchRow.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -168,6 +168,9 @@ const AdvancedSearchRow: React.FC<AdvancedSearchRowProps> = ({
onClick={() => {
removeRow(rowIndex, setSearchObject);
}}
aria-label={t("advancedSearchRemoveRowText", {
placeholders: { "@inputNumber": rowIndex + 1 }
})}
>
<img className="input-with-dropdown__icon" src={IconMinus} alt="" />
</button>
Expand Down
1 change: 1 addition & 0 deletions src/apps/material/material.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -231,6 +231,7 @@ const Material: React.FC<MaterialProps> = ({ wid }) => {
</MaterialDisclosure>
{hasReview && hasReview.length > 0 && (
<DisclosureControllable
detailsClassName="disclosure text-body-large"
id="reviews"
showContent={shouldOpenReviewDisclosure}
cyData="material-reviews-disclosure"
Expand Down
45 changes: 45 additions & 0 deletions src/apps/opening-hours-sidebar/OpeningHoursSidebar.dev.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,45 @@
import { ComponentMeta, ComponentStory } from "@storybook/react";
import React from "react";
import serviceUrlArgs from "../../core/storybook/serviceUrlArgs";
import OpeningHoursSidebar from "./OpeningHoursSidebar.entry";

export default {
title: "Apps / Opening Hour Sidebar",
component: OpeningHoursSidebar,
argTypes: {
...serviceUrlArgs,
openingHoursSidebarTitleText: {
name: "Today's opening hours",
defaultValue: "Today's opening hours",
control: { type: "text" }
},
openingHoursText: {
name: "Opening hours text",
defaultValue: "Opening hours",
control: { type: "text" }
},
openingHoursSidebarLinkText: {
name: "Opening hours link text",
defaultValue: "Go to @branchName",
control: { type: "text" }
},
openingHoursSidebarBranchesConfig: {
name: "Opening hours sidebar branches",
defaultValue:
'[{"branch_id":"10","name":"Hovedbiblioteket","link":"/hovedbiblioteket","promoted":true},{"branch_id":"12","name":"Brønshøj Bibliotek","link":"/bronshoj-bibliotek","promoted":false},{"branch_id":"18","name":"Læsefilialen","link":"/laesefilialen","promoted":false},{"branch_id":"24","name":"Det virtuelle bibliotek","link":"/det-virtuelle-bibliotek","promoted":false}]',
control: { type: "text" }
},
size: {
name: "Size",
defaultValue: "small",
control: {
type: "select",
options: ["small", "large"]
}
}
}
} as ComponentMeta<typeof OpeningHoursSidebar>;

export const App: ComponentStory<typeof OpeningHoursSidebar> = (args) => (
<OpeningHoursSidebar {...args} />
);
27 changes: 27 additions & 0 deletions src/apps/opening-hours-sidebar/OpeningHoursSidebar.entry.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,27 @@
import React, { FC } from "react";
import { withText } from "../../core/utils/text";
import { withUrls } from "../../core/utils/url";
import OpeningHoursSidebar, {
OpeningHoursSidebarType
} from "./OpeningHoursSidebar";
import { withConfig } from "../../core/utils/config";

interface OpeningHoursClockEntryTextProps {
openingHoursText: string;
openingHoursSidebarTitleText: string;
openingHoursSidebarLinkText: string;
}

interface OpeningHoursClockEntryConfigProps {
openingHoursSidebarBranchesConfig: string;
}

const OpeningHoursSidebarEntry: FC<
OpeningHoursClockEntryTextProps &
OpeningHoursSidebarType &
OpeningHoursClockEntryConfigProps
> = ({ size }) => {
return <OpeningHoursSidebar size={size} />;
};

export default withConfig(withUrls(withText(OpeningHoursSidebarEntry)));
4 changes: 4 additions & 0 deletions src/apps/opening-hours-sidebar/OpeningHoursSidebar.mount.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
import addMount from "../../core/addMount";
import OpeningHoursSidebar from "./OpeningHoursSidebar.entry";

addMount({ appName: "opening-hours-sidebar", app: OpeningHoursSidebar });
38 changes: 38 additions & 0 deletions src/apps/opening-hours-sidebar/OpeningHoursSidebar.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,38 @@
import React, { FC } from "react";
import useDialog from "../../components/dialog/useDialog";
import OpeningHoursSidebarContent from "./OpeningHoursSidebarContent";
import OpeningHoursSidebarButtonLarge from "./OpeningHoursSidebarButtonLarge";
import OpeningHoursSidebarButtonSmall from "./OpeningHoursSidebarButtonSmall";
import Dialog from "../../components/dialog/Dialog";
import useOpeningHoursSidebar from "./useOpeningHoursSidebar";

export type OpeningHoursSidebarType = {
size: "small" | "large";
};

const OpeningHoursSidebar: FC<OpeningHoursSidebarType> = ({ size }) => {
const { dialogContent, openDialogWithContent, closeDialog, dialogRef } =
useDialog();

const { libraries } = useOpeningHoursSidebar();

const openDialog = () =>
openDialogWithContent(<OpeningHoursSidebarContent libraries={libraries} />);

return (
<>
{size === "large" && (
<OpeningHoursSidebarButtonLarge openDialog={openDialog} />
)}
{size === "small" && (
<OpeningHoursSidebarButtonSmall openDialog={openDialog} />
)}

<Dialog isSidebar closeDialog={closeDialog} ref={dialogRef}>
{dialogContent}
</Dialog>
</>
);
};

export default OpeningHoursSidebar;
36 changes: 36 additions & 0 deletions src/apps/opening-hours-sidebar/OpeningHoursSidebarButtonLarge.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,36 @@
import React, { FC } from "react";
import iconWatch from "@danskernesdigitalebibliotek/dpl-design-system/build/icons/basic/icon-watch-static.svg";
import { useText } from "../../core/utils/text";

type ButtonLargeProps = {
openDialog: () => void;
};

const ButtonLarge: FC<ButtonLargeProps> = ({ openDialog }) => {
const t = useText();

return (
<div className="header__clock">
<div className="pagefold-parent--medium">
<div className="pagefold-triangle--medium" />
</div>
<button
type="button"
className="header__clock-items"
onClick={openDialog}
>
<img
loading="lazy"
width="58"
height="58"
src={iconWatch}
className="mb-8"
alt=""
/>
<span className="text-small-caption">{t("openingHoursText")}</span>
</button>
</div>
);
};

export default ButtonLarge;
31 changes: 31 additions & 0 deletions src/apps/opening-hours-sidebar/OpeningHoursSidebarButtonSmall.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,31 @@
import React, { FC } from "react";
import iconWatch from "@danskernesdigitalebibliotek/dpl-design-system/build/icons/basic/icon-watch-static.svg";
import { useText } from "../../core/utils/text";

type ButtonSmallProps = {
openDialog: () => void;
};

const ButtonSmall: FC<ButtonSmallProps> = ({ openDialog }) => {
const t = useText();

return (
<button
type="button"
className="header__button header__button--left-border"
onClick={openDialog}
>
<img
className="header__button-icon"
loading="lazy"
width="24"
height="24"
src={iconWatch}
alt="clock icon"
/>
<span className="header__button-text">{t("openingHoursText")}</span>
</button>
);
};

export default ButtonSmall;
45 changes: 45 additions & 0 deletions src/apps/opening-hours-sidebar/OpeningHoursSidebarContent.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,45 @@
import React, { FC } from "react";
import iconWatch from "@danskernesdigitalebibliotek/dpl-design-system/build/icons/basic/icon-watch-static.svg";
import DisclosureControllable from "../../components/Disclosures/DisclosureControllable";
import OpeningHoursSidebarSummary from "./OpeningHoursSidebarSummary";
import OpeningHoursSidebarDetails from "./OpeningHoursSidebarDetails";
import { LibraryType, toDayString } from "./helper";
import { useText } from "../../core/utils/text";

const OpeningHoursSidebarContent: FC<{ libraries: LibraryType[] }> = ({
libraries
}) => {
const t = useText();
return (
<section className="opening-hours-sidebar">
<header className="opening-hours-sidebar__header">
<img src={iconWatch} className="opening-hours-sidebar__icon" alt="" />
<div className="opening-hours-sidebar__texts">
<h2 className="opening-hours-sidebar__title">
{t("openingHoursSidebarTitleText")}
</h2>
<p className="opening-hours-sidebar__date">{toDayString()}</p>
</div>
</header>

{libraries.map(({ branch_id, name, openingHoursData, link }, i) => (
<DisclosureControllable
showContent={i === 0}
key={branch_id}
id={branch_id}
detailsClassName="opening-hours-sidebar-details"
summaryClassName="opening-hours-sidebar-summary"
summary={<OpeningHoursSidebarSummary name={name} />}
>
<OpeningHoursSidebarDetails
openingHoursData={openingHoursData}
link={link}
name={name}
/>
</DisclosureControllable>
))}
</section>
);
};

export default OpeningHoursSidebarContent;
Loading

0 comments on commit 65e8999

Please sign in to comment.