@conduction/components 2.0.2 → 2.0.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (166) hide show
  1. package/.github/workflows/npm-publish.yml +39 -39
  2. package/.prettierrc +30 -30
  3. package/README.md +15 -13
  4. package/lib/components/card/detailsCard/DetailsCard.d.ts +14 -14
  5. package/lib/components/card/detailsCard/DetailsCard.js +10 -10
  6. package/lib/components/card/detailsCard/DetailsCard.module.css +51 -51
  7. package/lib/components/card/downloadCard/DownloadCard.d.ts +10 -10
  8. package/lib/components/card/downloadCard/DownloadCard.js +8 -8
  9. package/lib/components/card/downloadCard/DownloadCard.module.css +27 -27
  10. package/lib/components/card/horizontalImageCard/HorizontalImageCard.d.ts +13 -13
  11. package/lib/components/card/horizontalImageCard/HorizontalImageCard.js +9 -9
  12. package/lib/components/card/horizontalImageCard/HorizontalImageCard.module.css +34 -34
  13. package/lib/components/card/imageAndDetailsCard/ImageAndDetailsCard.d.ts +14 -14
  14. package/lib/components/card/imageAndDetailsCard/ImageAndDetailsCard.js +9 -9
  15. package/lib/components/card/imageAndDetailsCard/ImageAndDetailsCard.module.css +63 -63
  16. package/lib/components/card/index.d.ts +7 -7
  17. package/lib/components/card/index.js +7 -7
  18. package/lib/components/card/infoCard/InfoCard.d.ts +8 -7
  19. package/lib/components/card/infoCard/InfoCard.js +6 -5
  20. package/lib/components/card/infoCard/InfoCard.module.css +26 -26
  21. package/lib/components/card/richContentCard/RichContentCard.d.ts +19 -19
  22. package/lib/components/card/richContentCard/RichContentCard.js +15 -15
  23. package/lib/components/card/richContentCard/RichContentCard.module.css +93 -93
  24. package/lib/components/container/Container.d.ts +6 -6
  25. package/lib/components/container/Container.js +4 -4
  26. package/lib/components/container/Container.module.css +9 -9
  27. package/lib/components/denhaag-wrappers/breadcrumbs/Breadcrumbs.css +222 -222
  28. package/lib/components/denhaag-wrappers/breadcrumbs/Breadcrumbs.d.ts +17 -17
  29. package/lib/components/denhaag-wrappers/breadcrumbs/Breadcrumbs.js +20 -20
  30. package/lib/components/denhaag-wrappers/pagination/Pagination.css +120 -120
  31. package/lib/components/denhaag-wrappers/pagination/Pagination.d.ts +9 -9
  32. package/lib/components/denhaag-wrappers/pagination/Pagination.js +15 -15
  33. package/lib/components/editableTableRow/EditableTableRow.d.ts +14 -14
  34. package/lib/components/editableTableRow/EditableTableRow.js +31 -31
  35. package/lib/components/editableTableRow/EditableTableRow.module.css +25 -25
  36. package/lib/components/formFields/checkbox.d.ts +7 -7
  37. package/lib/components/formFields/checkbox.js +3 -3
  38. package/lib/components/formFields/index.d.ts +6 -6
  39. package/lib/components/formFields/index.js +6 -6
  40. package/lib/components/formFields/input.d.ts +19 -19
  41. package/lib/components/formFields/input.js +13 -13
  42. package/lib/components/formFields/radio.d.ts +9 -9
  43. package/lib/components/formFields/radio.js +3 -3
  44. package/lib/components/formFields/select/select.d.ts +17 -17
  45. package/lib/components/formFields/select/select.js +14 -14
  46. package/lib/components/formFields/select/select.module.css +35 -35
  47. package/lib/components/formFields/textarea.d.ts +8 -8
  48. package/lib/components/formFields/textarea.js +3 -3
  49. package/lib/components/formFields/types.d.ts +6 -6
  50. package/lib/components/formFields/types.js +1 -1
  51. package/lib/components/imageDivider/ImageDivider.d.ts +7 -7
  52. package/lib/components/imageDivider/ImageDivider.js +6 -6
  53. package/lib/components/imageDivider/imageDivider.module.css +5 -5
  54. package/lib/components/logo/Logo.d.ts +8 -8
  55. package/lib/components/logo/Logo.js +10 -10
  56. package/lib/components/logo/Logo.module.css +15 -15
  57. package/lib/components/metaIcon/MetaIcon.d.ts +7 -7
  58. package/lib/components/metaIcon/MetaIcon.js +3 -3
  59. package/lib/components/metaIcon/MetaIcon.module.css +29 -29
  60. package/lib/components/modals/NotificationModal.d.ts +21 -0
  61. package/lib/components/modals/NotificationModal.js +34 -0
  62. package/lib/components/modals/NotificationModal.module.css +56 -0
  63. package/lib/components/notificationPopUp/{NotificationPopUp.module.css → NotificationPopUP.module.css} +61 -61
  64. package/lib/components/notificationPopUp/NotificationPopUp.d.ts +22 -22
  65. package/lib/components/notificationPopUp/NotificationPopUp.js +31 -31
  66. package/lib/components/privateRoute/PrivateRoute.d.ts +6 -6
  67. package/lib/components/privateRoute/PrivateRoute.js +15 -15
  68. package/lib/components/quoteWrapper/QuoteWrapper.d.ts +7 -7
  69. package/lib/components/quoteWrapper/QuoteWrapper.js +5 -5
  70. package/lib/components/quoteWrapper/QuoteWrapper.module.css +12 -12
  71. package/lib/components/statusSteps/StatusSteps.d.ts +13 -13
  72. package/lib/components/statusSteps/StatusSteps.js +5 -5
  73. package/lib/components/tag/Tag.d.ts +6 -6
  74. package/lib/components/tag/Tag.js +3 -3
  75. package/lib/components/tag/Tag.module.css +20 -20
  76. package/lib/components/topNav/TopNav.d.ts +12 -0
  77. package/lib/components/topNav/TopNav.js +10 -0
  78. package/lib/components/topNav/TopNav.module.css +71 -0
  79. package/lib/components/topNav/index.d.ts +3 -3
  80. package/lib/components/topNav/index.js +3 -3
  81. package/lib/components/topNav/primaryTopNav/PrimaryTopNav.d.ts +17 -17
  82. package/lib/components/topNav/primaryTopNav/PrimaryTopNav.js +7 -7
  83. package/lib/components/topNav/primaryTopNav/PrimaryTopNav.module.css +60 -60
  84. package/lib/components/topNav/secondaryTopNav/SecondaryTopNav.d.ts +11 -11
  85. package/lib/components/topNav/secondaryTopNav/SecondaryTopNav.js +7 -7
  86. package/lib/components/topNav/secondaryTopNav/SecondaryTopNav.module.css +43 -43
  87. package/lib/index.d.ts +24 -24
  88. package/lib/index.js +17 -17
  89. package/lib/pages/index.d.ts +3 -0
  90. package/lib/pages/index.js +5 -0
  91. package/lib/templates/landing/LandingTemplate.d.ts +2 -0
  92. package/lib/templates/landing/LandingTemplate.js +6 -0
  93. package/lib/templates/landing/LandingTemplate.module.css +17 -0
  94. package/lib/templates/testing/TestingTemplate.d.ts +2 -0
  95. package/lib/templates/testing/TestingTemplate.js +6 -0
  96. package/lib/templates/testing/TestingTemplate.module.css +0 -0
  97. package/package.json +42 -42
  98. package/src/components/card/detailsCard/DetailsCard.module.css +51 -51
  99. package/src/components/card/detailsCard/DetailsCard.tsx +56 -56
  100. package/src/components/card/downloadCard/DownloadCard.js +10 -10
  101. package/src/components/card/downloadCard/DownloadCard.module.css +27 -27
  102. package/src/components/card/downloadCard/DownloadCard.tsx +31 -31
  103. package/src/components/card/horizontalImageCard/HorizontalImageCard.js +9 -9
  104. package/src/components/card/horizontalImageCard/HorizontalImageCard.module.css +34 -34
  105. package/src/components/card/horizontalImageCard/HorizontalImageCard.tsx +37 -37
  106. package/src/components/card/imageAndDetailsCard/ImageAndDetailsCard.js +9 -9
  107. package/src/components/card/imageAndDetailsCard/ImageAndDetailsCard.module.css +63 -63
  108. package/src/components/card/imageAndDetailsCard/ImageAndDetailsCard.tsx +49 -49
  109. package/src/components/card/index.js +5 -5
  110. package/src/components/card/index.tsx +8 -8
  111. package/src/components/card/infoCard/InfoCard.module.css +26 -26
  112. package/src/components/card/infoCard/InfoCard.tsx +19 -17
  113. package/src/components/card/richContentCard/RichContentCard.js +17 -17
  114. package/src/components/card/richContentCard/RichContentCard.module.css +93 -93
  115. package/src/components/card/richContentCard/RichContentCard.tsx +98 -98
  116. package/src/components/container/Container.js +3 -3
  117. package/src/components/container/Container.module.css +9 -9
  118. package/src/components/container/Container.tsx +11 -11
  119. package/src/components/denhaag-wrappers/breadcrumbs/Breadcrumbs.css +222 -222
  120. package/src/components/denhaag-wrappers/breadcrumbs/Breadcrumbs.js +20 -20
  121. package/src/components/denhaag-wrappers/breadcrumbs/Breadcrumbs.tsx +89 -89
  122. package/src/components/denhaag-wrappers/pagination/Pagination.css +120 -120
  123. package/src/components/denhaag-wrappers/pagination/Pagination.tsx +112 -112
  124. package/src/components/editableTableRow/EditableTableRow.js +34 -34
  125. package/src/components/editableTableRow/EditableTableRow.module.css +25 -25
  126. package/src/components/editableTableRow/EditableTableRow.tsx +138 -138
  127. package/src/components/formFields/checkbox.js +3 -3
  128. package/src/components/formFields/checkbox.tsx +14 -14
  129. package/src/components/formFields/index.js +4 -4
  130. package/src/components/formFields/index.tsx +19 -19
  131. package/src/components/formFields/input.js +12 -12
  132. package/src/components/formFields/input.tsx +123 -123
  133. package/src/components/formFields/radio.tsx +21 -21
  134. package/src/components/formFields/select/select.module.css +35 -35
  135. package/src/components/formFields/select/select.tsx +63 -63
  136. package/src/components/formFields/textarea.js +3 -3
  137. package/src/components/formFields/textarea.tsx +13 -13
  138. package/src/components/formFields/types.js +1 -1
  139. package/src/components/formFields/types.ts +7 -7
  140. package/src/components/imageDivider/ImageDivider.js +6 -6
  141. package/src/components/imageDivider/ImageDivider.tsx +12 -12
  142. package/src/components/imageDivider/imageDivider.module.css +5 -5
  143. package/src/components/logo/Logo.js +10 -10
  144. package/src/components/logo/Logo.module.css +15 -15
  145. package/src/components/logo/Logo.tsx +25 -25
  146. package/src/components/metaIcon/MetaIcon.js +3 -3
  147. package/src/components/metaIcon/MetaIcon.module.css +29 -29
  148. package/src/components/metaIcon/MetaIcon.tsx +18 -18
  149. package/src/components/notificationPopUp/NotificationPopUp.module.css +61 -61
  150. package/src/components/notificationPopUp/NotificationPopUp.tsx +82 -82
  151. package/src/components/privateRoute/PrivateRoute.js +15 -15
  152. package/src/components/privateRoute/PrivateRoute.tsx +22 -22
  153. package/src/components/quoteWrapper/QuoteWrapper.module.css +12 -12
  154. package/src/components/quoteWrapper/QuoteWrapper.tsx +15 -15
  155. package/src/components/statusSteps/StatusSteps.js +5 -5
  156. package/src/components/statusSteps/StatusSteps.tsx +54 -54
  157. package/src/components/tag/Tag.module.css +20 -20
  158. package/src/components/tag/Tag.tsx +8 -8
  159. package/src/components/topNav/index.ts +4 -4
  160. package/src/components/topNav/primaryTopNav/PrimaryTopNav.module.css +60 -60
  161. package/src/components/topNav/primaryTopNav/PrimaryTopNav.tsx +52 -52
  162. package/src/components/topNav/secondaryTopNav/SecondaryTopNav.module.css +43 -43
  163. package/src/components/topNav/secondaryTopNav/SecondaryTopNav.tsx +27 -27
  164. package/src/custom.d.ts +4 -4
  165. package/src/index.js +14 -14
  166. package/src/index.ts +73 -73
