@ndla/ui 50.13.0 → 50.13.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/BlogPost/BlogPost.js +6 -6
- package/es/Embed/ConceptEmbed.js +10 -8
- package/es/Embed/conceptComponents.js +11 -10
- package/es/KeyFigure/KeyFigure.js +5 -8
- package/es/locale/messages-nn.js +1 -1
- package/lib/BlogPost/BlogPost.d.ts +1 -4
- package/lib/BlogPost/BlogPost.js +6 -6
- package/lib/CompetenceGoalTab/styles.d.ts +5 -5
- package/lib/Embed/ConceptEmbed.d.ts +3 -2
- package/lib/Embed/ConceptEmbed.js +10 -8
- package/lib/Embed/conceptComponents.d.ts +1 -0
- package/lib/Embed/conceptComponents.js +11 -10
- package/lib/Hero/HeroContent.d.ts +1 -1
- package/lib/KeyFigure/KeyFigure.d.ts +1 -2
- package/lib/KeyFigure/KeyFigure.js +5 -8
- package/lib/NDLAFilm/filmStyles.d.ts +2 -2
- package/lib/Search/ActiveFilterContent.d.ts +1 -1
- package/lib/Search/ContentTypeResultStyles.d.ts +6 -6
- package/lib/SearchTypeResult/ActiveFilterContent.d.ts +1 -1
- package/lib/TagSelector/MenuList.d.ts +1 -1
- package/lib/TagSelector/ValueButton.d.ts +1 -1
- package/lib/locale/messages-nn.js +1 -1
- package/package.json +4 -4
- package/src/BlogPost/BlogPost.stories.tsx +1 -1
- package/src/BlogPost/BlogPost.tsx +4 -6
- package/src/Embed/ConceptEmbed.tsx +4 -3
- package/src/Embed/conceptComponents.tsx +8 -4
- package/src/KeyFigure/KeyFigure.tsx +3 -4
- package/src/locale/messages-nn.ts +1 -1
|
@@ -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>, 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"]} */"));
|
|
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":"AAuDmC","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  showTitle?: boolean;\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      showTitle = true,\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            {showTitle && (\n              <h1>\n                {isConcept && title.title}\n                {<small data-is-concept={isConcept}>{t(`searchPage.resultType.${conceptType}`)}</small>}\n              </h1>\n            )}\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>, 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"]} */"));
|
|
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":"AA8DsC","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  showTitle?: boolean;\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      showTitle = true,\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            {showTitle && (\n              <h1>\n                {isConcept && title.title}\n                {<small data-is-concept={isConcept}>{t(`searchPage.resultType.${conceptType}`)}</small>}\n              </h1>\n            )}\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>, 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"]} */"));
|
|
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":"AAoEiC","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  showTitle?: boolean;\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      showTitle = true,\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            {showTitle && (\n              <h1>\n                {isConcept && title.title}\n                {<small data-is-concept={isConcept}>{t(`searchPage.resultType.${conceptType}`)}</small>}\n              </h1>\n            )}\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>, 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"]} */"));
|
|
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":"AA2E4B","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  showTitle?: boolean;\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      showTitle = true,\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            {showTitle && (\n              <h1>\n                {isConcept && title.title}\n                {<small data-is-concept={isConcept}>{t(`searchPage.resultType.${conceptType}`)}</small>}\n              </h1>\n            )}\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>, 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"]} */"));
|
|
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":"AA4G+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  showTitle?: boolean;\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      showTitle = true,\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            {showTitle && (\n              <h1>\n                {isConcept && title.title}\n                {<small data-is-concept={isConcept}>{t(`searchPage.resultType.${conceptType}`)}</small>}\n              </h1>\n            )}\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>, 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"]} */"));
|
|
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":"AAsI8B","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  showTitle?: boolean;\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      showTitle = true,\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            {showTitle && (\n              <h1>\n                {isConcept && title.title}\n                {<small data-is-concept={isConcept}>{t(`searchPage.resultType.${conceptType}`)}</small>}\n              </h1>\n            )}\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>, 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"]} */"));
|
|
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":"AA4I6D","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  showTitle?: boolean;\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      showTitle = true,\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            {showTitle && (\n              <h1>\n                {isConcept && title.title}\n                {<small data-is-concept={isConcept}>{t(`searchPage.resultType.${conceptType}`)}</small>}\n              </h1>\n            )}\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>, 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"]} */"));
|
|
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":"AAuJgC","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  showTitle?: boolean;\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      showTitle = true,\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            {showTitle && (\n              <h1>\n                {isConcept && title.title}\n                {<small data-is-concept={isConcept}>{t(`searchPage.resultType.${conceptType}`)}</small>}\n              </h1>\n            )}\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>, 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"]} */"));
|
|
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":"AA6J4B","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  showTitle?: boolean;\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      showTitle = true,\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            {showTitle && (\n              <h1>\n                {isConcept && title.title}\n                {<small data-is-concept={isConcept}>{t(`searchPage.resultType.${conceptType}`)}</small>}\n              </h1>\n            )}\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,
|
|
@@ -80,6 +80,7 @@ export const ConceptNotionV2 = /*#__PURE__*/forwardRef((_ref, ref) => {
|
|
|
80
80
|
lang,
|
|
81
81
|
exampleIds,
|
|
82
82
|
exampleLangs,
|
|
83
|
+
showTitle = true,
|
|
83
84
|
...rest
|
|
84
85
|
} = _ref;
|
|
85
86
|
const {
|
|
@@ -94,7 +95,7 @@ export const ConceptNotionV2 = /*#__PURE__*/forwardRef((_ref, ref) => {
|
|
|
94
95
|
"data-is-concept": isConcept,
|
|
95
96
|
children: [_jsxs(NotionHeader, {
|
|
96
97
|
"data-is-concept": isConcept,
|
|
97
|
-
children: [_jsxs("h1", {
|
|
98
|
+
children: [showTitle && _jsxs("h1", {
|
|
98
99
|
children: [isConcept && title.title, _jsx("small", {
|
|
99
100
|
"data-is-concept": isConcept,
|
|
100
101
|
children: t(`searchPage.resultType.${conceptType}`)
|