@ndla/ui 6.2.1 → 8.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/es/Masthead/Masthead.js +7 -2
- package/es/MessageBox/MessageBox.js +26 -12
- package/es/Notion/FigureNotion.js +0 -1
- package/es/Notion/Notion.js +13 -14
- package/es/Notion/NotionVisualElement.js +1 -1
- package/es/SearchTypeResult/SearchItem.js +9 -9
- package/es/locale/messages-en.js +2 -2
- package/es/locale/messages-nb.js +2 -2
- package/es/locale/messages-nn.js +2 -2
- package/lib/Masthead/Masthead.d.ts +9 -3
- package/lib/Masthead/Masthead.js +7 -2
- package/lib/MessageBox/MessageBox.d.ts +3 -2
- package/lib/MessageBox/MessageBox.js +25 -11
- package/lib/Notion/FigureNotion.js +0 -1
- package/lib/Notion/Notion.d.ts +1 -2
- package/lib/Notion/Notion.js +13 -14
- package/lib/Notion/NotionVisualElement.js +1 -1
- package/lib/SearchTypeResult/SearchItem.js +9 -9
- package/lib/locale/messages-en.d.ts +2 -2
- package/lib/locale/messages-en.js +2 -2
- package/lib/locale/messages-nb.d.ts +2 -2
- package/lib/locale/messages-nb.js +2 -2
- package/lib/locale/messages-nn.d.ts +2 -2
- package/lib/locale/messages-nn.js +2 -2
- package/package.json +3 -2
- package/src/Masthead/Masthead.tsx +15 -2
- package/src/MessageBox/MessageBox.tsx +22 -2
- package/src/Notion/FigureNotion.tsx +0 -1
- package/src/Notion/Notion.tsx +3 -15
- package/src/Notion/NotionVisualElement.tsx +1 -1
- package/src/SearchTypeResult/SearchItem.tsx +1 -8
- package/src/locale/messages-en.ts +2 -2
- package/src/locale/messages-nb.ts +2 -2
- package/src/locale/messages-nn.ts +2 -2
|
@@ -56,14 +56,14 @@ var Container = _styled("div", {
|
|
|
56
56
|
} : {
|
|
57
57
|
name: "1f9iwsz",
|
|
58
58
|
styles: "display:flex;height:400px;align-items:center;justify-content:center;",
|
|
59
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlNlYXJjaEl0ZW0udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWlENEIiLCJmaWxlIjoiU2VhcmNoSXRlbS50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAyMC1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgcGFyc2UgZnJvbSAnaHRtbC1yZWFjdC1wYXJzZXInO1xuXG5pbXBvcnQgU2FmZUxpbmsgZnJvbSAnQG5kbGEvc2FmZWxpbmsnO1xuaW1wb3J0IHsgYW5pbWF0aW9ucywgY29sb3JzLCBmb250cywgc3BhY2luZyB9IGZyb20gJ0BuZGxhL2NvcmUnO1xuXG5pbXBvcnQgeyBDb250ZW50VHlwZSB9IGZyb20gJy4vU2VhcmNoVHlwZVJlc3VsdCc7XG5pbXBvcnQgY29uc3RhbnRzIGZyb20gJy4uL21vZGVsJztcbmltcG9ydCBJdGVtQ29udGV4dHMsIHsgSXRlbUNvbnRleHRzVHlwZSB9IGZyb20gJy4vY29tcG9uZW50cy9JdGVtQ29udGV4dHMnO1xuaW1wb3J0IEl0ZW1Ub3BpY0hlYWRlciBmcm9tICcuL2NvbXBvbmVudHMvSXRlbVRvcGljSGVhZGVyJztcbmltcG9ydCBJdGVtUmVzb3VyY2VIZWFkZXIgZnJvbSAnLi9jb21wb25lbnRzL0l0ZW1SZXNvdXJjZUhlYWRlcic7XG5cbmNvbnN0IHsgY29udGVudFR5cGVzIH0gPSBjb25zdGFudHM7XG5cbmV4cG9ydCBjb25zdCByZXNvdXJjZVR5cGVDb2xvciA9ICh0eXBlOiBzdHJpbmcpID0+IHtcbiAgc3dpdGNoICh0eXBlKSB7XG4gICAgY2FzZSBjb250ZW50VHlwZXMuU1VCSkVDVF9NQVRFUklBTDpcbiAgICAgIHJldHVybiBjb2xvcnMuc3ViamVjdE1hdGVyaWFsLmxpZ2h0O1xuICAgIGNhc2UgY29udGVudFR5cGVzLlRPUElDOlxuICAgICAgcmV0dXJuIGNvbG9ycy5zdWJqZWN0LmxpZ2h0O1xuICAgIGNhc2UgY29udGVudFR5cGVzLlRBU0tTX0FORF9BQ1RJVklUSUVTOlxuICAgICAgcmV0dXJuIGNvbG9ycy50YXNrc0FuZEFjdGl2aXRpZXMubGlnaHQ7XG4gICAgY2FzZSBjb250ZW50VHlwZXMuQVNTRVNTTUVOVF9SRVNPVVJDRVM6XG4gICAgICByZXR1cm4gY29sb3JzLmFzc2Vzc21lbnRSZXNvdXJjZS5saWdodDtcbiAgICBjYXNlIGNvbnRlbnRUeXBlcy5FWFRFUk5BTF9MRUFSTklOR19SRVNPVVJDRVM6XG4gICAgICByZXR1cm4gY29sb3JzLmV4dGVybmFsTGVhcm5pbmdSZXNvdXJjZS5saWdodDtcbiAgICBjYXNlIGNvbnRlbnRUeXBlcy5TT1VSQ0VfTUFURVJJQUw6XG4gICAgICByZXR1cm4gY29sb3JzLnNvdXJjZU1hdGVyaWFsLmxpZ2h0O1xuICAgIGNhc2UgY29udGVudFR5cGVzLkxFQVJOSU5HX1BBVEg6XG4gICAgICByZXR1cm4gY29sb3JzLmxlYXJuaW5nUGF0aC5saWdodDtcbiAgICBkZWZhdWx0OlxuICAgICAgcmV0dXJuICcnO1xuICB9XG59O1xuXG50eXBlIEl0ZW1UeXBlUHJvcHMgPSB7XG4gIGNvbnRlbnRUeXBlPzogQ29udGVudFR5cGU7XG4gIGlzVG9waWM/
|
|
59
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchItem.tsx"],"names":[],"mappings":"AAiD4B","file":"SearchItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n\nimport SafeLink from '@ndla/safelink';\nimport { animations, colors, fonts, spacing } from '@ndla/core';\n\nimport { ContentType } from './SearchTypeResult';\nimport constants from '../model';\nimport ItemContexts, { ItemContextsType } from './components/ItemContexts';\nimport ItemTopicHeader from './components/ItemTopicHeader';\nimport ItemResourceHeader from './components/ItemResourceHeader';\n\nconst { contentTypes } = constants;\n\nexport const resourceTypeColor = (type: string) => {\n  switch (type) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.light;\n    case contentTypes.TOPIC:\n      return colors.subject.light;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.light;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.light;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.light;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.light;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.light;\n    default:\n      return '';\n  }\n};\n\ntype ItemTypeProps = {\n  contentType?: ContentType;\n  isTopic?: boolean;\n};\n\nconst Container = styled.div`\n  display: flex;\n  height: 400px;\n  align-items: center;\n  justify-content: center;\n`;\n\nconst ItemWrapper = styled.div`\n  flex-direction: column;\n  display: flex;\n  width: 100%;\n  height: 100%;\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: 5px;\n  transition: all ${animations.durations.fast} ease-in-out;\n  &:hover {\n    height: calc(100% + 4px);\n    width: calc(100% + 4px);\n    .topic-header-image {\n      height: calc(100% + 6px);\n      width: calc(100% + 6px);\n    }\n    .topic-label {\n      svg {\n        transform: scale(1.2);\n      }\n    }\n    .topic-label-list {\n      margin-left: 2px;\n    }\n    .resource-type-wrapper {\n      padding: 0 calc(${spacing.normal} + 2px);\n      .resource-icon-wrapper {\n        left: 19px;\n        svg {\n          transform: scale(1.2);\n        }\n      }\n    }\n    .resource-no-image {\n      background-color: ${colors.brand.greyLightest};\n      .c-content-type-badge {\n        width: 26px;\n        height: 26px;\n        left: 45px;\n        margin-left: 0;\n        top: 100%;\n        margin-top: -13px;\n        opacity: 1;\n      }\n    }\n  }\n`;\n\nconst ItemLink = styled(SafeLink)`\n  box-shadow: none;\n  color: unset;\n  text-decoration: none;\n  display: flex;\n  flex-direction: column;\n  position: relative;\n  min-height: 0;\n  flex: 1;\n`;\n\nconst TextWrapper = styled.div`\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n`;\n\nconst ItemTitleWrapper = styled.div<ItemTypeProps>`\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `${ItemWrapper}:hover & {\n    padding-left:2px; padding-right: 2px;}`};\n`;\n\nconst ItemTitle = styled.h3<ItemTypeProps>`\n  ${fonts.sizes('24px', '28px')};\n  color: ${colors.brand.primary};\n  ${(props) => props.isTopic && `margin-bottom: ${spacing.small};`};\n  font-weight: ${fonts.weight.semibold};\n  overflow-wrap: anywhere;\n  display: inline;\n  ${ItemWrapper}:hover & {\n    box-shadow: inset 0 -1px;\n    background-color: transparent;\n  }\n`;\nconst ItemText = styled.div<ItemTypeProps>`\n  overflow: hidden;\n  ${fonts.sizes('16px', '24px')};\n  word-break: break-word;\n  overflow-wrap: anywhere;\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `\n    ${fonts.sizes('18px', '28px')};\n    `};\n`;\n\nconst ContextWrapper = styled.div`\n  background: white;\n  z-index: 1;\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n  ${ItemWrapper}:hover & {\n    padding-left: calc(${spacing.normal} + 2px);\n    padding-right: calc(${spacing.normal} + 2px);\n    padding-bottom: calc(${spacing.small} + 2px);\n  }\n`;\n\nexport type SearchItemProps = {\n  id: string | number;\n  title: string;\n  url: string;\n  ingress: string;\n  contexts?: ItemContextsType['contexts'];\n  img?: { url: string; alt: string };\n  labels?: string[];\n  type?: ContentType;\n};\nexport type SearchItemType = {\n  item: SearchItemProps;\n  type?: ContentType;\n};\nconst SearchItem = ({ item, type }: SearchItemType) => {\n  const { title, url, ingress, contexts, img = null, labels = [] } = item;\n\n  const isTopic = type === contentTypes.TOPIC || type === contentTypes.MULTIDISCIPLINARY_TOPIC;\n\n  return (\n    <Container>\n      <ItemWrapper>\n        <ItemLink to={url}>\n          {isTopic ? (\n            <ItemTopicHeader image={img} type={type}>\n              <ItemTitleWrapper isTopic>\n                <ItemTitle isTopic>{title}</ItemTitle>\n              </ItemTitleWrapper>\n              <ItemText isTopic>{parse(ingress)}</ItemText>\n            </ItemTopicHeader>\n          ) : (\n            <>\n              <ItemResourceHeader labels={labels} img={img} type={type} />\n              <TextWrapper>\n                <ItemTitleWrapper>\n                  <ItemTitle>{title}</ItemTitle>\n                </ItemTitleWrapper>\n                <ItemText>{parse(ingress)}</ItemText>\n              </TextWrapper>\n            </>\n          )}\n          <ContextWrapper>\n            {contexts && contexts.length > 0 && <ItemContexts contexts={contexts} id={item.id} title={item.title} />}\n          </ContextWrapper>\n        </ItemLink>\n      </ItemWrapper>\n    </Container>\n  );\n};\n\nexport default SearchItem;\n"]} */",
|
|
60
60
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
61
61
|
});
|
|
62
62
|
|
|
63
63
|
var ItemWrapper = _styled("div", {
|
|
64
64
|
target: "e1hz9lam1",
|
|
65
65
|
label: "ItemWrapper"
|
|
66
|
-
})("flex-direction:column;display:flex;width:100%;height:100%;border:1px solid ", colors.brand.neutral7, ";border-radius:5px;transition:all ", animations.durations.fast, " ease-in-out;&:hover{height:calc(100% + 4px);width:calc(100% + 4px);.topic-header-image{height:calc(100% + 6px);width:calc(100% + 6px);}.topic-label{svg{transform:scale(1.2);}}.topic-label-list{margin-left:2px;}.resource-type-wrapper{padding:0 calc(", spacing.normal, " + 2px);.resource-icon-wrapper{left:19px;svg{transform:scale(1.2);}}}.resource-no-image{background-color:", colors.brand.greyLightest, ";.c-content-type-badge{width:26px;height:26px;left:45px;margin-left:0;top:100%;margin-top:-13px;opacity:1;}}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlNlYXJjaEl0ZW0udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXdEOEIiLCJmaWxlIjoiU2VhcmNoSXRlbS50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAyMC1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgcGFyc2UgZnJvbSAnaHRtbC1yZWFjdC1wYXJzZXInO1xuXG5pbXBvcnQgU2FmZUxpbmsgZnJvbSAnQG5kbGEvc2FmZWxpbmsnO1xuaW1wb3J0IHsgYW5pbWF0aW9ucywgY29sb3JzLCBmb250cywgc3BhY2luZyB9IGZyb20gJ0BuZGxhL2NvcmUnO1xuXG5pbXBvcnQgeyBDb250ZW50VHlwZSB9IGZyb20gJy4vU2VhcmNoVHlwZVJlc3VsdCc7XG5pbXBvcnQgY29uc3RhbnRzIGZyb20gJy4uL21vZGVsJztcbmltcG9ydCBJdGVtQ29udGV4dHMsIHsgSXRlbUNvbnRleHRzVHlwZSB9IGZyb20gJy4vY29tcG9uZW50cy9JdGVtQ29udGV4dHMnO1xuaW1wb3J0IEl0ZW1Ub3BpY0hlYWRlciBmcm9tICcuL2NvbXBvbmVudHMvSXRlbVRvcGljSGVhZGVyJztcbmltcG9ydCBJdGVtUmVzb3VyY2VIZWFkZXIgZnJvbSAnLi9jb21wb25lbnRzL0l0ZW1SZXNvdXJjZUhlYWRlcic7XG5cbmNvbnN0IHsgY29udGVudFR5cGVzIH0gPSBjb25zdGFudHM7XG5cbmV4cG9ydCBjb25zdCByZXNvdXJjZVR5cGVDb2xvciA9ICh0eXBlOiBzdHJpbmcpID0+IHtcbiAgc3dpdGNoICh0eXBlKSB7XG4gICAgY2FzZSBjb250ZW50VHlwZXMuU1VCSkVDVF9NQVRFUklBTDpcbiAgICAgIHJldHVybiBjb2xvcnMuc3ViamVjdE1hdGVyaWFsLmxpZ2h0O1xuICAgIGNhc2UgY29udGVudFR5cGVzLlRPUElDOlxuICAgICAgcmV0dXJuIGNvbG9ycy5zdWJqZWN0LmxpZ2h0O1xuICAgIGNhc2UgY29udGVudFR5cGVzLlRBU0tTX0FORF9BQ1RJVklUSUVTOlxuICAgICAgcmV0dXJuIGNvbG9ycy50YXNrc0FuZEFjdGl2aXRpZXMubGlnaHQ7XG4gICAgY2FzZSBjb250ZW50VHlwZXMuQVNTRVNTTUVOVF9SRVNPVVJDRVM6XG4gICAgICByZXR1cm4gY29sb3JzLmFzc2Vzc21lbnRSZXNvdXJjZS5saWdodDtcbiAgICBjYXNlIGNvbnRlbnRUeXBlcy5FWFRFUk5BTF9MRUFSTklOR19SRVNPVVJDRVM6XG4gICAgICByZXR1cm4gY29sb3JzLmV4dGVybmFsTGVhcm5pbmdSZXNvdXJjZS5saWdodDtcbiAgICBjYXNlIGNvbnRlbnRUeXBlcy5TT1VSQ0VfTUFURVJJQUw6XG4gICAgICByZXR1cm4gY29sb3JzLnNvdXJjZU1hdGVyaWFsLmxpZ2h0O1xuICAgIGNhc2UgY29udGVudFR5cGVzLkxFQVJOSU5HX1BBVEg6XG4gICAgICByZXR1cm4gY29sb3JzLmxlYXJuaW5nUGF0aC5saWdodDtcbiAgICBkZWZhdWx0OlxuICAgICAgcmV0dXJuICcnO1xuICB9XG59O1xuXG50eXBlIEl0ZW1UeXBlUHJvcHMgPSB7XG4gIGNvbnRlbnRUeXBlPzogQ29udGVudFR5cGU7XG4gIGlzVG9waWM/
|
|
66
|
+
})("flex-direction:column;display:flex;width:100%;height:100%;border:1px solid ", colors.brand.neutral7, ";border-radius:5px;transition:all ", animations.durations.fast, " ease-in-out;&:hover{height:calc(100% + 4px);width:calc(100% + 4px);.topic-header-image{height:calc(100% + 6px);width:calc(100% + 6px);}.topic-label{svg{transform:scale(1.2);}}.topic-label-list{margin-left:2px;}.resource-type-wrapper{padding:0 calc(", spacing.normal, " + 2px);.resource-icon-wrapper{left:19px;svg{transform:scale(1.2);}}}.resource-no-image{background-color:", colors.brand.greyLightest, ";.c-content-type-badge{width:26px;height:26px;left:45px;margin-left:0;top:100%;margin-top:-13px;opacity:1;}}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchItem.tsx"],"names":[],"mappings":"AAwD8B","file":"SearchItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n\nimport SafeLink from '@ndla/safelink';\nimport { animations, colors, fonts, spacing } from '@ndla/core';\n\nimport { ContentType } from './SearchTypeResult';\nimport constants from '../model';\nimport ItemContexts, { ItemContextsType } from './components/ItemContexts';\nimport ItemTopicHeader from './components/ItemTopicHeader';\nimport ItemResourceHeader from './components/ItemResourceHeader';\n\nconst { contentTypes } = constants;\n\nexport const resourceTypeColor = (type: string) => {\n  switch (type) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.light;\n    case contentTypes.TOPIC:\n      return colors.subject.light;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.light;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.light;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.light;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.light;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.light;\n    default:\n      return '';\n  }\n};\n\ntype ItemTypeProps = {\n  contentType?: ContentType;\n  isTopic?: boolean;\n};\n\nconst Container = styled.div`\n  display: flex;\n  height: 400px;\n  align-items: center;\n  justify-content: center;\n`;\n\nconst ItemWrapper = styled.div`\n  flex-direction: column;\n  display: flex;\n  width: 100%;\n  height: 100%;\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: 5px;\n  transition: all ${animations.durations.fast} ease-in-out;\n  &:hover {\n    height: calc(100% + 4px);\n    width: calc(100% + 4px);\n    .topic-header-image {\n      height: calc(100% + 6px);\n      width: calc(100% + 6px);\n    }\n    .topic-label {\n      svg {\n        transform: scale(1.2);\n      }\n    }\n    .topic-label-list {\n      margin-left: 2px;\n    }\n    .resource-type-wrapper {\n      padding: 0 calc(${spacing.normal} + 2px);\n      .resource-icon-wrapper {\n        left: 19px;\n        svg {\n          transform: scale(1.2);\n        }\n      }\n    }\n    .resource-no-image {\n      background-color: ${colors.brand.greyLightest};\n      .c-content-type-badge {\n        width: 26px;\n        height: 26px;\n        left: 45px;\n        margin-left: 0;\n        top: 100%;\n        margin-top: -13px;\n        opacity: 1;\n      }\n    }\n  }\n`;\n\nconst ItemLink = styled(SafeLink)`\n  box-shadow: none;\n  color: unset;\n  text-decoration: none;\n  display: flex;\n  flex-direction: column;\n  position: relative;\n  min-height: 0;\n  flex: 1;\n`;\n\nconst TextWrapper = styled.div`\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n`;\n\nconst ItemTitleWrapper = styled.div<ItemTypeProps>`\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `${ItemWrapper}:hover & {\n    padding-left:2px; padding-right: 2px;}`};\n`;\n\nconst ItemTitle = styled.h3<ItemTypeProps>`\n  ${fonts.sizes('24px', '28px')};\n  color: ${colors.brand.primary};\n  ${(props) => props.isTopic && `margin-bottom: ${spacing.small};`};\n  font-weight: ${fonts.weight.semibold};\n  overflow-wrap: anywhere;\n  display: inline;\n  ${ItemWrapper}:hover & {\n    box-shadow: inset 0 -1px;\n    background-color: transparent;\n  }\n`;\nconst ItemText = styled.div<ItemTypeProps>`\n  overflow: hidden;\n  ${fonts.sizes('16px', '24px')};\n  word-break: break-word;\n  overflow-wrap: anywhere;\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `\n    ${fonts.sizes('18px', '28px')};\n    `};\n`;\n\nconst ContextWrapper = styled.div`\n  background: white;\n  z-index: 1;\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n  ${ItemWrapper}:hover & {\n    padding-left: calc(${spacing.normal} + 2px);\n    padding-right: calc(${spacing.normal} + 2px);\n    padding-bottom: calc(${spacing.small} + 2px);\n  }\n`;\n\nexport type SearchItemProps = {\n  id: string | number;\n  title: string;\n  url: string;\n  ingress: string;\n  contexts?: ItemContextsType['contexts'];\n  img?: { url: string; alt: string };\n  labels?: string[];\n  type?: ContentType;\n};\nexport type SearchItemType = {\n  item: SearchItemProps;\n  type?: ContentType;\n};\nconst SearchItem = ({ item, type }: SearchItemType) => {\n  const { title, url, ingress, contexts, img = null, labels = [] } = item;\n\n  const isTopic = type === contentTypes.TOPIC || type === contentTypes.MULTIDISCIPLINARY_TOPIC;\n\n  return (\n    <Container>\n      <ItemWrapper>\n        <ItemLink to={url}>\n          {isTopic ? (\n            <ItemTopicHeader image={img} type={type}>\n              <ItemTitleWrapper isTopic>\n                <ItemTitle isTopic>{title}</ItemTitle>\n              </ItemTitleWrapper>\n              <ItemText isTopic>{parse(ingress)}</ItemText>\n            </ItemTopicHeader>\n          ) : (\n            <>\n              <ItemResourceHeader labels={labels} img={img} type={type} />\n              <TextWrapper>\n                <ItemTitleWrapper>\n                  <ItemTitle>{title}</ItemTitle>\n                </ItemTitleWrapper>\n                <ItemText>{parse(ingress)}</ItemText>\n              </TextWrapper>\n            </>\n          )}\n          <ContextWrapper>\n            {contexts && contexts.length > 0 && <ItemContexts contexts={contexts} id={item.id} title={item.title} />}\n          </ContextWrapper>\n        </ItemLink>\n      </ItemWrapper>\n    </Container>\n  );\n};\n\nexport default SearchItem;\n"]} */"));
|
|
67
67
|
|
|
68
68
|
var ItemLink = /*#__PURE__*/_styled(SafeLink, {
|
|
69
69
|
target: "e1hz9lam2",
|
|
@@ -74,40 +74,40 @@ var ItemLink = /*#__PURE__*/_styled(SafeLink, {
|
|
|
74
74
|
} : {
|
|
75
75
|
name: "lqgaa6",
|
|
76
76
|
styles: "box-shadow:none;color:unset;text-decoration:none;display:flex;flex-direction:column;position:relative;min-height:0;flex:1;",
|
|
77
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlNlYXJjaEl0ZW0udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXVHaUMiLCJmaWxlIjoiU2VhcmNoSXRlbS50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAyMC1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgcGFyc2UgZnJvbSAnaHRtbC1yZWFjdC1wYXJzZXInO1xuXG5pbXBvcnQgU2FmZUxpbmsgZnJvbSAnQG5kbGEvc2FmZWxpbmsnO1xuaW1wb3J0IHsgYW5pbWF0aW9ucywgY29sb3JzLCBmb250cywgc3BhY2luZyB9IGZyb20gJ0BuZGxhL2NvcmUnO1xuXG5pbXBvcnQgeyBDb250ZW50VHlwZSB9IGZyb20gJy4vU2VhcmNoVHlwZVJlc3VsdCc7XG5pbXBvcnQgY29uc3RhbnRzIGZyb20gJy4uL21vZGVsJztcbmltcG9ydCBJdGVtQ29udGV4dHMsIHsgSXRlbUNvbnRleHRzVHlwZSB9IGZyb20gJy4vY29tcG9uZW50cy9JdGVtQ29udGV4dHMnO1xuaW1wb3J0IEl0ZW1Ub3BpY0hlYWRlciBmcm9tICcuL2NvbXBvbmVudHMvSXRlbVRvcGljSGVhZGVyJztcbmltcG9ydCBJdGVtUmVzb3VyY2VIZWFkZXIgZnJvbSAnLi9jb21wb25lbnRzL0l0ZW1SZXNvdXJjZUhlYWRlcic7XG5cbmNvbnN0IHsgY29udGVudFR5cGVzIH0gPSBjb25zdGFudHM7XG5cbmV4cG9ydCBjb25zdCByZXNvdXJjZVR5cGVDb2xvciA9ICh0eXBlOiBzdHJpbmcpID0+IHtcbiAgc3dpdGNoICh0eXBlKSB7XG4gICAgY2FzZSBjb250ZW50VHlwZXMuU1VCSkVDVF9NQVRFUklBTDpcbiAgICAgIHJldHVybiBjb2xvcnMuc3ViamVjdE1hdGVyaWFsLmxpZ2h0O1xuICAgIGNhc2UgY29udGVudFR5cGVzLlRPUElDOlxuICAgICAgcmV0dXJuIGNvbG9ycy5zdWJqZWN0LmxpZ2h0O1xuICAgIGNhc2UgY29udGVudFR5cGVzLlRBU0tTX0FORF9BQ1RJVklUSUVTOlxuICAgICAgcmV0dXJuIGNvbG9ycy50YXNrc0FuZEFjdGl2aXRpZXMubGlnaHQ7XG4gICAgY2FzZSBjb250ZW50VHlwZXMuQVNTRVNTTUVOVF9SRVNPVVJDRVM6XG4gICAgICByZXR1cm4gY29sb3JzLmFzc2Vzc21lbnRSZXNvdXJjZS5saWdodDtcbiAgICBjYXNlIGNvbnRlbnRUeXBlcy5FWFRFUk5BTF9MRUFSTklOR19SRVNPVVJDRVM6XG4gICAgICByZXR1cm4gY29sb3JzLmV4dGVybmFsTGVhcm5pbmdSZXNvdXJjZS5saWdodDtcbiAgICBjYXNlIGNvbnRlbnRUeXBlcy5TT1VSQ0VfTUFURVJJQUw6XG4gICAgICByZXR1cm4gY29sb3JzLnNvdXJjZU1hdGVyaWFsLmxpZ2h0O1xuICAgIGNhc2UgY29udGVudFR5cGVzLkxFQVJOSU5HX1BBVEg6XG4gICAgICByZXR1cm4gY29sb3JzLmxlYXJuaW5nUGF0aC5saWdodDtcbiAgICBkZWZhdWx0OlxuICAgICAgcmV0dXJuICcnO1xuICB9XG59O1xuXG50eXBlIEl0ZW1UeXBlUHJvcHMgPSB7XG4gIGNvbnRlbnRUeXBlPzogQ29udGVudFR5cGU7XG4gIGlzVG9waWM/
|
|
77
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchItem.tsx"],"names":[],"mappings":"AAuGiC","file":"SearchItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n\nimport SafeLink from '@ndla/safelink';\nimport { animations, colors, fonts, spacing } from '@ndla/core';\n\nimport { ContentType } from './SearchTypeResult';\nimport constants from '../model';\nimport ItemContexts, { ItemContextsType } from './components/ItemContexts';\nimport ItemTopicHeader from './components/ItemTopicHeader';\nimport ItemResourceHeader from './components/ItemResourceHeader';\n\nconst { contentTypes } = constants;\n\nexport const resourceTypeColor = (type: string) => {\n  switch (type) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.light;\n    case contentTypes.TOPIC:\n      return colors.subject.light;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.light;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.light;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.light;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.light;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.light;\n    default:\n      return '';\n  }\n};\n\ntype ItemTypeProps = {\n  contentType?: ContentType;\n  isTopic?: boolean;\n};\n\nconst Container = styled.div`\n  display: flex;\n  height: 400px;\n  align-items: center;\n  justify-content: center;\n`;\n\nconst ItemWrapper = styled.div`\n  flex-direction: column;\n  display: flex;\n  width: 100%;\n  height: 100%;\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: 5px;\n  transition: all ${animations.durations.fast} ease-in-out;\n  &:hover {\n    height: calc(100% + 4px);\n    width: calc(100% + 4px);\n    .topic-header-image {\n      height: calc(100% + 6px);\n      width: calc(100% + 6px);\n    }\n    .topic-label {\n      svg {\n        transform: scale(1.2);\n      }\n    }\n    .topic-label-list {\n      margin-left: 2px;\n    }\n    .resource-type-wrapper {\n      padding: 0 calc(${spacing.normal} + 2px);\n      .resource-icon-wrapper {\n        left: 19px;\n        svg {\n          transform: scale(1.2);\n        }\n      }\n    }\n    .resource-no-image {\n      background-color: ${colors.brand.greyLightest};\n      .c-content-type-badge {\n        width: 26px;\n        height: 26px;\n        left: 45px;\n        margin-left: 0;\n        top: 100%;\n        margin-top: -13px;\n        opacity: 1;\n      }\n    }\n  }\n`;\n\nconst ItemLink = styled(SafeLink)`\n  box-shadow: none;\n  color: unset;\n  text-decoration: none;\n  display: flex;\n  flex-direction: column;\n  position: relative;\n  min-height: 0;\n  flex: 1;\n`;\n\nconst TextWrapper = styled.div`\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n`;\n\nconst ItemTitleWrapper = styled.div<ItemTypeProps>`\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `${ItemWrapper}:hover & {\n    padding-left:2px; padding-right: 2px;}`};\n`;\n\nconst ItemTitle = styled.h3<ItemTypeProps>`\n  ${fonts.sizes('24px', '28px')};\n  color: ${colors.brand.primary};\n  ${(props) => props.isTopic && `margin-bottom: ${spacing.small};`};\n  font-weight: ${fonts.weight.semibold};\n  overflow-wrap: anywhere;\n  display: inline;\n  ${ItemWrapper}:hover & {\n    box-shadow: inset 0 -1px;\n    background-color: transparent;\n  }\n`;\nconst ItemText = styled.div<ItemTypeProps>`\n  overflow: hidden;\n  ${fonts.sizes('16px', '24px')};\n  word-break: break-word;\n  overflow-wrap: anywhere;\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `\n    ${fonts.sizes('18px', '28px')};\n    `};\n`;\n\nconst ContextWrapper = styled.div`\n  background: white;\n  z-index: 1;\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n  ${ItemWrapper}:hover & {\n    padding-left: calc(${spacing.normal} + 2px);\n    padding-right: calc(${spacing.normal} + 2px);\n    padding-bottom: calc(${spacing.small} + 2px);\n  }\n`;\n\nexport type SearchItemProps = {\n  id: string | number;\n  title: string;\n  url: string;\n  ingress: string;\n  contexts?: ItemContextsType['contexts'];\n  img?: { url: string; alt: string };\n  labels?: string[];\n  type?: ContentType;\n};\nexport type SearchItemType = {\n  item: SearchItemProps;\n  type?: ContentType;\n};\nconst SearchItem = ({ item, type }: SearchItemType) => {\n  const { title, url, ingress, contexts, img = null, labels = [] } = item;\n\n  const isTopic = type === contentTypes.TOPIC || type === contentTypes.MULTIDISCIPLINARY_TOPIC;\n\n  return (\n    <Container>\n      <ItemWrapper>\n        <ItemLink to={url}>\n          {isTopic ? (\n            <ItemTopicHeader image={img} type={type}>\n              <ItemTitleWrapper isTopic>\n                <ItemTitle isTopic>{title}</ItemTitle>\n              </ItemTitleWrapper>\n              <ItemText isTopic>{parse(ingress)}</ItemText>\n            </ItemTopicHeader>\n          ) : (\n            <>\n              <ItemResourceHeader labels={labels} img={img} type={type} />\n              <TextWrapper>\n                <ItemTitleWrapper>\n                  <ItemTitle>{title}</ItemTitle>\n                </ItemTitleWrapper>\n                <ItemText>{parse(ingress)}</ItemText>\n              </TextWrapper>\n            </>\n          )}\n          <ContextWrapper>\n            {contexts && contexts.length > 0 && <ItemContexts contexts={contexts} id={item.id} title={item.title} />}\n          </ContextWrapper>\n        </ItemLink>\n      </ItemWrapper>\n    </Container>\n  );\n};\n\nexport default SearchItem;\n"]} */",
|
|
78
78
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
79
79
|
});
|
|
80
80
|
|
|
81
81
|
var TextWrapper = _styled("div", {
|
|
82
82
|
target: "e1hz9lam3",
|
|
83
83
|
label: "TextWrapper"
|
|
84
|
-
})("padding:0 ", spacing.normal, " ", spacing.small, ";transition:all ", animations.durations.fast, " ease-in-out;"
|
|
84
|
+
})("padding:0 ", spacing.normal, " ", spacing.small, ";transition:all ", animations.durations.fast, " ease-in-out;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchItem.tsx"],"names":[],"mappings":"AAkH8B","file":"SearchItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n\nimport SafeLink from '@ndla/safelink';\nimport { animations, colors, fonts, spacing } from '@ndla/core';\n\nimport { ContentType } from './SearchTypeResult';\nimport constants from '../model';\nimport ItemContexts, { ItemContextsType } from './components/ItemContexts';\nimport ItemTopicHeader from './components/ItemTopicHeader';\nimport ItemResourceHeader from './components/ItemResourceHeader';\n\nconst { contentTypes } = constants;\n\nexport const resourceTypeColor = (type: string) => {\n  switch (type) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.light;\n    case contentTypes.TOPIC:\n      return colors.subject.light;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.light;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.light;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.light;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.light;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.light;\n    default:\n      return '';\n  }\n};\n\ntype ItemTypeProps = {\n  contentType?: ContentType;\n  isTopic?: boolean;\n};\n\nconst Container = styled.div`\n  display: flex;\n  height: 400px;\n  align-items: center;\n  justify-content: center;\n`;\n\nconst ItemWrapper = styled.div`\n  flex-direction: column;\n  display: flex;\n  width: 100%;\n  height: 100%;\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: 5px;\n  transition: all ${animations.durations.fast} ease-in-out;\n  &:hover {\n    height: calc(100% + 4px);\n    width: calc(100% + 4px);\n    .topic-header-image {\n      height: calc(100% + 6px);\n      width: calc(100% + 6px);\n    }\n    .topic-label {\n      svg {\n        transform: scale(1.2);\n      }\n    }\n    .topic-label-list {\n      margin-left: 2px;\n    }\n    .resource-type-wrapper {\n      padding: 0 calc(${spacing.normal} + 2px);\n      .resource-icon-wrapper {\n        left: 19px;\n        svg {\n          transform: scale(1.2);\n        }\n      }\n    }\n    .resource-no-image {\n      background-color: ${colors.brand.greyLightest};\n      .c-content-type-badge {\n        width: 26px;\n        height: 26px;\n        left: 45px;\n        margin-left: 0;\n        top: 100%;\n        margin-top: -13px;\n        opacity: 1;\n      }\n    }\n  }\n`;\n\nconst ItemLink = styled(SafeLink)`\n  box-shadow: none;\n  color: unset;\n  text-decoration: none;\n  display: flex;\n  flex-direction: column;\n  position: relative;\n  min-height: 0;\n  flex: 1;\n`;\n\nconst TextWrapper = styled.div`\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n`;\n\nconst ItemTitleWrapper = styled.div<ItemTypeProps>`\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `${ItemWrapper}:hover & {\n    padding-left:2px; padding-right: 2px;}`};\n`;\n\nconst ItemTitle = styled.h3<ItemTypeProps>`\n  ${fonts.sizes('24px', '28px')};\n  color: ${colors.brand.primary};\n  ${(props) => props.isTopic && `margin-bottom: ${spacing.small};`};\n  font-weight: ${fonts.weight.semibold};\n  overflow-wrap: anywhere;\n  display: inline;\n  ${ItemWrapper}:hover & {\n    box-shadow: inset 0 -1px;\n    background-color: transparent;\n  }\n`;\nconst ItemText = styled.div<ItemTypeProps>`\n  overflow: hidden;\n  ${fonts.sizes('16px', '24px')};\n  word-break: break-word;\n  overflow-wrap: anywhere;\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `\n    ${fonts.sizes('18px', '28px')};\n    `};\n`;\n\nconst ContextWrapper = styled.div`\n  background: white;\n  z-index: 1;\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n  ${ItemWrapper}:hover & {\n    padding-left: calc(${spacing.normal} + 2px);\n    padding-right: calc(${spacing.normal} + 2px);\n    padding-bottom: calc(${spacing.small} + 2px);\n  }\n`;\n\nexport type SearchItemProps = {\n  id: string | number;\n  title: string;\n  url: string;\n  ingress: string;\n  contexts?: ItemContextsType['contexts'];\n  img?: { url: string; alt: string };\n  labels?: string[];\n  type?: ContentType;\n};\nexport type SearchItemType = {\n  item: SearchItemProps;\n  type?: ContentType;\n};\nconst SearchItem = ({ item, type }: SearchItemType) => {\n  const { title, url, ingress, contexts, img = null, labels = [] } = item;\n\n  const isTopic = type === contentTypes.TOPIC || type === contentTypes.MULTIDISCIPLINARY_TOPIC;\n\n  return (\n    <Container>\n      <ItemWrapper>\n        <ItemLink to={url}>\n          {isTopic ? (\n            <ItemTopicHeader image={img} type={type}>\n              <ItemTitleWrapper isTopic>\n                <ItemTitle isTopic>{title}</ItemTitle>\n              </ItemTitleWrapper>\n              <ItemText isTopic>{parse(ingress)}</ItemText>\n            </ItemTopicHeader>\n          ) : (\n            <>\n              <ItemResourceHeader labels={labels} img={img} type={type} />\n              <TextWrapper>\n                <ItemTitleWrapper>\n                  <ItemTitle>{title}</ItemTitle>\n                </ItemTitleWrapper>\n                <ItemText>{parse(ingress)}</ItemText>\n              </TextWrapper>\n            </>\n          )}\n          <ContextWrapper>\n            {contexts && contexts.length > 0 && <ItemContexts contexts={contexts} id={item.id} title={item.title} />}\n          </ContextWrapper>\n        </ItemLink>\n      </ItemWrapper>\n    </Container>\n  );\n};\n\nexport default SearchItem;\n"]} */"));
|
|
85
85
|
|
|
86
86
|
var ItemTitleWrapper = _styled("div", {
|
|
87
87
|
target: "e1hz9lam4",
|
|
88
88
|
label: "ItemTitleWrapper"
|
|
89
89
|
})("transition:all ", animations.durations.fast, " ease-in-out;margin-top:", spacing.small, ";", function (props) {
|
|
90
90
|
return props.isTopic && "".concat(ItemWrapper, ":hover & {\n padding-left:2px; padding-right: 2px;}");
|
|
91
|
-
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
91
|
+
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchItem.tsx"],"names":[],"mappings":"AAuHkD","file":"SearchItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n\nimport SafeLink from '@ndla/safelink';\nimport { animations, colors, fonts, spacing } from '@ndla/core';\n\nimport { ContentType } from './SearchTypeResult';\nimport constants from '../model';\nimport ItemContexts, { ItemContextsType } from './components/ItemContexts';\nimport ItemTopicHeader from './components/ItemTopicHeader';\nimport ItemResourceHeader from './components/ItemResourceHeader';\n\nconst { contentTypes } = constants;\n\nexport const resourceTypeColor = (type: string) => {\n  switch (type) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.light;\n    case contentTypes.TOPIC:\n      return colors.subject.light;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.light;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.light;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.light;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.light;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.light;\n    default:\n      return '';\n  }\n};\n\ntype ItemTypeProps = {\n  contentType?: ContentType;\n  isTopic?: boolean;\n};\n\nconst Container = styled.div`\n  display: flex;\n  height: 400px;\n  align-items: center;\n  justify-content: center;\n`;\n\nconst ItemWrapper = styled.div`\n  flex-direction: column;\n  display: flex;\n  width: 100%;\n  height: 100%;\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: 5px;\n  transition: all ${animations.durations.fast} ease-in-out;\n  &:hover {\n    height: calc(100% + 4px);\n    width: calc(100% + 4px);\n    .topic-header-image {\n      height: calc(100% + 6px);\n      width: calc(100% + 6px);\n    }\n    .topic-label {\n      svg {\n        transform: scale(1.2);\n      }\n    }\n    .topic-label-list {\n      margin-left: 2px;\n    }\n    .resource-type-wrapper {\n      padding: 0 calc(${spacing.normal} + 2px);\n      .resource-icon-wrapper {\n        left: 19px;\n        svg {\n          transform: scale(1.2);\n        }\n      }\n    }\n    .resource-no-image {\n      background-color: ${colors.brand.greyLightest};\n      .c-content-type-badge {\n        width: 26px;\n        height: 26px;\n        left: 45px;\n        margin-left: 0;\n        top: 100%;\n        margin-top: -13px;\n        opacity: 1;\n      }\n    }\n  }\n`;\n\nconst ItemLink = styled(SafeLink)`\n  box-shadow: none;\n  color: unset;\n  text-decoration: none;\n  display: flex;\n  flex-direction: column;\n  position: relative;\n  min-height: 0;\n  flex: 1;\n`;\n\nconst TextWrapper = styled.div`\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n`;\n\nconst ItemTitleWrapper = styled.div<ItemTypeProps>`\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `${ItemWrapper}:hover & {\n    padding-left:2px; padding-right: 2px;}`};\n`;\n\nconst ItemTitle = styled.h3<ItemTypeProps>`\n  ${fonts.sizes('24px', '28px')};\n  color: ${colors.brand.primary};\n  ${(props) => props.isTopic && `margin-bottom: ${spacing.small};`};\n  font-weight: ${fonts.weight.semibold};\n  overflow-wrap: anywhere;\n  display: inline;\n  ${ItemWrapper}:hover & {\n    box-shadow: inset 0 -1px;\n    background-color: transparent;\n  }\n`;\nconst ItemText = styled.div<ItemTypeProps>`\n  overflow: hidden;\n  ${fonts.sizes('16px', '24px')};\n  word-break: break-word;\n  overflow-wrap: anywhere;\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `\n    ${fonts.sizes('18px', '28px')};\n    `};\n`;\n\nconst ContextWrapper = styled.div`\n  background: white;\n  z-index: 1;\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n  ${ItemWrapper}:hover & {\n    padding-left: calc(${spacing.normal} + 2px);\n    padding-right: calc(${spacing.normal} + 2px);\n    padding-bottom: calc(${spacing.small} + 2px);\n  }\n`;\n\nexport type SearchItemProps = {\n  id: string | number;\n  title: string;\n  url: string;\n  ingress: string;\n  contexts?: ItemContextsType['contexts'];\n  img?: { url: string; alt: string };\n  labels?: string[];\n  type?: ContentType;\n};\nexport type SearchItemType = {\n  item: SearchItemProps;\n  type?: ContentType;\n};\nconst SearchItem = ({ item, type }: SearchItemType) => {\n  const { title, url, ingress, contexts, img = null, labels = [] } = item;\n\n  const isTopic = type === contentTypes.TOPIC || type === contentTypes.MULTIDISCIPLINARY_TOPIC;\n\n  return (\n    <Container>\n      <ItemWrapper>\n        <ItemLink to={url}>\n          {isTopic ? (\n            <ItemTopicHeader image={img} type={type}>\n              <ItemTitleWrapper isTopic>\n                <ItemTitle isTopic>{title}</ItemTitle>\n              </ItemTitleWrapper>\n              <ItemText isTopic>{parse(ingress)}</ItemText>\n            </ItemTopicHeader>\n          ) : (\n            <>\n              <ItemResourceHeader labels={labels} img={img} type={type} />\n              <TextWrapper>\n                <ItemTitleWrapper>\n                  <ItemTitle>{title}</ItemTitle>\n                </ItemTitleWrapper>\n                <ItemText>{parse(ingress)}</ItemText>\n              </TextWrapper>\n            </>\n          )}\n          <ContextWrapper>\n            {contexts && contexts.length > 0 && <ItemContexts contexts={contexts} id={item.id} title={item.title} />}\n          </ContextWrapper>\n        </ItemLink>\n      </ItemWrapper>\n    </Container>\n  );\n};\n\nexport default SearchItem;\n"]} */"));
|
|
92
92
|
|
|
93
93
|
var ItemTitle = _styled("h3", {
|
|
94
94
|
target: "e1hz9lam5",
|
|
95
95
|
label: "ItemTitle"
|
|
96
96
|
})(fonts.sizes('24px', '28px'), ";color:", colors.brand.primary, ";", function (props) {
|
|
97
97
|
return props.isTopic && "margin-bottom: ".concat(spacing.small, ";");
|
|
98
|
-
}, ";font-weight:", fonts.weight.semibold, ";overflow-wrap:anywhere;display:inline;", ItemWrapper, ":hover &{box-shadow:inset 0 -1px;background-color:transparent;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
98
|
+
}, ";font-weight:", fonts.weight.semibold, ";overflow-wrap:anywhere;display:inline;", ItemWrapper, ":hover &{box-shadow:inset 0 -1px;background-color:transparent;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchItem.tsx"],"names":[],"mappings":"AAgI0C","file":"SearchItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n\nimport SafeLink from '@ndla/safelink';\nimport { animations, colors, fonts, spacing } from '@ndla/core';\n\nimport { ContentType } from './SearchTypeResult';\nimport constants from '../model';\nimport ItemContexts, { ItemContextsType } from './components/ItemContexts';\nimport ItemTopicHeader from './components/ItemTopicHeader';\nimport ItemResourceHeader from './components/ItemResourceHeader';\n\nconst { contentTypes } = constants;\n\nexport const resourceTypeColor = (type: string) => {\n  switch (type) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.light;\n    case contentTypes.TOPIC:\n      return colors.subject.light;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.light;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.light;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.light;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.light;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.light;\n    default:\n      return '';\n  }\n};\n\ntype ItemTypeProps = {\n  contentType?: ContentType;\n  isTopic?: boolean;\n};\n\nconst Container = styled.div`\n  display: flex;\n  height: 400px;\n  align-items: center;\n  justify-content: center;\n`;\n\nconst ItemWrapper = styled.div`\n  flex-direction: column;\n  display: flex;\n  width: 100%;\n  height: 100%;\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: 5px;\n  transition: all ${animations.durations.fast} ease-in-out;\n  &:hover {\n    height: calc(100% + 4px);\n    width: calc(100% + 4px);\n    .topic-header-image {\n      height: calc(100% + 6px);\n      width: calc(100% + 6px);\n    }\n    .topic-label {\n      svg {\n        transform: scale(1.2);\n      }\n    }\n    .topic-label-list {\n      margin-left: 2px;\n    }\n    .resource-type-wrapper {\n      padding: 0 calc(${spacing.normal} + 2px);\n      .resource-icon-wrapper {\n        left: 19px;\n        svg {\n          transform: scale(1.2);\n        }\n      }\n    }\n    .resource-no-image {\n      background-color: ${colors.brand.greyLightest};\n      .c-content-type-badge {\n        width: 26px;\n        height: 26px;\n        left: 45px;\n        margin-left: 0;\n        top: 100%;\n        margin-top: -13px;\n        opacity: 1;\n      }\n    }\n  }\n`;\n\nconst ItemLink = styled(SafeLink)`\n  box-shadow: none;\n  color: unset;\n  text-decoration: none;\n  display: flex;\n  flex-direction: column;\n  position: relative;\n  min-height: 0;\n  flex: 1;\n`;\n\nconst TextWrapper = styled.div`\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n`;\n\nconst ItemTitleWrapper = styled.div<ItemTypeProps>`\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `${ItemWrapper}:hover & {\n    padding-left:2px; padding-right: 2px;}`};\n`;\n\nconst ItemTitle = styled.h3<ItemTypeProps>`\n  ${fonts.sizes('24px', '28px')};\n  color: ${colors.brand.primary};\n  ${(props) => props.isTopic && `margin-bottom: ${spacing.small};`};\n  font-weight: ${fonts.weight.semibold};\n  overflow-wrap: anywhere;\n  display: inline;\n  ${ItemWrapper}:hover & {\n    box-shadow: inset 0 -1px;\n    background-color: transparent;\n  }\n`;\nconst ItemText = styled.div<ItemTypeProps>`\n  overflow: hidden;\n  ${fonts.sizes('16px', '24px')};\n  word-break: break-word;\n  overflow-wrap: anywhere;\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `\n    ${fonts.sizes('18px', '28px')};\n    `};\n`;\n\nconst ContextWrapper = styled.div`\n  background: white;\n  z-index: 1;\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n  ${ItemWrapper}:hover & {\n    padding-left: calc(${spacing.normal} + 2px);\n    padding-right: calc(${spacing.normal} + 2px);\n    padding-bottom: calc(${spacing.small} + 2px);\n  }\n`;\n\nexport type SearchItemProps = {\n  id: string | number;\n  title: string;\n  url: string;\n  ingress: string;\n  contexts?: ItemContextsType['contexts'];\n  img?: { url: string; alt: string };\n  labels?: string[];\n  type?: ContentType;\n};\nexport type SearchItemType = {\n  item: SearchItemProps;\n  type?: ContentType;\n};\nconst SearchItem = ({ item, type }: SearchItemType) => {\n  const { title, url, ingress, contexts, img = null, labels = [] } = item;\n\n  const isTopic = type === contentTypes.TOPIC || type === contentTypes.MULTIDISCIPLINARY_TOPIC;\n\n  return (\n    <Container>\n      <ItemWrapper>\n        <ItemLink to={url}>\n          {isTopic ? (\n            <ItemTopicHeader image={img} type={type}>\n              <ItemTitleWrapper isTopic>\n                <ItemTitle isTopic>{title}</ItemTitle>\n              </ItemTitleWrapper>\n              <ItemText isTopic>{parse(ingress)}</ItemText>\n            </ItemTopicHeader>\n          ) : (\n            <>\n              <ItemResourceHeader labels={labels} img={img} type={type} />\n              <TextWrapper>\n                <ItemTitleWrapper>\n                  <ItemTitle>{title}</ItemTitle>\n                </ItemTitleWrapper>\n                <ItemText>{parse(ingress)}</ItemText>\n              </TextWrapper>\n            </>\n          )}\n          <ContextWrapper>\n            {contexts && contexts.length > 0 && <ItemContexts contexts={contexts} id={item.id} title={item.title} />}\n          </ContextWrapper>\n        </ItemLink>\n      </ItemWrapper>\n    </Container>\n  );\n};\n\nexport default SearchItem;\n"]} */"));
|
|
99
99
|
|
|
100
100
|
var ItemText = _styled("div", {
|
|
101
101
|
target: "e1hz9lam6",
|
|
102
102
|
label: "ItemText"
|
|
103
103
|
})("overflow:hidden;", fonts.sizes('16px', '24px'), ";word-break:break-word;overflow-wrap:anywhere;transition:all ", animations.durations.fast, " ease-in-out;margin-top:", spacing.small, ";", function (props) {
|
|
104
|
-
return props.isTopic && "\n ".concat(fonts.sizes('18px', '28px'), ";\n ")
|
|
105
|
-
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
104
|
+
return props.isTopic && "\n ".concat(fonts.sizes('18px', '28px'), ";\n ");
|
|
105
|
+
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchItem.tsx"],"names":[],"mappings":"AA4I0C","file":"SearchItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n\nimport SafeLink from '@ndla/safelink';\nimport { animations, colors, fonts, spacing } from '@ndla/core';\n\nimport { ContentType } from './SearchTypeResult';\nimport constants from '../model';\nimport ItemContexts, { ItemContextsType } from './components/ItemContexts';\nimport ItemTopicHeader from './components/ItemTopicHeader';\nimport ItemResourceHeader from './components/ItemResourceHeader';\n\nconst { contentTypes } = constants;\n\nexport const resourceTypeColor = (type: string) => {\n  switch (type) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.light;\n    case contentTypes.TOPIC:\n      return colors.subject.light;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.light;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.light;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.light;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.light;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.light;\n    default:\n      return '';\n  }\n};\n\ntype ItemTypeProps = {\n  contentType?: ContentType;\n  isTopic?: boolean;\n};\n\nconst Container = styled.div`\n  display: flex;\n  height: 400px;\n  align-items: center;\n  justify-content: center;\n`;\n\nconst ItemWrapper = styled.div`\n  flex-direction: column;\n  display: flex;\n  width: 100%;\n  height: 100%;\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: 5px;\n  transition: all ${animations.durations.fast} ease-in-out;\n  &:hover {\n    height: calc(100% + 4px);\n    width: calc(100% + 4px);\n    .topic-header-image {\n      height: calc(100% + 6px);\n      width: calc(100% + 6px);\n    }\n    .topic-label {\n      svg {\n        transform: scale(1.2);\n      }\n    }\n    .topic-label-list {\n      margin-left: 2px;\n    }\n    .resource-type-wrapper {\n      padding: 0 calc(${spacing.normal} + 2px);\n      .resource-icon-wrapper {\n        left: 19px;\n        svg {\n          transform: scale(1.2);\n        }\n      }\n    }\n    .resource-no-image {\n      background-color: ${colors.brand.greyLightest};\n      .c-content-type-badge {\n        width: 26px;\n        height: 26px;\n        left: 45px;\n        margin-left: 0;\n        top: 100%;\n        margin-top: -13px;\n        opacity: 1;\n      }\n    }\n  }\n`;\n\nconst ItemLink = styled(SafeLink)`\n  box-shadow: none;\n  color: unset;\n  text-decoration: none;\n  display: flex;\n  flex-direction: column;\n  position: relative;\n  min-height: 0;\n  flex: 1;\n`;\n\nconst TextWrapper = styled.div`\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n`;\n\nconst ItemTitleWrapper = styled.div<ItemTypeProps>`\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `${ItemWrapper}:hover & {\n    padding-left:2px; padding-right: 2px;}`};\n`;\n\nconst ItemTitle = styled.h3<ItemTypeProps>`\n  ${fonts.sizes('24px', '28px')};\n  color: ${colors.brand.primary};\n  ${(props) => props.isTopic && `margin-bottom: ${spacing.small};`};\n  font-weight: ${fonts.weight.semibold};\n  overflow-wrap: anywhere;\n  display: inline;\n  ${ItemWrapper}:hover & {\n    box-shadow: inset 0 -1px;\n    background-color: transparent;\n  }\n`;\nconst ItemText = styled.div<ItemTypeProps>`\n  overflow: hidden;\n  ${fonts.sizes('16px', '24px')};\n  word-break: break-word;\n  overflow-wrap: anywhere;\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `\n    ${fonts.sizes('18px', '28px')};\n    `};\n`;\n\nconst ContextWrapper = styled.div`\n  background: white;\n  z-index: 1;\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n  ${ItemWrapper}:hover & {\n    padding-left: calc(${spacing.normal} + 2px);\n    padding-right: calc(${spacing.normal} + 2px);\n    padding-bottom: calc(${spacing.small} + 2px);\n  }\n`;\n\nexport type SearchItemProps = {\n  id: string | number;\n  title: string;\n  url: string;\n  ingress: string;\n  contexts?: ItemContextsType['contexts'];\n  img?: { url: string; alt: string };\n  labels?: string[];\n  type?: ContentType;\n};\nexport type SearchItemType = {\n  item: SearchItemProps;\n  type?: ContentType;\n};\nconst SearchItem = ({ item, type }: SearchItemType) => {\n  const { title, url, ingress, contexts, img = null, labels = [] } = item;\n\n  const isTopic = type === contentTypes.TOPIC || type === contentTypes.MULTIDISCIPLINARY_TOPIC;\n\n  return (\n    <Container>\n      <ItemWrapper>\n        <ItemLink to={url}>\n          {isTopic ? (\n            <ItemTopicHeader image={img} type={type}>\n              <ItemTitleWrapper isTopic>\n                <ItemTitle isTopic>{title}</ItemTitle>\n              </ItemTitleWrapper>\n              <ItemText isTopic>{parse(ingress)}</ItemText>\n            </ItemTopicHeader>\n          ) : (\n            <>\n              <ItemResourceHeader labels={labels} img={img} type={type} />\n              <TextWrapper>\n                <ItemTitleWrapper>\n                  <ItemTitle>{title}</ItemTitle>\n                </ItemTitleWrapper>\n                <ItemText>{parse(ingress)}</ItemText>\n              </TextWrapper>\n            </>\n          )}\n          <ContextWrapper>\n            {contexts && contexts.length > 0 && <ItemContexts contexts={contexts} id={item.id} title={item.title} />}\n          </ContextWrapper>\n        </ItemLink>\n      </ItemWrapper>\n    </Container>\n  );\n};\n\nexport default SearchItem;\n"]} */"));
|
|
106
106
|
|
|
107
107
|
var ContextWrapper = _styled("div", {
|
|
108
108
|
target: "e1hz9lam7",
|
|
109
109
|
label: "ContextWrapper"
|
|
110
|
-
})("background:white;z-index:1;padding:0 ", spacing.normal, " ", spacing.small, ";transition:all ", animations.durations.fast, " ease-in-out;", ItemWrapper, ":hover &{padding-left:calc(", spacing.normal, " + 2px);padding-right:calc(", spacing.normal, " + 2px);padding-bottom:calc(", spacing.small, " + 2px);}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
110
|
+
})("background:white;z-index:1;padding:0 ", spacing.normal, " ", spacing.small, ";transition:all ", animations.durations.fast, " ease-in-out;", ItemWrapper, ":hover &{padding-left:calc(", spacing.normal, " + 2px);padding-right:calc(", spacing.normal, " + 2px);padding-bottom:calc(", spacing.small, " + 2px);}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchItem.tsx"],"names":[],"mappings":"AA0JiC","file":"SearchItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n\nimport SafeLink from '@ndla/safelink';\nimport { animations, colors, fonts, spacing } from '@ndla/core';\n\nimport { ContentType } from './SearchTypeResult';\nimport constants from '../model';\nimport ItemContexts, { ItemContextsType } from './components/ItemContexts';\nimport ItemTopicHeader from './components/ItemTopicHeader';\nimport ItemResourceHeader from './components/ItemResourceHeader';\n\nconst { contentTypes } = constants;\n\nexport const resourceTypeColor = (type: string) => {\n  switch (type) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.light;\n    case contentTypes.TOPIC:\n      return colors.subject.light;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.light;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.light;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.light;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.light;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.light;\n    default:\n      return '';\n  }\n};\n\ntype ItemTypeProps = {\n  contentType?: ContentType;\n  isTopic?: boolean;\n};\n\nconst Container = styled.div`\n  display: flex;\n  height: 400px;\n  align-items: center;\n  justify-content: center;\n`;\n\nconst ItemWrapper = styled.div`\n  flex-direction: column;\n  display: flex;\n  width: 100%;\n  height: 100%;\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: 5px;\n  transition: all ${animations.durations.fast} ease-in-out;\n  &:hover {\n    height: calc(100% + 4px);\n    width: calc(100% + 4px);\n    .topic-header-image {\n      height: calc(100% + 6px);\n      width: calc(100% + 6px);\n    }\n    .topic-label {\n      svg {\n        transform: scale(1.2);\n      }\n    }\n    .topic-label-list {\n      margin-left: 2px;\n    }\n    .resource-type-wrapper {\n      padding: 0 calc(${spacing.normal} + 2px);\n      .resource-icon-wrapper {\n        left: 19px;\n        svg {\n          transform: scale(1.2);\n        }\n      }\n    }\n    .resource-no-image {\n      background-color: ${colors.brand.greyLightest};\n      .c-content-type-badge {\n        width: 26px;\n        height: 26px;\n        left: 45px;\n        margin-left: 0;\n        top: 100%;\n        margin-top: -13px;\n        opacity: 1;\n      }\n    }\n  }\n`;\n\nconst ItemLink = styled(SafeLink)`\n  box-shadow: none;\n  color: unset;\n  text-decoration: none;\n  display: flex;\n  flex-direction: column;\n  position: relative;\n  min-height: 0;\n  flex: 1;\n`;\n\nconst TextWrapper = styled.div`\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n`;\n\nconst ItemTitleWrapper = styled.div<ItemTypeProps>`\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `${ItemWrapper}:hover & {\n    padding-left:2px; padding-right: 2px;}`};\n`;\n\nconst ItemTitle = styled.h3<ItemTypeProps>`\n  ${fonts.sizes('24px', '28px')};\n  color: ${colors.brand.primary};\n  ${(props) => props.isTopic && `margin-bottom: ${spacing.small};`};\n  font-weight: ${fonts.weight.semibold};\n  overflow-wrap: anywhere;\n  display: inline;\n  ${ItemWrapper}:hover & {\n    box-shadow: inset 0 -1px;\n    background-color: transparent;\n  }\n`;\nconst ItemText = styled.div<ItemTypeProps>`\n  overflow: hidden;\n  ${fonts.sizes('16px', '24px')};\n  word-break: break-word;\n  overflow-wrap: anywhere;\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `\n    ${fonts.sizes('18px', '28px')};\n    `};\n`;\n\nconst ContextWrapper = styled.div`\n  background: white;\n  z-index: 1;\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n  ${ItemWrapper}:hover & {\n    padding-left: calc(${spacing.normal} + 2px);\n    padding-right: calc(${spacing.normal} + 2px);\n    padding-bottom: calc(${spacing.small} + 2px);\n  }\n`;\n\nexport type SearchItemProps = {\n  id: string | number;\n  title: string;\n  url: string;\n  ingress: string;\n  contexts?: ItemContextsType['contexts'];\n  img?: { url: string; alt: string };\n  labels?: string[];\n  type?: ContentType;\n};\nexport type SearchItemType = {\n  item: SearchItemProps;\n  type?: ContentType;\n};\nconst SearchItem = ({ item, type }: SearchItemType) => {\n  const { title, url, ingress, contexts, img = null, labels = [] } = item;\n\n  const isTopic = type === contentTypes.TOPIC || type === contentTypes.MULTIDISCIPLINARY_TOPIC;\n\n  return (\n    <Container>\n      <ItemWrapper>\n        <ItemLink to={url}>\n          {isTopic ? (\n            <ItemTopicHeader image={img} type={type}>\n              <ItemTitleWrapper isTopic>\n                <ItemTitle isTopic>{title}</ItemTitle>\n              </ItemTitleWrapper>\n              <ItemText isTopic>{parse(ingress)}</ItemText>\n            </ItemTopicHeader>\n          ) : (\n            <>\n              <ItemResourceHeader labels={labels} img={img} type={type} />\n              <TextWrapper>\n                <ItemTitleWrapper>\n                  <ItemTitle>{title}</ItemTitle>\n                </ItemTitleWrapper>\n                <ItemText>{parse(ingress)}</ItemText>\n              </TextWrapper>\n            </>\n          )}\n          <ContextWrapper>\n            {contexts && contexts.length > 0 && <ItemContexts contexts={contexts} id={item.id} title={item.title} />}\n          </ContextWrapper>\n        </ItemLink>\n      </ItemWrapper>\n    </Container>\n  );\n};\n\nexport default SearchItem;\n"]} */"));
|
|
111
111
|
|
|
112
112
|
var SearchItem = function SearchItem(_ref) {
|
|
113
113
|
var item = _ref.item,
|
package/es/locale/messages-en.js
CHANGED
|
@@ -296,8 +296,8 @@ var messages = _objectSpread(_objectSpread({
|
|
|
296
296
|
noContent: 'We are sorry, but we do not yet offer any program courses.',
|
|
297
297
|
feide: 'This resource is accessible only to teachers who are logged in with Feide.',
|
|
298
298
|
resources: 'This is not a complete course produced by NDLA, but a collection of resources we hope you will find useful.',
|
|
299
|
-
|
|
300
|
-
|
|
299
|
+
subjectOutdated: 'This course is not updated to the current curriculum.',
|
|
300
|
+
subjectBeta: 'This course is in beta.',
|
|
301
301
|
newVersion: 'This learning resource is not updated to the current curriculum. You can find an updated version here: ',
|
|
302
302
|
frontPageBeta: 'Revised subjects have been revised in accordance with the new curriculum that will be put into effect from August 2022. Beta versions of subjects are subjects we are still working on. We hope, however, that the learning resources available by now may come in useful already.',
|
|
303
303
|
frontPageExpired: 'Expired subjects are not being taught any longer, but it may still be possible to take exams in these subjects.',
|
package/es/locale/messages-nb.js
CHANGED
|
@@ -296,8 +296,8 @@ var messages = _objectSpread(_objectSpread({
|
|
|
296
296
|
noContent: 'Vi har dessverre ikke noen programfag ennå.',
|
|
297
297
|
feide: 'Denne ressursen er bare tilgjengelig for lærere som er pålogget med Feide.',
|
|
298
298
|
resources: 'Dette er ikke et komplett læremiddel produsert av NDLA, men ei ressurssamling som vi håper kan være nyttig for deg.',
|
|
299
|
-
|
|
300
|
-
|
|
299
|
+
subjectOutdated: 'Dette faget følger en utgått læreplan.',
|
|
300
|
+
subjectBeta: 'Dette faget er i betaversjon.',
|
|
301
301
|
newVersion: 'Denne læringsressursen er ikke oppdatert etter gjeldende læreplan. Du finner en oppdatert versjon her: ',
|
|
302
302
|
frontPageBeta: 'Kommende fag er tilpassa ny læreplan som gjelder fra høsten 2022. Betafag er fag under arbeid. Vi håper likevel at læringsressursene i betafaga kan være nyttige allerede nå.',
|
|
303
303
|
frontPageExpired: 'Utgåtte fag undervises det ikke i lenger, men det kan fortsatt være mulig å ta eksamen i faga som privatist.',
|
package/es/locale/messages-nn.js
CHANGED
|
@@ -296,8 +296,8 @@ var messages = _objectSpread(_objectSpread({
|
|
|
296
296
|
noContent: 'Vi har dessverre ikkje nokon programfag enno.',
|
|
297
297
|
feide: 'Denne ressursen er berre tilgjengeleg for lærarar som er pålogga med Feide.',
|
|
298
298
|
resources: 'Dette er ikkje eit komplett læremiddel produsert av NDLA, men ei ressurssamling som vi håper kan vere nyttig for deg.',
|
|
299
|
-
|
|
300
|
-
|
|
299
|
+
subjectOutdated: 'Dette faget følgjer ein utgått læreplan.',
|
|
300
|
+
subjectBeta: 'Dette faget er i betaversjon.',
|
|
301
301
|
newVersion: 'Denne læringsressursen er ikkje oppdatert etter gjeldande læreplan. Du finn ein oppdatert versjon her: ',
|
|
302
302
|
frontPageBeta: 'Kommande fag er tilpassa ny læreplan som gjeld fra hausten 2022. Betafag er fag under arbeid. Vi håper likevel at læringsressursane i betafaga kan vere nyttige allereie no.',
|
|
303
303
|
frontPageExpired: 'Utgåtte fag blir det ikkje undervist i lenger, men det kan framleis vere mogleg å ta eksamen i faget som privatist.',
|
|
@@ -14,14 +14,20 @@ interface MastheadItemProps {
|
|
|
14
14
|
left?: boolean;
|
|
15
15
|
}
|
|
16
16
|
export declare const MastheadItem: ({ children, className, left, right }: MastheadItemProps) => JSX.Element;
|
|
17
|
+
interface Alert {
|
|
18
|
+
content: string;
|
|
19
|
+
closable?: boolean;
|
|
20
|
+
number: number;
|
|
21
|
+
}
|
|
17
22
|
interface Props {
|
|
18
23
|
children?: ReactNode;
|
|
19
24
|
fixed?: boolean;
|
|
20
25
|
infoContent?: ReactNode;
|
|
21
26
|
ndlaFilm?: boolean;
|
|
22
27
|
skipToMainContentId?: string;
|
|
23
|
-
messages?:
|
|
28
|
+
messages?: Alert[];
|
|
29
|
+
onCloseAlert?: (id: number) => void;
|
|
24
30
|
}
|
|
25
|
-
export declare const Masthead: ({ children, fixed, infoContent, ndlaFilm, skipToMainContentId, messages, t, }: Props & WithTranslation) => JSX.Element;
|
|
26
|
-
declare const _default: React.ComponentType<Pick<Pick<Props & WithTranslation<"translation">, "fixed" | "children" | "t" | "tReady" | "messages" | "ndlaFilm" | "infoContent" | "skipToMainContentId">, "fixed" | "children" | "messages" | "ndlaFilm" | "infoContent" | "skipToMainContentId"> & import("react-i18next").WithTranslationProps>;
|
|
31
|
+
export declare const Masthead: ({ children, fixed, infoContent, ndlaFilm, skipToMainContentId, messages, onCloseAlert, t, }: Props & WithTranslation) => JSX.Element;
|
|
32
|
+
declare const _default: React.ComponentType<Pick<Pick<Props & WithTranslation<"translation">, "fixed" | "children" | "t" | "tReady" | "messages" | "ndlaFilm" | "infoContent" | "skipToMainContentId" | "onCloseAlert">, "fixed" | "children" | "messages" | "ndlaFilm" | "infoContent" | "skipToMainContentId" | "onCloseAlert"> & import("react-i18next").WithTranslationProps>;
|
|
27
33
|
export default _default;
|
package/lib/Masthead/Masthead.js
CHANGED
|
@@ -60,6 +60,7 @@ var Masthead = function Masthead(_ref3) {
|
|
|
60
60
|
ndlaFilm = _ref3.ndlaFilm,
|
|
61
61
|
skipToMainContentId = _ref3.skipToMainContentId,
|
|
62
62
|
messages = _ref3.messages,
|
|
63
|
+
onCloseAlert = _ref3.onCloseAlert,
|
|
63
64
|
t = _ref3.t;
|
|
64
65
|
var mastheadRef = (0, _react.useRef)(null);
|
|
65
66
|
|
|
@@ -92,8 +93,12 @@ var Masthead = function Masthead(_ref3) {
|
|
|
92
93
|
ndlaFilm: !!ndlaFilm
|
|
93
94
|
})), messages === null || messages === void 0 ? void 0 : messages.map(function (message) {
|
|
94
95
|
return (0, _core.jsx)(_MessageBox.MessageBox, {
|
|
95
|
-
type: _MessageBox.MessageBoxType.masthead
|
|
96
|
-
|
|
96
|
+
type: _MessageBox.MessageBoxType.masthead,
|
|
97
|
+
showCloseButton: message.closable,
|
|
98
|
+
onClose: function onClose() {
|
|
99
|
+
return onCloseAlert === null || onCloseAlert === void 0 ? void 0 : onCloseAlert(message.number);
|
|
100
|
+
}
|
|
101
|
+
}, message.content);
|
|
97
102
|
}), infoContent && (0, _core.jsx)(_Animation.DisplayOnPageYOffset, {
|
|
98
103
|
yOffsetMin: 0,
|
|
99
104
|
yOffsetMax: 90
|
|
@@ -26,7 +26,8 @@ declare type Props = {
|
|
|
26
26
|
children?: string;
|
|
27
27
|
links?: LinkProps[];
|
|
28
28
|
showCloseButton?: boolean;
|
|
29
|
+
onClose?: () => void;
|
|
29
30
|
};
|
|
30
|
-
export declare const MessageBox: ({ type, sticky, children, links,
|
|
31
|
-
declare const _default: React.ComponentType<Pick<Pick<Props & WithTranslation<"translation">, "sticky" | "children" | "type" | "t" | "tReady" | "links" | "showCloseButton">, "sticky" | "children" | "type" | "links" | "showCloseButton"> & import("react-i18next").WithTranslationProps>;
|
|
31
|
+
export declare const MessageBox: ({ type, sticky, children, links, showCloseButton, onClose, }: Props & WithTranslation) => JSX.Element;
|
|
32
|
+
declare const _default: React.ComponentType<Pick<Pick<Props & WithTranslation<"translation">, "sticky" | "children" | "type" | "t" | "tReady" | "onClose" | "links" | "showCloseButton">, "sticky" | "children" | "type" | "onClose" | "links" | "showCloseButton"> & import("react-i18next").WithTranslationProps>;
|
|
32
33
|
export default _default;
|