@ndla/ui 45.0.8 → 45.0.10
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/BannerCard/BannerCard.js +20 -10
- package/es/Embed/ConceptEmbed.js +44 -22
- package/es/Embed/ConceptListEmbed.js +5 -4
- package/es/Embed/conceptComponents.js +54 -41
- package/es/FrontpageArticle/FrontpageArticle.js +3 -2
- package/es/Gloss/Gloss.js +12 -11
- package/es/LicenseByline/EmbedByline.js +5 -5
- package/es/Notion/NotionImage.js +2 -2
- package/es/locale/messages-en.js +5 -3
- package/es/locale/messages-nb.js +4 -2
- package/es/locale/messages-nn.js +5 -3
- package/es/locale/messages-se.js +5 -3
- package/es/locale/messages-sma.js +5 -3
- package/lib/BannerCard/BannerCard.d.ts +1 -1
- package/lib/BannerCard/BannerCard.js +21 -12
- package/lib/Embed/ConceptEmbed.d.ts +1 -1
- package/lib/Embed/ConceptEmbed.js +44 -22
- package/lib/Embed/ConceptListEmbed.js +5 -4
- package/lib/Embed/conceptComponents.d.ts +5 -2
- package/lib/Embed/conceptComponents.js +53 -41
- package/lib/Figure/FigureOpenDialogButton.d.ts +1 -1
- package/lib/FrontpageArticle/FrontpageArticle.js +3 -2
- package/lib/Gloss/Gloss.js +12 -11
- package/lib/LicenseByline/EmbedByline.d.ts +2 -2
- package/lib/LicenseByline/EmbedByline.js +5 -5
- package/lib/Notion/NotionImage.d.ts +1 -1
- package/lib/Notion/NotionImage.js +2 -2
- package/lib/locale/messages-en.d.ts +3 -1
- package/lib/locale/messages-en.js +5 -3
- package/lib/locale/messages-nb.d.ts +3 -1
- package/lib/locale/messages-nb.js +4 -2
- package/lib/locale/messages-nn.d.ts +3 -1
- package/lib/locale/messages-nn.js +5 -3
- package/lib/locale/messages-se.d.ts +3 -1
- package/lib/locale/messages-se.js +5 -3
- package/lib/locale/messages-sma.d.ts +3 -1
- package/lib/locale/messages-sma.js +5 -3
- package/lib/types.d.ts +1 -0
- package/package.json +5 -5
- package/src/BannerCard/BannerCard.tsx +2 -2
- package/src/ContactBlock/Contactblock.stories.tsx +1 -0
- package/src/Embed/AudioEmbed.stories.tsx +3 -0
- package/src/Embed/ConceptEmbed.stories.tsx +3 -0
- package/src/Embed/ConceptEmbed.tsx +96 -69
- package/src/Embed/ConceptListEmbed.tsx +2 -1
- package/src/Embed/IframeEmbed.stories.tsx +1 -0
- package/src/Embed/ImageEmbed.stories.tsx +1 -0
- package/src/Embed/conceptComponents.tsx +58 -37
- package/src/Figure/FigureOpenDialogButton.tsx +1 -1
- package/src/FrontpageArticle/FrontpageArticle.tsx +1 -1
- package/src/Gloss/Gloss.tsx +5 -5
- package/src/LicenseByline/EmbedByline.tsx +2 -2
- package/src/Notion/NotionImage.tsx +1 -1
- package/src/locale/messages-en.ts +3 -1
- package/src/locale/messages-nb.ts +3 -1
- package/src/locale/messages-nn.ts +3 -1
- package/src/locale/messages-se.ts +3 -1
- package/src/locale/messages-sma.ts +3 -1
- package/src/types.ts +1 -0
|
@@ -23,13 +23,13 @@ var ConceptList = /*#__PURE__*/_styled("div", {
|
|
|
23
23
|
} : {
|
|
24
24
|
name: "1m0jptr",
|
|
25
25
|
styles: "&>figure:first-of-type{margin-top:32px;}& li{display:block;}",
|
|
26
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNvbmNlcHRMaXN0RW1iZWQudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQW1COEIiLCJmaWxlIjoiQ29uY2VwdExpc3RFbWJlZC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAyMy1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCB7IHVzZVRyYW5zbGF0aW9uIH0gZnJvbSAncmVhY3QtaTE4bmV4dCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBjb2xvcnMgfSBmcm9tICdAbmRsYS9jb3JlJztcbmltcG9ydCB7IENvbmNlcHRMaXN0TWV0YURhdGEgfSBmcm9tICdAbmRsYS90eXBlcy1lbWJlZCc7XG5pbXBvcnQgeyBGaWd1cmUgfSBmcm9tICcuLi9GaWd1cmUnO1xuaW1wb3J0IHsgQmxvY2tDb25jZXB0IH0gZnJvbSAnLi9Db25jZXB0RW1iZWQnO1xuXG5pbnRlcmZhY2UgUHJvcHMge1xuICBlbWJlZDogQ29uY2VwdExpc3RNZXRhRGF0YTtcbn1cblxuY29uc3QgQ29uY2VwdExpc3QgPSBzdHlsZWQuZGl2YFxuICAmID4gZmlndXJlOmZpcnN0LW9mLXR5cGUge1xuICAgIG1hcmdpbi10b3A6IDMycHg7XG4gIH1cbiAgJiBsaSB7XG4gICAgZGlzcGxheTogYmxvY2s7XG4gIH1cbmA7XG5cbmNvbnN0IFN0eWxlZFNwYW4gPSBzdHlsZWQuc3BhbmBcbiAgY29sb3I6ICR7Y29sb3JzLnN1cHBvcnQucmVkfTtcbmA7XG5cbmNvbnN0IENvbmNlcHRMaXN0RW1iZWQgPSAoeyBlbWJlZCB9OiBQcm9wcykgPT4ge1xuICBjb25zdCB7IHQgfSA9IHVzZVRyYW5zbGF0aW9uKCk7XG4gIGlmIChlbWJlZC5zdGF0dXMgPT09ICdlcnJvcicpIHtcbiAgICByZXR1cm4gPFN0eWxlZFNwYW4+e3QoJ2VtYmVkLmNvbmNlcHRMaXN0RXJyb3InKX08L1N0eWxlZFNwYW4+O1xuICB9XG4gIGNvbnN0IHsgZW1iZWREYXRhLCBkYXRhIH0gPSBlbWJlZDtcbiAgcmV0dXJuIChcbiAgICA8ZGl2PlxuICAgICAgPEZpZ3VyZSB0eXBlPVwiZnVsbFwiIHJlc2l6ZUlmcmFtZT5cbiAgICAgICAge2VtYmVkRGF0YS50aXRsZSAmJiA8aDI+e2VtYmVkRGF0YS50aXRsZX08L2gyPn1cbiAgICAgICAgPENvbmNlcHRMaXN0PlxuICAgICAgICAgIDx1bD5cbiAgICAgICAgICAgIHtkYXRhLmNvbmNlcHRzLm1hcCgoeyBjb25jZXB0LCB2aXN1YWxFbGVtZW50IH0pID0+IChcbiAgICAgICAgICAgICAgPGxpIGtleT17Y29uY2VwdC5pZH0+
|
|
26
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNvbmNlcHRMaXN0RW1iZWQudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQW1COEIiLCJmaWxlIjoiQ29uY2VwdExpc3RFbWJlZC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAyMy1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCB7IHVzZVRyYW5zbGF0aW9uIH0gZnJvbSAncmVhY3QtaTE4bmV4dCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBjb2xvcnMgfSBmcm9tICdAbmRsYS9jb3JlJztcbmltcG9ydCB7IENvbmNlcHRMaXN0TWV0YURhdGEgfSBmcm9tICdAbmRsYS90eXBlcy1lbWJlZCc7XG5pbXBvcnQgeyBGaWd1cmUgfSBmcm9tICcuLi9GaWd1cmUnO1xuaW1wb3J0IHsgQmxvY2tDb25jZXB0IH0gZnJvbSAnLi9Db25jZXB0RW1iZWQnO1xuXG5pbnRlcmZhY2UgUHJvcHMge1xuICBlbWJlZDogQ29uY2VwdExpc3RNZXRhRGF0YTtcbn1cblxuY29uc3QgQ29uY2VwdExpc3QgPSBzdHlsZWQuZGl2YFxuICAmID4gZmlndXJlOmZpcnN0LW9mLXR5cGUge1xuICAgIG1hcmdpbi10b3A6IDMycHg7XG4gIH1cbiAgJiBsaSB7XG4gICAgZGlzcGxheTogYmxvY2s7XG4gIH1cbmA7XG5cbmNvbnN0IFN0eWxlZFNwYW4gPSBzdHlsZWQuc3BhbmBcbiAgY29sb3I6ICR7Y29sb3JzLnN1cHBvcnQucmVkfTtcbmA7XG5cbmNvbnN0IENvbmNlcHRMaXN0RW1iZWQgPSAoeyBlbWJlZCB9OiBQcm9wcykgPT4ge1xuICBjb25zdCB7IHQgfSA9IHVzZVRyYW5zbGF0aW9uKCk7XG4gIGlmIChlbWJlZC5zdGF0dXMgPT09ICdlcnJvcicpIHtcbiAgICByZXR1cm4gPFN0eWxlZFNwYW4+e3QoJ2VtYmVkLmNvbmNlcHRMaXN0RXJyb3InKX08L1N0eWxlZFNwYW4+O1xuICB9XG4gIGNvbnN0IHsgZW1iZWREYXRhLCBkYXRhIH0gPSBlbWJlZDtcbiAgcmV0dXJuIChcbiAgICA8ZGl2PlxuICAgICAgPEZpZ3VyZSB0eXBlPVwiZnVsbFwiIHJlc2l6ZUlmcmFtZT5cbiAgICAgICAge2VtYmVkRGF0YS50aXRsZSAmJiA8aDI+e2VtYmVkRGF0YS50aXRsZX08L2gyPn1cbiAgICAgICAgPENvbmNlcHRMaXN0PlxuICAgICAgICAgIDx1bD5cbiAgICAgICAgICAgIHtkYXRhLmNvbmNlcHRzLm1hcCgoeyBjb25jZXB0LCB2aXN1YWxFbGVtZW50IH0pID0+IChcbiAgICAgICAgICAgICAgPGxpIGtleT17Y29uY2VwdC5pZH0+XG4gICAgICAgICAgICAgICAgPEJsb2NrQ29uY2VwdFxuICAgICAgICAgICAgICAgICAgdGl0bGU9e2NvbmNlcHQudGl0bGV9XG4gICAgICAgICAgICAgICAgICBjb250ZW50PXtjb25jZXB0LmNvbnRlbnQuY29udGVudH1cbiAgICAgICAgICAgICAgICAgIG1ldGFJbWFnZT17Y29uY2VwdC5tZXRhSW1hZ2V9XG4gICAgICAgICAgICAgICAgICBjb3B5cmlnaHQ9e2NvbmNlcHQuY29weXJpZ2h0fVxuICAgICAgICAgICAgICAgICAgc291cmNlPXtjb25jZXB0LnNvdXJjZX1cbiAgICAgICAgICAgICAgICAgIHZpc3VhbEVsZW1lbnQ9e3Zpc3VhbEVsZW1lbnR9XG4gICAgICAgICAgICAgICAgICBjb25jZXB0VHlwZT17Y29uY2VwdC5jb25jZXB0VHlwZX1cbiAgICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgICA8L2xpPlxuICAgICAgICAgICAgKSl9XG4gICAgICAgICAgPC91bD5cbiAgICAgICAgPC9Db25jZXB0TGlzdD5cbiAgICAgIDwvRmlndXJlPlxuICAgIDwvZGl2PlxuICApO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgQ29uY2VwdExpc3RFbWJlZDtcbiJdfQ== */",
|
|
27
27
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
28
28
|
});
|
|
29
29
|
var StyledSpan = /*#__PURE__*/_styled("span", {
|
|
30
30
|
target: "e1g5p4xu0",
|
|
31
31
|
label: "StyledSpan"
|
|
32
|
-
})("color:", colors.support.red, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNvbmNlcHRMaXN0RW1iZWQudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTRCOEIiLCJmaWxlIjoiQ29uY2VwdExpc3RFbWJlZC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAyMy1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCB7IHVzZVRyYW5zbGF0aW9uIH0gZnJvbSAncmVhY3QtaTE4bmV4dCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBjb2xvcnMgfSBmcm9tICdAbmRsYS9jb3JlJztcbmltcG9ydCB7IENvbmNlcHRMaXN0TWV0YURhdGEgfSBmcm9tICdAbmRsYS90eXBlcy1lbWJlZCc7XG5pbXBvcnQgeyBGaWd1cmUgfSBmcm9tICcuLi9GaWd1cmUnO1xuaW1wb3J0IHsgQmxvY2tDb25jZXB0IH0gZnJvbSAnLi9Db25jZXB0RW1iZWQnO1xuXG5pbnRlcmZhY2UgUHJvcHMge1xuICBlbWJlZDogQ29uY2VwdExpc3RNZXRhRGF0YTtcbn1cblxuY29uc3QgQ29uY2VwdExpc3QgPSBzdHlsZWQuZGl2YFxuICAmID4gZmlndXJlOmZpcnN0LW9mLXR5cGUge1xuICAgIG1hcmdpbi10b3A6IDMycHg7XG4gIH1cbiAgJiBsaSB7XG4gICAgZGlzcGxheTogYmxvY2s7XG4gIH1cbmA7XG5cbmNvbnN0IFN0eWxlZFNwYW4gPSBzdHlsZWQuc3BhbmBcbiAgY29sb3I6ICR7Y29sb3JzLnN1cHBvcnQucmVkfTtcbmA7XG5cbmNvbnN0IENvbmNlcHRMaXN0RW1iZWQgPSAoeyBlbWJlZCB9OiBQcm9wcykgPT4ge1xuICBjb25zdCB7IHQgfSA9IHVzZVRyYW5zbGF0aW9uKCk7XG4gIGlmIChlbWJlZC5zdGF0dXMgPT09ICdlcnJvcicpIHtcbiAgICByZXR1cm4gPFN0eWxlZFNwYW4+e3QoJ2VtYmVkLmNvbmNlcHRMaXN0RXJyb3InKX08L1N0eWxlZFNwYW4+O1xuICB9XG4gIGNvbnN0IHsgZW1iZWREYXRhLCBkYXRhIH0gPSBlbWJlZDtcbiAgcmV0dXJuIChcbiAgICA8ZGl2PlxuICAgICAgPEZpZ3VyZSB0eXBlPVwiZnVsbFwiIHJlc2l6ZUlmcmFtZT5cbiAgICAgICAge2VtYmVkRGF0YS50aXRsZSAmJiA8aDI+e2VtYmVkRGF0YS50aXRsZX08L2gyPn1cbiAgICAgICAgPENvbmNlcHRMaXN0PlxuICAgICAgICAgIDx1bD5cbiAgICAgICAgICAgIHtkYXRhLmNvbmNlcHRzLm1hcCgoeyBjb25jZXB0LCB2aXN1YWxFbGVtZW50IH0pID0+IChcbiAgICAgICAgICAgICAgPGxpIGtleT17Y29uY2VwdC5pZH0+
|
|
32
|
+
})("color:", colors.support.red, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNvbmNlcHRMaXN0RW1iZWQudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTRCOEIiLCJmaWxlIjoiQ29uY2VwdExpc3RFbWJlZC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAyMy1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCB7IHVzZVRyYW5zbGF0aW9uIH0gZnJvbSAncmVhY3QtaTE4bmV4dCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBjb2xvcnMgfSBmcm9tICdAbmRsYS9jb3JlJztcbmltcG9ydCB7IENvbmNlcHRMaXN0TWV0YURhdGEgfSBmcm9tICdAbmRsYS90eXBlcy1lbWJlZCc7XG5pbXBvcnQgeyBGaWd1cmUgfSBmcm9tICcuLi9GaWd1cmUnO1xuaW1wb3J0IHsgQmxvY2tDb25jZXB0IH0gZnJvbSAnLi9Db25jZXB0RW1iZWQnO1xuXG5pbnRlcmZhY2UgUHJvcHMge1xuICBlbWJlZDogQ29uY2VwdExpc3RNZXRhRGF0YTtcbn1cblxuY29uc3QgQ29uY2VwdExpc3QgPSBzdHlsZWQuZGl2YFxuICAmID4gZmlndXJlOmZpcnN0LW9mLXR5cGUge1xuICAgIG1hcmdpbi10b3A6IDMycHg7XG4gIH1cbiAgJiBsaSB7XG4gICAgZGlzcGxheTogYmxvY2s7XG4gIH1cbmA7XG5cbmNvbnN0IFN0eWxlZFNwYW4gPSBzdHlsZWQuc3BhbmBcbiAgY29sb3I6ICR7Y29sb3JzLnN1cHBvcnQucmVkfTtcbmA7XG5cbmNvbnN0IENvbmNlcHRMaXN0RW1iZWQgPSAoeyBlbWJlZCB9OiBQcm9wcykgPT4ge1xuICBjb25zdCB7IHQgfSA9IHVzZVRyYW5zbGF0aW9uKCk7XG4gIGlmIChlbWJlZC5zdGF0dXMgPT09ICdlcnJvcicpIHtcbiAgICByZXR1cm4gPFN0eWxlZFNwYW4+e3QoJ2VtYmVkLmNvbmNlcHRMaXN0RXJyb3InKX08L1N0eWxlZFNwYW4+O1xuICB9XG4gIGNvbnN0IHsgZW1iZWREYXRhLCBkYXRhIH0gPSBlbWJlZDtcbiAgcmV0dXJuIChcbiAgICA8ZGl2PlxuICAgICAgPEZpZ3VyZSB0eXBlPVwiZnVsbFwiIHJlc2l6ZUlmcmFtZT5cbiAgICAgICAge2VtYmVkRGF0YS50aXRsZSAmJiA8aDI+e2VtYmVkRGF0YS50aXRsZX08L2gyPn1cbiAgICAgICAgPENvbmNlcHRMaXN0PlxuICAgICAgICAgIDx1bD5cbiAgICAgICAgICAgIHtkYXRhLmNvbmNlcHRzLm1hcCgoeyBjb25jZXB0LCB2aXN1YWxFbGVtZW50IH0pID0+IChcbiAgICAgICAgICAgICAgPGxpIGtleT17Y29uY2VwdC5pZH0+XG4gICAgICAgICAgICAgICAgPEJsb2NrQ29uY2VwdFxuICAgICAgICAgICAgICAgICAgdGl0bGU9e2NvbmNlcHQudGl0bGV9XG4gICAgICAgICAgICAgICAgICBjb250ZW50PXtjb25jZXB0LmNvbnRlbnQuY29udGVudH1cbiAgICAgICAgICAgICAgICAgIG1ldGFJbWFnZT17Y29uY2VwdC5tZXRhSW1hZ2V9XG4gICAgICAgICAgICAgICAgICBjb3B5cmlnaHQ9e2NvbmNlcHQuY29weXJpZ2h0fVxuICAgICAgICAgICAgICAgICAgc291cmNlPXtjb25jZXB0LnNvdXJjZX1cbiAgICAgICAgICAgICAgICAgIHZpc3VhbEVsZW1lbnQ9e3Zpc3VhbEVsZW1lbnR9XG4gICAgICAgICAgICAgICAgICBjb25jZXB0VHlwZT17Y29uY2VwdC5jb25jZXB0VHlwZX1cbiAgICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgICA8L2xpPlxuICAgICAgICAgICAgKSl9XG4gICAgICAgICAgPC91bD5cbiAgICAgICAgPC9Db25jZXB0TGlzdD5cbiAgICAgIDwvRmlndXJlPlxuICAgIDwvZGl2PlxuICApO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgQ29uY2VwdExpc3RFbWJlZDtcbiJdfQ== */"));
|
|
33
33
|
var ConceptListEmbed = function ConceptListEmbed(_ref) {
|
|
34
34
|
var embed = _ref.embed;
|
|
35
35
|
var _useTranslation = useTranslation(),
|
|
@@ -54,12 +54,13 @@ var ConceptListEmbed = function ConceptListEmbed(_ref) {
|
|
|
54
54
|
visualElement = _ref2.visualElement;
|
|
55
55
|
return _jsx("li", {
|
|
56
56
|
children: _jsx(BlockConcept, {
|
|
57
|
-
title: concept.title
|
|
57
|
+
title: concept.title,
|
|
58
58
|
content: concept.content.content,
|
|
59
59
|
metaImage: concept.metaImage,
|
|
60
60
|
copyright: concept.copyright,
|
|
61
61
|
source: concept.source,
|
|
62
|
-
visualElement: visualElement
|
|
62
|
+
visualElement: visualElement,
|
|
63
|
+
conceptType: concept.conceptType
|
|
63
64
|
})
|
|
64
65
|
}, concept.id);
|
|
65
66
|
})
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
|
|
2
2
|
import _styled from "@emotion/styled/base";
|
|
3
|
-
var _excluded = ["visualElement", "title", "content", "source", "copyright", "closeButton", "inPopover", "previewAlt", "tags", "subjects", "heartButton", "conceptHeartButton"];
|
|
3
|
+
var _excluded = ["visualElement", "title", "content", "source", "copyright", "closeButton", "inPopover", "previewAlt", "tags", "subjects", "heartButton", "conceptHeartButton", "conceptType", "glossData"];
|
|
4
4
|
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
|
|
5
5
|
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
|
|
6
6
|
function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
|
|
@@ -28,35 +28,37 @@ import BrightcoveEmbed from './BrightcoveEmbed';
|
|
|
28
28
|
import H5pEmbed from './H5pEmbed';
|
|
29
29
|
import { ExternalEmbed, IframeEmbed } from '.';
|
|
30
30
|
import { EmbedByline } from '../LicenseByline';
|
|
31
|
+
import { Gloss } from '../Gloss';
|
|
31
32
|
import { jsx as _jsx } from "@emotion/react/jsx-runtime";
|
|
32
33
|
import { jsxs as _jsxs } from "@emotion/react/jsx-runtime";
|
|
34
|
+
import { Fragment as _Fragment } from "@emotion/react/jsx-runtime";
|
|
33
35
|
var ContentPadding = /*#__PURE__*/_styled("div", {
|
|
34
36
|
target: "eqcj3r4",
|
|
35
37
|
label: "ContentPadding"
|
|
36
|
-
})("padding:", spacing.normal, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
38
|
+
})("padding:", spacing.normal, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["conceptComponents.tsx"],"names":[],"mappings":"AAoDiC","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 { AudioMeta, AudioMetaData, ConceptData, ConceptVisualElementMeta } from '@ndla/types-embed';\nimport { useTranslation } from 'react-i18next';\nimport { css } from '@emotion/react';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { parseMarkdown } from '@ndla/util';\nimport styled from '@emotion/styled';\nimport { NotionDialogContent, NotionDialogText } from '@ndla/notion';\nimport { COPYRIGHTED } from '@ndla/licenses';\nimport { Copyright } from '../types';\nimport ImageEmbed from './ImageEmbed';\nimport BrightcoveEmbed from './BrightcoveEmbed';\nimport H5pEmbed from './H5pEmbed';\nimport { ExternalEmbed, HeartButtonType, IframeEmbed } from '.';\nimport { EmbedByline } from '../LicenseByline';\nimport { Gloss } from '../Gloss';\n\nexport type ConceptType = 'concept' | 'gloss';\n\nexport interface ConceptNotionData {\n  title: ConceptData['concept']['title'];\n  content?: string;\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}\n\ninterface ConceptNotionProps extends RefAttributes<HTMLDivElement>, ConceptNotionData {\n  className?: string;\n  closeButton?: ReactNode;\n  previewAlt?: boolean;\n  inPopover?: boolean;\n  tags?: string[];\n  subjects?: string[];\n  heartButton?: HeartButtonType;\n  conceptHeartButton?: ReactNode;\n}\n\nconst ContentPadding = styled.div`\n  padding: ${spacing.normal};\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: 1;\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: 100;\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    padding-left: ${spacing.small};\n    margin-left: ${spacing.xsmall};\n    border-left: 1px solid ${colors.brand.greyLight};\n    ${fonts.sizes('20px', 1.2)};\n    font-weight: ${fonts.weight.normal};\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 StyledList = styled.ul`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n  list-style: none;\n  > li {\n    margin: 0;\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      ...rest\n    },\n    ref,\n  ) => {\n    const { t } = useTranslation();\n\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <ContentPadding>\n          <NotionHeader>\n            <h1>\n              {title.title} {<small>{t(`searchPage.resultType.${conceptType}`)}</small>}\n            </h1>\n            {closeButton}\n          </NotionHeader>\n          {conceptType !== 'gloss' ? (\n            <>\n              <StyledNotionDialogContent>\n                {visualElement?.resource === 'image' ? (\n                  <ImageEmbed embed={visualElement} heartButton={heartButton} />\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                <NotionDialogText>{parseMarkdown(content ?? '', 'body')}</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                  ? { src: visualElement.data.audioFile.url, title: visualElement.data.title.title }\n                  : undefined\n              }\n            />\n          )}\n        </ContentPadding>\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"]} */"));
|
|
37
39
|
var 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:1;box-shadow:0 0 30px rgba(0, 0, 0, 0.2);", mq.range({
|
|
38
40
|
from: breakpoints.tablet
|
|
39
41
|
}), "{width:500px;}", mq.range({
|
|
40
42
|
from: breakpoints.desktop
|
|
41
43
|
}), "{width:720px;}", mq.range({
|
|
42
44
|
until: breakpoints.tablet
|
|
43
|
-
}), "{padding:", spacing.small, ";z-index:100;height:100%;width:100%;overflow:auto;};label:notionContentCss;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
45
|
+
}), "{padding:", spacing.small, ";z-index:100;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":"AAwD4B","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 { AudioMeta, AudioMetaData, ConceptData, ConceptVisualElementMeta } from '@ndla/types-embed';\nimport { useTranslation } from 'react-i18next';\nimport { css } from '@emotion/react';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { parseMarkdown } from '@ndla/util';\nimport styled from '@emotion/styled';\nimport { NotionDialogContent, NotionDialogText } from '@ndla/notion';\nimport { COPYRIGHTED } from '@ndla/licenses';\nimport { Copyright } from '../types';\nimport ImageEmbed from './ImageEmbed';\nimport BrightcoveEmbed from './BrightcoveEmbed';\nimport H5pEmbed from './H5pEmbed';\nimport { ExternalEmbed, HeartButtonType, IframeEmbed } from '.';\nimport { EmbedByline } from '../LicenseByline';\nimport { Gloss } from '../Gloss';\n\nexport type ConceptType = 'concept' | 'gloss';\n\nexport interface ConceptNotionData {\n  title: ConceptData['concept']['title'];\n  content?: string;\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}\n\ninterface ConceptNotionProps extends RefAttributes<HTMLDivElement>, ConceptNotionData {\n  className?: string;\n  closeButton?: ReactNode;\n  previewAlt?: boolean;\n  inPopover?: boolean;\n  tags?: string[];\n  subjects?: string[];\n  heartButton?: HeartButtonType;\n  conceptHeartButton?: ReactNode;\n}\n\nconst ContentPadding = styled.div`\n  padding: ${spacing.normal};\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: 1;\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: 100;\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    padding-left: ${spacing.small};\n    margin-left: ${spacing.xsmall};\n    border-left: 1px solid ${colors.brand.greyLight};\n    ${fonts.sizes('20px', 1.2)};\n    font-weight: ${fonts.weight.normal};\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 StyledList = styled.ul`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n  list-style: none;\n  > li {\n    margin: 0;\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      ...rest\n    },\n    ref,\n  ) => {\n    const { t } = useTranslation();\n\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <ContentPadding>\n          <NotionHeader>\n            <h1>\n              {title.title} {<small>{t(`searchPage.resultType.${conceptType}`)}</small>}\n            </h1>\n            {closeButton}\n          </NotionHeader>\n          {conceptType !== 'gloss' ? (\n            <>\n              <StyledNotionDialogContent>\n                {visualElement?.resource === 'image' ? (\n                  <ImageEmbed embed={visualElement} heartButton={heartButton} />\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                <NotionDialogText>{parseMarkdown(content ?? '', 'body')}</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                  ? { src: visualElement.data.audioFile.url, title: visualElement.data.title.title }\n                  : undefined\n              }\n            />\n          )}\n        </ContentPadding>\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"]} */"));
|
|
44
46
|
var NotionHeader = /*#__PURE__*/_styled("div", {
|
|
45
47
|
target: "eqcj3r3",
|
|
46
48
|
label: "NotionHeader"
|
|
47
|
-
})("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{padding-left:", spacing.small, ";margin-left:", spacing.xsmall, ";border-left:1px solid ", colors.brand.greyLight, ";", fonts.sizes('20px', 1.2), ";font-weight:", fonts.weight.normal, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
49
|
+
})("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{padding-left:", spacing.small, ";margin-left:", spacing.xsmall, ";border-left:1px solid ", colors.brand.greyLight, ";", fonts.sizes('20px', 1.2), ";font-weight:", fonts.weight.normal, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["conceptComponents.tsx"],"names":[],"mappings":"AAyF+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 { AudioMeta, AudioMetaData, ConceptData, ConceptVisualElementMeta } from '@ndla/types-embed';\nimport { useTranslation } from 'react-i18next';\nimport { css } from '@emotion/react';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { parseMarkdown } from '@ndla/util';\nimport styled from '@emotion/styled';\nimport { NotionDialogContent, NotionDialogText } from '@ndla/notion';\nimport { COPYRIGHTED } from '@ndla/licenses';\nimport { Copyright } from '../types';\nimport ImageEmbed from './ImageEmbed';\nimport BrightcoveEmbed from './BrightcoveEmbed';\nimport H5pEmbed from './H5pEmbed';\nimport { ExternalEmbed, HeartButtonType, IframeEmbed } from '.';\nimport { EmbedByline } from '../LicenseByline';\nimport { Gloss } from '../Gloss';\n\nexport type ConceptType = 'concept' | 'gloss';\n\nexport interface ConceptNotionData {\n  title: ConceptData['concept']['title'];\n  content?: string;\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}\n\ninterface ConceptNotionProps extends RefAttributes<HTMLDivElement>, ConceptNotionData {\n  className?: string;\n  closeButton?: ReactNode;\n  previewAlt?: boolean;\n  inPopover?: boolean;\n  tags?: string[];\n  subjects?: string[];\n  heartButton?: HeartButtonType;\n  conceptHeartButton?: ReactNode;\n}\n\nconst ContentPadding = styled.div`\n  padding: ${spacing.normal};\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: 1;\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: 100;\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    padding-left: ${spacing.small};\n    margin-left: ${spacing.xsmall};\n    border-left: 1px solid ${colors.brand.greyLight};\n    ${fonts.sizes('20px', 1.2)};\n    font-weight: ${fonts.weight.normal};\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 StyledList = styled.ul`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n  list-style: none;\n  > li {\n    margin: 0;\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      ...rest\n    },\n    ref,\n  ) => {\n    const { t } = useTranslation();\n\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <ContentPadding>\n          <NotionHeader>\n            <h1>\n              {title.title} {<small>{t(`searchPage.resultType.${conceptType}`)}</small>}\n            </h1>\n            {closeButton}\n          </NotionHeader>\n          {conceptType !== 'gloss' ? (\n            <>\n              <StyledNotionDialogContent>\n                {visualElement?.resource === 'image' ? (\n                  <ImageEmbed embed={visualElement} heartButton={heartButton} />\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                <NotionDialogText>{parseMarkdown(content ?? '', 'body')}</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                  ? { src: visualElement.data.audioFile.url, title: visualElement.data.title.title }\n                  : undefined\n              }\n            />\n          )}\n        </ContentPadding>\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"]} */"));
|
|
48
50
|
var ListWrapper = /*#__PURE__*/_styled("div", {
|
|
49
51
|
target: "eqcj3r2",
|
|
50
52
|
label: "ListWrapper"
|
|
51
|
-
})("display:flex;gap:", spacing.small, ";align-items:center;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
53
|
+
})("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":"AA8G8B","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 { AudioMeta, AudioMetaData, ConceptData, ConceptVisualElementMeta } from '@ndla/types-embed';\nimport { useTranslation } from 'react-i18next';\nimport { css } from '@emotion/react';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { parseMarkdown } from '@ndla/util';\nimport styled from '@emotion/styled';\nimport { NotionDialogContent, NotionDialogText } from '@ndla/notion';\nimport { COPYRIGHTED } from '@ndla/licenses';\nimport { Copyright } from '../types';\nimport ImageEmbed from './ImageEmbed';\nimport BrightcoveEmbed from './BrightcoveEmbed';\nimport H5pEmbed from './H5pEmbed';\nimport { ExternalEmbed, HeartButtonType, IframeEmbed } from '.';\nimport { EmbedByline } from '../LicenseByline';\nimport { Gloss } from '../Gloss';\n\nexport type ConceptType = 'concept' | 'gloss';\n\nexport interface ConceptNotionData {\n  title: ConceptData['concept']['title'];\n  content?: string;\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}\n\ninterface ConceptNotionProps extends RefAttributes<HTMLDivElement>, ConceptNotionData {\n  className?: string;\n  closeButton?: ReactNode;\n  previewAlt?: boolean;\n  inPopover?: boolean;\n  tags?: string[];\n  subjects?: string[];\n  heartButton?: HeartButtonType;\n  conceptHeartButton?: ReactNode;\n}\n\nconst ContentPadding = styled.div`\n  padding: ${spacing.normal};\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: 1;\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: 100;\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    padding-left: ${spacing.small};\n    margin-left: ${spacing.xsmall};\n    border-left: 1px solid ${colors.brand.greyLight};\n    ${fonts.sizes('20px', 1.2)};\n    font-weight: ${fonts.weight.normal};\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 StyledList = styled.ul`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n  list-style: none;\n  > li {\n    margin: 0;\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      ...rest\n    },\n    ref,\n  ) => {\n    const { t } = useTranslation();\n\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <ContentPadding>\n          <NotionHeader>\n            <h1>\n              {title.title} {<small>{t(`searchPage.resultType.${conceptType}`)}</small>}\n            </h1>\n            {closeButton}\n          </NotionHeader>\n          {conceptType !== 'gloss' ? (\n            <>\n              <StyledNotionDialogContent>\n                {visualElement?.resource === 'image' ? (\n                  <ImageEmbed embed={visualElement} heartButton={heartButton} />\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                <NotionDialogText>{parseMarkdown(content ?? '', 'body')}</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                  ? { src: visualElement.data.audioFile.url, title: visualElement.data.title.title }\n                  : undefined\n              }\n            />\n          )}\n        </ContentPadding>\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"]} */"));
|
|
52
54
|
var StyledNotionDialogContent = /*#__PURE__*/_styled(NotionDialogContent, {
|
|
53
55
|
target: "eqcj3r1",
|
|
54
56
|
label: "StyledNotionDialogContent"
|
|
55
|
-
})("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,
|
|
57
|
+
})("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":"AAoH6D","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 { AudioMeta, AudioMetaData, ConceptData, ConceptVisualElementMeta } from '@ndla/types-embed';\nimport { useTranslation } from 'react-i18next';\nimport { css } from '@emotion/react';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { parseMarkdown } from '@ndla/util';\nimport styled from '@emotion/styled';\nimport { NotionDialogContent, NotionDialogText } from '@ndla/notion';\nimport { COPYRIGHTED } from '@ndla/licenses';\nimport { Copyright } from '../types';\nimport ImageEmbed from './ImageEmbed';\nimport BrightcoveEmbed from './BrightcoveEmbed';\nimport H5pEmbed from './H5pEmbed';\nimport { ExternalEmbed, HeartButtonType, IframeEmbed } from '.';\nimport { EmbedByline } from '../LicenseByline';\nimport { Gloss } from '../Gloss';\n\nexport type ConceptType = 'concept' | 'gloss';\n\nexport interface ConceptNotionData {\n  title: ConceptData['concept']['title'];\n  content?: string;\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}\n\ninterface ConceptNotionProps extends RefAttributes<HTMLDivElement>, ConceptNotionData {\n  className?: string;\n  closeButton?: ReactNode;\n  previewAlt?: boolean;\n  inPopover?: boolean;\n  tags?: string[];\n  subjects?: string[];\n  heartButton?: HeartButtonType;\n  conceptHeartButton?: ReactNode;\n}\n\nconst ContentPadding = styled.div`\n  padding: ${spacing.normal};\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: 1;\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: 100;\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    padding-left: ${spacing.small};\n    margin-left: ${spacing.xsmall};\n    border-left: 1px solid ${colors.brand.greyLight};\n    ${fonts.sizes('20px', 1.2)};\n    font-weight: ${fonts.weight.normal};\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 StyledList = styled.ul`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n  list-style: none;\n  > li {\n    margin: 0;\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      ...rest\n    },\n    ref,\n  ) => {\n    const { t } = useTranslation();\n\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <ContentPadding>\n          <NotionHeader>\n            <h1>\n              {title.title} {<small>{t(`searchPage.resultType.${conceptType}`)}</small>}\n            </h1>\n            {closeButton}\n          </NotionHeader>\n          {conceptType !== 'gloss' ? (\n            <>\n              <StyledNotionDialogContent>\n                {visualElement?.resource === 'image' ? (\n                  <ImageEmbed embed={visualElement} heartButton={heartButton} />\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                <NotionDialogText>{parseMarkdown(content ?? '', 'body')}</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                  ? { src: visualElement.data.audioFile.url, title: visualElement.data.title.title }\n                  : undefined\n              }\n            />\n          )}\n        </ContentPadding>\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"]} */"));
|
|
56
58
|
var StyledList = /*#__PURE__*/_styled("ul", {
|
|
57
59
|
target: "eqcj3r0",
|
|
58
60
|
label: "StyledList"
|
|
59
|
-
})("display:flex;gap:", spacing.small, ";align-items:center;list-style:none;>li{margin:0;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,
|
|
61
|
+
})("display:flex;gap:", spacing.small, ";align-items:center;list-style:none;>li{margin:0;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":"AA+H4B","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 { AudioMeta, AudioMetaData, ConceptData, ConceptVisualElementMeta } from '@ndla/types-embed';\nimport { useTranslation } from 'react-i18next';\nimport { css } from '@emotion/react';\nimport { breakpoints, colors, fonts, misc, mq, spacing } from '@ndla/core';\nimport { parseMarkdown } from '@ndla/util';\nimport styled from '@emotion/styled';\nimport { NotionDialogContent, NotionDialogText } from '@ndla/notion';\nimport { COPYRIGHTED } from '@ndla/licenses';\nimport { Copyright } from '../types';\nimport ImageEmbed from './ImageEmbed';\nimport BrightcoveEmbed from './BrightcoveEmbed';\nimport H5pEmbed from './H5pEmbed';\nimport { ExternalEmbed, HeartButtonType, IframeEmbed } from '.';\nimport { EmbedByline } from '../LicenseByline';\nimport { Gloss } from '../Gloss';\n\nexport type ConceptType = 'concept' | 'gloss';\n\nexport interface ConceptNotionData {\n  title: ConceptData['concept']['title'];\n  content?: string;\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}\n\ninterface ConceptNotionProps extends RefAttributes<HTMLDivElement>, ConceptNotionData {\n  className?: string;\n  closeButton?: ReactNode;\n  previewAlt?: boolean;\n  inPopover?: boolean;\n  tags?: string[];\n  subjects?: string[];\n  heartButton?: HeartButtonType;\n  conceptHeartButton?: ReactNode;\n}\n\nconst ContentPadding = styled.div`\n  padding: ${spacing.normal};\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: 1;\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: 100;\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    padding-left: ${spacing.small};\n    margin-left: ${spacing.xsmall};\n    border-left: 1px solid ${colors.brand.greyLight};\n    ${fonts.sizes('20px', 1.2)};\n    font-weight: ${fonts.weight.normal};\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 StyledList = styled.ul`\n  display: flex;\n  gap: ${spacing.small};\n  align-items: center;\n  list-style: none;\n  > li {\n    margin: 0;\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      ...rest\n    },\n    ref,\n  ) => {\n    const { t } = useTranslation();\n\n    return (\n      <div css={inPopover ? notionContentCss : undefined} {...rest} ref={ref}>\n        <ContentPadding>\n          <NotionHeader>\n            <h1>\n              {title.title} {<small>{t(`searchPage.resultType.${conceptType}`)}</small>}\n            </h1>\n            {closeButton}\n          </NotionHeader>\n          {conceptType !== 'gloss' ? (\n            <>\n              <StyledNotionDialogContent>\n                {visualElement?.resource === 'image' ? (\n                  <ImageEmbed embed={visualElement} heartButton={heartButton} />\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                <NotionDialogText>{parseMarkdown(content ?? '', 'body')}</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                  ? { src: visualElement.data.audioFile.url, title: visualElement.data.title.title }\n                  : undefined\n              }\n            />\n          )}\n        </ContentPadding>\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"]} */"));
|
|
60
62
|
export var ConceptNotionV2 = /*#__PURE__*/forwardRef(function (_ref, ref) {
|
|
61
63
|
var _copyright$license;
|
|
62
64
|
var visualElement = _ref.visualElement,
|
|
@@ -71,6 +73,8 @@ export var ConceptNotionV2 = /*#__PURE__*/forwardRef(function (_ref, ref) {
|
|
|
71
73
|
subjects = _ref.subjects,
|
|
72
74
|
heartButton = _ref.heartButton,
|
|
73
75
|
conceptHeartButton = _ref.conceptHeartButton,
|
|
76
|
+
conceptType = _ref.conceptType,
|
|
77
|
+
glossData = _ref.glossData,
|
|
74
78
|
rest = _objectWithoutProperties(_ref, _excluded);
|
|
75
79
|
var _useTranslation = useTranslation(),
|
|
76
80
|
t = _useTranslation.t;
|
|
@@ -81,46 +85,55 @@ export var ConceptNotionV2 = /*#__PURE__*/forwardRef(function (_ref, ref) {
|
|
|
81
85
|
children: [_jsxs(ContentPadding, {
|
|
82
86
|
children: [_jsxs(NotionHeader, {
|
|
83
87
|
children: [_jsxs("h1", {
|
|
84
|
-
children: [title, " ", _jsx("small", {
|
|
85
|
-
children: t(
|
|
88
|
+
children: [title.title, " ", _jsx("small", {
|
|
89
|
+
children: t("searchPage.resultType.".concat(conceptType))
|
|
86
90
|
})]
|
|
87
91
|
}), closeButton]
|
|
88
|
-
}), _jsxs(
|
|
89
|
-
children: [(
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
children:
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
children:
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
92
|
+
}), conceptType !== 'gloss' ? _jsxs(_Fragment, {
|
|
93
|
+
children: [_jsxs(StyledNotionDialogContent, {
|
|
94
|
+
children: [(visualElement === null || visualElement === void 0 ? void 0 : visualElement.resource) === 'image' ? _jsx(ImageEmbed, {
|
|
95
|
+
embed: visualElement,
|
|
96
|
+
heartButton: heartButton
|
|
97
|
+
}) : (visualElement === null || visualElement === void 0 ? void 0 : visualElement.resource) === 'brightcove' ? _jsx(BrightcoveEmbed, {
|
|
98
|
+
embed: visualElement,
|
|
99
|
+
heartButton: heartButton
|
|
100
|
+
}) : (visualElement === null || visualElement === void 0 ? void 0 : visualElement.resource) === 'h5p' ? _jsx(H5pEmbed, {
|
|
101
|
+
embed: visualElement
|
|
102
|
+
}) : (visualElement === null || visualElement === void 0 ? void 0 : visualElement.resource) === 'iframe' ? _jsx(IframeEmbed, {
|
|
103
|
+
embed: visualElement
|
|
104
|
+
}) : (visualElement === null || visualElement === void 0 ? void 0 : visualElement.resource) === 'external' ? _jsx(ExternalEmbed, {
|
|
105
|
+
embed: visualElement
|
|
106
|
+
}) : null, _jsx(NotionDialogText, {
|
|
107
|
+
children: parseMarkdown(content !== null && content !== void 0 ? content : '', 'body')
|
|
108
|
+
})]
|
|
109
|
+
}), tags && _jsxs(ListWrapper, {
|
|
110
|
+
children: ["".concat(t('notions.tags'), ":"), _jsx(StyledList, {
|
|
111
|
+
children: tags.map(function (tag, index) {
|
|
112
|
+
return _jsx("li", {
|
|
113
|
+
children: tag
|
|
114
|
+
}, index);
|
|
115
|
+
})
|
|
116
|
+
})]
|
|
117
|
+
}), subjects && _jsxs(ListWrapper, {
|
|
118
|
+
children: ["".concat(t('notions.usedIn'), ":"), _jsx(StyledList, {
|
|
119
|
+
children: subjects.map(function (subject, index) {
|
|
120
|
+
return _jsx("li", {
|
|
121
|
+
children: subject
|
|
122
|
+
}, index);
|
|
123
|
+
})
|
|
124
|
+
})]
|
|
119
125
|
})]
|
|
126
|
+
}) : _jsx(Gloss, {
|
|
127
|
+
title: title,
|
|
128
|
+
glossData: glossData,
|
|
129
|
+
audio: (visualElement === null || visualElement === void 0 ? void 0 : visualElement.status) === 'success' && visualElement.resource === 'audio' ? {
|
|
130
|
+
src: visualElement.data.audioFile.url,
|
|
131
|
+
title: visualElement.data.title.title
|
|
132
|
+
} : undefined
|
|
120
133
|
})]
|
|
121
134
|
}), copyright && _jsx(EmbedByline, {
|
|
122
135
|
copyright: copyright,
|
|
123
|
-
type:
|
|
136
|
+
type: conceptType,
|
|
124
137
|
children: ((_copyright$license = copyright.license) === null || _copyright$license === void 0 ? void 0 : _copyright$license.license.toLowerCase()) !== COPYRIGHTED && conceptHeartButton
|
|
125
138
|
})]
|
|
126
139
|
}));
|
|
@@ -20,13 +20,13 @@ export var WIDE_FRONTPAGE_ARTICLE_MAX_WIDTH = '1100px';
|
|
|
20
20
|
var StyledArticle = /*#__PURE__*/_styled("article", {
|
|
21
21
|
target: "e10a6yg81",
|
|
22
22
|
label: "StyledArticle"
|
|
23
|
-
})("width:100%;max-width:773px;h2[id]{margin-top:", spacing.large, ";}div[data-type='campaign-block']{margin:", spacing.large, " 0px;}div[data-type='grid']{h2,h3,h4{margin-top:0px;}}&[data-wide='true']{max-width:1100px;h2[id]{margin-top:", spacingUnit * 4, "px;}div[data-type='campaign-block']{margin:", spacingUnit * 4, "px 0px;}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkZyb250cGFnZUFydGljbGUudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTJCb0MiLCJmaWxlIjoiRnJvbnRwYWdlQXJ0aWNsZS50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAyMy1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCB7IENTU1Byb3BlcnRpZXMsIFJlYWN0Tm9kZSwgdXNlTWVtbyB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IGJyZWFrcG9pbnRzLCBmb250cywgbXEsIHNwYWNpbmcsIHNwYWNpbmdVbml0IH0gZnJvbSAnQG5kbGEvY29yZSc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBBcnRpY2xlIH0gZnJvbSAnLi4vdHlwZXMnO1xuaW1wb3J0IExheW91dEl0ZW0gZnJvbSAnLi4vTGF5b3V0JztcbmltcG9ydCB7IEhlYWRpbmcgfSBmcm9tICcuLi9UeXBvZ3JhcGh5JztcbmltcG9ydCB7IEFydGljbGVCeWxpbmUgfSBmcm9tICcuLi9BcnRpY2xlJztcbmltcG9ydCB7IHVzZU1hc3RoZWFkSGVpZ2h0IH0gZnJvbSAnLi4vTWFzdGhlYWQnO1xuXG5pbnRlcmZhY2UgUHJvcHMge1xuICBhcnRpY2xlOiBPbWl0PEFydGljbGUsICdmb290Tm90ZXMnPjtcbiAgaWQ6IHN0cmluZztcbiAgaXNXaWRlPzogYm9vbGVhbjtcbiAgbGljZW5zZUJveD86IFJlYWN0Tm9kZTtcbn1cblxuZXhwb3J0IGNvbnN0IEZST05UUEFHRV9BUlRJQ0xFX01BWF9XSURUSCA9ICc3NzNweCc7XG5leHBvcnQgY29uc3QgV0lERV9GUk9OVFBBR0VfQVJUSUNMRV9NQVhfV0lEVEggPSAnMTEwMHB4JztcblxuY29uc3QgU3R5bGVkQXJ0aWNsZSA9IHN0eWxlZC5hcnRpY2xlYFxuICB3aWR0aDogMTAwJTtcbiAgbWF4LXdpZHRoOiA3NzNweDtcbiAgaDJbaWRdIHtcbiAgICBtYXJnaW4tdG9wOiAke3NwYWNpbmcubGFyZ2V9O1xuICB9XG4gIGRpdltkYXRhLXR5cGU9J2NhbXBhaWduLWJsb2NrJ10ge1xuICAgIG1hcmdpbjogJHtzcGFjaW5nLmxhcmdlfSAwcHg7XG4gIH1cbiAgZGl2W2RhdGEtdHlwZT0nZ3JpZCddIHtcbiAgICBoMixcbiAgICBoMyxcbiAgICBoNCB7XG4gICAgICBtYXJnaW4tdG9wOiAwcHg7XG4gICAgfVxuICB9XG4gICZbZGF0YS13aWRlPSd0cnVlJ10ge1xuICAgIG1heC13aWR0aDogMTEwMHB4O1xuICAgIGgyW2lkXSB7XG4gICAgICBtYXJnaW4tdG9wOiAke3NwYWNpbmdVbml0ICogNH1weDtcbiAgICB9XG4gICAgZGl2W2RhdGEtdHlwZT0nY2FtcGFpZ24tYmxvY2snXSB7XG4gICAgICBtYXJnaW46ICR7c3BhY2luZ1VuaXQgKiA0fXB4IDBweDtcbiAgICB9XG4gIH1cbmA7XG5cbmNvbnN0IFN0eWxlZEludHJvZHVjdGlvbiA9IHN0eWxlZC5kaXZgXG4gIGZvbnQtd2VpZ2h0OiAke2ZvbnRzLndlaWdodC5saWdodH07XG4gIGZvbnQtZmFtaWx5OiAke2ZvbnRzLnNhbnN9O1xuICBtYXJnaW4tdG9wOiAke3NwYWNpbmcuc21hbGx9O1xuICAke2ZvbnRzLnNpemVzKCcyMnB4JywgJzMwcHgnKX07XG5cbiAgJHttcS5yYW5nZSh7IGZyb206IGJyZWFrcG9pbnRzLnRhYmxldCB9KX0ge1xuICAgIG1hcmdpbi10b3A6ICR7c3BhY2luZy5tZWRpdW1sYXJnZX07XG4gICAgJHtmb250cy5zaXplcygnMjZweCcsICczNnB4Jyl9O1xuICB9XG5gO1xuXG5leHBvcnQgY29uc3QgRnJvbnRwYWdlQXJ0aWNsZSA9ICh7IGFydGljbGUsIGlkLCBpc1dpZGUsIGxpY2Vuc2VCb3ggfTogUHJvcHMpID0+
|
|
23
|
+
})("width:100%;max-width:773px;h2[id]{margin-top:", spacing.large, ";}div[data-type='campaign-block']{margin:", spacing.large, " 0px;}div[data-type='grid']{h2,h3,h4{margin-top:0px;}}&[data-wide='true']{max-width:1100px;h2[id]{margin-top:", spacingUnit * 4, "px;}div[data-type='campaign-block']{margin:", spacingUnit * 4, "px 0px;}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkZyb250cGFnZUFydGljbGUudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTJCb0MiLCJmaWxlIjoiRnJvbnRwYWdlQXJ0aWNsZS50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAyMy1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCB7IENTU1Byb3BlcnRpZXMsIFJlYWN0Tm9kZSwgdXNlTWVtbyB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IGJyZWFrcG9pbnRzLCBmb250cywgbXEsIHNwYWNpbmcsIHNwYWNpbmdVbml0IH0gZnJvbSAnQG5kbGEvY29yZSc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBBcnRpY2xlIH0gZnJvbSAnLi4vdHlwZXMnO1xuaW1wb3J0IExheW91dEl0ZW0gZnJvbSAnLi4vTGF5b3V0JztcbmltcG9ydCB7IEhlYWRpbmcgfSBmcm9tICcuLi9UeXBvZ3JhcGh5JztcbmltcG9ydCB7IEFydGljbGVCeWxpbmUgfSBmcm9tICcuLi9BcnRpY2xlJztcbmltcG9ydCB7IHVzZU1hc3RoZWFkSGVpZ2h0IH0gZnJvbSAnLi4vTWFzdGhlYWQnO1xuXG5pbnRlcmZhY2UgUHJvcHMge1xuICBhcnRpY2xlOiBPbWl0PEFydGljbGUsICdmb290Tm90ZXMnPjtcbiAgaWQ6IHN0cmluZztcbiAgaXNXaWRlPzogYm9vbGVhbjtcbiAgbGljZW5zZUJveD86IFJlYWN0Tm9kZTtcbn1cblxuZXhwb3J0IGNvbnN0IEZST05UUEFHRV9BUlRJQ0xFX01BWF9XSURUSCA9ICc3NzNweCc7XG5leHBvcnQgY29uc3QgV0lERV9GUk9OVFBBR0VfQVJUSUNMRV9NQVhfV0lEVEggPSAnMTEwMHB4JztcblxuY29uc3QgU3R5bGVkQXJ0aWNsZSA9IHN0eWxlZC5hcnRpY2xlYFxuICB3aWR0aDogMTAwJTtcbiAgbWF4LXdpZHRoOiA3NzNweDtcbiAgaDJbaWRdIHtcbiAgICBtYXJnaW4tdG9wOiAke3NwYWNpbmcubGFyZ2V9O1xuICB9XG4gIGRpdltkYXRhLXR5cGU9J2NhbXBhaWduLWJsb2NrJ10ge1xuICAgIG1hcmdpbjogJHtzcGFjaW5nLmxhcmdlfSAwcHg7XG4gIH1cbiAgZGl2W2RhdGEtdHlwZT0nZ3JpZCddIHtcbiAgICBoMixcbiAgICBoMyxcbiAgICBoNCB7XG4gICAgICBtYXJnaW4tdG9wOiAwcHg7XG4gICAgfVxuICB9XG4gICZbZGF0YS13aWRlPSd0cnVlJ10ge1xuICAgIG1heC13aWR0aDogMTEwMHB4O1xuICAgIGgyW2lkXSB7XG4gICAgICBtYXJnaW4tdG9wOiAke3NwYWNpbmdVbml0ICogNH1weDtcbiAgICB9XG4gICAgZGl2W2RhdGEtdHlwZT0nY2FtcGFpZ24tYmxvY2snXSB7XG4gICAgICBtYXJnaW46ICR7c3BhY2luZ1VuaXQgKiA0fXB4IDBweDtcbiAgICB9XG4gIH1cbmA7XG5cbmNvbnN0IFN0eWxlZEludHJvZHVjdGlvbiA9IHN0eWxlZC5kaXZgXG4gIGZvbnQtd2VpZ2h0OiAke2ZvbnRzLndlaWdodC5saWdodH07XG4gIGZvbnQtZmFtaWx5OiAke2ZvbnRzLnNhbnN9O1xuICBtYXJnaW4tdG9wOiAke3NwYWNpbmcuc21hbGx9O1xuICAke2ZvbnRzLnNpemVzKCcyMnB4JywgJzMwcHgnKX07XG5cbiAgJHttcS5yYW5nZSh7IGZyb206IGJyZWFrcG9pbnRzLnRhYmxldCB9KX0ge1xuICAgIG1hcmdpbi10b3A6ICR7c3BhY2luZy5tZWRpdW1sYXJnZX07XG4gICAgJHtmb250cy5zaXplcygnMjZweCcsICczNnB4Jyl9O1xuICB9XG5gO1xuXG5leHBvcnQgY29uc3QgRnJvbnRwYWdlQXJ0aWNsZSA9ICh7IGFydGljbGUsIGlkLCBpc1dpZGUsIGxpY2Vuc2VCb3ggfTogUHJvcHMpID0+IHtcbiAgY29uc3QgeyBoZWlnaHQgPSAwIH0gPSB1c2VNYXN0aGVhZEhlaWdodCgpO1xuICBjb25zdCBjc3NWYXJzID0gdXNlTWVtbygoKSA9PiAoeyAnLS1tYXN0aGVhZC1oZWlnaHQnOiBgJHtoZWlnaHR9cHhgIH0gYXMgdW5rbm93biBhcyBDU1NQcm9wZXJ0aWVzKSwgW2hlaWdodF0pO1xuICBjb25zdCB7IHRpdGxlLCBpbnRyb2R1Y3Rpb24sIGNvbnRlbnQgfSA9IGFydGljbGU7XG5cbiAgaWYgKGlzV2lkZSkge1xuICAgIHJldHVybiAoXG4gICAgICA8U3R5bGVkQXJ0aWNsZSBkYXRhLXdpZGU9e2lzV2lkZX0gc3R5bGU9e2Nzc1ZhcnN9IGlkPXtpZH0+XG4gICAgICAgIDxMYXlvdXRJdGVtPntjb250ZW50fTwvTGF5b3V0SXRlbT5cbiAgICAgIDwvU3R5bGVkQXJ0aWNsZT5cbiAgICApO1xuICB9XG5cbiAgY29uc3QgYXV0aG9ycyA9XG4gICAgYXJ0aWNsZS5jb3B5cmlnaHQ/LmNyZWF0b3JzLmxlbmd0aCB8fCBhcnRpY2xlLmNvcHlyaWdodD8ucmlnaHRzaG9sZGVycy5sZW5ndGhcbiAgICAgID8gYXJ0aWNsZS5jb3B5cmlnaHQuY3JlYXRvcnNcbiAgICAgIDogYXJ0aWNsZS5jb3B5cmlnaHQ/LnByb2Nlc3NvcnM7XG4gIHJldHVybiAoXG4gICAgPFN0eWxlZEFydGljbGUgc3R5bGU9e2Nzc1ZhcnN9PlxuICAgICAgPExheW91dEl0ZW0+XG4gICAgICAgIDxIZWFkaW5nIGlkPXtpZH0gaGVhZGluZ1N0eWxlPVwiaDFcIiBlbGVtZW50PVwiaDFcIiBtYXJnaW49XCJub3JtYWxcIiB0YWJJbmRleD17LTF9PlxuICAgICAgICAgIHt0aXRsZX1cbiAgICAgICAgPC9IZWFkaW5nPlxuICAgICAgICA8U3R5bGVkSW50cm9kdWN0aW9uPntpbnRyb2R1Y3Rpb259PC9TdHlsZWRJbnRyb2R1Y3Rpb24+XG4gICAgICA8L0xheW91dEl0ZW0+XG4gICAgICA8TGF5b3V0SXRlbT57Y29udGVudH08L0xheW91dEl0ZW0+XG4gICAgICA8QXJ0aWNsZUJ5bGluZVxuICAgICAgICBhdXRob3JzPXthdXRob3JzfVxuICAgICAgICBzdXBwbGllcnM9e2FydGljbGUuY29weXJpZ2h0Py5yaWdodHNob2xkZXJzfVxuICAgICAgICBsaWNlbnNlPXthcnRpY2xlLmNvcHlyaWdodD8ubGljZW5zZT8ubGljZW5zZSF9XG4gICAgICAgIHB1Ymxpc2hlZD17YXJ0aWNsZS5wdWJsaXNoZWR9XG4gICAgICAgIGFjY29yZGlvbkhlYWRlclZhcmlhbnQ9eyd3aGl0ZSd9XG4gICAgICAgIGxpY2Vuc2VCb3g9e2xpY2Vuc2VCb3h9XG4gICAgICAvPlxuICAgIDwvU3R5bGVkQXJ0aWNsZT5cbiAgKTtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IEZyb250cGFnZUFydGljbGU7XG4iXX0= */"));
|
|
24
24
|
var StyledIntroduction = /*#__PURE__*/_styled("div", {
|
|
25
25
|
target: "e10a6yg80",
|
|
26
26
|
label: "StyledIntroduction"
|
|
27
27
|
})("font-weight:", fonts.weight.light, ";font-family:", fonts.sans, ";margin-top:", spacing.small, ";", fonts.sizes('22px', '30px'), ";", mq.range({
|
|
28
28
|
from: breakpoints.tablet
|
|
29
|
-
}), "{margin-top:", spacing.mediumlarge, ";", fonts.sizes('26px', '36px'), ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkZyb250cGFnZUFydGljbGUudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXNEcUMiLCJmaWxlIjoiRnJvbnRwYWdlQXJ0aWNsZS50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAyMy1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCB7IENTU1Byb3BlcnRpZXMsIFJlYWN0Tm9kZSwgdXNlTWVtbyB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IGJyZWFrcG9pbnRzLCBmb250cywgbXEsIHNwYWNpbmcsIHNwYWNpbmdVbml0IH0gZnJvbSAnQG5kbGEvY29yZSc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBBcnRpY2xlIH0gZnJvbSAnLi4vdHlwZXMnO1xuaW1wb3J0IExheW91dEl0ZW0gZnJvbSAnLi4vTGF5b3V0JztcbmltcG9ydCB7IEhlYWRpbmcgfSBmcm9tICcuLi9UeXBvZ3JhcGh5JztcbmltcG9ydCB7IEFydGljbGVCeWxpbmUgfSBmcm9tICcuLi9BcnRpY2xlJztcbmltcG9ydCB7IHVzZU1hc3RoZWFkSGVpZ2h0IH0gZnJvbSAnLi4vTWFzdGhlYWQnO1xuXG5pbnRlcmZhY2UgUHJvcHMge1xuICBhcnRpY2xlOiBPbWl0PEFydGljbGUsICdmb290Tm90ZXMnPjtcbiAgaWQ6IHN0cmluZztcbiAgaXNXaWRlPzogYm9vbGVhbjtcbiAgbGljZW5zZUJveD86IFJlYWN0Tm9kZTtcbn1cblxuZXhwb3J0IGNvbnN0IEZST05UUEFHRV9BUlRJQ0xFX01BWF9XSURUSCA9ICc3NzNweCc7XG5leHBvcnQgY29uc3QgV0lERV9GUk9OVFBBR0VfQVJUSUNMRV9NQVhfV0lEVEggPSAnMTEwMHB4JztcblxuY29uc3QgU3R5bGVkQXJ0aWNsZSA9IHN0eWxlZC5hcnRpY2xlYFxuICB3aWR0aDogMTAwJTtcbiAgbWF4LXdpZHRoOiA3NzNweDtcbiAgaDJbaWRdIHtcbiAgICBtYXJnaW4tdG9wOiAke3NwYWNpbmcubGFyZ2V9O1xuICB9XG4gIGRpdltkYXRhLXR5cGU9J2NhbXBhaWduLWJsb2NrJ10ge1xuICAgIG1hcmdpbjogJHtzcGFjaW5nLmxhcmdlfSAwcHg7XG4gIH1cbiAgZGl2W2RhdGEtdHlwZT0nZ3JpZCddIHtcbiAgICBoMixcbiAgICBoMyxcbiAgICBoNCB7XG4gICAgICBtYXJnaW4tdG9wOiAwcHg7XG4gICAgfVxuICB9XG4gICZbZGF0YS13aWRlPSd0cnVlJ10ge1xuICAgIG1heC13aWR0aDogMTEwMHB4O1xuICAgIGgyW2lkXSB7XG4gICAgICBtYXJnaW4tdG9wOiAke3NwYWNpbmdVbml0ICogNH1weDtcbiAgICB9XG4gICAgZGl2W2RhdGEtdHlwZT0nY2FtcGFpZ24tYmxvY2snXSB7XG4gICAgICBtYXJnaW46ICR7c3BhY2luZ1VuaXQgKiA0fXB4IDBweDtcbiAgICB9XG4gIH1cbmA7XG5cbmNvbnN0IFN0eWxlZEludHJvZHVjdGlvbiA9IHN0eWxlZC5kaXZgXG4gIGZvbnQtd2VpZ2h0OiAke2ZvbnRzLndlaWdodC5saWdodH07XG4gIGZvbnQtZmFtaWx5OiAke2ZvbnRzLnNhbnN9O1xuICBtYXJnaW4tdG9wOiAke3NwYWNpbmcuc21hbGx9O1xuICAke2ZvbnRzLnNpemVzKCcyMnB4JywgJzMwcHgnKX07XG5cbiAgJHttcS5yYW5nZSh7IGZyb206IGJyZWFrcG9pbnRzLnRhYmxldCB9KX0ge1xuICAgIG1hcmdpbi10b3A6ICR7c3BhY2luZy5tZWRpdW1sYXJnZX07XG4gICAgJHtmb250cy5zaXplcygnMjZweCcsICczNnB4Jyl9O1xuICB9XG5gO1xuXG5leHBvcnQgY29uc3QgRnJvbnRwYWdlQXJ0aWNsZSA9ICh7IGFydGljbGUsIGlkLCBpc1dpZGUsIGxpY2Vuc2VCb3ggfTogUHJvcHMpID0+
|
|
29
|
+
}), "{margin-top:", spacing.mediumlarge, ";", fonts.sizes('26px', '36px'), ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkZyb250cGFnZUFydGljbGUudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXNEcUMiLCJmaWxlIjoiRnJvbnRwYWdlQXJ0aWNsZS50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAyMy1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCB7IENTU1Byb3BlcnRpZXMsIFJlYWN0Tm9kZSwgdXNlTWVtbyB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IGJyZWFrcG9pbnRzLCBmb250cywgbXEsIHNwYWNpbmcsIHNwYWNpbmdVbml0IH0gZnJvbSAnQG5kbGEvY29yZSc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBBcnRpY2xlIH0gZnJvbSAnLi4vdHlwZXMnO1xuaW1wb3J0IExheW91dEl0ZW0gZnJvbSAnLi4vTGF5b3V0JztcbmltcG9ydCB7IEhlYWRpbmcgfSBmcm9tICcuLi9UeXBvZ3JhcGh5JztcbmltcG9ydCB7IEFydGljbGVCeWxpbmUgfSBmcm9tICcuLi9BcnRpY2xlJztcbmltcG9ydCB7IHVzZU1hc3RoZWFkSGVpZ2h0IH0gZnJvbSAnLi4vTWFzdGhlYWQnO1xuXG5pbnRlcmZhY2UgUHJvcHMge1xuICBhcnRpY2xlOiBPbWl0PEFydGljbGUsICdmb290Tm90ZXMnPjtcbiAgaWQ6IHN0cmluZztcbiAgaXNXaWRlPzogYm9vbGVhbjtcbiAgbGljZW5zZUJveD86IFJlYWN0Tm9kZTtcbn1cblxuZXhwb3J0IGNvbnN0IEZST05UUEFHRV9BUlRJQ0xFX01BWF9XSURUSCA9ICc3NzNweCc7XG5leHBvcnQgY29uc3QgV0lERV9GUk9OVFBBR0VfQVJUSUNMRV9NQVhfV0lEVEggPSAnMTEwMHB4JztcblxuY29uc3QgU3R5bGVkQXJ0aWNsZSA9IHN0eWxlZC5hcnRpY2xlYFxuICB3aWR0aDogMTAwJTtcbiAgbWF4LXdpZHRoOiA3NzNweDtcbiAgaDJbaWRdIHtcbiAgICBtYXJnaW4tdG9wOiAke3NwYWNpbmcubGFyZ2V9O1xuICB9XG4gIGRpdltkYXRhLXR5cGU9J2NhbXBhaWduLWJsb2NrJ10ge1xuICAgIG1hcmdpbjogJHtzcGFjaW5nLmxhcmdlfSAwcHg7XG4gIH1cbiAgZGl2W2RhdGEtdHlwZT0nZ3JpZCddIHtcbiAgICBoMixcbiAgICBoMyxcbiAgICBoNCB7XG4gICAgICBtYXJnaW4tdG9wOiAwcHg7XG4gICAgfVxuICB9XG4gICZbZGF0YS13aWRlPSd0cnVlJ10ge1xuICAgIG1heC13aWR0aDogMTEwMHB4O1xuICAgIGgyW2lkXSB7XG4gICAgICBtYXJnaW4tdG9wOiAke3NwYWNpbmdVbml0ICogNH1weDtcbiAgICB9XG4gICAgZGl2W2RhdGEtdHlwZT0nY2FtcGFpZ24tYmxvY2snXSB7XG4gICAgICBtYXJnaW46ICR7c3BhY2luZ1VuaXQgKiA0fXB4IDBweDtcbiAgICB9XG4gIH1cbmA7XG5cbmNvbnN0IFN0eWxlZEludHJvZHVjdGlvbiA9IHN0eWxlZC5kaXZgXG4gIGZvbnQtd2VpZ2h0OiAke2ZvbnRzLndlaWdodC5saWdodH07XG4gIGZvbnQtZmFtaWx5OiAke2ZvbnRzLnNhbnN9O1xuICBtYXJnaW4tdG9wOiAke3NwYWNpbmcuc21hbGx9O1xuICAke2ZvbnRzLnNpemVzKCcyMnB4JywgJzMwcHgnKX07XG5cbiAgJHttcS5yYW5nZSh7IGZyb206IGJyZWFrcG9pbnRzLnRhYmxldCB9KX0ge1xuICAgIG1hcmdpbi10b3A6ICR7c3BhY2luZy5tZWRpdW1sYXJnZX07XG4gICAgJHtmb250cy5zaXplcygnMjZweCcsICczNnB4Jyl9O1xuICB9XG5gO1xuXG5leHBvcnQgY29uc3QgRnJvbnRwYWdlQXJ0aWNsZSA9ICh7IGFydGljbGUsIGlkLCBpc1dpZGUsIGxpY2Vuc2VCb3ggfTogUHJvcHMpID0+IHtcbiAgY29uc3QgeyBoZWlnaHQgPSAwIH0gPSB1c2VNYXN0aGVhZEhlaWdodCgpO1xuICBjb25zdCBjc3NWYXJzID0gdXNlTWVtbygoKSA9PiAoeyAnLS1tYXN0aGVhZC1oZWlnaHQnOiBgJHtoZWlnaHR9cHhgIH0gYXMgdW5rbm93biBhcyBDU1NQcm9wZXJ0aWVzKSwgW2hlaWdodF0pO1xuICBjb25zdCB7IHRpdGxlLCBpbnRyb2R1Y3Rpb24sIGNvbnRlbnQgfSA9IGFydGljbGU7XG5cbiAgaWYgKGlzV2lkZSkge1xuICAgIHJldHVybiAoXG4gICAgICA8U3R5bGVkQXJ0aWNsZSBkYXRhLXdpZGU9e2lzV2lkZX0gc3R5bGU9e2Nzc1ZhcnN9IGlkPXtpZH0+XG4gICAgICAgIDxMYXlvdXRJdGVtPntjb250ZW50fTwvTGF5b3V0SXRlbT5cbiAgICAgIDwvU3R5bGVkQXJ0aWNsZT5cbiAgICApO1xuICB9XG5cbiAgY29uc3QgYXV0aG9ycyA9XG4gICAgYXJ0aWNsZS5jb3B5cmlnaHQ/LmNyZWF0b3JzLmxlbmd0aCB8fCBhcnRpY2xlLmNvcHlyaWdodD8ucmlnaHRzaG9sZGVycy5sZW5ndGhcbiAgICAgID8gYXJ0aWNsZS5jb3B5cmlnaHQuY3JlYXRvcnNcbiAgICAgIDogYXJ0aWNsZS5jb3B5cmlnaHQ/LnByb2Nlc3NvcnM7XG4gIHJldHVybiAoXG4gICAgPFN0eWxlZEFydGljbGUgc3R5bGU9e2Nzc1ZhcnN9PlxuICAgICAgPExheW91dEl0ZW0+XG4gICAgICAgIDxIZWFkaW5nIGlkPXtpZH0gaGVhZGluZ1N0eWxlPVwiaDFcIiBlbGVtZW50PVwiaDFcIiBtYXJnaW49XCJub3JtYWxcIiB0YWJJbmRleD17LTF9PlxuICAgICAgICAgIHt0aXRsZX1cbiAgICAgICAgPC9IZWFkaW5nPlxuICAgICAgICA8U3R5bGVkSW50cm9kdWN0aW9uPntpbnRyb2R1Y3Rpb259PC9TdHlsZWRJbnRyb2R1Y3Rpb24+XG4gICAgICA8L0xheW91dEl0ZW0+XG4gICAgICA8TGF5b3V0SXRlbT57Y29udGVudH08L0xheW91dEl0ZW0+XG4gICAgICA8QXJ0aWNsZUJ5bGluZVxuICAgICAgICBhdXRob3JzPXthdXRob3JzfVxuICAgICAgICBzdXBwbGllcnM9e2FydGljbGUuY29weXJpZ2h0Py5yaWdodHNob2xkZXJzfVxuICAgICAgICBsaWNlbnNlPXthcnRpY2xlLmNvcHlyaWdodD8ubGljZW5zZT8ubGljZW5zZSF9XG4gICAgICAgIHB1Ymxpc2hlZD17YXJ0aWNsZS5wdWJsaXNoZWR9XG4gICAgICAgIGFjY29yZGlvbkhlYWRlclZhcmlhbnQ9eyd3aGl0ZSd9XG4gICAgICAgIGxpY2Vuc2VCb3g9e2xpY2Vuc2VCb3h9XG4gICAgICAvPlxuICAgIDwvU3R5bGVkQXJ0aWNsZT5cbiAgKTtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IEZyb250cGFnZUFydGljbGU7XG4iXX0= */"));
|
|
30
30
|
export var FrontpageArticle = function FrontpageArticle(_ref) {
|
|
31
31
|
var _article$copyright, _article$copyright2, _article$copyright3, _article$copyright4, _article$copyright5, _article$copyright5$l;
|
|
32
32
|
var article = _ref.article,
|
|
@@ -48,6 +48,7 @@ export var FrontpageArticle = function FrontpageArticle(_ref) {
|
|
|
48
48
|
return _jsx(StyledArticle, {
|
|
49
49
|
"data-wide": isWide,
|
|
50
50
|
style: cssVars,
|
|
51
|
+
id: id,
|
|
51
52
|
children: _jsx(LayoutItem, {
|
|
52
53
|
children: content
|
|
53
54
|
})
|