@ndla/ui 50.10.0 → 50.10.2
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/es/Article/Article.js +3 -7
- package/es/Article/ArticleByline.js +7 -7
- package/es/Embed/ConceptEmbed.js +7 -8
- package/es/Embed/CopyrightEmbed.js +2 -1
- package/es/Embed/conceptComponents.js +9 -9
- package/es/FramedContent/FramedContent.js +1 -1
- package/es/Layout/LayoutItem.js +1 -1
- package/es/List/UnOrderedList.js +1 -1
- package/es/all.css +1 -1
- package/lib/Article/Article.js +2 -6
- package/lib/Article/ArticleByline.js +7 -7
- package/lib/Embed/ConceptEmbed.js +7 -8
- package/lib/Embed/CopyrightEmbed.js +2 -1
- package/lib/Embed/conceptComponents.d.ts +1 -1
- package/lib/Embed/conceptComponents.js +9 -9
- package/lib/FramedContent/FramedContent.js +1 -1
- package/lib/Layout/LayoutItem.js +1 -1
- package/lib/List/UnOrderedList.js +1 -1
- package/lib/all.css +1 -1
- package/package.json +4 -4
- package/src/Article/Article.tsx +1 -7
- package/src/Article/ArticleByline.tsx +2 -2
- package/src/Article/component.article.scss +0 -9
- package/src/Embed/ConceptEmbed.tsx +0 -1
- package/src/Embed/CopyrightEmbed.tsx +1 -1
- package/src/Embed/conceptComponents.tsx +1 -1
- package/src/FramedContent/FramedContent.tsx +0 -8
- package/src/Layout/LayoutItem.tsx +1 -1
- package/src/List/UnOrderedList.tsx +3 -3
|
@@ -20,7 +20,7 @@ const StyledFigCaption = /*#__PURE__*/_styled("figcaption", {
|
|
|
20
20
|
} : {
|
|
21
21
|
name: "1oo694u",
|
|
22
22
|
styles: "background:unset;font-size:unset;padding:unset;color:unset",
|
|
23
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNvcHlyaWdodEVtYmVkLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFrQjBDIiwiZmlsZSI6IkNvcHlyaWdodEVtYmVkLnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDI0LXByZXNlbnQsIE5ETEEuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgR1BMdjMgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqXG4gKi9cblxuaW1wb3J0IHsgUmVhY3ROb2RlIH0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgc3R5bGVkIGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCB7IENvcHlyaWdodE1ldGFEYXRhIH0gZnJvbSBcIkBuZGxhL3R5cGVzLWVtYmVkXCI7XG5pbXBvcnQgeyBFbWJlZEJ5bGluZSB9IGZyb20gXCIuLi9MaWNlbnNlQnlsaW5lXCI7XG5cbmludGVyZmFjZSBQcm9wcyB7XG4gIGVtYmVkOiBDb3B5cmlnaHRNZXRhRGF0YTtcbiAgY2hpbGRyZW4/OiBSZWFjdE5vZGU7XG59XG5cbmNvbnN0IFN0eWxlZEZpZ0NhcHRpb24gPSBzdHlsZWQuZmlnY2FwdGlvbmBcbiAgYmFja2dyb3VuZDogdW5zZXQ7XG4gIGZvbnQtc2l6ZTogdW5zZXQ7XG4gIHBhZGRpbmc6IHVuc2V0O1xuICBjb2xvcjogdW5zZXQ7XG5gO1xuXG5jb25zdCBDb3B5cmlnaHRFbWJlZCA9ICh7IGVtYmVkLCBjaGlsZHJlbiB9OiBQcm9wcykgPT4ge1xuICByZXR1cm4gKFxuICAgIDxmaWd1cmU+
|
|
23
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNvcHlyaWdodEVtYmVkLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFrQjBDIiwiZmlsZSI6IkNvcHlyaWdodEVtYmVkLnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDI0LXByZXNlbnQsIE5ETEEuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgR1BMdjMgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqXG4gKi9cblxuaW1wb3J0IHsgUmVhY3ROb2RlIH0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgc3R5bGVkIGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCB7IENvcHlyaWdodE1ldGFEYXRhIH0gZnJvbSBcIkBuZGxhL3R5cGVzLWVtYmVkXCI7XG5pbXBvcnQgeyBFbWJlZEJ5bGluZSB9IGZyb20gXCIuLi9MaWNlbnNlQnlsaW5lXCI7XG5cbmludGVyZmFjZSBQcm9wcyB7XG4gIGVtYmVkOiBDb3B5cmlnaHRNZXRhRGF0YTtcbiAgY2hpbGRyZW4/OiBSZWFjdE5vZGU7XG59XG5cbmNvbnN0IFN0eWxlZEZpZ0NhcHRpb24gPSBzdHlsZWQuZmlnY2FwdGlvbmBcbiAgYmFja2dyb3VuZDogdW5zZXQ7XG4gIGZvbnQtc2l6ZTogdW5zZXQ7XG4gIHBhZGRpbmc6IHVuc2V0O1xuICBjb2xvcjogdW5zZXQ7XG5gO1xuXG5jb25zdCBDb3B5cmlnaHRFbWJlZCA9ICh7IGVtYmVkLCBjaGlsZHJlbiB9OiBQcm9wcykgPT4ge1xuICByZXR1cm4gKFxuICAgIDxmaWd1cmU+XG4gICAgICB7Y2hpbGRyZW59XG4gICAgICA8U3R5bGVkRmlnQ2FwdGlvbiBjb250ZW50RWRpdGFibGU9e2ZhbHNlfT5cbiAgICAgICAgPEVtYmVkQnlsaW5lIHR5cGU9XCJjb3B5cmlnaHRcIiBjb3B5cmlnaHQ9e2VtYmVkLmVtYmVkRGF0YS5jb3B5cmlnaHR9IGJvdHRvbVJvdW5kZWQgLz5cbiAgICAgIDwvU3R5bGVkRmlnQ2FwdGlvbj5cbiAgICA8L2ZpZ3VyZT5cbiAgKTtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IENvcHlyaWdodEVtYmVkO1xuIl19 */",
|
|
24
24
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
25
25
|
});
|
|
26
26
|
const CopyrightEmbed = _ref => {
|
|
@@ -30,6 +30,7 @@ const CopyrightEmbed = _ref => {
|
|
|
30
30
|
} = _ref;
|
|
31
31
|
return _jsxs("figure", {
|
|
32
32
|
children: [children, _jsx(StyledFigCaption, {
|
|
33
|
+
contentEditable: false,
|
|
33
34
|
children: _jsx(EmbedByline, {
|
|
34
35
|
type: "copyright",
|
|
35
36
|
copyright: embed.embedData.copyright,
|
|
@@ -24,42 +24,42 @@ import { Fragment as _Fragment } from "@emotion/react/jsx-runtime";
|
|
|
24
24
|
const NotionDialogText = /*#__PURE__*/_styled("div", {
|
|
25
25
|
target: "eqcj3r7",
|
|
26
26
|
label: "NotionDialogText"
|
|
27
|
-
})("font-weight:", fonts.weight.normal, ";", fonts.sizes("18px", 1.3), ";color:", colors.text.primary, ";font-family:", fonts.sans, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["conceptComponents.tsx"],"names":[],"mappings":"AAsDmC","file":"conceptComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2023-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 { forwardRef, ReactNode, RefAttributes } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, fonts, misc, mq, spacing, stackOrder } from \"@ndla/core\";\nimport { COPYRIGHTED } from \"@ndla/licenses\";\nimport { ConceptData, ConceptVisualElementMeta } from \"@ndla/types-embed\";\nimport { ExternalEmbed, HeartButtonType, IframeEmbed } from \".\";\nimport BrightcoveEmbed from \"./BrightcoveEmbed\";\nimport H5pEmbed from \"./H5pEmbed\";\nimport ImageEmbed from \"./ImageEmbed\";\nimport { Gloss } from \"../Gloss\";\nimport { EmbedByline } from \"../LicenseByline\";\nimport { Copyright } from \"../types\";\n\nexport type ConceptType = \"concept\" | \"gloss\";\n\nexport interface ConceptNotionData {\n  title: ConceptData[\"concept\"][\"title\"];\n  content?: ReactNode;\n  metaImage?: {\n    url?: string;\n    alt?: string;\n  };\n  copyright?: Copyright;\n  source?: string;\n  visualElement?: ConceptVisualElementMeta;\n  conceptType: ConceptData[\"concept\"][\"conceptType\"];\n  glossData?: ConceptData[\"concept\"][\"glossData\"];\n  lang?: string;\n}\n\ninterface ConceptNotionProps extends RefAttributes<HTMLDivElement>, ConceptNotionData {\n  className?: string;\n  closeButton?: ReactNode;\n  previewAlt?: boolean;\n  inPopover?: boolean;\n  tags?: string[];\n  subjects?: string[];\n  headerButtons?: ReactNode;\n  heartButton?: HeartButtonType;\n  conceptHeartButton?: ReactNode;\n  exampleIds?: string;\n  exampleLangs?: string;\n}\n\nconst NotionDialogText = styled.div`\n  font-weight: ${fonts.weight.normal};\n  ${fonts.sizes(\"18px\", 1.3)};\n  color: ${colors.text.primary};\n  font-family: ${fonts.sans};\n`;\n\nconst NotionDialogContent = styled.div`\n  padding-bottom: ${spacing.normal};\n  display: flex;\n  flex-direction: column;\n`;\n\nconst ContentSpacing = styled.div`\n  padding: ${spacing.normal};\n  &[data-is-concept=\"false\"] {\n    margin-bottom: ${spacing.normal};\n  }\n`;\n\nconst notionContentCss = css`\n  @keyframes animateIn {\n    0% {\n      opacity: 0;\n      transform: translate3d(0, -13px, 0);\n    }\n    100% {\n      opacity: 1;\n      transform: translate3d(0, 0, 0);\n    }\n  }\n\n  animation-name: animateIn;\n  animation-duration: 300ms;\n  background-color: white;\n  z-index: ${stackOrder.offsetSingle};\n  box-shadow: 0 0 30px rgba(0, 0, 0, 0.2);\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 500px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 720px;\n  }\n\n  ${mq.range({ until: breakpoints.tablet })} {\n    padding: ${spacing.small};\n    z-index: ${stackOrder.popover};\n    height: 100%;\n    width: 100%;\n    overflow: auto;\n  }\n`;\n\nconst NotionHeader = styled.div`\n  display: flex;\n  align-items: center;\n  justify-content: flex-end;\n  border-bottom: 2px solid ${colors.brand.tertiary};\n  padding-bottom: ${spacing.small};\n  h1 {\n    flex-grow: 1;\n    margin: 0;\n    font-weight: ${fonts.weight.bold};\n    ${fonts.sizes(\"22px\", 1.2)};\n  }\n  small {\n    &[data-is-concept=\"true\"] {\n      border-left: 1px solid ${colors.brand.greyLight};\n      padding-left: ${spacing.small};\n      margin-left: ${spacing.xsmall};\n    }\n    ${fonts.sizes(\"20px\", 1.2)};\n    font-weight: ${fonts.weight.normal};\n  }\n  &[data-is-concept=\"false\"] {\n    margin-bottom: ${spacing.large};\n  }\n`;\n\nconst ListWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n`;\n\nconst StyledNotionDialogContent = styled(NotionDialogContent)`\n  padding-top: ${spacing.small};\n  .c-figure {\n    left: unset !important;\n    width: 100% !important;\n    padding: 0;\n    margin: 0;\n    padding-bottom: ${spacing.normal};\n  }\n`;\n\nconst ButtonWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  align-items: center;\n`;\n\nconst StyledList = styled.ul`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n  list-style: none;\n  > li {\n    font-family: ${fonts.sans};\n    font-weight: ${fonts.weight.semibold};\n    border-radius: ${misc.borderRadius};\n    background-color: ${colors.brand.greyLightest};\n    ${fonts.sizes(\"12px\", 1.2)};\n    padding: ${spacing.xxsmall};\n  }\n`;\n\nexport const ConceptNotionV2 = forwardRef<HTMLDivElement, ConceptNotionProps>(\n  (\n    {\n      visualElement,\n      title,\n      content,\n      source,\n      copyright,\n      closeButton,\n      inPopover,\n      previewAlt,\n      tags,\n      subjects,\n      heartButton,\n      conceptHeartButton,\n      conceptType,\n      glossData,\n      headerButtons,\n      lang,\n      exampleIds,\n      exampleLangs,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t } = useTranslation();\n    const isConcept = conceptType === \"concept\";\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <ContentSpacing data-is-concept={isConcept}>\n          <NotionHeader data-is-concept={isConcept}>\n            <h1>\n              {isConcept && title.title}\n              {<small data-is-concept={isConcept}>{t(`searchPage.resultType.${conceptType}`)}</small>}\n            </h1>\n            <ButtonWrapper>\n              {headerButtons}\n              {closeButton}\n            </ButtonWrapper>\n          </NotionHeader>\n          {isConcept ? (\n            <>\n              <StyledNotionDialogContent>\n                {visualElement?.resource === \"image\" ? (\n                  <ImageEmbed embed={visualElement} heartButton={heartButton} lang={lang} />\n                ) : visualElement?.resource === \"brightcove\" ? (\n                  <BrightcoveEmbed embed={visualElement} heartButton={heartButton} />\n                ) : visualElement?.resource === \"h5p\" ? (\n                  <H5pEmbed embed={visualElement} />\n                ) : visualElement?.resource === \"iframe\" ? (\n                  <IframeEmbed embed={visualElement} />\n                ) : visualElement?.resource === \"external\" ? (\n                  <ExternalEmbed embed={visualElement} />\n                ) : null}\n                {content && <NotionDialogText lang={lang}>{content}</NotionDialogText>}\n              </StyledNotionDialogContent>\n              {tags && (\n                <ListWrapper>\n                  {`${t(\"notions.tags\")}:`}\n                  <StyledList>\n                    {tags.map((tag, index) => (\n                      <li key={index}>{tag}</li>\n                    ))}\n                  </StyledList>\n                </ListWrapper>\n              )}\n              {subjects && (\n                <ListWrapper>\n                  {`${t(\"notions.usedIn\")}:`}\n                  <StyledList>\n                    {subjects.map((subject, index) => (\n                      <li key={index}>{subject}</li>\n                    ))}\n                  </StyledList>\n                </ListWrapper>\n              )}\n            </>\n          ) : (\n            <Gloss\n              title={title}\n              glossData={glossData!}\n              audio={\n                visualElement?.status === \"success\" && visualElement.resource === \"audio\"\n                  ? {\n                      src: visualElement.data.audioFile.url,\n                      title: visualElement.data.title.title,\n                    }\n                  : undefined\n              }\n              exampleIds={exampleIds}\n              exampleLangs={exampleLangs}\n            />\n          )}\n        </ContentSpacing>\n        {copyright && (\n          <EmbedByline copyright={copyright} type={conceptType as ConceptType}>\n            {copyright.license?.license.toLowerCase() !== COPYRIGHTED && conceptHeartButton}\n          </EmbedByline>\n        )}\n      </div>\n    );\n  },\n);\n"]} */"));
|
|
27
|
+
})("font-weight:", fonts.weight.normal, ";", fonts.sizes("18px", 1.3), ";color:", colors.text.primary, ";font-family:", fonts.sans, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["conceptComponents.tsx"],"names":[],"mappings":"AAsDmC","file":"conceptComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2023-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 { forwardRef, ReactNode, RefAttributes } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, fonts, misc, mq, spacing, stackOrder } from \"@ndla/core\";\nimport { COPYRIGHTED } from \"@ndla/licenses\";\nimport { ConceptData, ConceptVisualElementMeta } from \"@ndla/types-embed\";\nimport { ExternalEmbed, HeartButtonType, IframeEmbed } from \".\";\nimport BrightcoveEmbed from \"./BrightcoveEmbed\";\nimport H5pEmbed from \"./H5pEmbed\";\nimport ImageEmbed from \"./ImageEmbed\";\nimport { Gloss } from \"../Gloss\";\nimport { EmbedByline } from \"../LicenseByline\";\nimport { Copyright } from \"../types\";\n\nexport type ConceptType = \"concept\" | \"gloss\";\n\nexport interface ConceptNotionData {\n  title: ConceptData[\"concept\"][\"title\"];\n  content?: ReactNode;\n  metaImage?: {\n    url?: string;\n    alt?: string;\n  };\n  copyright?: Copyright;\n  source?: string;\n  visualElement?: ConceptVisualElementMeta;\n  conceptType: ConceptData[\"concept\"][\"conceptType\"];\n  glossData?: ConceptData[\"concept\"][\"glossData\"];\n  lang?: string;\n}\n\ninterface ConceptNotionProps extends RefAttributes<HTMLDivElement>, Omit<ConceptNotionData, \"metaImage\"> {\n  className?: string;\n  closeButton?: ReactNode;\n  previewAlt?: boolean;\n  inPopover?: boolean;\n  tags?: string[];\n  subjects?: string[];\n  headerButtons?: ReactNode;\n  heartButton?: HeartButtonType;\n  conceptHeartButton?: ReactNode;\n  exampleIds?: string;\n  exampleLangs?: string;\n}\n\nconst NotionDialogText = styled.div`\n  font-weight: ${fonts.weight.normal};\n  ${fonts.sizes(\"18px\", 1.3)};\n  color: ${colors.text.primary};\n  font-family: ${fonts.sans};\n`;\n\nconst NotionDialogContent = styled.div`\n  padding-bottom: ${spacing.normal};\n  display: flex;\n  flex-direction: column;\n`;\n\nconst ContentSpacing = styled.div`\n  padding: ${spacing.normal};\n  &[data-is-concept=\"false\"] {\n    margin-bottom: ${spacing.normal};\n  }\n`;\n\nconst notionContentCss = css`\n  @keyframes animateIn {\n    0% {\n      opacity: 0;\n      transform: translate3d(0, -13px, 0);\n    }\n    100% {\n      opacity: 1;\n      transform: translate3d(0, 0, 0);\n    }\n  }\n\n  animation-name: animateIn;\n  animation-duration: 300ms;\n  background-color: white;\n  z-index: ${stackOrder.offsetSingle};\n  box-shadow: 0 0 30px rgba(0, 0, 0, 0.2);\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 500px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 720px;\n  }\n\n  ${mq.range({ until: breakpoints.tablet })} {\n    padding: ${spacing.small};\n    z-index: ${stackOrder.popover};\n    height: 100%;\n    width: 100%;\n    overflow: auto;\n  }\n`;\n\nconst NotionHeader = styled.div`\n  display: flex;\n  align-items: center;\n  justify-content: flex-end;\n  border-bottom: 2px solid ${colors.brand.tertiary};\n  padding-bottom: ${spacing.small};\n  h1 {\n    flex-grow: 1;\n    margin: 0;\n    font-weight: ${fonts.weight.bold};\n    ${fonts.sizes(\"22px\", 1.2)};\n  }\n  small {\n    &[data-is-concept=\"true\"] {\n      border-left: 1px solid ${colors.brand.greyLight};\n      padding-left: ${spacing.small};\n      margin-left: ${spacing.xsmall};\n    }\n    ${fonts.sizes(\"20px\", 1.2)};\n    font-weight: ${fonts.weight.normal};\n  }\n  &[data-is-concept=\"false\"] {\n    margin-bottom: ${spacing.large};\n  }\n`;\n\nconst ListWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n`;\n\nconst StyledNotionDialogContent = styled(NotionDialogContent)`\n  padding-top: ${spacing.small};\n  .c-figure {\n    left: unset !important;\n    width: 100% !important;\n    padding: 0;\n    margin: 0;\n    padding-bottom: ${spacing.normal};\n  }\n`;\n\nconst ButtonWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  align-items: center;\n`;\n\nconst StyledList = styled.ul`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n  list-style: none;\n  > li {\n    font-family: ${fonts.sans};\n    font-weight: ${fonts.weight.semibold};\n    border-radius: ${misc.borderRadius};\n    background-color: ${colors.brand.greyLightest};\n    ${fonts.sizes(\"12px\", 1.2)};\n    padding: ${spacing.xxsmall};\n  }\n`;\n\nexport const ConceptNotionV2 = forwardRef<HTMLDivElement, ConceptNotionProps>(\n  (\n    {\n      visualElement,\n      title,\n      content,\n      source,\n      copyright,\n      closeButton,\n      inPopover,\n      previewAlt,\n      tags,\n      subjects,\n      heartButton,\n      conceptHeartButton,\n      conceptType,\n      glossData,\n      headerButtons,\n      lang,\n      exampleIds,\n      exampleLangs,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t } = useTranslation();\n    const isConcept = conceptType === \"concept\";\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <ContentSpacing data-is-concept={isConcept}>\n          <NotionHeader data-is-concept={isConcept}>\n            <h1>\n              {isConcept && title.title}\n              {<small data-is-concept={isConcept}>{t(`searchPage.resultType.${conceptType}`)}</small>}\n            </h1>\n            <ButtonWrapper>\n              {headerButtons}\n              {closeButton}\n            </ButtonWrapper>\n          </NotionHeader>\n          {isConcept ? (\n            <>\n              <StyledNotionDialogContent>\n                {visualElement?.resource === \"image\" ? (\n                  <ImageEmbed embed={visualElement} heartButton={heartButton} lang={lang} />\n                ) : visualElement?.resource === \"brightcove\" ? (\n                  <BrightcoveEmbed embed={visualElement} heartButton={heartButton} />\n                ) : visualElement?.resource === \"h5p\" ? (\n                  <H5pEmbed embed={visualElement} />\n                ) : visualElement?.resource === \"iframe\" ? (\n                  <IframeEmbed embed={visualElement} />\n                ) : visualElement?.resource === \"external\" ? (\n                  <ExternalEmbed embed={visualElement} />\n                ) : null}\n                {content && <NotionDialogText lang={lang}>{content}</NotionDialogText>}\n              </StyledNotionDialogContent>\n              {tags && (\n                <ListWrapper>\n                  {`${t(\"notions.tags\")}:`}\n                  <StyledList>\n                    {tags.map((tag, index) => (\n                      <li key={index}>{tag}</li>\n                    ))}\n                  </StyledList>\n                </ListWrapper>\n              )}\n              {subjects && (\n                <ListWrapper>\n                  {`${t(\"notions.usedIn\")}:`}\n                  <StyledList>\n                    {subjects.map((subject, index) => (\n                      <li key={index}>{subject}</li>\n                    ))}\n                  </StyledList>\n                </ListWrapper>\n              )}\n            </>\n          ) : (\n            <Gloss\n              title={title}\n              glossData={glossData!}\n              audio={\n                visualElement?.status === \"success\" && visualElement.resource === \"audio\"\n                  ? {\n                      src: visualElement.data.audioFile.url,\n                      title: visualElement.data.title.title,\n                    }\n                  : undefined\n              }\n              exampleIds={exampleIds}\n              exampleLangs={exampleLangs}\n            />\n          )}\n        </ContentSpacing>\n        {copyright && (\n          <EmbedByline copyright={copyright} type={conceptType as ConceptType}>\n            {copyright.license?.license.toLowerCase() !== COPYRIGHTED && conceptHeartButton}\n          </EmbedByline>\n        )}\n      </div>\n    );\n  },\n);\n"]} */"));
|
|
28
28
|
const NotionDialogContent = /*#__PURE__*/_styled("div", {
|
|
29
29
|
target: "eqcj3r6",
|
|
30
30
|
label: "NotionDialogContent"
|
|
31
|
-
})("padding-bottom:", spacing.normal, ";display:flex;flex-direction:column;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["conceptComponents.tsx"],"names":[],"mappings":"AA6DsC","file":"conceptComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2023-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 { forwardRef, ReactNode, RefAttributes } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, fonts, misc, mq, spacing, stackOrder } from \"@ndla/core\";\nimport { COPYRIGHTED } from \"@ndla/licenses\";\nimport { ConceptData, ConceptVisualElementMeta } from \"@ndla/types-embed\";\nimport { ExternalEmbed, HeartButtonType, IframeEmbed } from \".\";\nimport BrightcoveEmbed from \"./BrightcoveEmbed\";\nimport H5pEmbed from \"./H5pEmbed\";\nimport ImageEmbed from \"./ImageEmbed\";\nimport { Gloss } from \"../Gloss\";\nimport { EmbedByline } from \"../LicenseByline\";\nimport { Copyright } from \"../types\";\n\nexport type ConceptType = \"concept\" | \"gloss\";\n\nexport interface ConceptNotionData {\n  title: ConceptData[\"concept\"][\"title\"];\n  content?: ReactNode;\n  metaImage?: {\n    url?: string;\n    alt?: string;\n  };\n  copyright?: Copyright;\n  source?: string;\n  visualElement?: ConceptVisualElementMeta;\n  conceptType: ConceptData[\"concept\"][\"conceptType\"];\n  glossData?: ConceptData[\"concept\"][\"glossData\"];\n  lang?: string;\n}\n\ninterface ConceptNotionProps extends RefAttributes<HTMLDivElement>, ConceptNotionData {\n  className?: string;\n  closeButton?: ReactNode;\n  previewAlt?: boolean;\n  inPopover?: boolean;\n  tags?: string[];\n  subjects?: string[];\n  headerButtons?: ReactNode;\n  heartButton?: HeartButtonType;\n  conceptHeartButton?: ReactNode;\n  exampleIds?: string;\n  exampleLangs?: string;\n}\n\nconst NotionDialogText = styled.div`\n  font-weight: ${fonts.weight.normal};\n  ${fonts.sizes(\"18px\", 1.3)};\n  color: ${colors.text.primary};\n  font-family: ${fonts.sans};\n`;\n\nconst NotionDialogContent = styled.div`\n  padding-bottom: ${spacing.normal};\n  display: flex;\n  flex-direction: column;\n`;\n\nconst ContentSpacing = styled.div`\n  padding: ${spacing.normal};\n  &[data-is-concept=\"false\"] {\n    margin-bottom: ${spacing.normal};\n  }\n`;\n\nconst notionContentCss = css`\n  @keyframes animateIn {\n    0% {\n      opacity: 0;\n      transform: translate3d(0, -13px, 0);\n    }\n    100% {\n      opacity: 1;\n      transform: translate3d(0, 0, 0);\n    }\n  }\n\n  animation-name: animateIn;\n  animation-duration: 300ms;\n  background-color: white;\n  z-index: ${stackOrder.offsetSingle};\n  box-shadow: 0 0 30px rgba(0, 0, 0, 0.2);\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 500px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 720px;\n  }\n\n  ${mq.range({ until: breakpoints.tablet })} {\n    padding: ${spacing.small};\n    z-index: ${stackOrder.popover};\n    height: 100%;\n    width: 100%;\n    overflow: auto;\n  }\n`;\n\nconst NotionHeader = styled.div`\n  display: flex;\n  align-items: center;\n  justify-content: flex-end;\n  border-bottom: 2px solid ${colors.brand.tertiary};\n  padding-bottom: ${spacing.small};\n  h1 {\n    flex-grow: 1;\n    margin: 0;\n    font-weight: ${fonts.weight.bold};\n    ${fonts.sizes(\"22px\", 1.2)};\n  }\n  small {\n    &[data-is-concept=\"true\"] {\n      border-left: 1px solid ${colors.brand.greyLight};\n      padding-left: ${spacing.small};\n      margin-left: ${spacing.xsmall};\n    }\n    ${fonts.sizes(\"20px\", 1.2)};\n    font-weight: ${fonts.weight.normal};\n  }\n  &[data-is-concept=\"false\"] {\n    margin-bottom: ${spacing.large};\n  }\n`;\n\nconst ListWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n`;\n\nconst StyledNotionDialogContent = styled(NotionDialogContent)`\n  padding-top: ${spacing.small};\n  .c-figure {\n    left: unset !important;\n    width: 100% !important;\n    padding: 0;\n    margin: 0;\n    padding-bottom: ${spacing.normal};\n  }\n`;\n\nconst ButtonWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  align-items: center;\n`;\n\nconst StyledList = styled.ul`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n  list-style: none;\n  > li {\n    font-family: ${fonts.sans};\n    font-weight: ${fonts.weight.semibold};\n    border-radius: ${misc.borderRadius};\n    background-color: ${colors.brand.greyLightest};\n    ${fonts.sizes(\"12px\", 1.2)};\n    padding: ${spacing.xxsmall};\n  }\n`;\n\nexport const ConceptNotionV2 = forwardRef<HTMLDivElement, ConceptNotionProps>(\n  (\n    {\n      visualElement,\n      title,\n      content,\n      source,\n      copyright,\n      closeButton,\n      inPopover,\n      previewAlt,\n      tags,\n      subjects,\n      heartButton,\n      conceptHeartButton,\n      conceptType,\n      glossData,\n      headerButtons,\n      lang,\n      exampleIds,\n      exampleLangs,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t } = useTranslation();\n    const isConcept = conceptType === \"concept\";\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <ContentSpacing data-is-concept={isConcept}>\n          <NotionHeader data-is-concept={isConcept}>\n            <h1>\n              {isConcept && title.title}\n              {<small data-is-concept={isConcept}>{t(`searchPage.resultType.${conceptType}`)}</small>}\n            </h1>\n            <ButtonWrapper>\n              {headerButtons}\n              {closeButton}\n            </ButtonWrapper>\n          </NotionHeader>\n          {isConcept ? (\n            <>\n              <StyledNotionDialogContent>\n                {visualElement?.resource === \"image\" ? (\n                  <ImageEmbed embed={visualElement} heartButton={heartButton} lang={lang} />\n                ) : visualElement?.resource === \"brightcove\" ? (\n                  <BrightcoveEmbed embed={visualElement} heartButton={heartButton} />\n                ) : visualElement?.resource === \"h5p\" ? (\n                  <H5pEmbed embed={visualElement} />\n                ) : visualElement?.resource === \"iframe\" ? (\n                  <IframeEmbed embed={visualElement} />\n                ) : visualElement?.resource === \"external\" ? (\n                  <ExternalEmbed embed={visualElement} />\n                ) : null}\n                {content && <NotionDialogText lang={lang}>{content}</NotionDialogText>}\n              </StyledNotionDialogContent>\n              {tags && (\n                <ListWrapper>\n                  {`${t(\"notions.tags\")}:`}\n                  <StyledList>\n                    {tags.map((tag, index) => (\n                      <li key={index}>{tag}</li>\n                    ))}\n                  </StyledList>\n                </ListWrapper>\n              )}\n              {subjects && (\n                <ListWrapper>\n                  {`${t(\"notions.usedIn\")}:`}\n                  <StyledList>\n                    {subjects.map((subject, index) => (\n                      <li key={index}>{subject}</li>\n                    ))}\n                  </StyledList>\n                </ListWrapper>\n              )}\n            </>\n          ) : (\n            <Gloss\n              title={title}\n              glossData={glossData!}\n              audio={\n                visualElement?.status === \"success\" && visualElement.resource === \"audio\"\n                  ? {\n                      src: visualElement.data.audioFile.url,\n                      title: visualElement.data.title.title,\n                    }\n                  : undefined\n              }\n              exampleIds={exampleIds}\n              exampleLangs={exampleLangs}\n            />\n          )}\n        </ContentSpacing>\n        {copyright && (\n          <EmbedByline copyright={copyright} type={conceptType as ConceptType}>\n            {copyright.license?.license.toLowerCase() !== COPYRIGHTED && conceptHeartButton}\n          </EmbedByline>\n        )}\n      </div>\n    );\n  },\n);\n"]} */"));
|
|
31
|
+
})("padding-bottom:", spacing.normal, ";display:flex;flex-direction:column;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["conceptComponents.tsx"],"names":[],"mappings":"AA6DsC","file":"conceptComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2023-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 { forwardRef, ReactNode, RefAttributes } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, fonts, misc, mq, spacing, stackOrder } from \"@ndla/core\";\nimport { COPYRIGHTED } from \"@ndla/licenses\";\nimport { ConceptData, ConceptVisualElementMeta } from \"@ndla/types-embed\";\nimport { ExternalEmbed, HeartButtonType, IframeEmbed } from \".\";\nimport BrightcoveEmbed from \"./BrightcoveEmbed\";\nimport H5pEmbed from \"./H5pEmbed\";\nimport ImageEmbed from \"./ImageEmbed\";\nimport { Gloss } from \"../Gloss\";\nimport { EmbedByline } from \"../LicenseByline\";\nimport { Copyright } from \"../types\";\n\nexport type ConceptType = \"concept\" | \"gloss\";\n\nexport interface ConceptNotionData {\n  title: ConceptData[\"concept\"][\"title\"];\n  content?: ReactNode;\n  metaImage?: {\n    url?: string;\n    alt?: string;\n  };\n  copyright?: Copyright;\n  source?: string;\n  visualElement?: ConceptVisualElementMeta;\n  conceptType: ConceptData[\"concept\"][\"conceptType\"];\n  glossData?: ConceptData[\"concept\"][\"glossData\"];\n  lang?: string;\n}\n\ninterface ConceptNotionProps extends RefAttributes<HTMLDivElement>, Omit<ConceptNotionData, \"metaImage\"> {\n  className?: string;\n  closeButton?: ReactNode;\n  previewAlt?: boolean;\n  inPopover?: boolean;\n  tags?: string[];\n  subjects?: string[];\n  headerButtons?: ReactNode;\n  heartButton?: HeartButtonType;\n  conceptHeartButton?: ReactNode;\n  exampleIds?: string;\n  exampleLangs?: string;\n}\n\nconst NotionDialogText = styled.div`\n  font-weight: ${fonts.weight.normal};\n  ${fonts.sizes(\"18px\", 1.3)};\n  color: ${colors.text.primary};\n  font-family: ${fonts.sans};\n`;\n\nconst NotionDialogContent = styled.div`\n  padding-bottom: ${spacing.normal};\n  display: flex;\n  flex-direction: column;\n`;\n\nconst ContentSpacing = styled.div`\n  padding: ${spacing.normal};\n  &[data-is-concept=\"false\"] {\n    margin-bottom: ${spacing.normal};\n  }\n`;\n\nconst notionContentCss = css`\n  @keyframes animateIn {\n    0% {\n      opacity: 0;\n      transform: translate3d(0, -13px, 0);\n    }\n    100% {\n      opacity: 1;\n      transform: translate3d(0, 0, 0);\n    }\n  }\n\n  animation-name: animateIn;\n  animation-duration: 300ms;\n  background-color: white;\n  z-index: ${stackOrder.offsetSingle};\n  box-shadow: 0 0 30px rgba(0, 0, 0, 0.2);\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 500px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 720px;\n  }\n\n  ${mq.range({ until: breakpoints.tablet })} {\n    padding: ${spacing.small};\n    z-index: ${stackOrder.popover};\n    height: 100%;\n    width: 100%;\n    overflow: auto;\n  }\n`;\n\nconst NotionHeader = styled.div`\n  display: flex;\n  align-items: center;\n  justify-content: flex-end;\n  border-bottom: 2px solid ${colors.brand.tertiary};\n  padding-bottom: ${spacing.small};\n  h1 {\n    flex-grow: 1;\n    margin: 0;\n    font-weight: ${fonts.weight.bold};\n    ${fonts.sizes(\"22px\", 1.2)};\n  }\n  small {\n    &[data-is-concept=\"true\"] {\n      border-left: 1px solid ${colors.brand.greyLight};\n      padding-left: ${spacing.small};\n      margin-left: ${spacing.xsmall};\n    }\n    ${fonts.sizes(\"20px\", 1.2)};\n    font-weight: ${fonts.weight.normal};\n  }\n  &[data-is-concept=\"false\"] {\n    margin-bottom: ${spacing.large};\n  }\n`;\n\nconst ListWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n`;\n\nconst StyledNotionDialogContent = styled(NotionDialogContent)`\n  padding-top: ${spacing.small};\n  .c-figure {\n    left: unset !important;\n    width: 100% !important;\n    padding: 0;\n    margin: 0;\n    padding-bottom: ${spacing.normal};\n  }\n`;\n\nconst ButtonWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  align-items: center;\n`;\n\nconst StyledList = styled.ul`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n  list-style: none;\n  > li {\n    font-family: ${fonts.sans};\n    font-weight: ${fonts.weight.semibold};\n    border-radius: ${misc.borderRadius};\n    background-color: ${colors.brand.greyLightest};\n    ${fonts.sizes(\"12px\", 1.2)};\n    padding: ${spacing.xxsmall};\n  }\n`;\n\nexport const ConceptNotionV2 = forwardRef<HTMLDivElement, ConceptNotionProps>(\n  (\n    {\n      visualElement,\n      title,\n      content,\n      source,\n      copyright,\n      closeButton,\n      inPopover,\n      previewAlt,\n      tags,\n      subjects,\n      heartButton,\n      conceptHeartButton,\n      conceptType,\n      glossData,\n      headerButtons,\n      lang,\n      exampleIds,\n      exampleLangs,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t } = useTranslation();\n    const isConcept = conceptType === \"concept\";\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <ContentSpacing data-is-concept={isConcept}>\n          <NotionHeader data-is-concept={isConcept}>\n            <h1>\n              {isConcept && title.title}\n              {<small data-is-concept={isConcept}>{t(`searchPage.resultType.${conceptType}`)}</small>}\n            </h1>\n            <ButtonWrapper>\n              {headerButtons}\n              {closeButton}\n            </ButtonWrapper>\n          </NotionHeader>\n          {isConcept ? (\n            <>\n              <StyledNotionDialogContent>\n                {visualElement?.resource === \"image\" ? (\n                  <ImageEmbed embed={visualElement} heartButton={heartButton} lang={lang} />\n                ) : visualElement?.resource === \"brightcove\" ? (\n                  <BrightcoveEmbed embed={visualElement} heartButton={heartButton} />\n                ) : visualElement?.resource === \"h5p\" ? (\n                  <H5pEmbed embed={visualElement} />\n                ) : visualElement?.resource === \"iframe\" ? (\n                  <IframeEmbed embed={visualElement} />\n                ) : visualElement?.resource === \"external\" ? (\n                  <ExternalEmbed embed={visualElement} />\n                ) : null}\n                {content && <NotionDialogText lang={lang}>{content}</NotionDialogText>}\n              </StyledNotionDialogContent>\n              {tags && (\n                <ListWrapper>\n                  {`${t(\"notions.tags\")}:`}\n                  <StyledList>\n                    {tags.map((tag, index) => (\n                      <li key={index}>{tag}</li>\n                    ))}\n                  </StyledList>\n                </ListWrapper>\n              )}\n              {subjects && (\n                <ListWrapper>\n                  {`${t(\"notions.usedIn\")}:`}\n                  <StyledList>\n                    {subjects.map((subject, index) => (\n                      <li key={index}>{subject}</li>\n                    ))}\n                  </StyledList>\n                </ListWrapper>\n              )}\n            </>\n          ) : (\n            <Gloss\n              title={title}\n              glossData={glossData!}\n              audio={\n                visualElement?.status === \"success\" && visualElement.resource === \"audio\"\n                  ? {\n                      src: visualElement.data.audioFile.url,\n                      title: visualElement.data.title.title,\n                    }\n                  : undefined\n              }\n              exampleIds={exampleIds}\n              exampleLangs={exampleLangs}\n            />\n          )}\n        </ContentSpacing>\n        {copyright && (\n          <EmbedByline copyright={copyright} type={conceptType as ConceptType}>\n            {copyright.license?.license.toLowerCase() !== COPYRIGHTED && conceptHeartButton}\n          </EmbedByline>\n        )}\n      </div>\n    );\n  },\n);\n"]} */"));
|
|
32
32
|
const ContentSpacing = /*#__PURE__*/_styled("div", {
|
|
33
33
|
target: "eqcj3r5",
|
|
34
34
|
label: "ContentSpacing"
|
|
35
|
-
})("padding:", spacing.normal, ";&[data-is-concept=\"false\"]{margin-bottom:", spacing.normal, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["conceptComponents.tsx"],"names":[],"mappings":"AAmEiC","file":"conceptComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2023-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 { forwardRef, ReactNode, RefAttributes } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, fonts, misc, mq, spacing, stackOrder } from \"@ndla/core\";\nimport { COPYRIGHTED } from \"@ndla/licenses\";\nimport { ConceptData, ConceptVisualElementMeta } from \"@ndla/types-embed\";\nimport { ExternalEmbed, HeartButtonType, IframeEmbed } from \".\";\nimport BrightcoveEmbed from \"./BrightcoveEmbed\";\nimport H5pEmbed from \"./H5pEmbed\";\nimport ImageEmbed from \"./ImageEmbed\";\nimport { Gloss } from \"../Gloss\";\nimport { EmbedByline } from \"../LicenseByline\";\nimport { Copyright } from \"../types\";\n\nexport type ConceptType = \"concept\" | \"gloss\";\n\nexport interface ConceptNotionData {\n  title: ConceptData[\"concept\"][\"title\"];\n  content?: ReactNode;\n  metaImage?: {\n    url?: string;\n    alt?: string;\n  };\n  copyright?: Copyright;\n  source?: string;\n  visualElement?: ConceptVisualElementMeta;\n  conceptType: ConceptData[\"concept\"][\"conceptType\"];\n  glossData?: ConceptData[\"concept\"][\"glossData\"];\n  lang?: string;\n}\n\ninterface ConceptNotionProps extends RefAttributes<HTMLDivElement>, ConceptNotionData {\n  className?: string;\n  closeButton?: ReactNode;\n  previewAlt?: boolean;\n  inPopover?: boolean;\n  tags?: string[];\n  subjects?: string[];\n  headerButtons?: ReactNode;\n  heartButton?: HeartButtonType;\n  conceptHeartButton?: ReactNode;\n  exampleIds?: string;\n  exampleLangs?: string;\n}\n\nconst NotionDialogText = styled.div`\n  font-weight: ${fonts.weight.normal};\n  ${fonts.sizes(\"18px\", 1.3)};\n  color: ${colors.text.primary};\n  font-family: ${fonts.sans};\n`;\n\nconst NotionDialogContent = styled.div`\n  padding-bottom: ${spacing.normal};\n  display: flex;\n  flex-direction: column;\n`;\n\nconst ContentSpacing = styled.div`\n  padding: ${spacing.normal};\n  &[data-is-concept=\"false\"] {\n    margin-bottom: ${spacing.normal};\n  }\n`;\n\nconst notionContentCss = css`\n  @keyframes animateIn {\n    0% {\n      opacity: 0;\n      transform: translate3d(0, -13px, 0);\n    }\n    100% {\n      opacity: 1;\n      transform: translate3d(0, 0, 0);\n    }\n  }\n\n  animation-name: animateIn;\n  animation-duration: 300ms;\n  background-color: white;\n  z-index: ${stackOrder.offsetSingle};\n  box-shadow: 0 0 30px rgba(0, 0, 0, 0.2);\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 500px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 720px;\n  }\n\n  ${mq.range({ until: breakpoints.tablet })} {\n    padding: ${spacing.small};\n    z-index: ${stackOrder.popover};\n    height: 100%;\n    width: 100%;\n    overflow: auto;\n  }\n`;\n\nconst NotionHeader = styled.div`\n  display: flex;\n  align-items: center;\n  justify-content: flex-end;\n  border-bottom: 2px solid ${colors.brand.tertiary};\n  padding-bottom: ${spacing.small};\n  h1 {\n    flex-grow: 1;\n    margin: 0;\n    font-weight: ${fonts.weight.bold};\n    ${fonts.sizes(\"22px\", 1.2)};\n  }\n  small {\n    &[data-is-concept=\"true\"] {\n      border-left: 1px solid ${colors.brand.greyLight};\n      padding-left: ${spacing.small};\n      margin-left: ${spacing.xsmall};\n    }\n    ${fonts.sizes(\"20px\", 1.2)};\n    font-weight: ${fonts.weight.normal};\n  }\n  &[data-is-concept=\"false\"] {\n    margin-bottom: ${spacing.large};\n  }\n`;\n\nconst ListWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n`;\n\nconst StyledNotionDialogContent = styled(NotionDialogContent)`\n  padding-top: ${spacing.small};\n  .c-figure {\n    left: unset !important;\n    width: 100% !important;\n    padding: 0;\n    margin: 0;\n    padding-bottom: ${spacing.normal};\n  }\n`;\n\nconst ButtonWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  align-items: center;\n`;\n\nconst StyledList = styled.ul`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n  list-style: none;\n  > li {\n    font-family: ${fonts.sans};\n    font-weight: ${fonts.weight.semibold};\n    border-radius: ${misc.borderRadius};\n    background-color: ${colors.brand.greyLightest};\n    ${fonts.sizes(\"12px\", 1.2)};\n    padding: ${spacing.xxsmall};\n  }\n`;\n\nexport const ConceptNotionV2 = forwardRef<HTMLDivElement, ConceptNotionProps>(\n  (\n    {\n      visualElement,\n      title,\n      content,\n      source,\n      copyright,\n      closeButton,\n      inPopover,\n      previewAlt,\n      tags,\n      subjects,\n      heartButton,\n      conceptHeartButton,\n      conceptType,\n      glossData,\n      headerButtons,\n      lang,\n      exampleIds,\n      exampleLangs,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t } = useTranslation();\n    const isConcept = conceptType === \"concept\";\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <ContentSpacing data-is-concept={isConcept}>\n          <NotionHeader data-is-concept={isConcept}>\n            <h1>\n              {isConcept && title.title}\n              {<small data-is-concept={isConcept}>{t(`searchPage.resultType.${conceptType}`)}</small>}\n            </h1>\n            <ButtonWrapper>\n              {headerButtons}\n              {closeButton}\n            </ButtonWrapper>\n          </NotionHeader>\n          {isConcept ? (\n            <>\n              <StyledNotionDialogContent>\n                {visualElement?.resource === \"image\" ? (\n                  <ImageEmbed embed={visualElement} heartButton={heartButton} lang={lang} />\n                ) : visualElement?.resource === \"brightcove\" ? (\n                  <BrightcoveEmbed embed={visualElement} heartButton={heartButton} />\n                ) : visualElement?.resource === \"h5p\" ? (\n                  <H5pEmbed embed={visualElement} />\n                ) : visualElement?.resource === \"iframe\" ? (\n                  <IframeEmbed embed={visualElement} />\n                ) : visualElement?.resource === \"external\" ? (\n                  <ExternalEmbed embed={visualElement} />\n                ) : null}\n                {content && <NotionDialogText lang={lang}>{content}</NotionDialogText>}\n              </StyledNotionDialogContent>\n              {tags && (\n                <ListWrapper>\n                  {`${t(\"notions.tags\")}:`}\n                  <StyledList>\n                    {tags.map((tag, index) => (\n                      <li key={index}>{tag}</li>\n                    ))}\n                  </StyledList>\n                </ListWrapper>\n              )}\n              {subjects && (\n                <ListWrapper>\n                  {`${t(\"notions.usedIn\")}:`}\n                  <StyledList>\n                    {subjects.map((subject, index) => (\n                      <li key={index}>{subject}</li>\n                    ))}\n                  </StyledList>\n                </ListWrapper>\n              )}\n            </>\n          ) : (\n            <Gloss\n              title={title}\n              glossData={glossData!}\n              audio={\n                visualElement?.status === \"success\" && visualElement.resource === \"audio\"\n                  ? {\n                      src: visualElement.data.audioFile.url,\n                      title: visualElement.data.title.title,\n                    }\n                  : undefined\n              }\n              exampleIds={exampleIds}\n              exampleLangs={exampleLangs}\n            />\n          )}\n        </ContentSpacing>\n        {copyright && (\n          <EmbedByline copyright={copyright} type={conceptType as ConceptType}>\n            {copyright.license?.license.toLowerCase() !== COPYRIGHTED && conceptHeartButton}\n          </EmbedByline>\n        )}\n      </div>\n    );\n  },\n);\n"]} */"));
|
|
35
|
+
})("padding:", spacing.normal, ";&[data-is-concept=\"false\"]{margin-bottom:", spacing.normal, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["conceptComponents.tsx"],"names":[],"mappings":"AAmEiC","file":"conceptComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2023-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 { forwardRef, ReactNode, RefAttributes } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, fonts, misc, mq, spacing, stackOrder } from \"@ndla/core\";\nimport { COPYRIGHTED } from \"@ndla/licenses\";\nimport { ConceptData, ConceptVisualElementMeta } from \"@ndla/types-embed\";\nimport { ExternalEmbed, HeartButtonType, IframeEmbed } from \".\";\nimport BrightcoveEmbed from \"./BrightcoveEmbed\";\nimport H5pEmbed from \"./H5pEmbed\";\nimport ImageEmbed from \"./ImageEmbed\";\nimport { Gloss } from \"../Gloss\";\nimport { EmbedByline } from \"../LicenseByline\";\nimport { Copyright } from \"../types\";\n\nexport type ConceptType = \"concept\" | \"gloss\";\n\nexport interface ConceptNotionData {\n  title: ConceptData[\"concept\"][\"title\"];\n  content?: ReactNode;\n  metaImage?: {\n    url?: string;\n    alt?: string;\n  };\n  copyright?: Copyright;\n  source?: string;\n  visualElement?: ConceptVisualElementMeta;\n  conceptType: ConceptData[\"concept\"][\"conceptType\"];\n  glossData?: ConceptData[\"concept\"][\"glossData\"];\n  lang?: string;\n}\n\ninterface ConceptNotionProps extends RefAttributes<HTMLDivElement>, Omit<ConceptNotionData, \"metaImage\"> {\n  className?: string;\n  closeButton?: ReactNode;\n  previewAlt?: boolean;\n  inPopover?: boolean;\n  tags?: string[];\n  subjects?: string[];\n  headerButtons?: ReactNode;\n  heartButton?: HeartButtonType;\n  conceptHeartButton?: ReactNode;\n  exampleIds?: string;\n  exampleLangs?: string;\n}\n\nconst NotionDialogText = styled.div`\n  font-weight: ${fonts.weight.normal};\n  ${fonts.sizes(\"18px\", 1.3)};\n  color: ${colors.text.primary};\n  font-family: ${fonts.sans};\n`;\n\nconst NotionDialogContent = styled.div`\n  padding-bottom: ${spacing.normal};\n  display: flex;\n  flex-direction: column;\n`;\n\nconst ContentSpacing = styled.div`\n  padding: ${spacing.normal};\n  &[data-is-concept=\"false\"] {\n    margin-bottom: ${spacing.normal};\n  }\n`;\n\nconst notionContentCss = css`\n  @keyframes animateIn {\n    0% {\n      opacity: 0;\n      transform: translate3d(0, -13px, 0);\n    }\n    100% {\n      opacity: 1;\n      transform: translate3d(0, 0, 0);\n    }\n  }\n\n  animation-name: animateIn;\n  animation-duration: 300ms;\n  background-color: white;\n  z-index: ${stackOrder.offsetSingle};\n  box-shadow: 0 0 30px rgba(0, 0, 0, 0.2);\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 500px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 720px;\n  }\n\n  ${mq.range({ until: breakpoints.tablet })} {\n    padding: ${spacing.small};\n    z-index: ${stackOrder.popover};\n    height: 100%;\n    width: 100%;\n    overflow: auto;\n  }\n`;\n\nconst NotionHeader = styled.div`\n  display: flex;\n  align-items: center;\n  justify-content: flex-end;\n  border-bottom: 2px solid ${colors.brand.tertiary};\n  padding-bottom: ${spacing.small};\n  h1 {\n    flex-grow: 1;\n    margin: 0;\n    font-weight: ${fonts.weight.bold};\n    ${fonts.sizes(\"22px\", 1.2)};\n  }\n  small {\n    &[data-is-concept=\"true\"] {\n      border-left: 1px solid ${colors.brand.greyLight};\n      padding-left: ${spacing.small};\n      margin-left: ${spacing.xsmall};\n    }\n    ${fonts.sizes(\"20px\", 1.2)};\n    font-weight: ${fonts.weight.normal};\n  }\n  &[data-is-concept=\"false\"] {\n    margin-bottom: ${spacing.large};\n  }\n`;\n\nconst ListWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n`;\n\nconst StyledNotionDialogContent = styled(NotionDialogContent)`\n  padding-top: ${spacing.small};\n  .c-figure {\n    left: unset !important;\n    width: 100% !important;\n    padding: 0;\n    margin: 0;\n    padding-bottom: ${spacing.normal};\n  }\n`;\n\nconst ButtonWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  align-items: center;\n`;\n\nconst StyledList = styled.ul`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n  list-style: none;\n  > li {\n    font-family: ${fonts.sans};\n    font-weight: ${fonts.weight.semibold};\n    border-radius: ${misc.borderRadius};\n    background-color: ${colors.brand.greyLightest};\n    ${fonts.sizes(\"12px\", 1.2)};\n    padding: ${spacing.xxsmall};\n  }\n`;\n\nexport const ConceptNotionV2 = forwardRef<HTMLDivElement, ConceptNotionProps>(\n  (\n    {\n      visualElement,\n      title,\n      content,\n      source,\n      copyright,\n      closeButton,\n      inPopover,\n      previewAlt,\n      tags,\n      subjects,\n      heartButton,\n      conceptHeartButton,\n      conceptType,\n      glossData,\n      headerButtons,\n      lang,\n      exampleIds,\n      exampleLangs,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t } = useTranslation();\n    const isConcept = conceptType === \"concept\";\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <ContentSpacing data-is-concept={isConcept}>\n          <NotionHeader data-is-concept={isConcept}>\n            <h1>\n              {isConcept && title.title}\n              {<small data-is-concept={isConcept}>{t(`searchPage.resultType.${conceptType}`)}</small>}\n            </h1>\n            <ButtonWrapper>\n              {headerButtons}\n              {closeButton}\n            </ButtonWrapper>\n          </NotionHeader>\n          {isConcept ? (\n            <>\n              <StyledNotionDialogContent>\n                {visualElement?.resource === \"image\" ? (\n                  <ImageEmbed embed={visualElement} heartButton={heartButton} lang={lang} />\n                ) : visualElement?.resource === \"brightcove\" ? (\n                  <BrightcoveEmbed embed={visualElement} heartButton={heartButton} />\n                ) : visualElement?.resource === \"h5p\" ? (\n                  <H5pEmbed embed={visualElement} />\n                ) : visualElement?.resource === \"iframe\" ? (\n                  <IframeEmbed embed={visualElement} />\n                ) : visualElement?.resource === \"external\" ? (\n                  <ExternalEmbed embed={visualElement} />\n                ) : null}\n                {content && <NotionDialogText lang={lang}>{content}</NotionDialogText>}\n              </StyledNotionDialogContent>\n              {tags && (\n                <ListWrapper>\n                  {`${t(\"notions.tags\")}:`}\n                  <StyledList>\n                    {tags.map((tag, index) => (\n                      <li key={index}>{tag}</li>\n                    ))}\n                  </StyledList>\n                </ListWrapper>\n              )}\n              {subjects && (\n                <ListWrapper>\n                  {`${t(\"notions.usedIn\")}:`}\n                  <StyledList>\n                    {subjects.map((subject, index) => (\n                      <li key={index}>{subject}</li>\n                    ))}\n                  </StyledList>\n                </ListWrapper>\n              )}\n            </>\n          ) : (\n            <Gloss\n              title={title}\n              glossData={glossData!}\n              audio={\n                visualElement?.status === \"success\" && visualElement.resource === \"audio\"\n                  ? {\n                      src: visualElement.data.audioFile.url,\n                      title: visualElement.data.title.title,\n                    }\n                  : undefined\n              }\n              exampleIds={exampleIds}\n              exampleLangs={exampleLangs}\n            />\n          )}\n        </ContentSpacing>\n        {copyright && (\n          <EmbedByline copyright={copyright} type={conceptType as ConceptType}>\n            {copyright.license?.license.toLowerCase() !== COPYRIGHTED && conceptHeartButton}\n          </EmbedByline>\n        )}\n      </div>\n    );\n  },\n);\n"]} */"));
|
|
36
36
|
const notionContentCss = /*#__PURE__*/css("@keyframes animateIn{0%{opacity:0;transform:translate3d(0, -13px, 0);}100%{opacity:1;transform:translate3d(0, 0, 0);}}animation-name:animateIn;animation-duration:300ms;background-color:white;z-index:", stackOrder.offsetSingle, ";box-shadow:0 0 30px rgba(0, 0, 0, 0.2);", mq.range({
|
|
37
37
|
from: breakpoints.tablet
|
|
38
38
|
}), "{width:500px;}", mq.range({
|
|
39
39
|
from: breakpoints.desktop
|
|
40
40
|
}), "{width:720px;}", mq.range({
|
|
41
41
|
until: breakpoints.tablet
|
|
42
|
-
}), "{padding:", spacing.small, ";z-index:", stackOrder.popover, ";height:100%;width:100%;overflow:auto;};label:notionContentCss;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["conceptComponents.tsx"],"names":[],"mappings":"AA0E4B","file":"conceptComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2023-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 { forwardRef, ReactNode, RefAttributes } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, fonts, misc, mq, spacing, stackOrder } from \"@ndla/core\";\nimport { COPYRIGHTED } from \"@ndla/licenses\";\nimport { ConceptData, ConceptVisualElementMeta } from \"@ndla/types-embed\";\nimport { ExternalEmbed, HeartButtonType, IframeEmbed } from \".\";\nimport BrightcoveEmbed from \"./BrightcoveEmbed\";\nimport H5pEmbed from \"./H5pEmbed\";\nimport ImageEmbed from \"./ImageEmbed\";\nimport { Gloss } from \"../Gloss\";\nimport { EmbedByline } from \"../LicenseByline\";\nimport { Copyright } from \"../types\";\n\nexport type ConceptType = \"concept\" | \"gloss\";\n\nexport interface ConceptNotionData {\n  title: ConceptData[\"concept\"][\"title\"];\n  content?: ReactNode;\n  metaImage?: {\n    url?: string;\n    alt?: string;\n  };\n  copyright?: Copyright;\n  source?: string;\n  visualElement?: ConceptVisualElementMeta;\n  conceptType: ConceptData[\"concept\"][\"conceptType\"];\n  glossData?: ConceptData[\"concept\"][\"glossData\"];\n  lang?: string;\n}\n\ninterface ConceptNotionProps extends RefAttributes<HTMLDivElement>, ConceptNotionData {\n  className?: string;\n  closeButton?: ReactNode;\n  previewAlt?: boolean;\n  inPopover?: boolean;\n  tags?: string[];\n  subjects?: string[];\n  headerButtons?: ReactNode;\n  heartButton?: HeartButtonType;\n  conceptHeartButton?: ReactNode;\n  exampleIds?: string;\n  exampleLangs?: string;\n}\n\nconst NotionDialogText = styled.div`\n  font-weight: ${fonts.weight.normal};\n  ${fonts.sizes(\"18px\", 1.3)};\n  color: ${colors.text.primary};\n  font-family: ${fonts.sans};\n`;\n\nconst NotionDialogContent = styled.div`\n  padding-bottom: ${spacing.normal};\n  display: flex;\n  flex-direction: column;\n`;\n\nconst ContentSpacing = styled.div`\n  padding: ${spacing.normal};\n  &[data-is-concept=\"false\"] {\n    margin-bottom: ${spacing.normal};\n  }\n`;\n\nconst notionContentCss = css`\n  @keyframes animateIn {\n    0% {\n      opacity: 0;\n      transform: translate3d(0, -13px, 0);\n    }\n    100% {\n      opacity: 1;\n      transform: translate3d(0, 0, 0);\n    }\n  }\n\n  animation-name: animateIn;\n  animation-duration: 300ms;\n  background-color: white;\n  z-index: ${stackOrder.offsetSingle};\n  box-shadow: 0 0 30px rgba(0, 0, 0, 0.2);\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 500px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 720px;\n  }\n\n  ${mq.range({ until: breakpoints.tablet })} {\n    padding: ${spacing.small};\n    z-index: ${stackOrder.popover};\n    height: 100%;\n    width: 100%;\n    overflow: auto;\n  }\n`;\n\nconst NotionHeader = styled.div`\n  display: flex;\n  align-items: center;\n  justify-content: flex-end;\n  border-bottom: 2px solid ${colors.brand.tertiary};\n  padding-bottom: ${spacing.small};\n  h1 {\n    flex-grow: 1;\n    margin: 0;\n    font-weight: ${fonts.weight.bold};\n    ${fonts.sizes(\"22px\", 1.2)};\n  }\n  small {\n    &[data-is-concept=\"true\"] {\n      border-left: 1px solid ${colors.brand.greyLight};\n      padding-left: ${spacing.small};\n      margin-left: ${spacing.xsmall};\n    }\n    ${fonts.sizes(\"20px\", 1.2)};\n    font-weight: ${fonts.weight.normal};\n  }\n  &[data-is-concept=\"false\"] {\n    margin-bottom: ${spacing.large};\n  }\n`;\n\nconst ListWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n`;\n\nconst StyledNotionDialogContent = styled(NotionDialogContent)`\n  padding-top: ${spacing.small};\n  .c-figure {\n    left: unset !important;\n    width: 100% !important;\n    padding: 0;\n    margin: 0;\n    padding-bottom: ${spacing.normal};\n  }\n`;\n\nconst ButtonWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  align-items: center;\n`;\n\nconst StyledList = styled.ul`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n  list-style: none;\n  > li {\n    font-family: ${fonts.sans};\n    font-weight: ${fonts.weight.semibold};\n    border-radius: ${misc.borderRadius};\n    background-color: ${colors.brand.greyLightest};\n    ${fonts.sizes(\"12px\", 1.2)};\n    padding: ${spacing.xxsmall};\n  }\n`;\n\nexport const ConceptNotionV2 = forwardRef<HTMLDivElement, ConceptNotionProps>(\n  (\n    {\n      visualElement,\n      title,\n      content,\n      source,\n      copyright,\n      closeButton,\n      inPopover,\n      previewAlt,\n      tags,\n      subjects,\n      heartButton,\n      conceptHeartButton,\n      conceptType,\n      glossData,\n      headerButtons,\n      lang,\n      exampleIds,\n      exampleLangs,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t } = useTranslation();\n    const isConcept = conceptType === \"concept\";\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <ContentSpacing data-is-concept={isConcept}>\n          <NotionHeader data-is-concept={isConcept}>\n            <h1>\n              {isConcept && title.title}\n              {<small data-is-concept={isConcept}>{t(`searchPage.resultType.${conceptType}`)}</small>}\n            </h1>\n            <ButtonWrapper>\n              {headerButtons}\n              {closeButton}\n            </ButtonWrapper>\n          </NotionHeader>\n          {isConcept ? (\n            <>\n              <StyledNotionDialogContent>\n                {visualElement?.resource === \"image\" ? (\n                  <ImageEmbed embed={visualElement} heartButton={heartButton} lang={lang} />\n                ) : visualElement?.resource === \"brightcove\" ? (\n                  <BrightcoveEmbed embed={visualElement} heartButton={heartButton} />\n                ) : visualElement?.resource === \"h5p\" ? (\n                  <H5pEmbed embed={visualElement} />\n                ) : visualElement?.resource === \"iframe\" ? (\n                  <IframeEmbed embed={visualElement} />\n                ) : visualElement?.resource === \"external\" ? (\n                  <ExternalEmbed embed={visualElement} />\n                ) : null}\n                {content && <NotionDialogText lang={lang}>{content}</NotionDialogText>}\n              </StyledNotionDialogContent>\n              {tags && (\n                <ListWrapper>\n                  {`${t(\"notions.tags\")}:`}\n                  <StyledList>\n                    {tags.map((tag, index) => (\n                      <li key={index}>{tag}</li>\n                    ))}\n                  </StyledList>\n                </ListWrapper>\n              )}\n              {subjects && (\n                <ListWrapper>\n                  {`${t(\"notions.usedIn\")}:`}\n                  <StyledList>\n                    {subjects.map((subject, index) => (\n                      <li key={index}>{subject}</li>\n                    ))}\n                  </StyledList>\n                </ListWrapper>\n              )}\n            </>\n          ) : (\n            <Gloss\n              title={title}\n              glossData={glossData!}\n              audio={\n                visualElement?.status === \"success\" && visualElement.resource === \"audio\"\n                  ? {\n                      src: visualElement.data.audioFile.url,\n                      title: visualElement.data.title.title,\n                    }\n                  : undefined\n              }\n              exampleIds={exampleIds}\n              exampleLangs={exampleLangs}\n            />\n          )}\n        </ContentSpacing>\n        {copyright && (\n          <EmbedByline copyright={copyright} type={conceptType as ConceptType}>\n            {copyright.license?.license.toLowerCase() !== COPYRIGHTED && conceptHeartButton}\n          </EmbedByline>\n        )}\n      </div>\n    );\n  },\n);\n"]} */"));
|
|
42
|
+
}), "{padding:", spacing.small, ";z-index:", stackOrder.popover, ";height:100%;width:100%;overflow:auto;};label:notionContentCss;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["conceptComponents.tsx"],"names":[],"mappings":"AA0E4B","file":"conceptComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2023-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 { forwardRef, ReactNode, RefAttributes } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, fonts, misc, mq, spacing, stackOrder } from \"@ndla/core\";\nimport { COPYRIGHTED } from \"@ndla/licenses\";\nimport { ConceptData, ConceptVisualElementMeta } from \"@ndla/types-embed\";\nimport { ExternalEmbed, HeartButtonType, IframeEmbed } from \".\";\nimport BrightcoveEmbed from \"./BrightcoveEmbed\";\nimport H5pEmbed from \"./H5pEmbed\";\nimport ImageEmbed from \"./ImageEmbed\";\nimport { Gloss } from \"../Gloss\";\nimport { EmbedByline } from \"../LicenseByline\";\nimport { Copyright } from \"../types\";\n\nexport type ConceptType = \"concept\" | \"gloss\";\n\nexport interface ConceptNotionData {\n  title: ConceptData[\"concept\"][\"title\"];\n  content?: ReactNode;\n  metaImage?: {\n    url?: string;\n    alt?: string;\n  };\n  copyright?: Copyright;\n  source?: string;\n  visualElement?: ConceptVisualElementMeta;\n  conceptType: ConceptData[\"concept\"][\"conceptType\"];\n  glossData?: ConceptData[\"concept\"][\"glossData\"];\n  lang?: string;\n}\n\ninterface ConceptNotionProps extends RefAttributes<HTMLDivElement>, Omit<ConceptNotionData, \"metaImage\"> {\n  className?: string;\n  closeButton?: ReactNode;\n  previewAlt?: boolean;\n  inPopover?: boolean;\n  tags?: string[];\n  subjects?: string[];\n  headerButtons?: ReactNode;\n  heartButton?: HeartButtonType;\n  conceptHeartButton?: ReactNode;\n  exampleIds?: string;\n  exampleLangs?: string;\n}\n\nconst NotionDialogText = styled.div`\n  font-weight: ${fonts.weight.normal};\n  ${fonts.sizes(\"18px\", 1.3)};\n  color: ${colors.text.primary};\n  font-family: ${fonts.sans};\n`;\n\nconst NotionDialogContent = styled.div`\n  padding-bottom: ${spacing.normal};\n  display: flex;\n  flex-direction: column;\n`;\n\nconst ContentSpacing = styled.div`\n  padding: ${spacing.normal};\n  &[data-is-concept=\"false\"] {\n    margin-bottom: ${spacing.normal};\n  }\n`;\n\nconst notionContentCss = css`\n  @keyframes animateIn {\n    0% {\n      opacity: 0;\n      transform: translate3d(0, -13px, 0);\n    }\n    100% {\n      opacity: 1;\n      transform: translate3d(0, 0, 0);\n    }\n  }\n\n  animation-name: animateIn;\n  animation-duration: 300ms;\n  background-color: white;\n  z-index: ${stackOrder.offsetSingle};\n  box-shadow: 0 0 30px rgba(0, 0, 0, 0.2);\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 500px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 720px;\n  }\n\n  ${mq.range({ until: breakpoints.tablet })} {\n    padding: ${spacing.small};\n    z-index: ${stackOrder.popover};\n    height: 100%;\n    width: 100%;\n    overflow: auto;\n  }\n`;\n\nconst NotionHeader = styled.div`\n  display: flex;\n  align-items: center;\n  justify-content: flex-end;\n  border-bottom: 2px solid ${colors.brand.tertiary};\n  padding-bottom: ${spacing.small};\n  h1 {\n    flex-grow: 1;\n    margin: 0;\n    font-weight: ${fonts.weight.bold};\n    ${fonts.sizes(\"22px\", 1.2)};\n  }\n  small {\n    &[data-is-concept=\"true\"] {\n      border-left: 1px solid ${colors.brand.greyLight};\n      padding-left: ${spacing.small};\n      margin-left: ${spacing.xsmall};\n    }\n    ${fonts.sizes(\"20px\", 1.2)};\n    font-weight: ${fonts.weight.normal};\n  }\n  &[data-is-concept=\"false\"] {\n    margin-bottom: ${spacing.large};\n  }\n`;\n\nconst ListWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n`;\n\nconst StyledNotionDialogContent = styled(NotionDialogContent)`\n  padding-top: ${spacing.small};\n  .c-figure {\n    left: unset !important;\n    width: 100% !important;\n    padding: 0;\n    margin: 0;\n    padding-bottom: ${spacing.normal};\n  }\n`;\n\nconst ButtonWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  align-items: center;\n`;\n\nconst StyledList = styled.ul`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n  list-style: none;\n  > li {\n    font-family: ${fonts.sans};\n    font-weight: ${fonts.weight.semibold};\n    border-radius: ${misc.borderRadius};\n    background-color: ${colors.brand.greyLightest};\n    ${fonts.sizes(\"12px\", 1.2)};\n    padding: ${spacing.xxsmall};\n  }\n`;\n\nexport const ConceptNotionV2 = forwardRef<HTMLDivElement, ConceptNotionProps>(\n  (\n    {\n      visualElement,\n      title,\n      content,\n      source,\n      copyright,\n      closeButton,\n      inPopover,\n      previewAlt,\n      tags,\n      subjects,\n      heartButton,\n      conceptHeartButton,\n      conceptType,\n      glossData,\n      headerButtons,\n      lang,\n      exampleIds,\n      exampleLangs,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t } = useTranslation();\n    const isConcept = conceptType === \"concept\";\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <ContentSpacing data-is-concept={isConcept}>\n          <NotionHeader data-is-concept={isConcept}>\n            <h1>\n              {isConcept && title.title}\n              {<small data-is-concept={isConcept}>{t(`searchPage.resultType.${conceptType}`)}</small>}\n            </h1>\n            <ButtonWrapper>\n              {headerButtons}\n              {closeButton}\n            </ButtonWrapper>\n          </NotionHeader>\n          {isConcept ? (\n            <>\n              <StyledNotionDialogContent>\n                {visualElement?.resource === \"image\" ? (\n                  <ImageEmbed embed={visualElement} heartButton={heartButton} lang={lang} />\n                ) : visualElement?.resource === \"brightcove\" ? (\n                  <BrightcoveEmbed embed={visualElement} heartButton={heartButton} />\n                ) : visualElement?.resource === \"h5p\" ? (\n                  <H5pEmbed embed={visualElement} />\n                ) : visualElement?.resource === \"iframe\" ? (\n                  <IframeEmbed embed={visualElement} />\n                ) : visualElement?.resource === \"external\" ? (\n                  <ExternalEmbed embed={visualElement} />\n                ) : null}\n                {content && <NotionDialogText lang={lang}>{content}</NotionDialogText>}\n              </StyledNotionDialogContent>\n              {tags && (\n                <ListWrapper>\n                  {`${t(\"notions.tags\")}:`}\n                  <StyledList>\n                    {tags.map((tag, index) => (\n                      <li key={index}>{tag}</li>\n                    ))}\n                  </StyledList>\n                </ListWrapper>\n              )}\n              {subjects && (\n                <ListWrapper>\n                  {`${t(\"notions.usedIn\")}:`}\n                  <StyledList>\n                    {subjects.map((subject, index) => (\n                      <li key={index}>{subject}</li>\n                    ))}\n                  </StyledList>\n                </ListWrapper>\n              )}\n            </>\n          ) : (\n            <Gloss\n              title={title}\n              glossData={glossData!}\n              audio={\n                visualElement?.status === \"success\" && visualElement.resource === \"audio\"\n                  ? {\n                      src: visualElement.data.audioFile.url,\n                      title: visualElement.data.title.title,\n                    }\n                  : undefined\n              }\n              exampleIds={exampleIds}\n              exampleLangs={exampleLangs}\n            />\n          )}\n        </ContentSpacing>\n        {copyright && (\n          <EmbedByline copyright={copyright} type={conceptType as ConceptType}>\n            {copyright.license?.license.toLowerCase() !== COPYRIGHTED && conceptHeartButton}\n          </EmbedByline>\n        )}\n      </div>\n    );\n  },\n);\n"]} */"));
|
|
43
43
|
const NotionHeader = /*#__PURE__*/_styled("div", {
|
|
44
44
|
target: "eqcj3r4",
|
|
45
45
|
label: "NotionHeader"
|
|
46
|
-
})("display:flex;align-items:center;justify-content:flex-end;border-bottom:2px solid ", colors.brand.tertiary, ";padding-bottom:", spacing.small, ";h1{flex-grow:1;margin:0;font-weight:", fonts.weight.bold, ";", fonts.sizes("22px", 1.2), ";}small{", fonts.sizes("20px", 1.2), ";font-weight:", fonts.weight.normal, ";&[data-is-concept=\"true\"]{border-left:1px solid ", colors.brand.greyLight, ";padding-left:", spacing.small, ";margin-left:", spacing.xsmall, ";}}&[data-is-concept=\"false\"]{margin-bottom:", spacing.large, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["conceptComponents.tsx"],"names":[],"mappings":"AA2G+B","file":"conceptComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2023-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 { forwardRef, ReactNode, RefAttributes } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, fonts, misc, mq, spacing, stackOrder } from \"@ndla/core\";\nimport { COPYRIGHTED } from \"@ndla/licenses\";\nimport { ConceptData, ConceptVisualElementMeta } from \"@ndla/types-embed\";\nimport { ExternalEmbed, HeartButtonType, IframeEmbed } from \".\";\nimport BrightcoveEmbed from \"./BrightcoveEmbed\";\nimport H5pEmbed from \"./H5pEmbed\";\nimport ImageEmbed from \"./ImageEmbed\";\nimport { Gloss } from \"../Gloss\";\nimport { EmbedByline } from \"../LicenseByline\";\nimport { Copyright } from \"../types\";\n\nexport type ConceptType = \"concept\" | \"gloss\";\n\nexport interface ConceptNotionData {\n  title: ConceptData[\"concept\"][\"title\"];\n  content?: ReactNode;\n  metaImage?: {\n    url?: string;\n    alt?: string;\n  };\n  copyright?: Copyright;\n  source?: string;\n  visualElement?: ConceptVisualElementMeta;\n  conceptType: ConceptData[\"concept\"][\"conceptType\"];\n  glossData?: ConceptData[\"concept\"][\"glossData\"];\n  lang?: string;\n}\n\ninterface ConceptNotionProps extends RefAttributes<HTMLDivElement>, ConceptNotionData {\n  className?: string;\n  closeButton?: ReactNode;\n  previewAlt?: boolean;\n  inPopover?: boolean;\n  tags?: string[];\n  subjects?: string[];\n  headerButtons?: ReactNode;\n  heartButton?: HeartButtonType;\n  conceptHeartButton?: ReactNode;\n  exampleIds?: string;\n  exampleLangs?: string;\n}\n\nconst NotionDialogText = styled.div`\n  font-weight: ${fonts.weight.normal};\n  ${fonts.sizes(\"18px\", 1.3)};\n  color: ${colors.text.primary};\n  font-family: ${fonts.sans};\n`;\n\nconst NotionDialogContent = styled.div`\n  padding-bottom: ${spacing.normal};\n  display: flex;\n  flex-direction: column;\n`;\n\nconst ContentSpacing = styled.div`\n  padding: ${spacing.normal};\n  &[data-is-concept=\"false\"] {\n    margin-bottom: ${spacing.normal};\n  }\n`;\n\nconst notionContentCss = css`\n  @keyframes animateIn {\n    0% {\n      opacity: 0;\n      transform: translate3d(0, -13px, 0);\n    }\n    100% {\n      opacity: 1;\n      transform: translate3d(0, 0, 0);\n    }\n  }\n\n  animation-name: animateIn;\n  animation-duration: 300ms;\n  background-color: white;\n  z-index: ${stackOrder.offsetSingle};\n  box-shadow: 0 0 30px rgba(0, 0, 0, 0.2);\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 500px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 720px;\n  }\n\n  ${mq.range({ until: breakpoints.tablet })} {\n    padding: ${spacing.small};\n    z-index: ${stackOrder.popover};\n    height: 100%;\n    width: 100%;\n    overflow: auto;\n  }\n`;\n\nconst NotionHeader = styled.div`\n  display: flex;\n  align-items: center;\n  justify-content: flex-end;\n  border-bottom: 2px solid ${colors.brand.tertiary};\n  padding-bottom: ${spacing.small};\n  h1 {\n    flex-grow: 1;\n    margin: 0;\n    font-weight: ${fonts.weight.bold};\n    ${fonts.sizes(\"22px\", 1.2)};\n  }\n  small {\n    &[data-is-concept=\"true\"] {\n      border-left: 1px solid ${colors.brand.greyLight};\n      padding-left: ${spacing.small};\n      margin-left: ${spacing.xsmall};\n    }\n    ${fonts.sizes(\"20px\", 1.2)};\n    font-weight: ${fonts.weight.normal};\n  }\n  &[data-is-concept=\"false\"] {\n    margin-bottom: ${spacing.large};\n  }\n`;\n\nconst ListWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n`;\n\nconst StyledNotionDialogContent = styled(NotionDialogContent)`\n  padding-top: ${spacing.small};\n  .c-figure {\n    left: unset !important;\n    width: 100% !important;\n    padding: 0;\n    margin: 0;\n    padding-bottom: ${spacing.normal};\n  }\n`;\n\nconst ButtonWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  align-items: center;\n`;\n\nconst StyledList = styled.ul`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n  list-style: none;\n  > li {\n    font-family: ${fonts.sans};\n    font-weight: ${fonts.weight.semibold};\n    border-radius: ${misc.borderRadius};\n    background-color: ${colors.brand.greyLightest};\n    ${fonts.sizes(\"12px\", 1.2)};\n    padding: ${spacing.xxsmall};\n  }\n`;\n\nexport const ConceptNotionV2 = forwardRef<HTMLDivElement, ConceptNotionProps>(\n  (\n    {\n      visualElement,\n      title,\n      content,\n      source,\n      copyright,\n      closeButton,\n      inPopover,\n      previewAlt,\n      tags,\n      subjects,\n      heartButton,\n      conceptHeartButton,\n      conceptType,\n      glossData,\n      headerButtons,\n      lang,\n      exampleIds,\n      exampleLangs,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t } = useTranslation();\n    const isConcept = conceptType === \"concept\";\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <ContentSpacing data-is-concept={isConcept}>\n          <NotionHeader data-is-concept={isConcept}>\n            <h1>\n              {isConcept && title.title}\n              {<small data-is-concept={isConcept}>{t(`searchPage.resultType.${conceptType}`)}</small>}\n            </h1>\n            <ButtonWrapper>\n              {headerButtons}\n              {closeButton}\n            </ButtonWrapper>\n          </NotionHeader>\n          {isConcept ? (\n            <>\n              <StyledNotionDialogContent>\n                {visualElement?.resource === \"image\" ? (\n                  <ImageEmbed embed={visualElement} heartButton={heartButton} lang={lang} />\n                ) : visualElement?.resource === \"brightcove\" ? (\n                  <BrightcoveEmbed embed={visualElement} heartButton={heartButton} />\n                ) : visualElement?.resource === \"h5p\" ? (\n                  <H5pEmbed embed={visualElement} />\n                ) : visualElement?.resource === \"iframe\" ? (\n                  <IframeEmbed embed={visualElement} />\n                ) : visualElement?.resource === \"external\" ? (\n                  <ExternalEmbed embed={visualElement} />\n                ) : null}\n                {content && <NotionDialogText lang={lang}>{content}</NotionDialogText>}\n              </StyledNotionDialogContent>\n              {tags && (\n                <ListWrapper>\n                  {`${t(\"notions.tags\")}:`}\n                  <StyledList>\n                    {tags.map((tag, index) => (\n                      <li key={index}>{tag}</li>\n                    ))}\n                  </StyledList>\n                </ListWrapper>\n              )}\n              {subjects && (\n                <ListWrapper>\n                  {`${t(\"notions.usedIn\")}:`}\n                  <StyledList>\n                    {subjects.map((subject, index) => (\n                      <li key={index}>{subject}</li>\n                    ))}\n                  </StyledList>\n                </ListWrapper>\n              )}\n            </>\n          ) : (\n            <Gloss\n              title={title}\n              glossData={glossData!}\n              audio={\n                visualElement?.status === \"success\" && visualElement.resource === \"audio\"\n                  ? {\n                      src: visualElement.data.audioFile.url,\n                      title: visualElement.data.title.title,\n                    }\n                  : undefined\n              }\n              exampleIds={exampleIds}\n              exampleLangs={exampleLangs}\n            />\n          )}\n        </ContentSpacing>\n        {copyright && (\n          <EmbedByline copyright={copyright} type={conceptType as ConceptType}>\n            {copyright.license?.license.toLowerCase() !== COPYRIGHTED && conceptHeartButton}\n          </EmbedByline>\n        )}\n      </div>\n    );\n  },\n);\n"]} */"));
|
|
46
|
+
})("display:flex;align-items:center;justify-content:flex-end;border-bottom:2px solid ", colors.brand.tertiary, ";padding-bottom:", spacing.small, ";h1{flex-grow:1;margin:0;font-weight:", fonts.weight.bold, ";", fonts.sizes("22px", 1.2), ";}small{", fonts.sizes("20px", 1.2), ";font-weight:", fonts.weight.normal, ";&[data-is-concept=\"true\"]{border-left:1px solid ", colors.brand.greyLight, ";padding-left:", spacing.small, ";margin-left:", spacing.xsmall, ";}}&[data-is-concept=\"false\"]{margin-bottom:", spacing.large, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["conceptComponents.tsx"],"names":[],"mappings":"AA2G+B","file":"conceptComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2023-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 { forwardRef, ReactNode, RefAttributes } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, fonts, misc, mq, spacing, stackOrder } from \"@ndla/core\";\nimport { COPYRIGHTED } from \"@ndla/licenses\";\nimport { ConceptData, ConceptVisualElementMeta } from \"@ndla/types-embed\";\nimport { ExternalEmbed, HeartButtonType, IframeEmbed } from \".\";\nimport BrightcoveEmbed from \"./BrightcoveEmbed\";\nimport H5pEmbed from \"./H5pEmbed\";\nimport ImageEmbed from \"./ImageEmbed\";\nimport { Gloss } from \"../Gloss\";\nimport { EmbedByline } from \"../LicenseByline\";\nimport { Copyright } from \"../types\";\n\nexport type ConceptType = \"concept\" | \"gloss\";\n\nexport interface ConceptNotionData {\n  title: ConceptData[\"concept\"][\"title\"];\n  content?: ReactNode;\n  metaImage?: {\n    url?: string;\n    alt?: string;\n  };\n  copyright?: Copyright;\n  source?: string;\n  visualElement?: ConceptVisualElementMeta;\n  conceptType: ConceptData[\"concept\"][\"conceptType\"];\n  glossData?: ConceptData[\"concept\"][\"glossData\"];\n  lang?: string;\n}\n\ninterface ConceptNotionProps extends RefAttributes<HTMLDivElement>, Omit<ConceptNotionData, \"metaImage\"> {\n  className?: string;\n  closeButton?: ReactNode;\n  previewAlt?: boolean;\n  inPopover?: boolean;\n  tags?: string[];\n  subjects?: string[];\n  headerButtons?: ReactNode;\n  heartButton?: HeartButtonType;\n  conceptHeartButton?: ReactNode;\n  exampleIds?: string;\n  exampleLangs?: string;\n}\n\nconst NotionDialogText = styled.div`\n  font-weight: ${fonts.weight.normal};\n  ${fonts.sizes(\"18px\", 1.3)};\n  color: ${colors.text.primary};\n  font-family: ${fonts.sans};\n`;\n\nconst NotionDialogContent = styled.div`\n  padding-bottom: ${spacing.normal};\n  display: flex;\n  flex-direction: column;\n`;\n\nconst ContentSpacing = styled.div`\n  padding: ${spacing.normal};\n  &[data-is-concept=\"false\"] {\n    margin-bottom: ${spacing.normal};\n  }\n`;\n\nconst notionContentCss = css`\n  @keyframes animateIn {\n    0% {\n      opacity: 0;\n      transform: translate3d(0, -13px, 0);\n    }\n    100% {\n      opacity: 1;\n      transform: translate3d(0, 0, 0);\n    }\n  }\n\n  animation-name: animateIn;\n  animation-duration: 300ms;\n  background-color: white;\n  z-index: ${stackOrder.offsetSingle};\n  box-shadow: 0 0 30px rgba(0, 0, 0, 0.2);\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 500px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 720px;\n  }\n\n  ${mq.range({ until: breakpoints.tablet })} {\n    padding: ${spacing.small};\n    z-index: ${stackOrder.popover};\n    height: 100%;\n    width: 100%;\n    overflow: auto;\n  }\n`;\n\nconst NotionHeader = styled.div`\n  display: flex;\n  align-items: center;\n  justify-content: flex-end;\n  border-bottom: 2px solid ${colors.brand.tertiary};\n  padding-bottom: ${spacing.small};\n  h1 {\n    flex-grow: 1;\n    margin: 0;\n    font-weight: ${fonts.weight.bold};\n    ${fonts.sizes(\"22px\", 1.2)};\n  }\n  small {\n    &[data-is-concept=\"true\"] {\n      border-left: 1px solid ${colors.brand.greyLight};\n      padding-left: ${spacing.small};\n      margin-left: ${spacing.xsmall};\n    }\n    ${fonts.sizes(\"20px\", 1.2)};\n    font-weight: ${fonts.weight.normal};\n  }\n  &[data-is-concept=\"false\"] {\n    margin-bottom: ${spacing.large};\n  }\n`;\n\nconst ListWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n`;\n\nconst StyledNotionDialogContent = styled(NotionDialogContent)`\n  padding-top: ${spacing.small};\n  .c-figure {\n    left: unset !important;\n    width: 100% !important;\n    padding: 0;\n    margin: 0;\n    padding-bottom: ${spacing.normal};\n  }\n`;\n\nconst ButtonWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  align-items: center;\n`;\n\nconst StyledList = styled.ul`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n  list-style: none;\n  > li {\n    font-family: ${fonts.sans};\n    font-weight: ${fonts.weight.semibold};\n    border-radius: ${misc.borderRadius};\n    background-color: ${colors.brand.greyLightest};\n    ${fonts.sizes(\"12px\", 1.2)};\n    padding: ${spacing.xxsmall};\n  }\n`;\n\nexport const ConceptNotionV2 = forwardRef<HTMLDivElement, ConceptNotionProps>(\n  (\n    {\n      visualElement,\n      title,\n      content,\n      source,\n      copyright,\n      closeButton,\n      inPopover,\n      previewAlt,\n      tags,\n      subjects,\n      heartButton,\n      conceptHeartButton,\n      conceptType,\n      glossData,\n      headerButtons,\n      lang,\n      exampleIds,\n      exampleLangs,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t } = useTranslation();\n    const isConcept = conceptType === \"concept\";\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <ContentSpacing data-is-concept={isConcept}>\n          <NotionHeader data-is-concept={isConcept}>\n            <h1>\n              {isConcept && title.title}\n              {<small data-is-concept={isConcept}>{t(`searchPage.resultType.${conceptType}`)}</small>}\n            </h1>\n            <ButtonWrapper>\n              {headerButtons}\n              {closeButton}\n            </ButtonWrapper>\n          </NotionHeader>\n          {isConcept ? (\n            <>\n              <StyledNotionDialogContent>\n                {visualElement?.resource === \"image\" ? (\n                  <ImageEmbed embed={visualElement} heartButton={heartButton} lang={lang} />\n                ) : visualElement?.resource === \"brightcove\" ? (\n                  <BrightcoveEmbed embed={visualElement} heartButton={heartButton} />\n                ) : visualElement?.resource === \"h5p\" ? (\n                  <H5pEmbed embed={visualElement} />\n                ) : visualElement?.resource === \"iframe\" ? (\n                  <IframeEmbed embed={visualElement} />\n                ) : visualElement?.resource === \"external\" ? (\n                  <ExternalEmbed embed={visualElement} />\n                ) : null}\n                {content && <NotionDialogText lang={lang}>{content}</NotionDialogText>}\n              </StyledNotionDialogContent>\n              {tags && (\n                <ListWrapper>\n                  {`${t(\"notions.tags\")}:`}\n                  <StyledList>\n                    {tags.map((tag, index) => (\n                      <li key={index}>{tag}</li>\n                    ))}\n                  </StyledList>\n                </ListWrapper>\n              )}\n              {subjects && (\n                <ListWrapper>\n                  {`${t(\"notions.usedIn\")}:`}\n                  <StyledList>\n                    {subjects.map((subject, index) => (\n                      <li key={index}>{subject}</li>\n                    ))}\n                  </StyledList>\n                </ListWrapper>\n              )}\n            </>\n          ) : (\n            <Gloss\n              title={title}\n              glossData={glossData!}\n              audio={\n                visualElement?.status === \"success\" && visualElement.resource === \"audio\"\n                  ? {\n                      src: visualElement.data.audioFile.url,\n                      title: visualElement.data.title.title,\n                    }\n                  : undefined\n              }\n              exampleIds={exampleIds}\n              exampleLangs={exampleLangs}\n            />\n          )}\n        </ContentSpacing>\n        {copyright && (\n          <EmbedByline copyright={copyright} type={conceptType as ConceptType}>\n            {copyright.license?.license.toLowerCase() !== COPYRIGHTED && conceptHeartButton}\n          </EmbedByline>\n        )}\n      </div>\n    );\n  },\n);\n"]} */"));
|
|
47
47
|
const ListWrapper = /*#__PURE__*/_styled("div", {
|
|
48
48
|
target: "eqcj3r3",
|
|
49
49
|
label: "ListWrapper"
|
|
50
|
-
})("display:flex;gap:", spacing.small, ";align-items:center;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["conceptComponents.tsx"],"names":[],"mappings":"AAqI8B","file":"conceptComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2023-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 { forwardRef, ReactNode, RefAttributes } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, fonts, misc, mq, spacing, stackOrder } from \"@ndla/core\";\nimport { COPYRIGHTED } from \"@ndla/licenses\";\nimport { ConceptData, ConceptVisualElementMeta } from \"@ndla/types-embed\";\nimport { ExternalEmbed, HeartButtonType, IframeEmbed } from \".\";\nimport BrightcoveEmbed from \"./BrightcoveEmbed\";\nimport H5pEmbed from \"./H5pEmbed\";\nimport ImageEmbed from \"./ImageEmbed\";\nimport { Gloss } from \"../Gloss\";\nimport { EmbedByline } from \"../LicenseByline\";\nimport { Copyright } from \"../types\";\n\nexport type ConceptType = \"concept\" | \"gloss\";\n\nexport interface ConceptNotionData {\n  title: ConceptData[\"concept\"][\"title\"];\n  content?: ReactNode;\n  metaImage?: {\n    url?: string;\n    alt?: string;\n  };\n  copyright?: Copyright;\n  source?: string;\n  visualElement?: ConceptVisualElementMeta;\n  conceptType: ConceptData[\"concept\"][\"conceptType\"];\n  glossData?: ConceptData[\"concept\"][\"glossData\"];\n  lang?: string;\n}\n\ninterface ConceptNotionProps extends RefAttributes<HTMLDivElement>, ConceptNotionData {\n  className?: string;\n  closeButton?: ReactNode;\n  previewAlt?: boolean;\n  inPopover?: boolean;\n  tags?: string[];\n  subjects?: string[];\n  headerButtons?: ReactNode;\n  heartButton?: HeartButtonType;\n  conceptHeartButton?: ReactNode;\n  exampleIds?: string;\n  exampleLangs?: string;\n}\n\nconst NotionDialogText = styled.div`\n  font-weight: ${fonts.weight.normal};\n  ${fonts.sizes(\"18px\", 1.3)};\n  color: ${colors.text.primary};\n  font-family: ${fonts.sans};\n`;\n\nconst NotionDialogContent = styled.div`\n  padding-bottom: ${spacing.normal};\n  display: flex;\n  flex-direction: column;\n`;\n\nconst ContentSpacing = styled.div`\n  padding: ${spacing.normal};\n  &[data-is-concept=\"false\"] {\n    margin-bottom: ${spacing.normal};\n  }\n`;\n\nconst notionContentCss = css`\n  @keyframes animateIn {\n    0% {\n      opacity: 0;\n      transform: translate3d(0, -13px, 0);\n    }\n    100% {\n      opacity: 1;\n      transform: translate3d(0, 0, 0);\n    }\n  }\n\n  animation-name: animateIn;\n  animation-duration: 300ms;\n  background-color: white;\n  z-index: ${stackOrder.offsetSingle};\n  box-shadow: 0 0 30px rgba(0, 0, 0, 0.2);\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 500px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 720px;\n  }\n\n  ${mq.range({ until: breakpoints.tablet })} {\n    padding: ${spacing.small};\n    z-index: ${stackOrder.popover};\n    height: 100%;\n    width: 100%;\n    overflow: auto;\n  }\n`;\n\nconst NotionHeader = styled.div`\n  display: flex;\n  align-items: center;\n  justify-content: flex-end;\n  border-bottom: 2px solid ${colors.brand.tertiary};\n  padding-bottom: ${spacing.small};\n  h1 {\n    flex-grow: 1;\n    margin: 0;\n    font-weight: ${fonts.weight.bold};\n    ${fonts.sizes(\"22px\", 1.2)};\n  }\n  small {\n    &[data-is-concept=\"true\"] {\n      border-left: 1px solid ${colors.brand.greyLight};\n      padding-left: ${spacing.small};\n      margin-left: ${spacing.xsmall};\n    }\n    ${fonts.sizes(\"20px\", 1.2)};\n    font-weight: ${fonts.weight.normal};\n  }\n  &[data-is-concept=\"false\"] {\n    margin-bottom: ${spacing.large};\n  }\n`;\n\nconst ListWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n`;\n\nconst StyledNotionDialogContent = styled(NotionDialogContent)`\n  padding-top: ${spacing.small};\n  .c-figure {\n    left: unset !important;\n    width: 100% !important;\n    padding: 0;\n    margin: 0;\n    padding-bottom: ${spacing.normal};\n  }\n`;\n\nconst ButtonWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  align-items: center;\n`;\n\nconst StyledList = styled.ul`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n  list-style: none;\n  > li {\n    font-family: ${fonts.sans};\n    font-weight: ${fonts.weight.semibold};\n    border-radius: ${misc.borderRadius};\n    background-color: ${colors.brand.greyLightest};\n    ${fonts.sizes(\"12px\", 1.2)};\n    padding: ${spacing.xxsmall};\n  }\n`;\n\nexport const ConceptNotionV2 = forwardRef<HTMLDivElement, ConceptNotionProps>(\n  (\n    {\n      visualElement,\n      title,\n      content,\n      source,\n      copyright,\n      closeButton,\n      inPopover,\n      previewAlt,\n      tags,\n      subjects,\n      heartButton,\n      conceptHeartButton,\n      conceptType,\n      glossData,\n      headerButtons,\n      lang,\n      exampleIds,\n      exampleLangs,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t } = useTranslation();\n    const isConcept = conceptType === \"concept\";\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <ContentSpacing data-is-concept={isConcept}>\n          <NotionHeader data-is-concept={isConcept}>\n            <h1>\n              {isConcept && title.title}\n              {<small data-is-concept={isConcept}>{t(`searchPage.resultType.${conceptType}`)}</small>}\n            </h1>\n            <ButtonWrapper>\n              {headerButtons}\n              {closeButton}\n            </ButtonWrapper>\n          </NotionHeader>\n          {isConcept ? (\n            <>\n              <StyledNotionDialogContent>\n                {visualElement?.resource === \"image\" ? (\n                  <ImageEmbed embed={visualElement} heartButton={heartButton} lang={lang} />\n                ) : visualElement?.resource === \"brightcove\" ? (\n                  <BrightcoveEmbed embed={visualElement} heartButton={heartButton} />\n                ) : visualElement?.resource === \"h5p\" ? (\n                  <H5pEmbed embed={visualElement} />\n                ) : visualElement?.resource === \"iframe\" ? (\n                  <IframeEmbed embed={visualElement} />\n                ) : visualElement?.resource === \"external\" ? (\n                  <ExternalEmbed embed={visualElement} />\n                ) : null}\n                {content && <NotionDialogText lang={lang}>{content}</NotionDialogText>}\n              </StyledNotionDialogContent>\n              {tags && (\n                <ListWrapper>\n                  {`${t(\"notions.tags\")}:`}\n                  <StyledList>\n                    {tags.map((tag, index) => (\n                      <li key={index}>{tag}</li>\n                    ))}\n                  </StyledList>\n                </ListWrapper>\n              )}\n              {subjects && (\n                <ListWrapper>\n                  {`${t(\"notions.usedIn\")}:`}\n                  <StyledList>\n                    {subjects.map((subject, index) => (\n                      <li key={index}>{subject}</li>\n                    ))}\n                  </StyledList>\n                </ListWrapper>\n              )}\n            </>\n          ) : (\n            <Gloss\n              title={title}\n              glossData={glossData!}\n              audio={\n                visualElement?.status === \"success\" && visualElement.resource === \"audio\"\n                  ? {\n                      src: visualElement.data.audioFile.url,\n                      title: visualElement.data.title.title,\n                    }\n                  : undefined\n              }\n              exampleIds={exampleIds}\n              exampleLangs={exampleLangs}\n            />\n          )}\n        </ContentSpacing>\n        {copyright && (\n          <EmbedByline copyright={copyright} type={conceptType as ConceptType}>\n            {copyright.license?.license.toLowerCase() !== COPYRIGHTED && conceptHeartButton}\n          </EmbedByline>\n        )}\n      </div>\n    );\n  },\n);\n"]} */"));
|
|
50
|
+
})("display:flex;gap:", spacing.small, ";align-items:center;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["conceptComponents.tsx"],"names":[],"mappings":"AAqI8B","file":"conceptComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2023-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 { forwardRef, ReactNode, RefAttributes } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, fonts, misc, mq, spacing, stackOrder } from \"@ndla/core\";\nimport { COPYRIGHTED } from \"@ndla/licenses\";\nimport { ConceptData, ConceptVisualElementMeta } from \"@ndla/types-embed\";\nimport { ExternalEmbed, HeartButtonType, IframeEmbed } from \".\";\nimport BrightcoveEmbed from \"./BrightcoveEmbed\";\nimport H5pEmbed from \"./H5pEmbed\";\nimport ImageEmbed from \"./ImageEmbed\";\nimport { Gloss } from \"../Gloss\";\nimport { EmbedByline } from \"../LicenseByline\";\nimport { Copyright } from \"../types\";\n\nexport type ConceptType = \"concept\" | \"gloss\";\n\nexport interface ConceptNotionData {\n  title: ConceptData[\"concept\"][\"title\"];\n  content?: ReactNode;\n  metaImage?: {\n    url?: string;\n    alt?: string;\n  };\n  copyright?: Copyright;\n  source?: string;\n  visualElement?: ConceptVisualElementMeta;\n  conceptType: ConceptData[\"concept\"][\"conceptType\"];\n  glossData?: ConceptData[\"concept\"][\"glossData\"];\n  lang?: string;\n}\n\ninterface ConceptNotionProps extends RefAttributes<HTMLDivElement>, Omit<ConceptNotionData, \"metaImage\"> {\n  className?: string;\n  closeButton?: ReactNode;\n  previewAlt?: boolean;\n  inPopover?: boolean;\n  tags?: string[];\n  subjects?: string[];\n  headerButtons?: ReactNode;\n  heartButton?: HeartButtonType;\n  conceptHeartButton?: ReactNode;\n  exampleIds?: string;\n  exampleLangs?: string;\n}\n\nconst NotionDialogText = styled.div`\n  font-weight: ${fonts.weight.normal};\n  ${fonts.sizes(\"18px\", 1.3)};\n  color: ${colors.text.primary};\n  font-family: ${fonts.sans};\n`;\n\nconst NotionDialogContent = styled.div`\n  padding-bottom: ${spacing.normal};\n  display: flex;\n  flex-direction: column;\n`;\n\nconst ContentSpacing = styled.div`\n  padding: ${spacing.normal};\n  &[data-is-concept=\"false\"] {\n    margin-bottom: ${spacing.normal};\n  }\n`;\n\nconst notionContentCss = css`\n  @keyframes animateIn {\n    0% {\n      opacity: 0;\n      transform: translate3d(0, -13px, 0);\n    }\n    100% {\n      opacity: 1;\n      transform: translate3d(0, 0, 0);\n    }\n  }\n\n  animation-name: animateIn;\n  animation-duration: 300ms;\n  background-color: white;\n  z-index: ${stackOrder.offsetSingle};\n  box-shadow: 0 0 30px rgba(0, 0, 0, 0.2);\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 500px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 720px;\n  }\n\n  ${mq.range({ until: breakpoints.tablet })} {\n    padding: ${spacing.small};\n    z-index: ${stackOrder.popover};\n    height: 100%;\n    width: 100%;\n    overflow: auto;\n  }\n`;\n\nconst NotionHeader = styled.div`\n  display: flex;\n  align-items: center;\n  justify-content: flex-end;\n  border-bottom: 2px solid ${colors.brand.tertiary};\n  padding-bottom: ${spacing.small};\n  h1 {\n    flex-grow: 1;\n    margin: 0;\n    font-weight: ${fonts.weight.bold};\n    ${fonts.sizes(\"22px\", 1.2)};\n  }\n  small {\n    &[data-is-concept=\"true\"] {\n      border-left: 1px solid ${colors.brand.greyLight};\n      padding-left: ${spacing.small};\n      margin-left: ${spacing.xsmall};\n    }\n    ${fonts.sizes(\"20px\", 1.2)};\n    font-weight: ${fonts.weight.normal};\n  }\n  &[data-is-concept=\"false\"] {\n    margin-bottom: ${spacing.large};\n  }\n`;\n\nconst ListWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n`;\n\nconst StyledNotionDialogContent = styled(NotionDialogContent)`\n  padding-top: ${spacing.small};\n  .c-figure {\n    left: unset !important;\n    width: 100% !important;\n    padding: 0;\n    margin: 0;\n    padding-bottom: ${spacing.normal};\n  }\n`;\n\nconst ButtonWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  align-items: center;\n`;\n\nconst StyledList = styled.ul`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n  list-style: none;\n  > li {\n    font-family: ${fonts.sans};\n    font-weight: ${fonts.weight.semibold};\n    border-radius: ${misc.borderRadius};\n    background-color: ${colors.brand.greyLightest};\n    ${fonts.sizes(\"12px\", 1.2)};\n    padding: ${spacing.xxsmall};\n  }\n`;\n\nexport const ConceptNotionV2 = forwardRef<HTMLDivElement, ConceptNotionProps>(\n  (\n    {\n      visualElement,\n      title,\n      content,\n      source,\n      copyright,\n      closeButton,\n      inPopover,\n      previewAlt,\n      tags,\n      subjects,\n      heartButton,\n      conceptHeartButton,\n      conceptType,\n      glossData,\n      headerButtons,\n      lang,\n      exampleIds,\n      exampleLangs,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t } = useTranslation();\n    const isConcept = conceptType === \"concept\";\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <ContentSpacing data-is-concept={isConcept}>\n          <NotionHeader data-is-concept={isConcept}>\n            <h1>\n              {isConcept && title.title}\n              {<small data-is-concept={isConcept}>{t(`searchPage.resultType.${conceptType}`)}</small>}\n            </h1>\n            <ButtonWrapper>\n              {headerButtons}\n              {closeButton}\n            </ButtonWrapper>\n          </NotionHeader>\n          {isConcept ? (\n            <>\n              <StyledNotionDialogContent>\n                {visualElement?.resource === \"image\" ? (\n                  <ImageEmbed embed={visualElement} heartButton={heartButton} lang={lang} />\n                ) : visualElement?.resource === \"brightcove\" ? (\n                  <BrightcoveEmbed embed={visualElement} heartButton={heartButton} />\n                ) : visualElement?.resource === \"h5p\" ? (\n                  <H5pEmbed embed={visualElement} />\n                ) : visualElement?.resource === \"iframe\" ? (\n                  <IframeEmbed embed={visualElement} />\n                ) : visualElement?.resource === \"external\" ? (\n                  <ExternalEmbed embed={visualElement} />\n                ) : null}\n                {content && <NotionDialogText lang={lang}>{content}</NotionDialogText>}\n              </StyledNotionDialogContent>\n              {tags && (\n                <ListWrapper>\n                  {`${t(\"notions.tags\")}:`}\n                  <StyledList>\n                    {tags.map((tag, index) => (\n                      <li key={index}>{tag}</li>\n                    ))}\n                  </StyledList>\n                </ListWrapper>\n              )}\n              {subjects && (\n                <ListWrapper>\n                  {`${t(\"notions.usedIn\")}:`}\n                  <StyledList>\n                    {subjects.map((subject, index) => (\n                      <li key={index}>{subject}</li>\n                    ))}\n                  </StyledList>\n                </ListWrapper>\n              )}\n            </>\n          ) : (\n            <Gloss\n              title={title}\n              glossData={glossData!}\n              audio={\n                visualElement?.status === \"success\" && visualElement.resource === \"audio\"\n                  ? {\n                      src: visualElement.data.audioFile.url,\n                      title: visualElement.data.title.title,\n                    }\n                  : undefined\n              }\n              exampleIds={exampleIds}\n              exampleLangs={exampleLangs}\n            />\n          )}\n        </ContentSpacing>\n        {copyright && (\n          <EmbedByline copyright={copyright} type={conceptType as ConceptType}>\n            {copyright.license?.license.toLowerCase() !== COPYRIGHTED && conceptHeartButton}\n          </EmbedByline>\n        )}\n      </div>\n    );\n  },\n);\n"]} */"));
|
|
51
51
|
const StyledNotionDialogContent = /*#__PURE__*/_styled(NotionDialogContent, {
|
|
52
52
|
target: "eqcj3r2",
|
|
53
53
|
label: "StyledNotionDialogContent"
|
|
54
|
-
})("padding-top:", spacing.small, ";.c-figure{left:unset!important;width:100%!important;padding:0;margin:0;padding-bottom:", spacing.normal, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["conceptComponents.tsx"],"names":[],"mappings":"AA2I6D","file":"conceptComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2023-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 { forwardRef, ReactNode, RefAttributes } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, fonts, misc, mq, spacing, stackOrder } from \"@ndla/core\";\nimport { COPYRIGHTED } from \"@ndla/licenses\";\nimport { ConceptData, ConceptVisualElementMeta } from \"@ndla/types-embed\";\nimport { ExternalEmbed, HeartButtonType, IframeEmbed } from \".\";\nimport BrightcoveEmbed from \"./BrightcoveEmbed\";\nimport H5pEmbed from \"./H5pEmbed\";\nimport ImageEmbed from \"./ImageEmbed\";\nimport { Gloss } from \"../Gloss\";\nimport { EmbedByline } from \"../LicenseByline\";\nimport { Copyright } from \"../types\";\n\nexport type ConceptType = \"concept\" | \"gloss\";\n\nexport interface ConceptNotionData {\n  title: ConceptData[\"concept\"][\"title\"];\n  content?: ReactNode;\n  metaImage?: {\n    url?: string;\n    alt?: string;\n  };\n  copyright?: Copyright;\n  source?: string;\n  visualElement?: ConceptVisualElementMeta;\n  conceptType: ConceptData[\"concept\"][\"conceptType\"];\n  glossData?: ConceptData[\"concept\"][\"glossData\"];\n  lang?: string;\n}\n\ninterface ConceptNotionProps extends RefAttributes<HTMLDivElement>, ConceptNotionData {\n  className?: string;\n  closeButton?: ReactNode;\n  previewAlt?: boolean;\n  inPopover?: boolean;\n  tags?: string[];\n  subjects?: string[];\n  headerButtons?: ReactNode;\n  heartButton?: HeartButtonType;\n  conceptHeartButton?: ReactNode;\n  exampleIds?: string;\n  exampleLangs?: string;\n}\n\nconst NotionDialogText = styled.div`\n  font-weight: ${fonts.weight.normal};\n  ${fonts.sizes(\"18px\", 1.3)};\n  color: ${colors.text.primary};\n  font-family: ${fonts.sans};\n`;\n\nconst NotionDialogContent = styled.div`\n  padding-bottom: ${spacing.normal};\n  display: flex;\n  flex-direction: column;\n`;\n\nconst ContentSpacing = styled.div`\n  padding: ${spacing.normal};\n  &[data-is-concept=\"false\"] {\n    margin-bottom: ${spacing.normal};\n  }\n`;\n\nconst notionContentCss = css`\n  @keyframes animateIn {\n    0% {\n      opacity: 0;\n      transform: translate3d(0, -13px, 0);\n    }\n    100% {\n      opacity: 1;\n      transform: translate3d(0, 0, 0);\n    }\n  }\n\n  animation-name: animateIn;\n  animation-duration: 300ms;\n  background-color: white;\n  z-index: ${stackOrder.offsetSingle};\n  box-shadow: 0 0 30px rgba(0, 0, 0, 0.2);\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 500px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 720px;\n  }\n\n  ${mq.range({ until: breakpoints.tablet })} {\n    padding: ${spacing.small};\n    z-index: ${stackOrder.popover};\n    height: 100%;\n    width: 100%;\n    overflow: auto;\n  }\n`;\n\nconst NotionHeader = styled.div`\n  display: flex;\n  align-items: center;\n  justify-content: flex-end;\n  border-bottom: 2px solid ${colors.brand.tertiary};\n  padding-bottom: ${spacing.small};\n  h1 {\n    flex-grow: 1;\n    margin: 0;\n    font-weight: ${fonts.weight.bold};\n    ${fonts.sizes(\"22px\", 1.2)};\n  }\n  small {\n    &[data-is-concept=\"true\"] {\n      border-left: 1px solid ${colors.brand.greyLight};\n      padding-left: ${spacing.small};\n      margin-left: ${spacing.xsmall};\n    }\n    ${fonts.sizes(\"20px\", 1.2)};\n    font-weight: ${fonts.weight.normal};\n  }\n  &[data-is-concept=\"false\"] {\n    margin-bottom: ${spacing.large};\n  }\n`;\n\nconst ListWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n`;\n\nconst StyledNotionDialogContent = styled(NotionDialogContent)`\n  padding-top: ${spacing.small};\n  .c-figure {\n    left: unset !important;\n    width: 100% !important;\n    padding: 0;\n    margin: 0;\n    padding-bottom: ${spacing.normal};\n  }\n`;\n\nconst ButtonWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  align-items: center;\n`;\n\nconst StyledList = styled.ul`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n  list-style: none;\n  > li {\n    font-family: ${fonts.sans};\n    font-weight: ${fonts.weight.semibold};\n    border-radius: ${misc.borderRadius};\n    background-color: ${colors.brand.greyLightest};\n    ${fonts.sizes(\"12px\", 1.2)};\n    padding: ${spacing.xxsmall};\n  }\n`;\n\nexport const ConceptNotionV2 = forwardRef<HTMLDivElement, ConceptNotionProps>(\n  (\n    {\n      visualElement,\n      title,\n      content,\n      source,\n      copyright,\n      closeButton,\n      inPopover,\n      previewAlt,\n      tags,\n      subjects,\n      heartButton,\n      conceptHeartButton,\n      conceptType,\n      glossData,\n      headerButtons,\n      lang,\n      exampleIds,\n      exampleLangs,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t } = useTranslation();\n    const isConcept = conceptType === \"concept\";\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <ContentSpacing data-is-concept={isConcept}>\n          <NotionHeader data-is-concept={isConcept}>\n            <h1>\n              {isConcept && title.title}\n              {<small data-is-concept={isConcept}>{t(`searchPage.resultType.${conceptType}`)}</small>}\n            </h1>\n            <ButtonWrapper>\n              {headerButtons}\n              {closeButton}\n            </ButtonWrapper>\n          </NotionHeader>\n          {isConcept ? (\n            <>\n              <StyledNotionDialogContent>\n                {visualElement?.resource === \"image\" ? (\n                  <ImageEmbed embed={visualElement} heartButton={heartButton} lang={lang} />\n                ) : visualElement?.resource === \"brightcove\" ? (\n                  <BrightcoveEmbed embed={visualElement} heartButton={heartButton} />\n                ) : visualElement?.resource === \"h5p\" ? (\n                  <H5pEmbed embed={visualElement} />\n                ) : visualElement?.resource === \"iframe\" ? (\n                  <IframeEmbed embed={visualElement} />\n                ) : visualElement?.resource === \"external\" ? (\n                  <ExternalEmbed embed={visualElement} />\n                ) : null}\n                {content && <NotionDialogText lang={lang}>{content}</NotionDialogText>}\n              </StyledNotionDialogContent>\n              {tags && (\n                <ListWrapper>\n                  {`${t(\"notions.tags\")}:`}\n                  <StyledList>\n                    {tags.map((tag, index) => (\n                      <li key={index}>{tag}</li>\n                    ))}\n                  </StyledList>\n                </ListWrapper>\n              )}\n              {subjects && (\n                <ListWrapper>\n                  {`${t(\"notions.usedIn\")}:`}\n                  <StyledList>\n                    {subjects.map((subject, index) => (\n                      <li key={index}>{subject}</li>\n                    ))}\n                  </StyledList>\n                </ListWrapper>\n              )}\n            </>\n          ) : (\n            <Gloss\n              title={title}\n              glossData={glossData!}\n              audio={\n                visualElement?.status === \"success\" && visualElement.resource === \"audio\"\n                  ? {\n                      src: visualElement.data.audioFile.url,\n                      title: visualElement.data.title.title,\n                    }\n                  : undefined\n              }\n              exampleIds={exampleIds}\n              exampleLangs={exampleLangs}\n            />\n          )}\n        </ContentSpacing>\n        {copyright && (\n          <EmbedByline copyright={copyright} type={conceptType as ConceptType}>\n            {copyright.license?.license.toLowerCase() !== COPYRIGHTED && conceptHeartButton}\n          </EmbedByline>\n        )}\n      </div>\n    );\n  },\n);\n"]} */"));
|
|
54
|
+
})("padding-top:", spacing.small, ";.c-figure{left:unset!important;width:100%!important;padding:0;margin:0;padding-bottom:", spacing.normal, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["conceptComponents.tsx"],"names":[],"mappings":"AA2I6D","file":"conceptComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2023-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 { forwardRef, ReactNode, RefAttributes } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, fonts, misc, mq, spacing, stackOrder } from \"@ndla/core\";\nimport { COPYRIGHTED } from \"@ndla/licenses\";\nimport { ConceptData, ConceptVisualElementMeta } from \"@ndla/types-embed\";\nimport { ExternalEmbed, HeartButtonType, IframeEmbed } from \".\";\nimport BrightcoveEmbed from \"./BrightcoveEmbed\";\nimport H5pEmbed from \"./H5pEmbed\";\nimport ImageEmbed from \"./ImageEmbed\";\nimport { Gloss } from \"../Gloss\";\nimport { EmbedByline } from \"../LicenseByline\";\nimport { Copyright } from \"../types\";\n\nexport type ConceptType = \"concept\" | \"gloss\";\n\nexport interface ConceptNotionData {\n  title: ConceptData[\"concept\"][\"title\"];\n  content?: ReactNode;\n  metaImage?: {\n    url?: string;\n    alt?: string;\n  };\n  copyright?: Copyright;\n  source?: string;\n  visualElement?: ConceptVisualElementMeta;\n  conceptType: ConceptData[\"concept\"][\"conceptType\"];\n  glossData?: ConceptData[\"concept\"][\"glossData\"];\n  lang?: string;\n}\n\ninterface ConceptNotionProps extends RefAttributes<HTMLDivElement>, Omit<ConceptNotionData, \"metaImage\"> {\n  className?: string;\n  closeButton?: ReactNode;\n  previewAlt?: boolean;\n  inPopover?: boolean;\n  tags?: string[];\n  subjects?: string[];\n  headerButtons?: ReactNode;\n  heartButton?: HeartButtonType;\n  conceptHeartButton?: ReactNode;\n  exampleIds?: string;\n  exampleLangs?: string;\n}\n\nconst NotionDialogText = styled.div`\n  font-weight: ${fonts.weight.normal};\n  ${fonts.sizes(\"18px\", 1.3)};\n  color: ${colors.text.primary};\n  font-family: ${fonts.sans};\n`;\n\nconst NotionDialogContent = styled.div`\n  padding-bottom: ${spacing.normal};\n  display: flex;\n  flex-direction: column;\n`;\n\nconst ContentSpacing = styled.div`\n  padding: ${spacing.normal};\n  &[data-is-concept=\"false\"] {\n    margin-bottom: ${spacing.normal};\n  }\n`;\n\nconst notionContentCss = css`\n  @keyframes animateIn {\n    0% {\n      opacity: 0;\n      transform: translate3d(0, -13px, 0);\n    }\n    100% {\n      opacity: 1;\n      transform: translate3d(0, 0, 0);\n    }\n  }\n\n  animation-name: animateIn;\n  animation-duration: 300ms;\n  background-color: white;\n  z-index: ${stackOrder.offsetSingle};\n  box-shadow: 0 0 30px rgba(0, 0, 0, 0.2);\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 500px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 720px;\n  }\n\n  ${mq.range({ until: breakpoints.tablet })} {\n    padding: ${spacing.small};\n    z-index: ${stackOrder.popover};\n    height: 100%;\n    width: 100%;\n    overflow: auto;\n  }\n`;\n\nconst NotionHeader = styled.div`\n  display: flex;\n  align-items: center;\n  justify-content: flex-end;\n  border-bottom: 2px solid ${colors.brand.tertiary};\n  padding-bottom: ${spacing.small};\n  h1 {\n    flex-grow: 1;\n    margin: 0;\n    font-weight: ${fonts.weight.bold};\n    ${fonts.sizes(\"22px\", 1.2)};\n  }\n  small {\n    &[data-is-concept=\"true\"] {\n      border-left: 1px solid ${colors.brand.greyLight};\n      padding-left: ${spacing.small};\n      margin-left: ${spacing.xsmall};\n    }\n    ${fonts.sizes(\"20px\", 1.2)};\n    font-weight: ${fonts.weight.normal};\n  }\n  &[data-is-concept=\"false\"] {\n    margin-bottom: ${spacing.large};\n  }\n`;\n\nconst ListWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n`;\n\nconst StyledNotionDialogContent = styled(NotionDialogContent)`\n  padding-top: ${spacing.small};\n  .c-figure {\n    left: unset !important;\n    width: 100% !important;\n    padding: 0;\n    margin: 0;\n    padding-bottom: ${spacing.normal};\n  }\n`;\n\nconst ButtonWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  align-items: center;\n`;\n\nconst StyledList = styled.ul`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n  list-style: none;\n  > li {\n    font-family: ${fonts.sans};\n    font-weight: ${fonts.weight.semibold};\n    border-radius: ${misc.borderRadius};\n    background-color: ${colors.brand.greyLightest};\n    ${fonts.sizes(\"12px\", 1.2)};\n    padding: ${spacing.xxsmall};\n  }\n`;\n\nexport const ConceptNotionV2 = forwardRef<HTMLDivElement, ConceptNotionProps>(\n  (\n    {\n      visualElement,\n      title,\n      content,\n      source,\n      copyright,\n      closeButton,\n      inPopover,\n      previewAlt,\n      tags,\n      subjects,\n      heartButton,\n      conceptHeartButton,\n      conceptType,\n      glossData,\n      headerButtons,\n      lang,\n      exampleIds,\n      exampleLangs,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t } = useTranslation();\n    const isConcept = conceptType === \"concept\";\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <ContentSpacing data-is-concept={isConcept}>\n          <NotionHeader data-is-concept={isConcept}>\n            <h1>\n              {isConcept && title.title}\n              {<small data-is-concept={isConcept}>{t(`searchPage.resultType.${conceptType}`)}</small>}\n            </h1>\n            <ButtonWrapper>\n              {headerButtons}\n              {closeButton}\n            </ButtonWrapper>\n          </NotionHeader>\n          {isConcept ? (\n            <>\n              <StyledNotionDialogContent>\n                {visualElement?.resource === \"image\" ? (\n                  <ImageEmbed embed={visualElement} heartButton={heartButton} lang={lang} />\n                ) : visualElement?.resource === \"brightcove\" ? (\n                  <BrightcoveEmbed embed={visualElement} heartButton={heartButton} />\n                ) : visualElement?.resource === \"h5p\" ? (\n                  <H5pEmbed embed={visualElement} />\n                ) : visualElement?.resource === \"iframe\" ? (\n                  <IframeEmbed embed={visualElement} />\n                ) : visualElement?.resource === \"external\" ? (\n                  <ExternalEmbed embed={visualElement} />\n                ) : null}\n                {content && <NotionDialogText lang={lang}>{content}</NotionDialogText>}\n              </StyledNotionDialogContent>\n              {tags && (\n                <ListWrapper>\n                  {`${t(\"notions.tags\")}:`}\n                  <StyledList>\n                    {tags.map((tag, index) => (\n                      <li key={index}>{tag}</li>\n                    ))}\n                  </StyledList>\n                </ListWrapper>\n              )}\n              {subjects && (\n                <ListWrapper>\n                  {`${t(\"notions.usedIn\")}:`}\n                  <StyledList>\n                    {subjects.map((subject, index) => (\n                      <li key={index}>{subject}</li>\n                    ))}\n                  </StyledList>\n                </ListWrapper>\n              )}\n            </>\n          ) : (\n            <Gloss\n              title={title}\n              glossData={glossData!}\n              audio={\n                visualElement?.status === \"success\" && visualElement.resource === \"audio\"\n                  ? {\n                      src: visualElement.data.audioFile.url,\n                      title: visualElement.data.title.title,\n                    }\n                  : undefined\n              }\n              exampleIds={exampleIds}\n              exampleLangs={exampleLangs}\n            />\n          )}\n        </ContentSpacing>\n        {copyright && (\n          <EmbedByline copyright={copyright} type={conceptType as ConceptType}>\n            {copyright.license?.license.toLowerCase() !== COPYRIGHTED && conceptHeartButton}\n          </EmbedByline>\n        )}\n      </div>\n    );\n  },\n);\n"]} */"));
|
|
55
55
|
const ButtonWrapper = /*#__PURE__*/_styled("div", {
|
|
56
56
|
target: "eqcj3r1",
|
|
57
57
|
label: "ButtonWrapper"
|
|
58
|
-
})("display:flex;gap:", spacing.xsmall, ";align-items:center;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["conceptComponents.tsx"],"names":[],"mappings":"AAsJgC","file":"conceptComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2023-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 { forwardRef, ReactNode, RefAttributes } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, fonts, misc, mq, spacing, stackOrder } from \"@ndla/core\";\nimport { COPYRIGHTED } from \"@ndla/licenses\";\nimport { ConceptData, ConceptVisualElementMeta } from \"@ndla/types-embed\";\nimport { ExternalEmbed, HeartButtonType, IframeEmbed } from \".\";\nimport BrightcoveEmbed from \"./BrightcoveEmbed\";\nimport H5pEmbed from \"./H5pEmbed\";\nimport ImageEmbed from \"./ImageEmbed\";\nimport { Gloss } from \"../Gloss\";\nimport { EmbedByline } from \"../LicenseByline\";\nimport { Copyright } from \"../types\";\n\nexport type ConceptType = \"concept\" | \"gloss\";\n\nexport interface ConceptNotionData {\n  title: ConceptData[\"concept\"][\"title\"];\n  content?: ReactNode;\n  metaImage?: {\n    url?: string;\n    alt?: string;\n  };\n  copyright?: Copyright;\n  source?: string;\n  visualElement?: ConceptVisualElementMeta;\n  conceptType: ConceptData[\"concept\"][\"conceptType\"];\n  glossData?: ConceptData[\"concept\"][\"glossData\"];\n  lang?: string;\n}\n\ninterface ConceptNotionProps extends RefAttributes<HTMLDivElement>, ConceptNotionData {\n  className?: string;\n  closeButton?: ReactNode;\n  previewAlt?: boolean;\n  inPopover?: boolean;\n  tags?: string[];\n  subjects?: string[];\n  headerButtons?: ReactNode;\n  heartButton?: HeartButtonType;\n  conceptHeartButton?: ReactNode;\n  exampleIds?: string;\n  exampleLangs?: string;\n}\n\nconst NotionDialogText = styled.div`\n  font-weight: ${fonts.weight.normal};\n  ${fonts.sizes(\"18px\", 1.3)};\n  color: ${colors.text.primary};\n  font-family: ${fonts.sans};\n`;\n\nconst NotionDialogContent = styled.div`\n  padding-bottom: ${spacing.normal};\n  display: flex;\n  flex-direction: column;\n`;\n\nconst ContentSpacing = styled.div`\n  padding: ${spacing.normal};\n  &[data-is-concept=\"false\"] {\n    margin-bottom: ${spacing.normal};\n  }\n`;\n\nconst notionContentCss = css`\n  @keyframes animateIn {\n    0% {\n      opacity: 0;\n      transform: translate3d(0, -13px, 0);\n    }\n    100% {\n      opacity: 1;\n      transform: translate3d(0, 0, 0);\n    }\n  }\n\n  animation-name: animateIn;\n  animation-duration: 300ms;\n  background-color: white;\n  z-index: ${stackOrder.offsetSingle};\n  box-shadow: 0 0 30px rgba(0, 0, 0, 0.2);\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 500px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 720px;\n  }\n\n  ${mq.range({ until: breakpoints.tablet })} {\n    padding: ${spacing.small};\n    z-index: ${stackOrder.popover};\n    height: 100%;\n    width: 100%;\n    overflow: auto;\n  }\n`;\n\nconst NotionHeader = styled.div`\n  display: flex;\n  align-items: center;\n  justify-content: flex-end;\n  border-bottom: 2px solid ${colors.brand.tertiary};\n  padding-bottom: ${spacing.small};\n  h1 {\n    flex-grow: 1;\n    margin: 0;\n    font-weight: ${fonts.weight.bold};\n    ${fonts.sizes(\"22px\", 1.2)};\n  }\n  small {\n    &[data-is-concept=\"true\"] {\n      border-left: 1px solid ${colors.brand.greyLight};\n      padding-left: ${spacing.small};\n      margin-left: ${spacing.xsmall};\n    }\n    ${fonts.sizes(\"20px\", 1.2)};\n    font-weight: ${fonts.weight.normal};\n  }\n  &[data-is-concept=\"false\"] {\n    margin-bottom: ${spacing.large};\n  }\n`;\n\nconst ListWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n`;\n\nconst StyledNotionDialogContent = styled(NotionDialogContent)`\n  padding-top: ${spacing.small};\n  .c-figure {\n    left: unset !important;\n    width: 100% !important;\n    padding: 0;\n    margin: 0;\n    padding-bottom: ${spacing.normal};\n  }\n`;\n\nconst ButtonWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  align-items: center;\n`;\n\nconst StyledList = styled.ul`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n  list-style: none;\n  > li {\n    font-family: ${fonts.sans};\n    font-weight: ${fonts.weight.semibold};\n    border-radius: ${misc.borderRadius};\n    background-color: ${colors.brand.greyLightest};\n    ${fonts.sizes(\"12px\", 1.2)};\n    padding: ${spacing.xxsmall};\n  }\n`;\n\nexport const ConceptNotionV2 = forwardRef<HTMLDivElement, ConceptNotionProps>(\n  (\n    {\n      visualElement,\n      title,\n      content,\n      source,\n      copyright,\n      closeButton,\n      inPopover,\n      previewAlt,\n      tags,\n      subjects,\n      heartButton,\n      conceptHeartButton,\n      conceptType,\n      glossData,\n      headerButtons,\n      lang,\n      exampleIds,\n      exampleLangs,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t } = useTranslation();\n    const isConcept = conceptType === \"concept\";\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <ContentSpacing data-is-concept={isConcept}>\n          <NotionHeader data-is-concept={isConcept}>\n            <h1>\n              {isConcept && title.title}\n              {<small data-is-concept={isConcept}>{t(`searchPage.resultType.${conceptType}`)}</small>}\n            </h1>\n            <ButtonWrapper>\n              {headerButtons}\n              {closeButton}\n            </ButtonWrapper>\n          </NotionHeader>\n          {isConcept ? (\n            <>\n              <StyledNotionDialogContent>\n                {visualElement?.resource === \"image\" ? (\n                  <ImageEmbed embed={visualElement} heartButton={heartButton} lang={lang} />\n                ) : visualElement?.resource === \"brightcove\" ? (\n                  <BrightcoveEmbed embed={visualElement} heartButton={heartButton} />\n                ) : visualElement?.resource === \"h5p\" ? (\n                  <H5pEmbed embed={visualElement} />\n                ) : visualElement?.resource === \"iframe\" ? (\n                  <IframeEmbed embed={visualElement} />\n                ) : visualElement?.resource === \"external\" ? (\n                  <ExternalEmbed embed={visualElement} />\n                ) : null}\n                {content && <NotionDialogText lang={lang}>{content}</NotionDialogText>}\n              </StyledNotionDialogContent>\n              {tags && (\n                <ListWrapper>\n                  {`${t(\"notions.tags\")}:`}\n                  <StyledList>\n                    {tags.map((tag, index) => (\n                      <li key={index}>{tag}</li>\n                    ))}\n                  </StyledList>\n                </ListWrapper>\n              )}\n              {subjects && (\n                <ListWrapper>\n                  {`${t(\"notions.usedIn\")}:`}\n                  <StyledList>\n                    {subjects.map((subject, index) => (\n                      <li key={index}>{subject}</li>\n                    ))}\n                  </StyledList>\n                </ListWrapper>\n              )}\n            </>\n          ) : (\n            <Gloss\n              title={title}\n              glossData={glossData!}\n              audio={\n                visualElement?.status === \"success\" && visualElement.resource === \"audio\"\n                  ? {\n                      src: visualElement.data.audioFile.url,\n                      title: visualElement.data.title.title,\n                    }\n                  : undefined\n              }\n              exampleIds={exampleIds}\n              exampleLangs={exampleLangs}\n            />\n          )}\n        </ContentSpacing>\n        {copyright && (\n          <EmbedByline copyright={copyright} type={conceptType as ConceptType}>\n            {copyright.license?.license.toLowerCase() !== COPYRIGHTED && conceptHeartButton}\n          </EmbedByline>\n        )}\n      </div>\n    );\n  },\n);\n"]} */"));
|
|
58
|
+
})("display:flex;gap:", spacing.xsmall, ";align-items:center;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["conceptComponents.tsx"],"names":[],"mappings":"AAsJgC","file":"conceptComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2023-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 { forwardRef, ReactNode, RefAttributes } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, fonts, misc, mq, spacing, stackOrder } from \"@ndla/core\";\nimport { COPYRIGHTED } from \"@ndla/licenses\";\nimport { ConceptData, ConceptVisualElementMeta } from \"@ndla/types-embed\";\nimport { ExternalEmbed, HeartButtonType, IframeEmbed } from \".\";\nimport BrightcoveEmbed from \"./BrightcoveEmbed\";\nimport H5pEmbed from \"./H5pEmbed\";\nimport ImageEmbed from \"./ImageEmbed\";\nimport { Gloss } from \"../Gloss\";\nimport { EmbedByline } from \"../LicenseByline\";\nimport { Copyright } from \"../types\";\n\nexport type ConceptType = \"concept\" | \"gloss\";\n\nexport interface ConceptNotionData {\n  title: ConceptData[\"concept\"][\"title\"];\n  content?: ReactNode;\n  metaImage?: {\n    url?: string;\n    alt?: string;\n  };\n  copyright?: Copyright;\n  source?: string;\n  visualElement?: ConceptVisualElementMeta;\n  conceptType: ConceptData[\"concept\"][\"conceptType\"];\n  glossData?: ConceptData[\"concept\"][\"glossData\"];\n  lang?: string;\n}\n\ninterface ConceptNotionProps extends RefAttributes<HTMLDivElement>, Omit<ConceptNotionData, \"metaImage\"> {\n  className?: string;\n  closeButton?: ReactNode;\n  previewAlt?: boolean;\n  inPopover?: boolean;\n  tags?: string[];\n  subjects?: string[];\n  headerButtons?: ReactNode;\n  heartButton?: HeartButtonType;\n  conceptHeartButton?: ReactNode;\n  exampleIds?: string;\n  exampleLangs?: string;\n}\n\nconst NotionDialogText = styled.div`\n  font-weight: ${fonts.weight.normal};\n  ${fonts.sizes(\"18px\", 1.3)};\n  color: ${colors.text.primary};\n  font-family: ${fonts.sans};\n`;\n\nconst NotionDialogContent = styled.div`\n  padding-bottom: ${spacing.normal};\n  display: flex;\n  flex-direction: column;\n`;\n\nconst ContentSpacing = styled.div`\n  padding: ${spacing.normal};\n  &[data-is-concept=\"false\"] {\n    margin-bottom: ${spacing.normal};\n  }\n`;\n\nconst notionContentCss = css`\n  @keyframes animateIn {\n    0% {\n      opacity: 0;\n      transform: translate3d(0, -13px, 0);\n    }\n    100% {\n      opacity: 1;\n      transform: translate3d(0, 0, 0);\n    }\n  }\n\n  animation-name: animateIn;\n  animation-duration: 300ms;\n  background-color: white;\n  z-index: ${stackOrder.offsetSingle};\n  box-shadow: 0 0 30px rgba(0, 0, 0, 0.2);\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 500px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 720px;\n  }\n\n  ${mq.range({ until: breakpoints.tablet })} {\n    padding: ${spacing.small};\n    z-index: ${stackOrder.popover};\n    height: 100%;\n    width: 100%;\n    overflow: auto;\n  }\n`;\n\nconst NotionHeader = styled.div`\n  display: flex;\n  align-items: center;\n  justify-content: flex-end;\n  border-bottom: 2px solid ${colors.brand.tertiary};\n  padding-bottom: ${spacing.small};\n  h1 {\n    flex-grow: 1;\n    margin: 0;\n    font-weight: ${fonts.weight.bold};\n    ${fonts.sizes(\"22px\", 1.2)};\n  }\n  small {\n    &[data-is-concept=\"true\"] {\n      border-left: 1px solid ${colors.brand.greyLight};\n      padding-left: ${spacing.small};\n      margin-left: ${spacing.xsmall};\n    }\n    ${fonts.sizes(\"20px\", 1.2)};\n    font-weight: ${fonts.weight.normal};\n  }\n  &[data-is-concept=\"false\"] {\n    margin-bottom: ${spacing.large};\n  }\n`;\n\nconst ListWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n`;\n\nconst StyledNotionDialogContent = styled(NotionDialogContent)`\n  padding-top: ${spacing.small};\n  .c-figure {\n    left: unset !important;\n    width: 100% !important;\n    padding: 0;\n    margin: 0;\n    padding-bottom: ${spacing.normal};\n  }\n`;\n\nconst ButtonWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  align-items: center;\n`;\n\nconst StyledList = styled.ul`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n  list-style: none;\n  > li {\n    font-family: ${fonts.sans};\n    font-weight: ${fonts.weight.semibold};\n    border-radius: ${misc.borderRadius};\n    background-color: ${colors.brand.greyLightest};\n    ${fonts.sizes(\"12px\", 1.2)};\n    padding: ${spacing.xxsmall};\n  }\n`;\n\nexport const ConceptNotionV2 = forwardRef<HTMLDivElement, ConceptNotionProps>(\n  (\n    {\n      visualElement,\n      title,\n      content,\n      source,\n      copyright,\n      closeButton,\n      inPopover,\n      previewAlt,\n      tags,\n      subjects,\n      heartButton,\n      conceptHeartButton,\n      conceptType,\n      glossData,\n      headerButtons,\n      lang,\n      exampleIds,\n      exampleLangs,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t } = useTranslation();\n    const isConcept = conceptType === \"concept\";\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <ContentSpacing data-is-concept={isConcept}>\n          <NotionHeader data-is-concept={isConcept}>\n            <h1>\n              {isConcept && title.title}\n              {<small data-is-concept={isConcept}>{t(`searchPage.resultType.${conceptType}`)}</small>}\n            </h1>\n            <ButtonWrapper>\n              {headerButtons}\n              {closeButton}\n            </ButtonWrapper>\n          </NotionHeader>\n          {isConcept ? (\n            <>\n              <StyledNotionDialogContent>\n                {visualElement?.resource === \"image\" ? (\n                  <ImageEmbed embed={visualElement} heartButton={heartButton} lang={lang} />\n                ) : visualElement?.resource === \"brightcove\" ? (\n                  <BrightcoveEmbed embed={visualElement} heartButton={heartButton} />\n                ) : visualElement?.resource === \"h5p\" ? (\n                  <H5pEmbed embed={visualElement} />\n                ) : visualElement?.resource === \"iframe\" ? (\n                  <IframeEmbed embed={visualElement} />\n                ) : visualElement?.resource === \"external\" ? (\n                  <ExternalEmbed embed={visualElement} />\n                ) : null}\n                {content && <NotionDialogText lang={lang}>{content}</NotionDialogText>}\n              </StyledNotionDialogContent>\n              {tags && (\n                <ListWrapper>\n                  {`${t(\"notions.tags\")}:`}\n                  <StyledList>\n                    {tags.map((tag, index) => (\n                      <li key={index}>{tag}</li>\n                    ))}\n                  </StyledList>\n                </ListWrapper>\n              )}\n              {subjects && (\n                <ListWrapper>\n                  {`${t(\"notions.usedIn\")}:`}\n                  <StyledList>\n                    {subjects.map((subject, index) => (\n                      <li key={index}>{subject}</li>\n                    ))}\n                  </StyledList>\n                </ListWrapper>\n              )}\n            </>\n          ) : (\n            <Gloss\n              title={title}\n              glossData={glossData!}\n              audio={\n                visualElement?.status === \"success\" && visualElement.resource === \"audio\"\n                  ? {\n                      src: visualElement.data.audioFile.url,\n                      title: visualElement.data.title.title,\n                    }\n                  : undefined\n              }\n              exampleIds={exampleIds}\n              exampleLangs={exampleLangs}\n            />\n          )}\n        </ContentSpacing>\n        {copyright && (\n          <EmbedByline copyright={copyright} type={conceptType as ConceptType}>\n            {copyright.license?.license.toLowerCase() !== COPYRIGHTED && conceptHeartButton}\n          </EmbedByline>\n        )}\n      </div>\n    );\n  },\n);\n"]} */"));
|
|
59
59
|
const StyledList = /*#__PURE__*/_styled("ul", {
|
|
60
60
|
target: "eqcj3r0",
|
|
61
61
|
label: "StyledList"
|
|
62
|
-
})("display:flex;gap:", spacing.small, ";align-items:center;list-style:none;>li{font-family:", fonts.sans, ";font-weight:", fonts.weight.semibold, ";border-radius:", misc.borderRadius, ";background-color:", colors.brand.greyLightest, ";", fonts.sizes("12px", 1.2), ";padding:", spacing.xxsmall, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["conceptComponents.tsx"],"names":[],"mappings":"AA4J4B","file":"conceptComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2023-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 { forwardRef, ReactNode, RefAttributes } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, fonts, misc, mq, spacing, stackOrder } from \"@ndla/core\";\nimport { COPYRIGHTED } from \"@ndla/licenses\";\nimport { ConceptData, ConceptVisualElementMeta } from \"@ndla/types-embed\";\nimport { ExternalEmbed, HeartButtonType, IframeEmbed } from \".\";\nimport BrightcoveEmbed from \"./BrightcoveEmbed\";\nimport H5pEmbed from \"./H5pEmbed\";\nimport ImageEmbed from \"./ImageEmbed\";\nimport { Gloss } from \"../Gloss\";\nimport { EmbedByline } from \"../LicenseByline\";\nimport { Copyright } from \"../types\";\n\nexport type ConceptType = \"concept\" | \"gloss\";\n\nexport interface ConceptNotionData {\n  title: ConceptData[\"concept\"][\"title\"];\n  content?: ReactNode;\n  metaImage?: {\n    url?: string;\n    alt?: string;\n  };\n  copyright?: Copyright;\n  source?: string;\n  visualElement?: ConceptVisualElementMeta;\n  conceptType: ConceptData[\"concept\"][\"conceptType\"];\n  glossData?: ConceptData[\"concept\"][\"glossData\"];\n  lang?: string;\n}\n\ninterface ConceptNotionProps extends RefAttributes<HTMLDivElement>, ConceptNotionData {\n  className?: string;\n  closeButton?: ReactNode;\n  previewAlt?: boolean;\n  inPopover?: boolean;\n  tags?: string[];\n  subjects?: string[];\n  headerButtons?: ReactNode;\n  heartButton?: HeartButtonType;\n  conceptHeartButton?: ReactNode;\n  exampleIds?: string;\n  exampleLangs?: string;\n}\n\nconst NotionDialogText = styled.div`\n  font-weight: ${fonts.weight.normal};\n  ${fonts.sizes(\"18px\", 1.3)};\n  color: ${colors.text.primary};\n  font-family: ${fonts.sans};\n`;\n\nconst NotionDialogContent = styled.div`\n  padding-bottom: ${spacing.normal};\n  display: flex;\n  flex-direction: column;\n`;\n\nconst ContentSpacing = styled.div`\n  padding: ${spacing.normal};\n  &[data-is-concept=\"false\"] {\n    margin-bottom: ${spacing.normal};\n  }\n`;\n\nconst notionContentCss = css`\n  @keyframes animateIn {\n    0% {\n      opacity: 0;\n      transform: translate3d(0, -13px, 0);\n    }\n    100% {\n      opacity: 1;\n      transform: translate3d(0, 0, 0);\n    }\n  }\n\n  animation-name: animateIn;\n  animation-duration: 300ms;\n  background-color: white;\n  z-index: ${stackOrder.offsetSingle};\n  box-shadow: 0 0 30px rgba(0, 0, 0, 0.2);\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 500px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 720px;\n  }\n\n  ${mq.range({ until: breakpoints.tablet })} {\n    padding: ${spacing.small};\n    z-index: ${stackOrder.popover};\n    height: 100%;\n    width: 100%;\n    overflow: auto;\n  }\n`;\n\nconst NotionHeader = styled.div`\n  display: flex;\n  align-items: center;\n  justify-content: flex-end;\n  border-bottom: 2px solid ${colors.brand.tertiary};\n  padding-bottom: ${spacing.small};\n  h1 {\n    flex-grow: 1;\n    margin: 0;\n    font-weight: ${fonts.weight.bold};\n    ${fonts.sizes(\"22px\", 1.2)};\n  }\n  small {\n    &[data-is-concept=\"true\"] {\n      border-left: 1px solid ${colors.brand.greyLight};\n      padding-left: ${spacing.small};\n      margin-left: ${spacing.xsmall};\n    }\n    ${fonts.sizes(\"20px\", 1.2)};\n    font-weight: ${fonts.weight.normal};\n  }\n  &[data-is-concept=\"false\"] {\n    margin-bottom: ${spacing.large};\n  }\n`;\n\nconst ListWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n`;\n\nconst StyledNotionDialogContent = styled(NotionDialogContent)`\n  padding-top: ${spacing.small};\n  .c-figure {\n    left: unset !important;\n    width: 100% !important;\n    padding: 0;\n    margin: 0;\n    padding-bottom: ${spacing.normal};\n  }\n`;\n\nconst ButtonWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  align-items: center;\n`;\n\nconst StyledList = styled.ul`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n  list-style: none;\n  > li {\n    font-family: ${fonts.sans};\n    font-weight: ${fonts.weight.semibold};\n    border-radius: ${misc.borderRadius};\n    background-color: ${colors.brand.greyLightest};\n    ${fonts.sizes(\"12px\", 1.2)};\n    padding: ${spacing.xxsmall};\n  }\n`;\n\nexport const ConceptNotionV2 = forwardRef<HTMLDivElement, ConceptNotionProps>(\n  (\n    {\n      visualElement,\n      title,\n      content,\n      source,\n      copyright,\n      closeButton,\n      inPopover,\n      previewAlt,\n      tags,\n      subjects,\n      heartButton,\n      conceptHeartButton,\n      conceptType,\n      glossData,\n      headerButtons,\n      lang,\n      exampleIds,\n      exampleLangs,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t } = useTranslation();\n    const isConcept = conceptType === \"concept\";\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <ContentSpacing data-is-concept={isConcept}>\n          <NotionHeader data-is-concept={isConcept}>\n            <h1>\n              {isConcept && title.title}\n              {<small data-is-concept={isConcept}>{t(`searchPage.resultType.${conceptType}`)}</small>}\n            </h1>\n            <ButtonWrapper>\n              {headerButtons}\n              {closeButton}\n            </ButtonWrapper>\n          </NotionHeader>\n          {isConcept ? (\n            <>\n              <StyledNotionDialogContent>\n                {visualElement?.resource === \"image\" ? (\n                  <ImageEmbed embed={visualElement} heartButton={heartButton} lang={lang} />\n                ) : visualElement?.resource === \"brightcove\" ? (\n                  <BrightcoveEmbed embed={visualElement} heartButton={heartButton} />\n                ) : visualElement?.resource === \"h5p\" ? (\n                  <H5pEmbed embed={visualElement} />\n                ) : visualElement?.resource === \"iframe\" ? (\n                  <IframeEmbed embed={visualElement} />\n                ) : visualElement?.resource === \"external\" ? (\n                  <ExternalEmbed embed={visualElement} />\n                ) : null}\n                {content && <NotionDialogText lang={lang}>{content}</NotionDialogText>}\n              </StyledNotionDialogContent>\n              {tags && (\n                <ListWrapper>\n                  {`${t(\"notions.tags\")}:`}\n                  <StyledList>\n                    {tags.map((tag, index) => (\n                      <li key={index}>{tag}</li>\n                    ))}\n                  </StyledList>\n                </ListWrapper>\n              )}\n              {subjects && (\n                <ListWrapper>\n                  {`${t(\"notions.usedIn\")}:`}\n                  <StyledList>\n                    {subjects.map((subject, index) => (\n                      <li key={index}>{subject}</li>\n                    ))}\n                  </StyledList>\n                </ListWrapper>\n              )}\n            </>\n          ) : (\n            <Gloss\n              title={title}\n              glossData={glossData!}\n              audio={\n                visualElement?.status === \"success\" && visualElement.resource === \"audio\"\n                  ? {\n                      src: visualElement.data.audioFile.url,\n                      title: visualElement.data.title.title,\n                    }\n                  : undefined\n              }\n              exampleIds={exampleIds}\n              exampleLangs={exampleLangs}\n            />\n          )}\n        </ContentSpacing>\n        {copyright && (\n          <EmbedByline copyright={copyright} type={conceptType as ConceptType}>\n            {copyright.license?.license.toLowerCase() !== COPYRIGHTED && conceptHeartButton}\n          </EmbedByline>\n        )}\n      </div>\n    );\n  },\n);\n"]} */"));
|
|
62
|
+
})("display:flex;gap:", spacing.small, ";align-items:center;list-style:none;>li{font-family:", fonts.sans, ";font-weight:", fonts.weight.semibold, ";border-radius:", misc.borderRadius, ";background-color:", colors.brand.greyLightest, ";", fonts.sizes("12px", 1.2), ";padding:", spacing.xxsmall, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["conceptComponents.tsx"],"names":[],"mappings":"AA4J4B","file":"conceptComponents.tsx","sourcesContent":["/**\n * Copyright (c) 2023-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 { forwardRef, ReactNode, RefAttributes } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, fonts, misc, mq, spacing, stackOrder } from \"@ndla/core\";\nimport { COPYRIGHTED } from \"@ndla/licenses\";\nimport { ConceptData, ConceptVisualElementMeta } from \"@ndla/types-embed\";\nimport { ExternalEmbed, HeartButtonType, IframeEmbed } from \".\";\nimport BrightcoveEmbed from \"./BrightcoveEmbed\";\nimport H5pEmbed from \"./H5pEmbed\";\nimport ImageEmbed from \"./ImageEmbed\";\nimport { Gloss } from \"../Gloss\";\nimport { EmbedByline } from \"../LicenseByline\";\nimport { Copyright } from \"../types\";\n\nexport type ConceptType = \"concept\" | \"gloss\";\n\nexport interface ConceptNotionData {\n  title: ConceptData[\"concept\"][\"title\"];\n  content?: ReactNode;\n  metaImage?: {\n    url?: string;\n    alt?: string;\n  };\n  copyright?: Copyright;\n  source?: string;\n  visualElement?: ConceptVisualElementMeta;\n  conceptType: ConceptData[\"concept\"][\"conceptType\"];\n  glossData?: ConceptData[\"concept\"][\"glossData\"];\n  lang?: string;\n}\n\ninterface ConceptNotionProps extends RefAttributes<HTMLDivElement>, Omit<ConceptNotionData, \"metaImage\"> {\n  className?: string;\n  closeButton?: ReactNode;\n  previewAlt?: boolean;\n  inPopover?: boolean;\n  tags?: string[];\n  subjects?: string[];\n  headerButtons?: ReactNode;\n  heartButton?: HeartButtonType;\n  conceptHeartButton?: ReactNode;\n  exampleIds?: string;\n  exampleLangs?: string;\n}\n\nconst NotionDialogText = styled.div`\n  font-weight: ${fonts.weight.normal};\n  ${fonts.sizes(\"18px\", 1.3)};\n  color: ${colors.text.primary};\n  font-family: ${fonts.sans};\n`;\n\nconst NotionDialogContent = styled.div`\n  padding-bottom: ${spacing.normal};\n  display: flex;\n  flex-direction: column;\n`;\n\nconst ContentSpacing = styled.div`\n  padding: ${spacing.normal};\n  &[data-is-concept=\"false\"] {\n    margin-bottom: ${spacing.normal};\n  }\n`;\n\nconst notionContentCss = css`\n  @keyframes animateIn {\n    0% {\n      opacity: 0;\n      transform: translate3d(0, -13px, 0);\n    }\n    100% {\n      opacity: 1;\n      transform: translate3d(0, 0, 0);\n    }\n  }\n\n  animation-name: animateIn;\n  animation-duration: 300ms;\n  background-color: white;\n  z-index: ${stackOrder.offsetSingle};\n  box-shadow: 0 0 30px rgba(0, 0, 0, 0.2);\n  ${mq.range({ from: breakpoints.tablet })} {\n    width: 500px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    width: 720px;\n  }\n\n  ${mq.range({ until: breakpoints.tablet })} {\n    padding: ${spacing.small};\n    z-index: ${stackOrder.popover};\n    height: 100%;\n    width: 100%;\n    overflow: auto;\n  }\n`;\n\nconst NotionHeader = styled.div`\n  display: flex;\n  align-items: center;\n  justify-content: flex-end;\n  border-bottom: 2px solid ${colors.brand.tertiary};\n  padding-bottom: ${spacing.small};\n  h1 {\n    flex-grow: 1;\n    margin: 0;\n    font-weight: ${fonts.weight.bold};\n    ${fonts.sizes(\"22px\", 1.2)};\n  }\n  small {\n    &[data-is-concept=\"true\"] {\n      border-left: 1px solid ${colors.brand.greyLight};\n      padding-left: ${spacing.small};\n      margin-left: ${spacing.xsmall};\n    }\n    ${fonts.sizes(\"20px\", 1.2)};\n    font-weight: ${fonts.weight.normal};\n  }\n  &[data-is-concept=\"false\"] {\n    margin-bottom: ${spacing.large};\n  }\n`;\n\nconst ListWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n`;\n\nconst StyledNotionDialogContent = styled(NotionDialogContent)`\n  padding-top: ${spacing.small};\n  .c-figure {\n    left: unset !important;\n    width: 100% !important;\n    padding: 0;\n    margin: 0;\n    padding-bottom: ${spacing.normal};\n  }\n`;\n\nconst ButtonWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.xsmall};\n  align-items: center;\n`;\n\nconst StyledList = styled.ul`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n  list-style: none;\n  > li {\n    font-family: ${fonts.sans};\n    font-weight: ${fonts.weight.semibold};\n    border-radius: ${misc.borderRadius};\n    background-color: ${colors.brand.greyLightest};\n    ${fonts.sizes(\"12px\", 1.2)};\n    padding: ${spacing.xxsmall};\n  }\n`;\n\nexport const ConceptNotionV2 = forwardRef<HTMLDivElement, ConceptNotionProps>(\n  (\n    {\n      visualElement,\n      title,\n      content,\n      source,\n      copyright,\n      closeButton,\n      inPopover,\n      previewAlt,\n      tags,\n      subjects,\n      heartButton,\n      conceptHeartButton,\n      conceptType,\n      glossData,\n      headerButtons,\n      lang,\n      exampleIds,\n      exampleLangs,\n      ...rest\n    },\n    ref,\n  ) => {\n    const { t } = useTranslation();\n    const isConcept = conceptType === \"concept\";\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <ContentSpacing data-is-concept={isConcept}>\n          <NotionHeader data-is-concept={isConcept}>\n            <h1>\n              {isConcept && title.title}\n              {<small data-is-concept={isConcept}>{t(`searchPage.resultType.${conceptType}`)}</small>}\n            </h1>\n            <ButtonWrapper>\n              {headerButtons}\n              {closeButton}\n            </ButtonWrapper>\n          </NotionHeader>\n          {isConcept ? (\n            <>\n              <StyledNotionDialogContent>\n                {visualElement?.resource === \"image\" ? (\n                  <ImageEmbed embed={visualElement} heartButton={heartButton} lang={lang} />\n                ) : visualElement?.resource === \"brightcove\" ? (\n                  <BrightcoveEmbed embed={visualElement} heartButton={heartButton} />\n                ) : visualElement?.resource === \"h5p\" ? (\n                  <H5pEmbed embed={visualElement} />\n                ) : visualElement?.resource === \"iframe\" ? (\n                  <IframeEmbed embed={visualElement} />\n                ) : visualElement?.resource === \"external\" ? (\n                  <ExternalEmbed embed={visualElement} />\n                ) : null}\n                {content && <NotionDialogText lang={lang}>{content}</NotionDialogText>}\n              </StyledNotionDialogContent>\n              {tags && (\n                <ListWrapper>\n                  {`${t(\"notions.tags\")}:`}\n                  <StyledList>\n                    {tags.map((tag, index) => (\n                      <li key={index}>{tag}</li>\n                    ))}\n                  </StyledList>\n                </ListWrapper>\n              )}\n              {subjects && (\n                <ListWrapper>\n                  {`${t(\"notions.usedIn\")}:`}\n                  <StyledList>\n                    {subjects.map((subject, index) => (\n                      <li key={index}>{subject}</li>\n                    ))}\n                  </StyledList>\n                </ListWrapper>\n              )}\n            </>\n          ) : (\n            <Gloss\n              title={title}\n              glossData={glossData!}\n              audio={\n                visualElement?.status === \"success\" && visualElement.resource === \"audio\"\n                  ? {\n                      src: visualElement.data.audioFile.url,\n                      title: visualElement.data.title.title,\n                    }\n                  : undefined\n              }\n              exampleIds={exampleIds}\n              exampleLangs={exampleLangs}\n            />\n          )}\n        </ContentSpacing>\n        {copyright && (\n          <EmbedByline copyright={copyright} type={conceptType as ConceptType}>\n            {copyright.license?.license.toLowerCase() !== COPYRIGHTED && conceptHeartButton}\n          </EmbedByline>\n        )}\n      </div>\n    );\n  },\n);\n"]} */"));
|
|
63
63
|
export const ConceptNotionV2 = /*#__PURE__*/forwardRef((_ref, ref) => {
|
|
64
64
|
let {
|
|
65
65
|
visualElement,
|
|
@@ -13,7 +13,7 @@ import { jsx as _jsx } from "@emotion/react/jsx-runtime";
|
|
|
13
13
|
const StyledFramedContent = /*#__PURE__*/_styled("div", {
|
|
14
14
|
target: "eg9ts460",
|
|
15
15
|
label: "StyledFramedContent"
|
|
16
|
-
})("padding:", spacing.mediumlarge, ";margin:", spacing.large, " 0;border:1px solid ", colors.brand.tertiary, ";overflow:hidden;.c-figure{width:100%!important;left:auto!important;padding:0;&.u-float-right,&.u-float-small-right{width:50%!important;margin-right:0;}&.u-float-left,&.u-float-small-left{width:50%!important;margin-left:0;}}
|
|
16
|
+
})("padding:", spacing.mediumlarge, ";margin:", spacing.large, " 0;border:1px solid ", colors.brand.tertiary, ";overflow:hidden;.c-figure{width:100%!important;left:auto!important;padding:0;&.u-float-right,&.u-float-small-right{width:50%!important;margin-right:0;}&.u-float-left,&.u-float-small-left{width:50%!important;margin-left:0;}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkZyYW1lZENvbnRlbnQudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVlzQyIsImZpbGUiOiJGcmFtZWRDb250ZW50LnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDIzLXByZXNlbnQsIE5ETEEuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgR1BMdjMgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqXG4gKi9cblxuaW1wb3J0IHsgQ29tcG9uZW50UHJvcHNXaXRoUmVmLCBmb3J3YXJkUmVmIH0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgc3R5bGVkIGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCB7IGNvbG9ycywgc3BhY2luZyB9IGZyb20gXCJAbmRsYS9jb3JlXCI7XG5cbmNvbnN0IFN0eWxlZEZyYW1lZENvbnRlbnQgPSBzdHlsZWQuZGl2YFxuICBwYWRkaW5nOiAke3NwYWNpbmcubWVkaXVtbGFyZ2V9O1xuICBtYXJnaW46ICR7c3BhY2luZy5sYXJnZX0gMDtcbiAgYm9yZGVyOiAxcHggc29saWQgJHtjb2xvcnMuYnJhbmQudGVydGlhcnl9O1xuICBvdmVyZmxvdzogaGlkZGVuO1xuXG4gIC5jLWZpZ3VyZSB7XG4gICAgd2lkdGg6IDEwMCUgIWltcG9ydGFudDtcbiAgICBsZWZ0OiBhdXRvICFpbXBvcnRhbnQ7XG4gICAgcGFkZGluZzogMDtcblxuICAgICYudS1mbG9hdC1yaWdodCxcbiAgICAmLnUtZmxvYXQtc21hbGwtcmlnaHQge1xuICAgICAgd2lkdGg6IDUwJSAhaW1wb3J0YW50O1xuICAgICAgbWFyZ2luLXJpZ2h0OiAwO1xuICAgIH1cblxuICAgICYudS1mbG9hdC1sZWZ0LFxuICAgICYudS1mbG9hdC1zbWFsbC1sZWZ0IHtcbiAgICAgIHdpZHRoOiA1MCUgIWltcG9ydGFudDtcbiAgICAgIG1hcmdpbi1sZWZ0OiAwO1xuICAgIH1cbiAgfVxuYDtcblxuY29uc3QgRnJhbWVkQ29udGVudCA9IGZvcndhcmRSZWY8SFRNTERpdkVsZW1lbnQsIENvbXBvbmVudFByb3BzV2l0aFJlZjxcImRpdlwiPj4oKHsgY2hpbGRyZW4sIC4uLnJlc3QgfSwgcmVmKSA9PiAoXG4gIDxTdHlsZWRGcmFtZWRDb250ZW50IHsuLi5yZXN0fSByZWY9e3JlZn0+XG4gICAge2NoaWxkcmVufVxuICA8L1N0eWxlZEZyYW1lZENvbnRlbnQ+XG4pKTtcblxuZXhwb3J0IGRlZmF1bHQgRnJhbWVkQ29udGVudDtcbiJdfQ== */"));
|
|
17
17
|
const FramedContent = /*#__PURE__*/forwardRef((_ref, ref) => {
|
|
18
18
|
let {
|
|
19
19
|
children,
|
package/es/Layout/LayoutItem.js
CHANGED
|
@@ -18,7 +18,7 @@ export const LayoutItem = _ref => {
|
|
|
18
18
|
if (layout === "extend") {
|
|
19
19
|
return "u-10/12@desktop u-push-1/12@desktop u-10/12@tablet u-push-1/12@tablet";
|
|
20
20
|
} else if (layout === "center") {
|
|
21
|
-
return "u-
|
|
21
|
+
return "u-10/12 u-push-1/12";
|
|
22
22
|
}
|
|
23
23
|
return undefined;
|
|
24
24
|
}, [layout]);
|
package/es/List/UnOrderedList.js
CHANGED
|
@@ -13,7 +13,7 @@ import { jsx as _jsx } from "@emotion/react/jsx-runtime";
|
|
|
13
13
|
const StyledUl = /*#__PURE__*/_styled("ul", {
|
|
14
14
|
target: "engrneb0",
|
|
15
15
|
label: "StyledUl"
|
|
16
|
-
})("padding-left:", spacing.nsmall, ";margin
|
|
16
|
+
})("padding-left:", spacing.nsmall, ";margin:", spacing.normal, " 0 ", spacing.normal, " ", spacing.normal, ";", fonts.size.text.content, ";ul{margin:0;}>li{::marker{color:", colors.brand.secondary, ";}}li{padding-top:0;padding-left:", spacing.nsmall, ";margin-top:", spacing.nsmall, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlVuT3JkZXJlZExpc3QudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVkwQiIsImZpbGUiOiJVbk9yZGVyZWRMaXN0LnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDIyLXByZXNlbnQsIE5ETEEuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgR1BMdjMgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqXG4gKi9cblxuaW1wb3J0IHsgZm9yd2FyZFJlZiwgSFRNTEF0dHJpYnV0ZXMgfSBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCBzdHlsZWQgZnJvbSBcIkBlbW90aW9uL3N0eWxlZFwiO1xuaW1wb3J0IHsgY29sb3JzLCBmb250cywgc3BhY2luZyB9IGZyb20gXCJAbmRsYS9jb3JlXCI7XG5cbmNvbnN0IFN0eWxlZFVsID0gc3R5bGVkLnVsYFxuICBwYWRkaW5nLWxlZnQ6ICR7c3BhY2luZy5uc21hbGx9O1xuICBtYXJnaW46ICR7c3BhY2luZy5ub3JtYWx9IDAgJHtzcGFjaW5nLm5vcm1hbH0gJHtzcGFjaW5nLm5vcm1hbH07XG4gICR7Zm9udHMuc2l6ZS50ZXh0LmNvbnRlbnR9O1xuXG4gIHVsIHtcbiAgICBtYXJnaW46IDA7XG4gIH1cblxuICA+IGxpIHtcbiAgICA6Om1hcmtlciB7XG4gICAgICBjb2xvcjogJHtjb2xvcnMuYnJhbmQuc2Vjb25kYXJ5fTtcbiAgICB9XG4gIH1cbiAgLy8gTGlzdCBpdGVtXG4gIGxpIHtcbiAgICBwYWRkaW5nLXRvcDogMDtcbiAgICBwYWRkaW5nLWxlZnQ6ICR7c3BhY2luZy5uc21hbGx9O1xuICAgIG1hcmdpbi10b3A6ICR7c3BhY2luZy5uc21hbGx9O1xuICB9XG5gO1xuXG5jb25zdCBVbk9yZGVyZWRMaXN0ID0gZm9yd2FyZFJlZjxIVE1MVUxpc3RFbGVtZW50LCBIVE1MQXR0cmlidXRlczxIVE1MVUxpc3RFbGVtZW50Pj4oKHsgY2hpbGRyZW4sIC4uLnJlc3QgfSwgcmVmKSA9PiB7XG4gIHJldHVybiAoXG4gICAgPFN0eWxlZFVsIHJlZj17cmVmfSB7Li4ucmVzdH0+XG4gICAgICB7Y2hpbGRyZW59XG4gICAgPC9TdHlsZWRVbD5cbiAgKTtcbn0pO1xuXG5leHBvcnQgZGVmYXVsdCBVbk9yZGVyZWRMaXN0O1xuIl19 */"));
|
|
17
17
|
const UnOrderedList = /*#__PURE__*/forwardRef((_ref, ref) => {
|
|
18
18
|
let {
|
|
19
19
|
children,
|