@@ -1,14 +1,14 @@
1
- import { jsx as _jsx } from "react/jsx-runtime";
2
- import * as styles from "./select.module.css";
3
- import { Controller } from "react-hook-form";
4
- import ReactSelect from "react-select";
5
- export const SelectMultiple = ({ name, options, errors, control, validation, defaultValue, disabled, }) => {
6
- return (_jsx(Controller, { ...{ control, name }, rules: validation, render: ({ field: { onChange, value } }) => {
7
- return (_jsx(ReactSelect, { className: styles.select, isMulti: true, isDisabled: disabled, ...{ options, value, onChange, errors, defaultValue } }));
8
- } }));
9
- };
10
- export const SelectSingle = ({ name, options, errors, control, validation, isClearable, defaultValue, }) => {
11
- return (_jsx(Controller, { ...{ control, name }, rules: validation, render: ({ field: { onChange, value } }) => {
12
- return (_jsx(ReactSelect, { className: styles.select, ...{ options, onChange, value, errors, isClearable, defaultValue } }));
13
- } }));
14
- };
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import * as styles from "./select.module.css";
3
+ import { Controller } from "react-hook-form";
4
+ import ReactSelect from "react-select";
5
+ export const SelectMultiple = ({ name, options, errors, control, validation, defaultValue, disabled, }) => {
6
+ return (_jsx(Controller, { ...{ control, name }, rules: validation, render: ({ field: { onChange, value } }) => {
7
+ return (_jsx(ReactSelect, { className: styles.select, isMulti: true, isDisabled: disabled, ...{ options, value, onChange, errors, defaultValue } }));
8
+ } }));
9
+ };
10
+ export const SelectSingle = ({ name, options, errors, control, validation, isClearable, defaultValue, }) => {
11
+ return (_jsx(Controller, { ...{ control, name }, rules: validation, render: ({ field: { onChange, value } }) => {
12
+ return (_jsx(ReactSelect, { className: styles.select, ...{ options, onChange, value, errors, isClearable, defaultValue } }));
13
+ } }));
14
+ };
@@ -1,35 +1,35 @@
1
- :root {
2
- --conduction-input-select-border: 1px solid var(--skeleton-color-grey-3);
3
- --conduction-input-select-border-focus: 2px dashed var(--skeleton-color-grey-5);
4
- }
5
-
6
- .select > div {
7
- background-color: var(--skeleton-color-white);
8
- border: var(--conduction-input-select-border);
9
- border-radius: var(--skeleton-border-radius-md);
10
- box-sizing: border-box;
11
- padding-block-start: var(--skeleton-size-xs);
12
- padding-block-end: var(--skeleton-size-xs);
13
- }
14
-
15
- .select > div:focus-within {
16
- outline: none;
17
- box-shadow: none;
18
- }
19
-
20
- .select > div:hover {
21
- border-color: var(--skeleton-color-grey-3);
22
- }
23
-
24
- .select > div:focus-within::after {
25
- content: "";
26
- display: block;
27
- position: absolute;
28
- pointer-events: none;
29
- bottom: calc(var(--skeleton-size-2xs) * -1);
30
- left: calc(var(--skeleton-size-2xs) * -1);
31
- right: calc(var(--skeleton-size-2xs) * -1);
32
- top: calc(var(--skeleton-size-2xs) * -1);
33
- border: var(--conduction-input-select-border-focus);
34
- border-radius: var(--skeleton-border-radius-md);
35
- }
1
+ :root {
2
+ --conduction-input-select-border: 1px solid var(--skeleton-color-grey-3);
3
+ --conduction-input-select-border-focus: 2px dashed var(--skeleton-color-grey-5);
4
+ }
5
+
6
+ .select > div {
7
+ background-color: var(--skeleton-color-white);
8
+ border: var(--conduction-input-select-border);
9
+ border-radius: var(--skeleton-border-radius-md);
10
+ box-sizing: border-box;
11
+ padding-block-start: var(--skeleton-size-xs);
12
+ padding-block-end: var(--skeleton-size-xs);
13
+ }
14
+
15
+ .select > div:focus-within {
16
+ outline: none;
17
+ box-shadow: none;
18
+ }
19
+
20
+ .select > div:hover {
21
+ border-color: var(--skeleton-color-grey-3);
22
+ }
23
+
24
+ .select > div:focus-within::after {
25
+ content: "";
26
+ display: block;
27
+ position: absolute;
28
+ pointer-events: none;
29
+ bottom: calc(var(--skeleton-size-2xs) * -1);
30
+ left: calc(var(--skeleton-size-2xs) * -1);
31
+ right: calc(var(--skeleton-size-2xs) * -1);
32
+ top: calc(var(--skeleton-size-2xs) * -1);
33
+ border: var(--conduction-input-select-border-focus);
34
+ border-radius: var(--skeleton-border-radius-md);
35
+ }
@@ -1,8 +1,8 @@
1
- import * as React from "react";
2
- import { IReactHookFormProps } from "./types";
3
- export interface ITextAreaProps {
4
- name: string;
5
- disabled?: boolean;
6
- defaultValue?: string;
7
- }
8
- export declare const Textarea: React.FC<ITextAreaProps & IReactHookFormProps>;
1
+ import * as React from "react";
2
+ import { IReactHookFormProps } from "./types";
3
+ export interface ITextAreaProps {
4
+ name: string;
5
+ disabled?: boolean;
6
+ defaultValue?: string;
7
+ }
8
+ export declare const Textarea: React.FC<ITextAreaProps & IReactHookFormProps>;
@@ -1,3 +1,3 @@
1
- import { jsx as _jsx } from "react/jsx-runtime";
2
- import { TextArea } from "@gemeente-denhaag/textarea";
3
- export const Textarea = ({ name, validation, register, errors }) => (_jsx(TextArea, { ...register(name, { ...validation }), invalid: errors[name] }));
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { TextArea } from "@gemeente-denhaag/textarea";
3
+ export const Textarea = ({ name, validation, register, errors }) => (_jsx(TextArea, { ...register(name, { ...validation }), invalid: errors[name] }));
@@ -1,6 +1,6 @@
1
- import { FieldErrors, FieldValues, RegisterOptions, UseFormRegister } from "react-hook-form";
2
- export interface IReactHookFormProps {
3
- register: UseFormRegister<FieldValues>;
4
- errors: FieldErrors;
5
- validation?: Omit<RegisterOptions<FieldValues, any>, "valueAsNumber" | "valueAsDate" | "setValueAs" | "disabled">;
6
- }
1
+ import { FieldErrors, FieldValues, RegisterOptions, UseFormRegister } from "react-hook-form";
2
+ export interface IReactHookFormProps {
3
+ register: UseFormRegister<FieldValues>;
4
+ errors: FieldErrors;
5
+ validation?: Omit<RegisterOptions<FieldValues, any>, "valueAsNumber" | "valueAsDate" | "setValueAs" | "disabled">;
6
+ }
@@ -1 +1 @@
1
- export {};
1
+ export {};
@@ -1,7 +1,7 @@
1
- import * as React from "react";
2
- interface ImageDividerProps {
3
- image: string;
4
- layoutClassName: string;
5
- }
6
- export declare const ImageDivider: React.FC<ImageDividerProps>;
7
- export {};
1
+ import * as React from "react";
2
+ interface ImageDividerProps {
3
+ image: string;
4
+ layoutClassName: string;
5
+ }
6
+ export declare const ImageDivider: React.FC<ImageDividerProps>;
7
+ export {};
@@ -1,6 +1,6 @@
1
- import { jsx as _jsx } from "react/jsx-runtime";
2
- import clsx from "clsx";
3
- import * as styles from "./imageDivider.module.css";
4
- export const ImageDivider = ({ image, layoutClassName }) => {
5
- return _jsx("img", { src: image, className: clsx(styles.divider, layoutClassName) });
6
- };
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import clsx from "clsx";
3
+ import * as styles from "./imageDivider.module.css";
4
+ export const ImageDivider = ({ image, layoutClassName }) => {
5
+ return _jsx("img", { src: image, className: clsx(styles.divider, layoutClassName) });
6
+ };
@@ -1,5 +1,5 @@
1
- .divider {
2
- display: block;
3
- object-fit: cover;
4
- width: 100%;
5
- }
1
+ .divider {
2
+ display: block;
3
+ object-fit: cover;
4
+ width: 100%;
5
+ }
@@ -1,8 +1,8 @@
1
- import * as React from "react";
2
- interface LogoProps {
3
- layoutClassName: string;
4
- href?: string;
5
- }
6
- export declare const AuthenticatedLogo: React.FC<LogoProps>;
7
- export declare const UnauthenticatedLogo: React.FC<LogoProps>;
8
- export {};
1
+ import * as React from "react";
2
+ interface LogoProps {
3
+ layoutClassName: string;
4
+ href?: string;
5
+ }
6
+ export declare const AuthenticatedLogo: React.FC<LogoProps>;
7
+ export declare const UnauthenticatedLogo: React.FC<LogoProps>;
8
+ export {};
@@ -1,10 +1,10 @@
1
- import { jsx as _jsx } from "react/jsx-runtime";
2
- import clsx from "clsx";
3
- import { Link } from "gatsby";
4
- import * as styles from "./Logo.module.css";
5
- export const AuthenticatedLogo = ({ layoutClassName, href }) => {
6
- return (_jsx(Link, { className: styles.logoContainer, to: href ?? "#", children: _jsx("div", { className: clsx(styles.authenticatedLogo, styles.logo, layoutClassName) }) }));
7
- };
8
- export const UnauthenticatedLogo = ({ layoutClassName, href }) => {
9
- return (_jsx(Link, { className: styles.logoContainer, to: href ?? "#", children: _jsx("div", { className: clsx(styles.unauthenticatedLogo, styles.logo, layoutClassName) }) }));
10
- };
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import clsx from "clsx";
3
+ import { Link } from "gatsby";
4
+ import * as styles from "./Logo.module.css";
5
+ export const AuthenticatedLogo = ({ layoutClassName, href }) => {
6
+ return (_jsx(Link, { className: styles.logoContainer, to: href ?? "#", children: _jsx("div", { className: clsx(styles.authenticatedLogo, styles.logo, layoutClassName) }) }));
7
+ };
8
+ export const UnauthenticatedLogo = ({ layoutClassName, href }) => {
9
+ return (_jsx(Link, { className: styles.logoContainer, to: href ?? "#", children: _jsx("div", { className: clsx(styles.unauthenticatedLogo, styles.logo, layoutClassName) }) }));
10
+ };
@@ -1,15 +1,15 @@
1
- .logoContainer {
2
- height: 100%;
3
- }
4
-
5
- .logo {
6
- background-size: 100% 100%;
7
- }
8
-
9
- .authenticatedLogo {
10
- background-image: var(--conduction-authenticated-logo-background);
11
- }
12
-
13
- .unauthenticatedLogo {
14
- background-image: var(--conduction-unauthenticated-logo-background);
15
- }
1
+ .logoContainer {
2
+ height: 100%;
3
+ }
4
+
5
+ .logo {
6
+ background-size: 100% 100%;
7
+ }
8
+
9
+ .authenticatedLogo {
10
+ background-image: var(--conduction-authenticated-logo-background);
11
+ }
12
+
13
+ .unauthenticatedLogo {
14
+ background-image: var(--conduction-unauthenticated-logo-background);
15
+ }
@@ -1,7 +1,7 @@
1
- import * as React from "react";
2
- export interface MetaIconProps {
3
- icon: JSX.Element;
4
- label: string;
5
- value: string;
6
- }
7
- export declare const MetaIcon: React.FC<MetaIconProps>;
1
+ import * as React from "react";
2
+ export interface MetaIconProps {
3
+ icon: JSX.Element;
4
+ label: string;
5
+ value: string;
6
+ }
7
+ export declare const MetaIcon: React.FC<MetaIconProps>;
@@ -1,3 +1,3 @@
1
- import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
- import * as styles from "./MetaIcon.module.css";
3
- export const MetaIcon = ({ icon, label, value }) => (_jsxs("div", { className: styles.container, children: [_jsx("span", { className: styles.icon, children: icon }), _jsx("span", { children: label }), _jsx("span", { className: styles.value, children: value })] }));
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import * as styles from "./MetaIcon.module.css";
3
+ export const MetaIcon = ({ icon, label, value }) => (_jsxs("div", { className: styles.container, children: [_jsx("span", { className: styles.icon, children: icon }), _jsx("span", { children: label }), _jsx("span", { className: styles.value, children: value })] }));
@@ -1,29 +1,29 @@
1
- :root {
2
- --conduction-meta-icon-icon-size: var(--skeleton-size-lg);
3
- --conduction-meta-icon-icon-color: var(--skeleton-color-secondary-4);
4
- }
5
-
6
- .container {
7
- display: flex;
8
- align-items: center;
9
- flex-direction: column;
10
- }
11
-
12
- .container > *:not(:last-child) {
13
- margin-block-end: var(--skeleton-size-xs);
14
- }
15
-
16
- .icon {
17
- color: var(--conduction-meta-icon-icon-color);
18
- height: var(--conduction-meta-icon-icon-size);
19
- width: var(--conduction-meta-icon-icon-size);
20
- }
21
-
22
- .icon > svg {
23
- height: 100%;
24
- width: 100%;
25
- }
26
-
27
- .value {
28
- font-weight: var(--skeleton-font-weight-bold);
29
- }
1
+ :root {
2
+ --conduction-meta-icon-icon-size: var(--skeleton-size-lg);
3
+ --conduction-meta-icon-icon-color: var(--skeleton-color-secondary-4);
4
+ }
5
+
6
+ .container {
7
+ display: flex;
8
+ align-items: center;
9
+ flex-direction: column;
10
+ }
11
+
12
+ .container > *:not(:last-child) {
13
+ margin-block-end: var(--skeleton-size-xs);
14
+ }
15
+
16
+ .icon {
17
+ color: var(--conduction-meta-icon-icon-color);
18
+ height: var(--conduction-meta-icon-icon-size);
19
+ width: var(--conduction-meta-icon-icon-size);
20
+ }
21
+
22
+ .icon > svg {
23
+ height: 100%;
24
+ width: 100%;
25
+ }
26
+
27
+ .value {
28
+ font-weight: var(--skeleton-font-weight-bold);
29
+ }
@@ -0,0 +1,21 @@
1
+ import * as React from "react";
2
+ export interface ModalProps {
3
+ title: string;
4
+ description: string | JSX.Element;
5
+ isShown: boolean;
6
+ hide: () => void;
7
+ layoutClassName: string;
8
+ primaryButton: {
9
+ label: string;
10
+ handleClick: () => any;
11
+ };
12
+ closeButton?: {
13
+ label: string;
14
+ };
15
+ }
16
+ export declare const NotificationModal: React.FC<ModalProps>;
17
+ export declare const toggleNotificationModal: () => {
18
+ isShown: boolean;
19
+ show: () => void;
20
+ hide: () => void;
21
+ };
@@ -0,0 +1,34 @@
1
+ import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import * as React from "react";
3
+ import * as styles from "./NotificationModal.module.css";
4
+ import ReactDOM from "react-dom";
5
+ import { Button, Heading3, Link, Paragraph } from "@gemeente-denhaag/components-react";
6
+ import clsx from "clsx";
7
+ import { CloseIcon, ArrowRightIcon } from "@gemeente-denhaag/icons";
8
+ export const NotificationModal = ({ title, description, isShown, hide, primaryButton, closeButton, layoutClassName, }) => {
9
+ const [fadeOut, setFadeOut] = React.useState(true);
10
+ const stylesContainer = document.getElementById("stylesContainer");
11
+ const animationDurationToken = getComputedStyle(document.documentElement).getPropertyValue("--conduction-notification-animation-duration");
12
+ const animationDurationString = animationDurationToken.replace(/\D/g, "");
13
+ const animationDuration = parseInt(animationDurationString);
14
+ const handleClick = (clickFunction) => {
15
+ setFadeOut(!setFadeOut);
16
+ clickFunction && clickFunction();
17
+ setTimeout(() => {
18
+ hide();
19
+ setFadeOut(true);
20
+ }, animationDuration);
21
+ };
22
+ const modal = (_jsx("div", { className: clsx(styles.cssanimation, fadeOut ? styles.fadeInBottom : styles.fadeOutBottom, layoutClassName), children: _jsxs("div", { className: styles.modal, children: [_jsx(Heading3, { children: title }), _jsx(Paragraph, { children: description }), _jsxs("div", { className: styles.buttons, children: [closeButton ? (_jsx("div", { onClick: () => handleClick(), children: _jsx(Link, { icon: _jsx(CloseIcon, {}), iconAlign: "start", children: closeButton.label }) })) : (_jsx(_Fragment, {})), _jsx(Button, { icon: _jsx(ArrowRightIcon, {}), onClick: () => handleClick(primaryButton.handleClick), children: primaryButton.label })] })] }) }));
23
+ return isShown ? ReactDOM.createPortal(modal, stylesContainer) : null;
24
+ };
25
+ export const toggleNotificationModal = () => {
26
+ const [isShown, setIsShown] = React.useState(false);
27
+ const show = () => setIsShown(true);
28
+ const hide = () => setIsShown(false);
29
+ return {
30
+ isShown,
31
+ show,
32
+ hide,
33
+ };
34
+ };
@@ -0,0 +1,56 @@
1
+ .modal {
2
+ background: var(--denhaag-color-warmgrey-1);
3
+ padding-inline-start: var(--nlportal-space-inline-lg);
4
+ padding-inline-end: var(--nlportal-space-inline-lg);
5
+ padding-block-start: var(--nlportal-space-block-lg);
6
+ padding-block-end: var(--nlportal-space-block-lg);
7
+ box-shadow: var(--conduction-notification-box-shadow);
8
+ border-radius: var(--nlportal-document-border-radius);
9
+ }
10
+
11
+ .modal > *:not(:last-child) {
12
+ margin-block-end: var(--nlportal-space-block-md);
13
+ }
14
+
15
+ .buttons {
16
+ display: flex;
17
+ justify-content: flex-end;
18
+ align-items: center;
19
+ }
20
+
21
+ .buttons > *:not(:last-child) {
22
+ margin-inline-end: var(--nlportal-space-inline-md);
23
+ }
24
+
25
+ .cssanimation {
26
+ animation-duration: var(--conduction-notification-animation-duration);
27
+ animation-fill-mode: both;
28
+ }
29
+
30
+ .fadeInBottom {
31
+ animation-name: fadeInBottom;
32
+ }
33
+
34
+ @keyframes fadeInBottom {
35
+ from {
36
+ opacity: 0;
37
+ transform: translateY(100%);
38
+ }
39
+ to {
40
+ opacity: 1;
41
+ }
42
+ }
43
+
44
+ .fadeOutBottom {
45
+ animation-name: fadeOutBottom;
46
+ }
47
+
48
+ @keyframes fadeOutBottom {
49
+ from {
50
+ opacity: 1;
51
+ }
52
+ to {
53
+ opacity: 0;
54
+ transform: translateY(100%);
55
+ }
56
+ }
@@ -1,61 +1,61 @@
1
- :root {
2
- --conduction-notification-pop-up-box-shadow: 0px 0px 6px 6px rgb(0 0 0 / 15%);
3
- --conduction-notification-pop-up-border: 1px solid var(--skeleton-color-grey-2);
4
- }
5
-
6
- :export {
7
- animationDuration: 200ms;
8
- }
9
-
10
- .modal {
11
- animation-fill-mode: both;
12
- background: var(--skeleton-color-grey-1);
13
- padding-inline-start: var(--skeleton-size-lg);
14
- padding-inline-end: var(--skeleton-size-lg);
15
- padding-block-start: var(--skeleton-size-lg);
16
- padding-block-end: var(--skeleton-size-lg);
17
- border-radius: var(--skeleton-border-radius-md);
18
- box-shadow: var(--conduction-notification-pop-up-box-shadow);
19
- }
20
-
21
- .modal > *:not(:last-child) {
22
- margin-block-end: var(--skeleton-size-md);
23
- }
24
-
25
- .buttons {
26
- display: flex;
27
- justify-content: flex-end;
28
- align-items: center;
29
- }
30
-
31
- .buttons > *:not(:last-child) {
32
- margin-inline-end: var(--skeleton-size-md);
33
- }
34
-
35
- .visible {
36
- animation-name: fadeInBottom;
37
- }
38
-
39
- @keyframes fadeInBottom {
40
- from {
41
- opacity: 0;
42
- transform: translateY(100%);
43
- }
44
- to {
45
- opacity: 1;
46
- }
47
- }
48
-
49
- .modal:not(.visible) {
50
- animation-name: fadeOutBottom;
51
- }
52
-
53
- @keyframes fadeOutBottom {
54
- from {
55
- opacity: 1;
56
- }
57
- to {
58
- opacity: 0;
59
- transform: translateY(100%);
60
- }
61
- }
1
+ :root {
2
+ --conduction-notification-pop-up-box-shadow: 0px 0px 6px 6px rgb(0 0 0 / 15%);
3
+ --conduction-notification-pop-up-border: 1px solid var(--skeleton-color-grey-2);
4
+ }
5
+
6
+ :export {
7
+ animationDuration: 200ms;
8
+ }
9
+
10
+ .modal {
11
+ animation-fill-mode: both;
12
+ background: var(--skeleton-color-grey-1);
13
+ padding-inline-start: var(--skeleton-size-lg);
14
+ padding-inline-end: var(--skeleton-size-lg);
15
+ padding-block-start: var(--skeleton-size-lg);
16
+ padding-block-end: var(--skeleton-size-lg);
17
+ border-radius: var(--skeleton-border-radius-md);
18
+ box-shadow: var(--conduction-notification-pop-up-box-shadow);
19
+ }
20
+
21
+ .modal > *:not(:last-child) {
22
+ margin-block-end: var(--skeleton-size-md);
23
+ }
24
+
25
+ .buttons {
26
+ display: flex;
27
+ justify-content: flex-end;
28
+ align-items: center;
29
+ }
30
+
31
+ .buttons > *:not(:last-child) {
32
+ margin-inline-end: var(--skeleton-size-md);
33
+ }
34
+
35
+ .visible {
36
+ animation-name: fadeInBottom;
37
+ }
38
+
39
+ @keyframes fadeInBottom {
40
+ from {
41
+ opacity: 0;
42
+ transform: translateY(100%);
43
+ }
44
+ to {
45
+ opacity: 1;
46
+ }
47
+ }
48
+
49
+ .modal:not(.visible) {
50
+ animation-name: fadeOutBottom;
51
+ }
52
+
53
+ @keyframes fadeOutBottom {
54
+ from {
55
+ opacity: 1;
56
+ }
57
+ to {
58
+ opacity: 0;
59
+ transform: translateY(100%);
60
+ }
61
+ }
@@ -1,22 +1,22 @@
1
- import * as React from "react";
2
- export interface NotificationPopUpProps {
3
- title: string;
4
- description: string | JSX.Element;
5
- isVisible: boolean;
6
- hide: () => void;
7
- primaryButton: {
8
- label: string;
9
- handleClick: () => any;
10
- };
11
- secondaryButton?: {
12
- label: string;
13
- handleClick: () => any;
14
- };
15
- layoutClassName?: string;
16
- }
17
- export declare const NotificationPopUp: React.FC<NotificationPopUpProps>;
18
- export declare const NotificationPopUpController: () => {
19
- isVisible: boolean;
20
- show: () => void;
21
- hide: () => void;
22
- };
1
+ import * as React from "react";
2
+ export interface NotificationPopUpProps {
3
+ title: string;
4
+ description: string | JSX.Element;
5
+ isVisible: boolean;
6
+ hide: () => void;
7
+ primaryButton: {
8
+ label: string;
9
+ handleClick: () => any;
10
+ };
11
+ secondaryButton?: {
12
+ label: string;
13
+ handleClick: () => any;
14
+ };
15
+ layoutClassName?: string;
16
+ }
17
+ export declare const NotificationPopUp: React.FC<NotificationPopUpProps>;
18
+ export declare const NotificationPopUpController: () => {
19
+ isVisible: boolean;
20
+ show: () => void;
21
+ hide: () => void;
22
+ };