@ndla/ui 55.0.14-alpha.0 → 55.0.15-alpha.0
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.
- package/dist/panda.buildinfo.json +22 -0
- package/dist/styles.css +86 -0
- package/es/Article/ArticleByline.js +7 -7
- package/es/AudioPlayer/AudioPlayer.js +1 -0
- package/es/Concept/Concept.js +2 -2
- package/es/ContactBlock/ContactBlock.js +17 -17
- package/es/Embed/BrightcoveEmbed.js +0 -1
- package/es/Embed/CopyrightEmbed.js +1 -2
- package/es/LicenseByline/EmbedByline.js +143 -33
- package/es/LicenseByline/LicenseLink.js +16 -9
- package/es/LicenseByline/index.js +2 -2
- package/es/index.js +0 -1
- package/es/styles.css +86 -0
- package/lib/Article/ArticleByline.js +8 -8
- package/lib/AudioPlayer/AudioPlayer.js +1 -0
- package/lib/Concept/Concept.js +1 -1
- package/lib/ContactBlock/ContactBlock.js +18 -18
- package/lib/Embed/BrightcoveEmbed.js +0 -1
- package/lib/Embed/CopyrightEmbed.js +1 -2
- package/lib/LicenseByline/EmbedByline.d.ts +2 -4
- package/lib/LicenseByline/EmbedByline.js +145 -35
- package/lib/LicenseByline/LicenseLink.d.ts +2 -2
- package/lib/LicenseByline/LicenseLink.js +16 -9
- package/lib/LicenseByline/index.d.ts +2 -2
- package/lib/LicenseByline/index.js +4 -5
- package/lib/index.d.ts +0 -1
- package/lib/index.js +0 -13
- package/lib/styles.css +86 -0
- package/package.json +5 -5
- package/src/Article/ArticleByline.tsx +1 -1
- package/src/AudioPlayer/AudioPlayer.tsx +1 -0
- package/src/Concept/Concept.tsx +2 -2
- package/src/ContactBlock/ContactBlock.tsx +1 -1
- package/src/Embed/BrightcoveEmbed.tsx +1 -1
- package/src/Embed/CopyrightEmbed.tsx +1 -1
- package/src/LicenseByline/EmbedByline.stories.tsx +9 -4
- package/src/LicenseByline/EmbedByline.tsx +139 -53
- package/src/LicenseByline/LicenseLink.tsx +15 -15
- package/src/LicenseByline/index.tsx +2 -2
- package/src/index.ts +0 -1
- package/es/LicenseByline/LicenseDescription.js +0 -63
- package/es/List/OrderedList.js +0 -41
- package/es/List/UnOrderedList.js +0 -28
- package/es/List/index.js +0 -10
- package/lib/LicenseByline/LicenseDescription.d.ts +0 -15
- package/lib/LicenseByline/LicenseDescription.js +0 -70
- package/lib/List/OrderedList.d.ts +0 -16
- package/lib/List/OrderedList.js +0 -48
- package/lib/List/UnOrderedList.d.ts +0 -10
- package/lib/List/UnOrderedList.js +0 -35
- package/lib/List/index.d.ts +0 -9
- package/lib/List/index.js +0 -20
- package/src/LicenseByline/LicenseDescription.tsx +0 -100
- package/src/List/OrderedList.stories.tsx +0 -135
- package/src/List/OrderedList.tsx +0 -158
- package/src/List/UnOrderedList.tsx +0 -43
- package/src/List/UnorderedList.stories.tsx +0 -72
- package/src/List/index.ts +0 -10
|
@@ -8,6 +8,7 @@
|
|
|
8
8
|
"borderColor]___[value:stroke.default",
|
|
9
9
|
"borderRadius]___[value:xsmall",
|
|
10
10
|
"boxShadow]___[value:full",
|
|
11
|
+
"marginBlockEnd]___[value:4xsmall",
|
|
11
12
|
"overflow]___[value:hidden",
|
|
12
13
|
"display]___[value:flex",
|
|
13
14
|
"display]___[value:block]___[cond:tabletWideDown",
|
|
@@ -258,6 +259,27 @@
|
|
|
258
259
|
"fontWeight]___[value:bold]___[cond:_first<___>& p",
|
|
259
260
|
"fontStyle]___[value:italic",
|
|
260
261
|
"background]___[value:surface.default",
|
|
262
|
+
"borderColor]___[value:stroke.error",
|
|
263
|
+
"background]___[value:surface.dangerSubtle",
|
|
264
|
+
"display]___[value:inline-flex",
|
|
265
|
+
"whiteSpace]___[value:pre-wrap",
|
|
266
|
+
"display]___[value:grid]___[cond:mobileWideDown",
|
|
267
|
+
"gridTemplateColumns]___[value:1fr auto]___[cond:mobileWideDown",
|
|
268
|
+
"alignItems]___[value:center]___[cond:mobileWideDown",
|
|
269
|
+
"overflow]___[value:hidden]___[cond:mobileWideDown",
|
|
270
|
+
"display]___[value:inline]___[cond:mobileWideDown<___>_open",
|
|
271
|
+
"whiteSpace]___[value:nowrap]___[cond:mobileWideDown",
|
|
272
|
+
"maxHeight]___[value:large]___[cond:mobileWideDown",
|
|
273
|
+
"textOverflow]___[value:ellipsis]___[cond:mobileWideDown",
|
|
274
|
+
"transitionProperty]___[value:max-height]___[cond:mobileWideDown",
|
|
275
|
+
"transitionDuration]___[value:slow]___[cond:mobileWideDown",
|
|
276
|
+
"transitionTimingFunction]___[value:ease-in]___[cond:mobileWideDown",
|
|
277
|
+
"whiteSpace]___[value:pre-wrap]___[cond:mobileWideDown<___>_open",
|
|
278
|
+
"maxHeight]___[value:none]___[cond:mobileWideDown<___>_open",
|
|
279
|
+
"display]___[value:none]___[cond:mobileWide",
|
|
280
|
+
"color]___[value:primary",
|
|
281
|
+
"whiteSpace]___[value:nowrap",
|
|
282
|
+
"textDecoration]___[value:none]___[cond:_focusWithin",
|
|
261
283
|
"textDecoration]___[value:underline]___[cond:& h3",
|
|
262
284
|
"transitionProperty]___[value:width, height]___[cond:& [data-forward]",
|
|
263
285
|
"transitionTimingFunction]___[value:ease-in-out]___[cond:& [data-forward]",
|
package/dist/styles.css
CHANGED
|
@@ -73,6 +73,10 @@
|
|
|
73
73
|
box-shadow: var(--shadows-full);
|
|
74
74
|
}
|
|
75
75
|
|
|
76
|
+
.mbe_4xsmall {
|
|
77
|
+
margin-block-end: var(--spacing-4xsmall);
|
|
78
|
+
}
|
|
79
|
+
|
|
76
80
|
.ov_hidden {
|
|
77
81
|
overflow: hidden;
|
|
78
82
|
}
|
|
@@ -415,6 +419,26 @@
|
|
|
415
419
|
background: var(--colors-surface-default);
|
|
416
420
|
}
|
|
417
421
|
|
|
422
|
+
.bg_surface\.dangerSubtle {
|
|
423
|
+
background: var(--colors-surface-danger-subtle);
|
|
424
|
+
}
|
|
425
|
+
|
|
426
|
+
.d_inline-flex {
|
|
427
|
+
display: inline-flex;
|
|
428
|
+
}
|
|
429
|
+
|
|
430
|
+
.white-space_pre-wrap {
|
|
431
|
+
white-space: pre-wrap;
|
|
432
|
+
}
|
|
433
|
+
|
|
434
|
+
.c_primary {
|
|
435
|
+
color: var(--colors-primary);
|
|
436
|
+
}
|
|
437
|
+
|
|
438
|
+
.white-space_nowrap {
|
|
439
|
+
white-space: nowrap;
|
|
440
|
+
}
|
|
441
|
+
|
|
418
442
|
.c_icon\.strong {
|
|
419
443
|
color: var(--colors-icon-strong);
|
|
420
444
|
}
|
|
@@ -604,6 +628,10 @@
|
|
|
604
628
|
font-style: italic;
|
|
605
629
|
}
|
|
606
630
|
|
|
631
|
+
.bd-c_stroke\.error {
|
|
632
|
+
border-color: var(--colors-stroke-error);
|
|
633
|
+
}
|
|
634
|
+
|
|
607
635
|
.grid-tc_repeat\(2\,_1fr\) {
|
|
608
636
|
grid-template-columns: repeat(2, 1fr);
|
|
609
637
|
}
|
|
@@ -926,6 +954,10 @@
|
|
|
926
954
|
content: "";
|
|
927
955
|
}
|
|
928
956
|
|
|
957
|
+
.focusWithin\:td_none:focus-within {
|
|
958
|
+
text-decoration: none;
|
|
959
|
+
}
|
|
960
|
+
|
|
929
961
|
.focusVisible\:ring_none:is(:focus-visible, [data-focus-visible]) {
|
|
930
962
|
outline: 2px solid transparent;
|
|
931
963
|
outline-offset: 2px;
|
|
@@ -1042,6 +1074,9 @@
|
|
|
1042
1074
|
@media screen and (min-width: 29.75rem) {
|
|
1043
1075
|
.mobileWide\:max-w_surface\.medium {
|
|
1044
1076
|
max-width: var(--sizes-surface-medium);
|
|
1077
|
+
}
|
|
1078
|
+
.mobileWide\:d_none {
|
|
1079
|
+
display: none;
|
|
1045
1080
|
}
|
|
1046
1081
|
}
|
|
1047
1082
|
|
|
@@ -1157,8 +1192,59 @@
|
|
|
1157
1192
|
}
|
|
1158
1193
|
|
|
1159
1194
|
@media screen and (max-width: 29.7475rem) {
|
|
1195
|
+
.mobileWideDown\:d_grid {
|
|
1196
|
+
display: grid;
|
|
1197
|
+
}
|
|
1198
|
+
.mobileWideDown\:ov_hidden {
|
|
1199
|
+
overflow: hidden;
|
|
1200
|
+
}
|
|
1201
|
+
.mobileWideDown\:white-space_nowrap {
|
|
1202
|
+
white-space: nowrap;
|
|
1203
|
+
}
|
|
1204
|
+
.mobileWideDown\:max-h_large {
|
|
1205
|
+
max-height: var(--sizes-large);
|
|
1206
|
+
}
|
|
1207
|
+
.mobileWideDown\:tov_ellipsis {
|
|
1208
|
+
text-overflow: ellipsis;
|
|
1209
|
+
}
|
|
1160
1210
|
.mobileWideDown\:cg_3xsmall {
|
|
1161
1211
|
column-gap: var(--spacing-3xsmall);
|
|
1212
|
+
}
|
|
1213
|
+
.mobileWideDown\:grid-tc_1fr_auto {
|
|
1214
|
+
grid-template-columns: 1fr auto;
|
|
1215
|
+
}
|
|
1216
|
+
.mobileWideDown\:ai_center {
|
|
1217
|
+
align-items: center;
|
|
1218
|
+
}
|
|
1219
|
+
.mobileWideDown\:trs-prop_max-height {
|
|
1220
|
+
--transition-prop: max-height;
|
|
1221
|
+
transition-property: max-height;
|
|
1222
|
+
}
|
|
1223
|
+
.mobileWideDown\:trs-dur_slow {
|
|
1224
|
+
--transition-duration: var(--durations-slow);
|
|
1225
|
+
transition-duration: var(--durations-slow);
|
|
1226
|
+
}
|
|
1227
|
+
.mobileWideDown\:trs-tmf_ease-in {
|
|
1228
|
+
--transition-easing: ease-in;
|
|
1229
|
+
transition-timing-function: ease-in;
|
|
1230
|
+
}
|
|
1231
|
+
}
|
|
1232
|
+
|
|
1233
|
+
@media screen and (max-width: 29.7475rem) {
|
|
1234
|
+
.mobileWideDown\:open\:d_inline:is([open], [data-open], [data-state="open"]) {
|
|
1235
|
+
display: inline;
|
|
1236
|
+
}
|
|
1237
|
+
}
|
|
1238
|
+
|
|
1239
|
+
@media screen and (max-width: 29.7475rem) {
|
|
1240
|
+
.mobileWideDown\:open\:white-space_pre-wrap:is([open], [data-open], [data-state="open"]) {
|
|
1241
|
+
white-space: pre-wrap;
|
|
1242
|
+
}
|
|
1243
|
+
}
|
|
1244
|
+
|
|
1245
|
+
@media screen and (max-width: 29.7475rem) {
|
|
1246
|
+
.mobileWideDown\:open\:max-h_none:is([open], [data-open], [data-state="open"]) {
|
|
1247
|
+
max-height: none;
|
|
1162
1248
|
}
|
|
1163
1249
|
}
|
|
1164
1250
|
|
|
@@ -14,22 +14,22 @@ import { AccordionRoot, AccordionHeader, AccordionContent, AccordionItem } from
|
|
|
14
14
|
import { breakpoints, colors, fonts, mq, spacing } from "@ndla/core";
|
|
15
15
|
import { getLicenseByAbbreviation } from "@ndla/licenses";
|
|
16
16
|
import ArticleFootNotes from "./ArticleFootNotes";
|
|
17
|
-
import LicenseLink from "../LicenseByline/LicenseLink";
|
|
17
|
+
import { LicenseLink } from "../LicenseByline/LicenseLink";
|
|
18
18
|
import { jsx as _jsx, jsxs as _jsxs } from "@emotion/react/jsx-runtime";
|
|
19
19
|
const Wrapper = /*#__PURE__*/_styled("div", {
|
|
20
20
|
target: "eeu23se5",
|
|
21
21
|
label: "Wrapper"
|
|
22
|
-
})("margin-top:", spacing.normal, ";padding-top:", spacing.normal, ";padding-bottom:", spacing.xsmall, ";border-top:1px solid ", colors.brand.greyLight, ";", fonts.sizes("16px", "24px"), ";font-family:", fonts.sans, ";color:", colors.brand.greyDark, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
22
|
+
})("margin-top:", spacing.normal, ";padding-top:", spacing.normal, ";padding-bottom:", spacing.xsmall, ";border-top:1px solid ", colors.brand.greyLight, ";", fonts.sizes("16px", "24px"), ";font-family:", fonts.sans, ";color:", colors.brand.greyDark, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ArticleByline.tsx"],"names":[],"mappings":"AAoB0B","file":"ArticleByline.tsx","sourcesContent":["/**\n * Copyright (c) 2020-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { TFunction } from \"i18next\";\nimport { ReactNode, useCallback, useEffect, useState } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { useLocation } from \"react-router-dom\";\nimport styled from \"@emotion/styled\";\nimport { AccordionRoot, AccordionHeader, AccordionContent, AccordionItem } from \"@ndla/accordion\";\nimport { breakpoints, colors, fonts, mq, spacing } from \"@ndla/core\";\nimport { getLicenseByAbbreviation } from \"@ndla/licenses\";\nimport ArticleFootNotes from \"./ArticleFootNotes\";\nimport { LicenseLink } from \"../LicenseByline/LicenseLink\";\nimport { FootNote } from \"../types\";\n\nconst Wrapper = styled.div`\n  margin-top: ${spacing.normal};\n  padding-top: ${spacing.normal};\n  padding-bottom: ${spacing.xsmall};\n  border-top: 1px solid ${colors.brand.greyLight};\n  ${fonts.sizes(\"16px\", \"24px\")};\n  font-family: ${fonts.sans};\n  color: ${colors.brand.greyDark};\n`;\n\nconst TextWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  width: 100%;\n  padding-bottom: ${spacing.mediumlarge};\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    flex-direction: column;\n    flex-direction: column-reverse;\n    gap: ${spacing.xsmall};\n  }\n  &[data-learning-path=\"true\"] {\n    flex-direction: column;\n    flex-direction: column-reverse;\n    gap: ${spacing.xsmall};\n  }\n`;\n\nconst PrimaryContributorsWrapper = styled.span`\n  margin-left: ${spacing.xxsmall};\n`;\n\ntype AuthorProps = {\n  name: string;\n};\n\ntype SupplierProps = {\n  name: string;\n};\n\ntype AccordionHeaderVariants = \"white\" | \"blue\";\n\ntype Props = {\n  authors?: AuthorProps[];\n  suppliers?: SupplierProps[];\n  published?: string;\n  license?: string;\n  licenseBox?: ReactNode;\n  locale?: string;\n  footnotes?: FootNote[];\n  accordionHeaderVariant?: AccordionHeaderVariants;\n  displayByline?: boolean;\n  bylineType?: \"article\" | \"learningPath\";\n};\n\nconst renderContributors = (contributors: SupplierProps[] | AuthorProps[], t: TFunction) => {\n  const contributorsArray = contributors.map((contributor, index) => {\n    if (index < 1) return contributor.name;\n    const sep = index === contributors.length - 1 ? ` ${t(\"article.conjunction\")} ` : \", \";\n    return `${sep}${contributor.name}`;\n  });\n  return contributorsArray.join(\"\");\n};\n\nconst getSuppliersText = (suppliers: SupplierProps[], t: TFunction) => {\n  if (suppliers.length === 0) {\n    return \"\";\n  }\n  return suppliers.length > 1\n    ? t(\"article.multipleSuppliersLabel\", {\n        names: renderContributors(suppliers, t),\n        interpolation: { escapeValue: false },\n      })\n    : t(\"article.supplierLabel\", {\n        name: renderContributors(suppliers, t),\n        interpolation: { escapeValue: false },\n      });\n};\n\nconst LicenseWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.small};\n  padding-right: ${spacing.xsmall};\n`;\n\nconst StyledAccordionHeader = styled(AccordionHeader)`\n  background-color: ${colors.brand.lightest};\n  ${fonts.sizes(\"16px\", \"29px\")};\n  font-weight: ${fonts.weight.semibold};\n\n  &[data-background-color=\"white\"][data-state=\"closed\"] {\n    background-color: ${colors.background.default};\n  }\n`;\n\nconst StyledAccordionContent = styled(AccordionContent)`\n  &[data-background-color=\"white\"] {\n    background-color: ${colors.background.default};\n  }\n`;\n\nconst refRegexp = /note\\d/;\nconst footnotesAccordionId = \"footnotes\";\n\nconst ArticleByline = ({\n  authors = [],\n  suppliers = [],\n  footnotes,\n  license: licenseString,\n  licenseBox,\n  published,\n  locale,\n  accordionHeaderVariant = \"blue\",\n  displayByline = true,\n  bylineType = \"article\",\n}: Props) => {\n  const { t } = useTranslation();\n  const { pathname } = useLocation();\n  const [openAccordions, setOpenAccordions] = useState<string[]>([]);\n  const accordionItemValue = \"rulesForUse\";\n\n  const onHashChange = useCallback(\n    (e: HashChangeEvent) => {\n      const hash = e.newURL.split(\"#\")[1];\n      if (hash.match(refRegexp) && !openAccordions.includes(footnotesAccordionId)) {\n        setOpenAccordions([...openAccordions, footnotesAccordionId]);\n        const el = document.getElementById(`#${hash}`);\n        el?.click();\n        el?.focus();\n      }\n    },\n    [openAccordions],\n  );\n\n  useEffect(() => {\n    setOpenAccordions((prev) => prev.filter((state) => state !== accordionItemValue));\n  }, [pathname]);\n\n  useEffect(() => {\n    window.addEventListener(\"hashchange\", onHashChange);\n    return () => window.removeEventListener(\"hashchange\", onHashChange);\n  }, [onHashChange]);\n\n  const license = licenseString && getLicenseByAbbreviation(licenseString, locale);\n\n  const showPrimaryContributors = suppliers.length > 0 || authors.length > 0;\n\n  return (\n    <Wrapper>\n      {displayByline && (\n        <TextWrapper data-learning-path={bylineType === \"learningPath\"}>\n          <LicenseWrapper>\n            {license && <LicenseLink license={license} />}\n            {showPrimaryContributors && (\n              <PrimaryContributorsWrapper>\n                {authors.length > 0 &&\n                  `${t(\"article.authorsLabel\", {\n                    names: renderContributors(authors, t),\n                    interpolation: { escapeValue: false },\n                  })}. `}\n                {getSuppliersText(suppliers, t)}\n              </PrimaryContributorsWrapper>\n            )}\n          </LicenseWrapper>\n          <div>\n            {t(`${bylineType}.lastUpdated`)} {published}\n          </div>\n        </TextWrapper>\n      )}\n      <AccordionRoot type=\"multiple\" onValueChange={setOpenAccordions} value={openAccordions}>\n        {licenseBox && (\n          <AccordionItem value={accordionItemValue}>\n            <StyledAccordionHeader headingLevel=\"h2\" data-background-color={accordionHeaderVariant}>\n              {t(\"article.useContent\")}\n            </StyledAccordionHeader>\n            <StyledAccordionContent data-background-color={accordionHeaderVariant}>{licenseBox}</StyledAccordionContent>\n          </AccordionItem>\n        )}\n\n        {!!footnotes?.length && (\n          <AccordionItem value={footnotesAccordionId}>\n            <StyledAccordionHeader headingLevel=\"h2\">{t(\"article.footnotes\")}</StyledAccordionHeader>\n            <StyledAccordionContent forceMount data-background-color={accordionHeaderVariant}>\n              <ArticleFootNotes footNotes={footnotes} />\n            </StyledAccordionContent>\n          </AccordionItem>\n        )}\n      </AccordionRoot>\n    </Wrapper>\n  );\n};\n\nexport default ArticleByline;\n"]} */"));
|
|
23
23
|
const TextWrapper = /*#__PURE__*/_styled("div", {
|
|
24
24
|
target: "eeu23se4",
|
|
25
25
|
label: "TextWrapper"
|
|
26
26
|
})("display:flex;justify-content:space-between;width:100%;padding-bottom:", spacing.mediumlarge, ";", mq.range({
|
|
27
27
|
until: breakpoints.tabletWide
|
|
28
|
-
}), "{flex-direction:column;flex-direction:column-reverse;gap:", spacing.xsmall, ";}&[data-learning-path=\"true\"]{flex-direction:column;flex-direction:column-reverse;gap:", spacing.xsmall, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
28
|
+
}), "{flex-direction:column;flex-direction:column-reverse;gap:", spacing.xsmall, ";}&[data-learning-path=\"true\"]{flex-direction:column;flex-direction:column-reverse;gap:", spacing.xsmall, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ArticleByline.tsx"],"names":[],"mappings":"AA8B8B","file":"ArticleByline.tsx","sourcesContent":["/**\n * Copyright (c) 2020-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { TFunction } from \"i18next\";\nimport { ReactNode, useCallback, useEffect, useState } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { useLocation } from \"react-router-dom\";\nimport styled from \"@emotion/styled\";\nimport { AccordionRoot, AccordionHeader, AccordionContent, AccordionItem } from \"@ndla/accordion\";\nimport { breakpoints, colors, fonts, mq, spacing } from \"@ndla/core\";\nimport { getLicenseByAbbreviation } from \"@ndla/licenses\";\nimport ArticleFootNotes from \"./ArticleFootNotes\";\nimport { LicenseLink } from \"../LicenseByline/LicenseLink\";\nimport { FootNote } from \"../types\";\n\nconst Wrapper = styled.div`\n  margin-top: ${spacing.normal};\n  padding-top: ${spacing.normal};\n  padding-bottom: ${spacing.xsmall};\n  border-top: 1px solid ${colors.brand.greyLight};\n  ${fonts.sizes(\"16px\", \"24px\")};\n  font-family: ${fonts.sans};\n  color: ${colors.brand.greyDark};\n`;\n\nconst TextWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  width: 100%;\n  padding-bottom: ${spacing.mediumlarge};\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    flex-direction: column;\n    flex-direction: column-reverse;\n    gap: ${spacing.xsmall};\n  }\n  &[data-learning-path=\"true\"] {\n    flex-direction: column;\n    flex-direction: column-reverse;\n    gap: ${spacing.xsmall};\n  }\n`;\n\nconst PrimaryContributorsWrapper = styled.span`\n  margin-left: ${spacing.xxsmall};\n`;\n\ntype AuthorProps = {\n  name: string;\n};\n\ntype SupplierProps = {\n  name: string;\n};\n\ntype AccordionHeaderVariants = \"white\" | \"blue\";\n\ntype Props = {\n  authors?: AuthorProps[];\n  suppliers?: SupplierProps[];\n  published?: string;\n  license?: string;\n  licenseBox?: ReactNode;\n  locale?: string;\n  footnotes?: FootNote[];\n  accordionHeaderVariant?: AccordionHeaderVariants;\n  displayByline?: boolean;\n  bylineType?: \"article\" | \"learningPath\";\n};\n\nconst renderContributors = (contributors: SupplierProps[] | AuthorProps[], t: TFunction) => {\n  const contributorsArray = contributors.map((contributor, index) => {\n    if (index < 1) return contributor.name;\n    const sep = index === contributors.length - 1 ? ` ${t(\"article.conjunction\")} ` : \", \";\n    return `${sep}${contributor.name}`;\n  });\n  return contributorsArray.join(\"\");\n};\n\nconst getSuppliersText = (suppliers: SupplierProps[], t: TFunction) => {\n  if (suppliers.length === 0) {\n    return \"\";\n  }\n  return suppliers.length > 1\n    ? t(\"article.multipleSuppliersLabel\", {\n        names: renderContributors(suppliers, t),\n        interpolation: { escapeValue: false },\n      })\n    : t(\"article.supplierLabel\", {\n        name: renderContributors(suppliers, t),\n        interpolation: { escapeValue: false },\n      });\n};\n\nconst LicenseWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.small};\n  padding-right: ${spacing.xsmall};\n`;\n\nconst StyledAccordionHeader = styled(AccordionHeader)`\n  background-color: ${colors.brand.lightest};\n  ${fonts.sizes(\"16px\", \"29px\")};\n  font-weight: ${fonts.weight.semibold};\n\n  &[data-background-color=\"white\"][data-state=\"closed\"] {\n    background-color: ${colors.background.default};\n  }\n`;\n\nconst StyledAccordionContent = styled(AccordionContent)`\n  &[data-background-color=\"white\"] {\n    background-color: ${colors.background.default};\n  }\n`;\n\nconst refRegexp = /note\\d/;\nconst footnotesAccordionId = \"footnotes\";\n\nconst ArticleByline = ({\n  authors = [],\n  suppliers = [],\n  footnotes,\n  license: licenseString,\n  licenseBox,\n  published,\n  locale,\n  accordionHeaderVariant = \"blue\",\n  displayByline = true,\n  bylineType = \"article\",\n}: Props) => {\n  const { t } = useTranslation();\n  const { pathname } = useLocation();\n  const [openAccordions, setOpenAccordions] = useState<string[]>([]);\n  const accordionItemValue = \"rulesForUse\";\n\n  const onHashChange = useCallback(\n    (e: HashChangeEvent) => {\n      const hash = e.newURL.split(\"#\")[1];\n      if (hash.match(refRegexp) && !openAccordions.includes(footnotesAccordionId)) {\n        setOpenAccordions([...openAccordions, footnotesAccordionId]);\n        const el = document.getElementById(`#${hash}`);\n        el?.click();\n        el?.focus();\n      }\n    },\n    [openAccordions],\n  );\n\n  useEffect(() => {\n    setOpenAccordions((prev) => prev.filter((state) => state !== accordionItemValue));\n  }, [pathname]);\n\n  useEffect(() => {\n    window.addEventListener(\"hashchange\", onHashChange);\n    return () => window.removeEventListener(\"hashchange\", onHashChange);\n  }, [onHashChange]);\n\n  const license = licenseString && getLicenseByAbbreviation(licenseString, locale);\n\n  const showPrimaryContributors = suppliers.length > 0 || authors.length > 0;\n\n  return (\n    <Wrapper>\n      {displayByline && (\n        <TextWrapper data-learning-path={bylineType === \"learningPath\"}>\n          <LicenseWrapper>\n            {license && <LicenseLink license={license} />}\n            {showPrimaryContributors && (\n              <PrimaryContributorsWrapper>\n                {authors.length > 0 &&\n                  `${t(\"article.authorsLabel\", {\n                    names: renderContributors(authors, t),\n                    interpolation: { escapeValue: false },\n                  })}. `}\n                {getSuppliersText(suppliers, t)}\n              </PrimaryContributorsWrapper>\n            )}\n          </LicenseWrapper>\n          <div>\n            {t(`${bylineType}.lastUpdated`)} {published}\n          </div>\n        </TextWrapper>\n      )}\n      <AccordionRoot type=\"multiple\" onValueChange={setOpenAccordions} value={openAccordions}>\n        {licenseBox && (\n          <AccordionItem value={accordionItemValue}>\n            <StyledAccordionHeader headingLevel=\"h2\" data-background-color={accordionHeaderVariant}>\n              {t(\"article.useContent\")}\n            </StyledAccordionHeader>\n            <StyledAccordionContent data-background-color={accordionHeaderVariant}>{licenseBox}</StyledAccordionContent>\n          </AccordionItem>\n        )}\n\n        {!!footnotes?.length && (\n          <AccordionItem value={footnotesAccordionId}>\n            <StyledAccordionHeader headingLevel=\"h2\">{t(\"article.footnotes\")}</StyledAccordionHeader>\n            <StyledAccordionContent forceMount data-background-color={accordionHeaderVariant}>\n              <ArticleFootNotes footNotes={footnotes} />\n            </StyledAccordionContent>\n          </AccordionItem>\n        )}\n      </AccordionRoot>\n    </Wrapper>\n  );\n};\n\nexport default ArticleByline;\n"]} */"));
|
|
29
29
|
const PrimaryContributorsWrapper = /*#__PURE__*/_styled("span", {
|
|
30
30
|
target: "eeu23se3",
|
|
31
31
|
label: "PrimaryContributorsWrapper"
|
|
32
|
-
})("margin-left:", spacing.xxsmall, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
32
|
+
})("margin-left:", spacing.xxsmall, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ArticleByline.tsx"],"names":[],"mappings":"AA+C8C","file":"ArticleByline.tsx","sourcesContent":["/**\n * Copyright (c) 2020-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { TFunction } from \"i18next\";\nimport { ReactNode, useCallback, useEffect, useState } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { useLocation } from \"react-router-dom\";\nimport styled from \"@emotion/styled\";\nimport { AccordionRoot, AccordionHeader, AccordionContent, AccordionItem } from \"@ndla/accordion\";\nimport { breakpoints, colors, fonts, mq, spacing } from \"@ndla/core\";\nimport { getLicenseByAbbreviation } from \"@ndla/licenses\";\nimport ArticleFootNotes from \"./ArticleFootNotes\";\nimport { LicenseLink } from \"../LicenseByline/LicenseLink\";\nimport { FootNote } from \"../types\";\n\nconst Wrapper = styled.div`\n  margin-top: ${spacing.normal};\n  padding-top: ${spacing.normal};\n  padding-bottom: ${spacing.xsmall};\n  border-top: 1px solid ${colors.brand.greyLight};\n  ${fonts.sizes(\"16px\", \"24px\")};\n  font-family: ${fonts.sans};\n  color: ${colors.brand.greyDark};\n`;\n\nconst TextWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  width: 100%;\n  padding-bottom: ${spacing.mediumlarge};\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    flex-direction: column;\n    flex-direction: column-reverse;\n    gap: ${spacing.xsmall};\n  }\n  &[data-learning-path=\"true\"] {\n    flex-direction: column;\n    flex-direction: column-reverse;\n    gap: ${spacing.xsmall};\n  }\n`;\n\nconst PrimaryContributorsWrapper = styled.span`\n  margin-left: ${spacing.xxsmall};\n`;\n\ntype AuthorProps = {\n  name: string;\n};\n\ntype SupplierProps = {\n  name: string;\n};\n\ntype AccordionHeaderVariants = \"white\" | \"blue\";\n\ntype Props = {\n  authors?: AuthorProps[];\n  suppliers?: SupplierProps[];\n  published?: string;\n  license?: string;\n  licenseBox?: ReactNode;\n  locale?: string;\n  footnotes?: FootNote[];\n  accordionHeaderVariant?: AccordionHeaderVariants;\n  displayByline?: boolean;\n  bylineType?: \"article\" | \"learningPath\";\n};\n\nconst renderContributors = (contributors: SupplierProps[] | AuthorProps[], t: TFunction) => {\n  const contributorsArray = contributors.map((contributor, index) => {\n    if (index < 1) return contributor.name;\n    const sep = index === contributors.length - 1 ? ` ${t(\"article.conjunction\")} ` : \", \";\n    return `${sep}${contributor.name}`;\n  });\n  return contributorsArray.join(\"\");\n};\n\nconst getSuppliersText = (suppliers: SupplierProps[], t: TFunction) => {\n  if (suppliers.length === 0) {\n    return \"\";\n  }\n  return suppliers.length > 1\n    ? t(\"article.multipleSuppliersLabel\", {\n        names: renderContributors(suppliers, t),\n        interpolation: { escapeValue: false },\n      })\n    : t(\"article.supplierLabel\", {\n        name: renderContributors(suppliers, t),\n        interpolation: { escapeValue: false },\n      });\n};\n\nconst LicenseWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.small};\n  padding-right: ${spacing.xsmall};\n`;\n\nconst StyledAccordionHeader = styled(AccordionHeader)`\n  background-color: ${colors.brand.lightest};\n  ${fonts.sizes(\"16px\", \"29px\")};\n  font-weight: ${fonts.weight.semibold};\n\n  &[data-background-color=\"white\"][data-state=\"closed\"] {\n    background-color: ${colors.background.default};\n  }\n`;\n\nconst StyledAccordionContent = styled(AccordionContent)`\n  &[data-background-color=\"white\"] {\n    background-color: ${colors.background.default};\n  }\n`;\n\nconst refRegexp = /note\\d/;\nconst footnotesAccordionId = \"footnotes\";\n\nconst ArticleByline = ({\n  authors = [],\n  suppliers = [],\n  footnotes,\n  license: licenseString,\n  licenseBox,\n  published,\n  locale,\n  accordionHeaderVariant = \"blue\",\n  displayByline = true,\n  bylineType = \"article\",\n}: Props) => {\n  const { t } = useTranslation();\n  const { pathname } = useLocation();\n  const [openAccordions, setOpenAccordions] = useState<string[]>([]);\n  const accordionItemValue = \"rulesForUse\";\n\n  const onHashChange = useCallback(\n    (e: HashChangeEvent) => {\n      const hash = e.newURL.split(\"#\")[1];\n      if (hash.match(refRegexp) && !openAccordions.includes(footnotesAccordionId)) {\n        setOpenAccordions([...openAccordions, footnotesAccordionId]);\n        const el = document.getElementById(`#${hash}`);\n        el?.click();\n        el?.focus();\n      }\n    },\n    [openAccordions],\n  );\n\n  useEffect(() => {\n    setOpenAccordions((prev) => prev.filter((state) => state !== accordionItemValue));\n  }, [pathname]);\n\n  useEffect(() => {\n    window.addEventListener(\"hashchange\", onHashChange);\n    return () => window.removeEventListener(\"hashchange\", onHashChange);\n  }, [onHashChange]);\n\n  const license = licenseString && getLicenseByAbbreviation(licenseString, locale);\n\n  const showPrimaryContributors = suppliers.length > 0 || authors.length > 0;\n\n  return (\n    <Wrapper>\n      {displayByline && (\n        <TextWrapper data-learning-path={bylineType === \"learningPath\"}>\n          <LicenseWrapper>\n            {license && <LicenseLink license={license} />}\n            {showPrimaryContributors && (\n              <PrimaryContributorsWrapper>\n                {authors.length > 0 &&\n                  `${t(\"article.authorsLabel\", {\n                    names: renderContributors(authors, t),\n                    interpolation: { escapeValue: false },\n                  })}. `}\n                {getSuppliersText(suppliers, t)}\n              </PrimaryContributorsWrapper>\n            )}\n          </LicenseWrapper>\n          <div>\n            {t(`${bylineType}.lastUpdated`)} {published}\n          </div>\n        </TextWrapper>\n      )}\n      <AccordionRoot type=\"multiple\" onValueChange={setOpenAccordions} value={openAccordions}>\n        {licenseBox && (\n          <AccordionItem value={accordionItemValue}>\n            <StyledAccordionHeader headingLevel=\"h2\" data-background-color={accordionHeaderVariant}>\n              {t(\"article.useContent\")}\n            </StyledAccordionHeader>\n            <StyledAccordionContent data-background-color={accordionHeaderVariant}>{licenseBox}</StyledAccordionContent>\n          </AccordionItem>\n        )}\n\n        {!!footnotes?.length && (\n          <AccordionItem value={footnotesAccordionId}>\n            <StyledAccordionHeader headingLevel=\"h2\">{t(\"article.footnotes\")}</StyledAccordionHeader>\n            <StyledAccordionContent forceMount data-background-color={accordionHeaderVariant}>\n              <ArticleFootNotes footNotes={footnotes} />\n            </StyledAccordionContent>\n          </AccordionItem>\n        )}\n      </AccordionRoot>\n    </Wrapper>\n  );\n};\n\nexport default ArticleByline;\n"]} */"));
|
|
33
33
|
const renderContributors = (contributors, t) => {
|
|
34
34
|
const contributorsArray = contributors.map((contributor, index) => {
|
|
35
35
|
if (index < 1) return contributor.name;
|
|
@@ -57,15 +57,15 @@ const getSuppliersText = (suppliers, t) => {
|
|
|
57
57
|
const LicenseWrapper = /*#__PURE__*/_styled("div", {
|
|
58
58
|
target: "eeu23se2",
|
|
59
59
|
label: "LicenseWrapper"
|
|
60
|
-
})("display:flex;gap:", spacing.small, ";padding-right:", spacing.xsmall, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
60
|
+
})("display:flex;gap:", spacing.small, ";padding-right:", spacing.xsmall, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ArticleByline.tsx"],"names":[],"mappings":"AAkGiC","file":"ArticleByline.tsx","sourcesContent":["/**\n * Copyright (c) 2020-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { TFunction } from \"i18next\";\nimport { ReactNode, useCallback, useEffect, useState } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { useLocation } from \"react-router-dom\";\nimport styled from \"@emotion/styled\";\nimport { AccordionRoot, AccordionHeader, AccordionContent, AccordionItem } from \"@ndla/accordion\";\nimport { breakpoints, colors, fonts, mq, spacing } from \"@ndla/core\";\nimport { getLicenseByAbbreviation } from \"@ndla/licenses\";\nimport ArticleFootNotes from \"./ArticleFootNotes\";\nimport { LicenseLink } from \"../LicenseByline/LicenseLink\";\nimport { FootNote } from \"../types\";\n\nconst Wrapper = styled.div`\n  margin-top: ${spacing.normal};\n  padding-top: ${spacing.normal};\n  padding-bottom: ${spacing.xsmall};\n  border-top: 1px solid ${colors.brand.greyLight};\n  ${fonts.sizes(\"16px\", \"24px\")};\n  font-family: ${fonts.sans};\n  color: ${colors.brand.greyDark};\n`;\n\nconst TextWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  width: 100%;\n  padding-bottom: ${spacing.mediumlarge};\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    flex-direction: column;\n    flex-direction: column-reverse;\n    gap: ${spacing.xsmall};\n  }\n  &[data-learning-path=\"true\"] {\n    flex-direction: column;\n    flex-direction: column-reverse;\n    gap: ${spacing.xsmall};\n  }\n`;\n\nconst PrimaryContributorsWrapper = styled.span`\n  margin-left: ${spacing.xxsmall};\n`;\n\ntype AuthorProps = {\n  name: string;\n};\n\ntype SupplierProps = {\n  name: string;\n};\n\ntype AccordionHeaderVariants = \"white\" | \"blue\";\n\ntype Props = {\n  authors?: AuthorProps[];\n  suppliers?: SupplierProps[];\n  published?: string;\n  license?: string;\n  licenseBox?: ReactNode;\n  locale?: string;\n  footnotes?: FootNote[];\n  accordionHeaderVariant?: AccordionHeaderVariants;\n  displayByline?: boolean;\n  bylineType?: \"article\" | \"learningPath\";\n};\n\nconst renderContributors = (contributors: SupplierProps[] | AuthorProps[], t: TFunction) => {\n  const contributorsArray = contributors.map((contributor, index) => {\n    if (index < 1) return contributor.name;\n    const sep = index === contributors.length - 1 ? ` ${t(\"article.conjunction\")} ` : \", \";\n    return `${sep}${contributor.name}`;\n  });\n  return contributorsArray.join(\"\");\n};\n\nconst getSuppliersText = (suppliers: SupplierProps[], t: TFunction) => {\n  if (suppliers.length === 0) {\n    return \"\";\n  }\n  return suppliers.length > 1\n    ? t(\"article.multipleSuppliersLabel\", {\n        names: renderContributors(suppliers, t),\n        interpolation: { escapeValue: false },\n      })\n    : t(\"article.supplierLabel\", {\n        name: renderContributors(suppliers, t),\n        interpolation: { escapeValue: false },\n      });\n};\n\nconst LicenseWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.small};\n  padding-right: ${spacing.xsmall};\n`;\n\nconst StyledAccordionHeader = styled(AccordionHeader)`\n  background-color: ${colors.brand.lightest};\n  ${fonts.sizes(\"16px\", \"29px\")};\n  font-weight: ${fonts.weight.semibold};\n\n  &[data-background-color=\"white\"][data-state=\"closed\"] {\n    background-color: ${colors.background.default};\n  }\n`;\n\nconst StyledAccordionContent = styled(AccordionContent)`\n  &[data-background-color=\"white\"] {\n    background-color: ${colors.background.default};\n  }\n`;\n\nconst refRegexp = /note\\d/;\nconst footnotesAccordionId = \"footnotes\";\n\nconst ArticleByline = ({\n  authors = [],\n  suppliers = [],\n  footnotes,\n  license: licenseString,\n  licenseBox,\n  published,\n  locale,\n  accordionHeaderVariant = \"blue\",\n  displayByline = true,\n  bylineType = \"article\",\n}: Props) => {\n  const { t } = useTranslation();\n  const { pathname } = useLocation();\n  const [openAccordions, setOpenAccordions] = useState<string[]>([]);\n  const accordionItemValue = \"rulesForUse\";\n\n  const onHashChange = useCallback(\n    (e: HashChangeEvent) => {\n      const hash = e.newURL.split(\"#\")[1];\n      if (hash.match(refRegexp) && !openAccordions.includes(footnotesAccordionId)) {\n        setOpenAccordions([...openAccordions, footnotesAccordionId]);\n        const el = document.getElementById(`#${hash}`);\n        el?.click();\n        el?.focus();\n      }\n    },\n    [openAccordions],\n  );\n\n  useEffect(() => {\n    setOpenAccordions((prev) => prev.filter((state) => state !== accordionItemValue));\n  }, [pathname]);\n\n  useEffect(() => {\n    window.addEventListener(\"hashchange\", onHashChange);\n    return () => window.removeEventListener(\"hashchange\", onHashChange);\n  }, [onHashChange]);\n\n  const license = licenseString && getLicenseByAbbreviation(licenseString, locale);\n\n  const showPrimaryContributors = suppliers.length > 0 || authors.length > 0;\n\n  return (\n    <Wrapper>\n      {displayByline && (\n        <TextWrapper data-learning-path={bylineType === \"learningPath\"}>\n          <LicenseWrapper>\n            {license && <LicenseLink license={license} />}\n            {showPrimaryContributors && (\n              <PrimaryContributorsWrapper>\n                {authors.length > 0 &&\n                  `${t(\"article.authorsLabel\", {\n                    names: renderContributors(authors, t),\n                    interpolation: { escapeValue: false },\n                  })}. `}\n                {getSuppliersText(suppliers, t)}\n              </PrimaryContributorsWrapper>\n            )}\n          </LicenseWrapper>\n          <div>\n            {t(`${bylineType}.lastUpdated`)} {published}\n          </div>\n        </TextWrapper>\n      )}\n      <AccordionRoot type=\"multiple\" onValueChange={setOpenAccordions} value={openAccordions}>\n        {licenseBox && (\n          <AccordionItem value={accordionItemValue}>\n            <StyledAccordionHeader headingLevel=\"h2\" data-background-color={accordionHeaderVariant}>\n              {t(\"article.useContent\")}\n            </StyledAccordionHeader>\n            <StyledAccordionContent data-background-color={accordionHeaderVariant}>{licenseBox}</StyledAccordionContent>\n          </AccordionItem>\n        )}\n\n        {!!footnotes?.length && (\n          <AccordionItem value={footnotesAccordionId}>\n            <StyledAccordionHeader headingLevel=\"h2\">{t(\"article.footnotes\")}</StyledAccordionHeader>\n            <StyledAccordionContent forceMount data-background-color={accordionHeaderVariant}>\n              <ArticleFootNotes footNotes={footnotes} />\n            </StyledAccordionContent>\n          </AccordionItem>\n        )}\n      </AccordionRoot>\n    </Wrapper>\n  );\n};\n\nexport default ArticleByline;\n"]} */"));
|
|
61
61
|
const StyledAccordionHeader = /*#__PURE__*/_styled(AccordionHeader, {
|
|
62
62
|
target: "eeu23se1",
|
|
63
63
|
label: "StyledAccordionHeader"
|
|
64
|
-
})("background-color:", colors.brand.lightest, ";", fonts.sizes("16px", "29px"), ";font-weight:", fonts.weight.semibold, ";&[data-background-color=\"white\"][data-state=\"closed\"]{background-color:", colors.background.default, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
64
|
+
})("background-color:", colors.brand.lightest, ";", fonts.sizes("16px", "29px"), ";font-weight:", fonts.weight.semibold, ";&[data-background-color=\"white\"][data-state=\"closed\"]{background-color:", colors.background.default, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ArticleByline.tsx"],"names":[],"mappings":"AAwGqD","file":"ArticleByline.tsx","sourcesContent":["/**\n * Copyright (c) 2020-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { TFunction } from \"i18next\";\nimport { ReactNode, useCallback, useEffect, useState } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { useLocation } from \"react-router-dom\";\nimport styled from \"@emotion/styled\";\nimport { AccordionRoot, AccordionHeader, AccordionContent, AccordionItem } from \"@ndla/accordion\";\nimport { breakpoints, colors, fonts, mq, spacing } from \"@ndla/core\";\nimport { getLicenseByAbbreviation } from \"@ndla/licenses\";\nimport ArticleFootNotes from \"./ArticleFootNotes\";\nimport { LicenseLink } from \"../LicenseByline/LicenseLink\";\nimport { FootNote } from \"../types\";\n\nconst Wrapper = styled.div`\n  margin-top: ${spacing.normal};\n  padding-top: ${spacing.normal};\n  padding-bottom: ${spacing.xsmall};\n  border-top: 1px solid ${colors.brand.greyLight};\n  ${fonts.sizes(\"16px\", \"24px\")};\n  font-family: ${fonts.sans};\n  color: ${colors.brand.greyDark};\n`;\n\nconst TextWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  width: 100%;\n  padding-bottom: ${spacing.mediumlarge};\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    flex-direction: column;\n    flex-direction: column-reverse;\n    gap: ${spacing.xsmall};\n  }\n  &[data-learning-path=\"true\"] {\n    flex-direction: column;\n    flex-direction: column-reverse;\n    gap: ${spacing.xsmall};\n  }\n`;\n\nconst PrimaryContributorsWrapper = styled.span`\n  margin-left: ${spacing.xxsmall};\n`;\n\ntype AuthorProps = {\n  name: string;\n};\n\ntype SupplierProps = {\n  name: string;\n};\n\ntype AccordionHeaderVariants = \"white\" | \"blue\";\n\ntype Props = {\n  authors?: AuthorProps[];\n  suppliers?: SupplierProps[];\n  published?: string;\n  license?: string;\n  licenseBox?: ReactNode;\n  locale?: string;\n  footnotes?: FootNote[];\n  accordionHeaderVariant?: AccordionHeaderVariants;\n  displayByline?: boolean;\n  bylineType?: \"article\" | \"learningPath\";\n};\n\nconst renderContributors = (contributors: SupplierProps[] | AuthorProps[], t: TFunction) => {\n  const contributorsArray = contributors.map((contributor, index) => {\n    if (index < 1) return contributor.name;\n    const sep = index === contributors.length - 1 ? ` ${t(\"article.conjunction\")} ` : \", \";\n    return `${sep}${contributor.name}`;\n  });\n  return contributorsArray.join(\"\");\n};\n\nconst getSuppliersText = (suppliers: SupplierProps[], t: TFunction) => {\n  if (suppliers.length === 0) {\n    return \"\";\n  }\n  return suppliers.length > 1\n    ? t(\"article.multipleSuppliersLabel\", {\n        names: renderContributors(suppliers, t),\n        interpolation: { escapeValue: false },\n      })\n    : t(\"article.supplierLabel\", {\n        name: renderContributors(suppliers, t),\n        interpolation: { escapeValue: false },\n      });\n};\n\nconst LicenseWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.small};\n  padding-right: ${spacing.xsmall};\n`;\n\nconst StyledAccordionHeader = styled(AccordionHeader)`\n  background-color: ${colors.brand.lightest};\n  ${fonts.sizes(\"16px\", \"29px\")};\n  font-weight: ${fonts.weight.semibold};\n\n  &[data-background-color=\"white\"][data-state=\"closed\"] {\n    background-color: ${colors.background.default};\n  }\n`;\n\nconst StyledAccordionContent = styled(AccordionContent)`\n  &[data-background-color=\"white\"] {\n    background-color: ${colors.background.default};\n  }\n`;\n\nconst refRegexp = /note\\d/;\nconst footnotesAccordionId = \"footnotes\";\n\nconst ArticleByline = ({\n  authors = [],\n  suppliers = [],\n  footnotes,\n  license: licenseString,\n  licenseBox,\n  published,\n  locale,\n  accordionHeaderVariant = \"blue\",\n  displayByline = true,\n  bylineType = \"article\",\n}: Props) => {\n  const { t } = useTranslation();\n  const { pathname } = useLocation();\n  const [openAccordions, setOpenAccordions] = useState<string[]>([]);\n  const accordionItemValue = \"rulesForUse\";\n\n  const onHashChange = useCallback(\n    (e: HashChangeEvent) => {\n      const hash = e.newURL.split(\"#\")[1];\n      if (hash.match(refRegexp) && !openAccordions.includes(footnotesAccordionId)) {\n        setOpenAccordions([...openAccordions, footnotesAccordionId]);\n        const el = document.getElementById(`#${hash}`);\n        el?.click();\n        el?.focus();\n      }\n    },\n    [openAccordions],\n  );\n\n  useEffect(() => {\n    setOpenAccordions((prev) => prev.filter((state) => state !== accordionItemValue));\n  }, [pathname]);\n\n  useEffect(() => {\n    window.addEventListener(\"hashchange\", onHashChange);\n    return () => window.removeEventListener(\"hashchange\", onHashChange);\n  }, [onHashChange]);\n\n  const license = licenseString && getLicenseByAbbreviation(licenseString, locale);\n\n  const showPrimaryContributors = suppliers.length > 0 || authors.length > 0;\n\n  return (\n    <Wrapper>\n      {displayByline && (\n        <TextWrapper data-learning-path={bylineType === \"learningPath\"}>\n          <LicenseWrapper>\n            {license && <LicenseLink license={license} />}\n            {showPrimaryContributors && (\n              <PrimaryContributorsWrapper>\n                {authors.length > 0 &&\n                  `${t(\"article.authorsLabel\", {\n                    names: renderContributors(authors, t),\n                    interpolation: { escapeValue: false },\n                  })}. `}\n                {getSuppliersText(suppliers, t)}\n              </PrimaryContributorsWrapper>\n            )}\n          </LicenseWrapper>\n          <div>\n            {t(`${bylineType}.lastUpdated`)} {published}\n          </div>\n        </TextWrapper>\n      )}\n      <AccordionRoot type=\"multiple\" onValueChange={setOpenAccordions} value={openAccordions}>\n        {licenseBox && (\n          <AccordionItem value={accordionItemValue}>\n            <StyledAccordionHeader headingLevel=\"h2\" data-background-color={accordionHeaderVariant}>\n              {t(\"article.useContent\")}\n            </StyledAccordionHeader>\n            <StyledAccordionContent data-background-color={accordionHeaderVariant}>{licenseBox}</StyledAccordionContent>\n          </AccordionItem>\n        )}\n\n        {!!footnotes?.length && (\n          <AccordionItem value={footnotesAccordionId}>\n            <StyledAccordionHeader headingLevel=\"h2\">{t(\"article.footnotes\")}</StyledAccordionHeader>\n            <StyledAccordionContent forceMount data-background-color={accordionHeaderVariant}>\n              <ArticleFootNotes footNotes={footnotes} />\n            </StyledAccordionContent>\n          </AccordionItem>\n        )}\n      </AccordionRoot>\n    </Wrapper>\n  );\n};\n\nexport default ArticleByline;\n"]} */"));
|
|
65
65
|
const StyledAccordionContent = /*#__PURE__*/_styled(AccordionContent, {
|
|
66
66
|
target: "eeu23se0",
|
|
67
67
|
label: "StyledAccordionContent"
|
|
68
|
-
})("&[data-background-color=\"white\"]{background-color:", colors.background.default, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
68
|
+
})("&[data-background-color=\"white\"]{background-color:", colors.background.default, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ArticleByline.tsx"],"names":[],"mappings":"AAkHuD","file":"ArticleByline.tsx","sourcesContent":["/**\n * Copyright (c) 2020-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { TFunction } from \"i18next\";\nimport { ReactNode, useCallback, useEffect, useState } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { useLocation } from \"react-router-dom\";\nimport styled from \"@emotion/styled\";\nimport { AccordionRoot, AccordionHeader, AccordionContent, AccordionItem } from \"@ndla/accordion\";\nimport { breakpoints, colors, fonts, mq, spacing } from \"@ndla/core\";\nimport { getLicenseByAbbreviation } from \"@ndla/licenses\";\nimport ArticleFootNotes from \"./ArticleFootNotes\";\nimport { LicenseLink } from \"../LicenseByline/LicenseLink\";\nimport { FootNote } from \"../types\";\n\nconst Wrapper = styled.div`\n  margin-top: ${spacing.normal};\n  padding-top: ${spacing.normal};\n  padding-bottom: ${spacing.xsmall};\n  border-top: 1px solid ${colors.brand.greyLight};\n  ${fonts.sizes(\"16px\", \"24px\")};\n  font-family: ${fonts.sans};\n  color: ${colors.brand.greyDark};\n`;\n\nconst TextWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  width: 100%;\n  padding-bottom: ${spacing.mediumlarge};\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    flex-direction: column;\n    flex-direction: column-reverse;\n    gap: ${spacing.xsmall};\n  }\n  &[data-learning-path=\"true\"] {\n    flex-direction: column;\n    flex-direction: column-reverse;\n    gap: ${spacing.xsmall};\n  }\n`;\n\nconst PrimaryContributorsWrapper = styled.span`\n  margin-left: ${spacing.xxsmall};\n`;\n\ntype AuthorProps = {\n  name: string;\n};\n\ntype SupplierProps = {\n  name: string;\n};\n\ntype AccordionHeaderVariants = \"white\" | \"blue\";\n\ntype Props = {\n  authors?: AuthorProps[];\n  suppliers?: SupplierProps[];\n  published?: string;\n  license?: string;\n  licenseBox?: ReactNode;\n  locale?: string;\n  footnotes?: FootNote[];\n  accordionHeaderVariant?: AccordionHeaderVariants;\n  displayByline?: boolean;\n  bylineType?: \"article\" | \"learningPath\";\n};\n\nconst renderContributors = (contributors: SupplierProps[] | AuthorProps[], t: TFunction) => {\n  const contributorsArray = contributors.map((contributor, index) => {\n    if (index < 1) return contributor.name;\n    const sep = index === contributors.length - 1 ? ` ${t(\"article.conjunction\")} ` : \", \";\n    return `${sep}${contributor.name}`;\n  });\n  return contributorsArray.join(\"\");\n};\n\nconst getSuppliersText = (suppliers: SupplierProps[], t: TFunction) => {\n  if (suppliers.length === 0) {\n    return \"\";\n  }\n  return suppliers.length > 1\n    ? t(\"article.multipleSuppliersLabel\", {\n        names: renderContributors(suppliers, t),\n        interpolation: { escapeValue: false },\n      })\n    : t(\"article.supplierLabel\", {\n        name: renderContributors(suppliers, t),\n        interpolation: { escapeValue: false },\n      });\n};\n\nconst LicenseWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.small};\n  padding-right: ${spacing.xsmall};\n`;\n\nconst StyledAccordionHeader = styled(AccordionHeader)`\n  background-color: ${colors.brand.lightest};\n  ${fonts.sizes(\"16px\", \"29px\")};\n  font-weight: ${fonts.weight.semibold};\n\n  &[data-background-color=\"white\"][data-state=\"closed\"] {\n    background-color: ${colors.background.default};\n  }\n`;\n\nconst StyledAccordionContent = styled(AccordionContent)`\n  &[data-background-color=\"white\"] {\n    background-color: ${colors.background.default};\n  }\n`;\n\nconst refRegexp = /note\\d/;\nconst footnotesAccordionId = \"footnotes\";\n\nconst ArticleByline = ({\n  authors = [],\n  suppliers = [],\n  footnotes,\n  license: licenseString,\n  licenseBox,\n  published,\n  locale,\n  accordionHeaderVariant = \"blue\",\n  displayByline = true,\n  bylineType = \"article\",\n}: Props) => {\n  const { t } = useTranslation();\n  const { pathname } = useLocation();\n  const [openAccordions, setOpenAccordions] = useState<string[]>([]);\n  const accordionItemValue = \"rulesForUse\";\n\n  const onHashChange = useCallback(\n    (e: HashChangeEvent) => {\n      const hash = e.newURL.split(\"#\")[1];\n      if (hash.match(refRegexp) && !openAccordions.includes(footnotesAccordionId)) {\n        setOpenAccordions([...openAccordions, footnotesAccordionId]);\n        const el = document.getElementById(`#${hash}`);\n        el?.click();\n        el?.focus();\n      }\n    },\n    [openAccordions],\n  );\n\n  useEffect(() => {\n    setOpenAccordions((prev) => prev.filter((state) => state !== accordionItemValue));\n  }, [pathname]);\n\n  useEffect(() => {\n    window.addEventListener(\"hashchange\", onHashChange);\n    return () => window.removeEventListener(\"hashchange\", onHashChange);\n  }, [onHashChange]);\n\n  const license = licenseString && getLicenseByAbbreviation(licenseString, locale);\n\n  const showPrimaryContributors = suppliers.length > 0 || authors.length > 0;\n\n  return (\n    <Wrapper>\n      {displayByline && (\n        <TextWrapper data-learning-path={bylineType === \"learningPath\"}>\n          <LicenseWrapper>\n            {license && <LicenseLink license={license} />}\n            {showPrimaryContributors && (\n              <PrimaryContributorsWrapper>\n                {authors.length > 0 &&\n                  `${t(\"article.authorsLabel\", {\n                    names: renderContributors(authors, t),\n                    interpolation: { escapeValue: false },\n                  })}. `}\n                {getSuppliersText(suppliers, t)}\n              </PrimaryContributorsWrapper>\n            )}\n          </LicenseWrapper>\n          <div>\n            {t(`${bylineType}.lastUpdated`)} {published}\n          </div>\n        </TextWrapper>\n      )}\n      <AccordionRoot type=\"multiple\" onValueChange={setOpenAccordions} value={openAccordions}>\n        {licenseBox && (\n          <AccordionItem value={accordionItemValue}>\n            <StyledAccordionHeader headingLevel=\"h2\" data-background-color={accordionHeaderVariant}>\n              {t(\"article.useContent\")}\n            </StyledAccordionHeader>\n            <StyledAccordionContent data-background-color={accordionHeaderVariant}>{licenseBox}</StyledAccordionContent>\n          </AccordionItem>\n        )}\n\n        {!!footnotes?.length && (\n          <AccordionItem value={footnotesAccordionId}>\n            <StyledAccordionHeader headingLevel=\"h2\">{t(\"article.footnotes\")}</StyledAccordionHeader>\n            <StyledAccordionContent forceMount data-background-color={accordionHeaderVariant}>\n              <ArticleFootNotes footNotes={footnotes} />\n            </StyledAccordionContent>\n          </AccordionItem>\n        )}\n      </AccordionRoot>\n    </Wrapper>\n  );\n};\n\nexport default ArticleByline;\n"]} */"));
|
|
69
69
|
const refRegexp = /note\d/;
|
|
70
70
|
const footnotesAccordionId = "footnotes";
|
|
71
71
|
const ArticleByline = _ref => {
|
package/es/Concept/Concept.js
CHANGED
|
@@ -10,7 +10,7 @@ import { forwardRef } from "react";
|
|
|
10
10
|
import { Figure } from "@ndla/primitives";
|
|
11
11
|
import { styled } from "@ndla/styled-system/jsx";
|
|
12
12
|
import { BrightcoveEmbed, ExternalEmbed, H5pEmbed, IframeEmbed, ImageEmbed } from "../Embed";
|
|
13
|
-
import {
|
|
13
|
+
import { EmbedByline } from "../LicenseByline/EmbedByline";
|
|
14
14
|
import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "@emotion/react/jsx-runtime";
|
|
15
15
|
const StyledFigure = styled(Figure, {
|
|
16
16
|
base: {
|
|
@@ -61,7 +61,7 @@ export const Concept = /*#__PURE__*/forwardRef((_ref, ref) => {
|
|
|
61
61
|
embed: visualElement
|
|
62
62
|
}) : visualElement?.resource === "external" ? _jsx(ExternalEmbed, {
|
|
63
63
|
embed: visualElement
|
|
64
|
-
}) : null, copyright && _jsx(
|
|
64
|
+
}) : null, copyright && _jsx(EmbedByline, {
|
|
65
65
|
copyright: copyright,
|
|
66
66
|
type: "concept"
|
|
67
67
|
})]
|