@ndla/ui 50.10.3 → 50.11.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.
Files changed (76) hide show
  1. package/es/ContentTypeBadge/ContentTypeBadge.js +21 -21
  2. package/es/ContentTypeBadge/index.js +1 -1
  3. package/es/Embed/ConceptEmbed.js +7 -7
  4. package/es/Embed/RelatedContentEmbed.js +1 -1
  5. package/es/Hero/Hero.js +7 -7
  6. package/es/Hero/index.js +1 -1
  7. package/es/RelatedArticleList/RelatedArticleList.js +8 -8
  8. package/es/ResourceGroup/ResourceGroup.js +6 -5
  9. package/es/ResourceGroup/ResourceItem.js +42 -37
  10. package/es/ResourceGroup/ResourceList.js +24 -26
  11. package/es/SearchTypeResult/SearchTypeResult.js +2 -2
  12. package/es/all.css +1 -1
  13. package/es/index.js +2 -2
  14. package/es/locale/messages-en.js +0 -1
  15. package/es/locale/messages-nb.js +0 -1
  16. package/es/locale/messages-nn.js +0 -1
  17. package/es/locale/messages-se.js +0 -1
  18. package/es/locale/messages-sma.js +0 -1
  19. package/es/model/ContentType.js +8 -6
  20. package/es/utils/resourceTypeColor.js +2 -2
  21. package/lib/ContentTypeBadge/ContentTypeBadge.d.ts +1 -1
  22. package/lib/ContentTypeBadge/ContentTypeBadge.js +23 -23
  23. package/lib/ContentTypeBadge/index.d.ts +1 -1
  24. package/lib/ContentTypeBadge/index.js +2 -2
  25. package/lib/Embed/ConceptEmbed.js +7 -7
  26. package/lib/Embed/RelatedContentEmbed.js +1 -1
  27. package/lib/Hero/Hero.d.ts +2 -2
  28. package/lib/Hero/Hero.js +8 -8
  29. package/lib/Hero/index.d.ts +1 -1
  30. package/lib/Hero/index.js +2 -2
  31. package/lib/RelatedArticleList/RelatedArticleList.js +8 -8
  32. package/lib/ResourceGroup/ResourceGroup.js +6 -5
  33. package/lib/ResourceGroup/ResourceItem.js +42 -37
  34. package/lib/ResourceGroup/ResourceList.js +24 -26
  35. package/lib/SearchTypeResult/SearchTypeResult.d.ts +1 -1
  36. package/lib/SearchTypeResult/SearchTypeResult.js +2 -2
  37. package/lib/all.css +1 -1
  38. package/lib/index.d.ts +2 -2
  39. package/lib/index.js +12 -12
  40. package/lib/locale/messages-en.d.ts +0 -1
  41. package/lib/locale/messages-en.js +0 -1
  42. package/lib/locale/messages-nb.d.ts +0 -1
  43. package/lib/locale/messages-nb.js +0 -1
  44. package/lib/locale/messages-nn.d.ts +0 -1
  45. package/lib/locale/messages-nn.js +0 -1
  46. package/lib/locale/messages-se.d.ts +0 -1
  47. package/lib/locale/messages-se.js +0 -1
  48. package/lib/locale/messages-sma.d.ts +0 -1
  49. package/lib/locale/messages-sma.js +0 -1
  50. package/lib/model/ContentType.d.ts +5 -3
  51. package/lib/model/ContentType.js +9 -7
  52. package/lib/model/index.d.ts +2 -1
  53. package/lib/utils/resourceTypeColor.js +2 -2
  54. package/package.json +17 -17
  55. package/src/Article/component.article.scss +2 -2
  56. package/src/ContentTypeBadge/ContentTypeBadge.stories.tsx +2 -2
  57. package/src/ContentTypeBadge/ContentTypeBadge.tsx +15 -19
  58. package/src/ContentTypeBadge/index.ts +1 -1
  59. package/src/Embed/ConceptEmbed.tsx +3 -3
  60. package/src/Embed/RelatedContentEmbed.tsx +1 -1
  61. package/src/Hero/Hero.tsx +8 -10
  62. package/src/Hero/index.ts +1 -1
  63. package/src/RelatedArticleList/RelatedArticleList.tsx +1 -1
  64. package/src/ResourceGroup/ResourceGroup.tsx +2 -2
  65. package/src/ResourceGroup/ResourceItem.stories.tsx +2 -2
  66. package/src/ResourceGroup/ResourceItem.tsx +62 -36
  67. package/src/ResourceGroup/ResourceList.tsx +28 -30
  68. package/src/SearchTypeResult/SearchTypeResult.tsx +1 -1
  69. package/src/index.ts +2 -2
  70. package/src/locale/messages-en.ts +0 -1
  71. package/src/locale/messages-nb.ts +0 -1
  72. package/src/locale/messages-nn.ts +0 -1
  73. package/src/locale/messages-se.ts +0 -1
  74. package/src/locale/messages-sma.ts +0 -1
  75. package/src/model/ContentType.ts +8 -5
  76. package/src/utils/resourceTypeColor.tsx +2 -2
@@ -13,7 +13,7 @@ import { css } from "@emotion/react";
13
13
  import { breakpoints, colors, mq } from "@ndla/core";
14
14
  import { MenuBook } from "@ndla/icons/action";
15
15
  import { Audio } from "@ndla/icons/common";
16
- import { SubjectMaterial, TasksAndActivities, AssessmentResource, Subject, ExternalLearningResource, SharedResource, LearningPath, MultidisciplinaryTopic } from "@ndla/icons/contentType";
16
+ import { AssessmentResource, ExternalLearningResource, LearningPath, MultidisciplinaryTopic, SharedResource, Subject, SubjectMaterial, TasksAndActivities } from "@ndla/icons/contentType";
17
17
  import { Concept, Media, Video } from "@ndla/icons/editor";
18
18
  import * as contentTypes from "../model/ContentType";
19
19
  import { jsx as _jsx } from "@emotion/react/jsx-runtime";
@@ -24,14 +24,14 @@ const sizes = {
24
24
  } : {
25
25
  name: "1nlcfpk-xx-small",
26
26
  styles: "width:20px;height:20px;border:1px solid;svg{width:10px;height:10x;};label:xx-small;",
27
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ContentTypeBadge.tsx"],"names":[],"mappings":"AAwCiB","file":"ContentTypeBadge.tsx","sourcesContent":["/**\n * Copyright (c) 2018-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 { CSSProperties, ComponentProps, useMemo } from \"react\";\n\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, mq } from \"@ndla/core\";\nimport { MenuBook } from \"@ndla/icons/action\";\nimport { Audio } from \"@ndla/icons/common\";\nimport {\n  SubjectMaterial,\n  TasksAndActivities,\n  AssessmentResource,\n  Subject,\n  ExternalLearningResource,\n  SharedResource,\n  LearningPath,\n  MultidisciplinaryTopic,\n} from \"@ndla/icons/contentType\";\n\nimport { Concept, Media, Video } from \"@ndla/icons/editor\";\n\nimport * as contentTypes from \"../model/ContentType\";\n\ninterface Props extends ComponentProps<\"div\"> {\n  size?: \"xx-small\" | \"x-small\" | \"small\" | \"large\";\n  type: string;\n  title?: string;\n  background?: boolean;\n  border?: boolean;\n  className?: string;\n}\n\nconst sizes = {\n  \"xx-small\": css`\n    width: 20px;\n    height: 20px;\n    border: 1px solid;\n    svg {\n      width: 10px;\n      height: 10x;\n    }\n  `,\n  \"x-small\": css`\n    width: 20px;\n    height: 20px;\n    border: 1px solid;\n    ${mq.range({ from: breakpoints.tablet })} {\n      height: 26px;\n      width: 26px;\n    }\n    svg {\n      width: 10px;\n      height: 10x;\n      ${mq.range({ from: breakpoints.tablet })} {\n        width: 12px;\n        height: 12px;\n      }\n    }\n  `,\n  small: \"\",\n  large: css`\n    width: 50px;\n    height: 50px;\n    svg {\n      width: 25px;\n      height: 25px;\n    }\n  `,\n} as const;\n\nconst BaseContentTypeBadge = styled.div`\n  display: inline-flex;\n  align-items: center;\n  justify-content: center;\n  border-radius: 100%;\n  width: 34px;\n  height: 34px;\n  color: var(--icon-color);\n`;\n\nconst borderStyle = css`\n  border: 2px solid;\n  border-color: var(--icon-color);\n`;\n\nconst backgroundStyle = css`\n  background-color: var(--background-color);\n`;\n\nconst iconMap = {\n  [contentTypes.SUBJECT_MATERIAL]: {\n    icon: SubjectMaterial,\n    iconColor: colors.subjectMaterial.dark,\n    backgroundColor: colors.subjectMaterial.light,\n  },\n  [contentTypes.TASKS_AND_ACTIVITIES]: {\n    icon: TasksAndActivities,\n    iconColor: colors.tasksAndActivities.dark,\n    backgroundColor: colors.tasksAndActivities.light,\n  },\n  [contentTypes.ASSESSMENT_RESOURCES]: {\n    icon: AssessmentResource,\n    iconColor: colors.assessmentResource.dark,\n    backgroundColor: colors.assessmentResource.light,\n  },\n  [contentTypes.SUBJECT]: {\n    icon: MenuBook,\n    iconColor: colors.subject.dark,\n    backgroundColor: colors.subject.light,\n  },\n  [contentTypes.EXTERNAL_LEARNING_RESOURCES]: {\n    icon: ExternalLearningResource,\n    iconColor: colors.externalLearningResource.dark,\n    backgroundColor: colors.externalLearningResource.light,\n  },\n  [contentTypes.SOURCE_MATERIAL]: {\n    icon: SharedResource,\n    iconColor: colors.sourceMaterial.dark,\n    backgroundColor: colors.sourceMaterial.light,\n  },\n  [contentTypes.LEARNING_PATH]: {\n    icon: LearningPath,\n    iconColor: colors.learningPath.dark,\n    backgroundColor: colors.learningPath.light,\n  },\n  [contentTypes.TOPIC]: {\n    icon: Subject,\n    iconColor: colors.subject.dark,\n    backgroundColor: colors.subject.light,\n  },\n  [contentTypes.MULTIDISCIPLINARY_TOPIC]: {\n    icon: MultidisciplinaryTopic,\n    backgroundColor: \"#b9b37b\",\n  },\n  [contentTypes.resourceEmbedTypeMapping.image]: {\n    icon: Media,\n    iconColor: colors.brand.grey,\n    backgroundColor: colors.brand.greyLight,\n  },\n  [contentTypes.resourceEmbedTypeMapping.audio]: {\n    icon: Audio,\n    iconColor: colors.brand.grey,\n    backgroundColor: colors.brand.greyLight,\n  },\n  [contentTypes.resourceEmbedTypeMapping.video]: {\n    icon: Video,\n    iconColor: colors.brand.grey,\n    backgroundColor: colors.brand.greyLight,\n  },\n  [contentTypes.resourceEmbedTypeMapping.concept]: {\n    icon: Concept,\n    iconColor: colors.brand.grey,\n    backgroundColor: colors.brand.greyLight,\n  },\n} as const;\n\nexport const ContentTypeBadge = ({\n  type,\n  background,\n  title,\n  size = \"small\",\n  border = true,\n  className,\n  ...rest\n}: Props) => {\n  const { Icon, style } = useMemo(() => {\n    const fromMap = iconMap[type];\n    const style = {\n      \"--icon-color\": fromMap.iconColor,\n      \"--background-color\": fromMap.backgroundColor,\n    } as CSSProperties;\n    return { Icon: fromMap.icon, style };\n  }, [type]);\n\n  const cssStyles = useMemo(() => {\n    const styles = [sizes[size]];\n    if (background) {\n      styles.push(backgroundStyle);\n    }\n    if (border) {\n      styles.push(borderStyle);\n    }\n    return styles;\n  }, [background, border, size]);\n\n  return (\n    <BaseContentTypeBadge\n      css={cssStyles}\n      title={title}\n      style={style}\n      aria-label={title}\n      className={className}\n      data-badge=\"\"\n      data-type={type}\n      {...rest}\n    >\n      <Icon />\n    </BaseContentTypeBadge>\n  );\n};\n\nexport const SubjectMaterialBadge = (props: Omit<Props, \"type\">) => (\n  <ContentTypeBadge {...props} type={contentTypes.SUBJECT_MATERIAL} />\n);\nexport const TasksAndActivitiesBadge = (props: Omit<Props, \"type\">) => (\n  <ContentTypeBadge {...props} type={contentTypes.TASKS_AND_ACTIVITIES} />\n);\nexport const AssessmentResourcesBadge = (props: Omit<Props, \"type\">) => (\n  <ContentTypeBadge {...props} type={contentTypes.ASSESSMENT_RESOURCES} />\n);\nexport const SubjectBadge = (props: Omit<Props, \"type\">) => <ContentTypeBadge {...props} type={contentTypes.SUBJECT} />;\nexport const ExternalLearningResourcesBadge = (props: Omit<Props, \"type\">) => (\n  <ContentTypeBadge {...props} type={contentTypes.EXTERNAL_LEARNING_RESOURCES} />\n);\nexport const SourceMaterialBadge = (props: Omit<Props, \"type\">) => (\n  <ContentTypeBadge {...props} type={contentTypes.SOURCE_MATERIAL} />\n);\n\nexport const LearningPathBadge = (props: Omit<Props, \"type\">) => (\n  <ContentTypeBadge {...props} type={contentTypes.LEARNING_PATH} />\n);\n\nexport const MultidisciplinaryTopicBadge = (props: Omit<Props, \"type\">) => (\n  <ContentTypeBadge {...props} type={contentTypes.MULTIDISCIPLINARY_TOPIC} />\n);\n"]} */",
27
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ContentTypeBadge.tsx"],"names":[],"mappings":"AAwCiB","file":"ContentTypeBadge.tsx","sourcesContent":["/**\n * Copyright (c) 2018-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 { CSSProperties, ComponentProps, useMemo } from \"react\";\n\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, mq } from \"@ndla/core\";\nimport { MenuBook } from \"@ndla/icons/action\";\nimport { Audio } from \"@ndla/icons/common\";\nimport {\n  AssessmentResource,\n  ExternalLearningResource,\n  LearningPath,\n  MultidisciplinaryTopic,\n  SharedResource,\n  Subject,\n  SubjectMaterial,\n  TasksAndActivities,\n} from \"@ndla/icons/contentType\";\n\nimport { Concept, Media, Video } from \"@ndla/icons/editor\";\n\nimport * as contentTypes from \"../model/ContentType\";\n\ninterface Props extends ComponentProps<\"div\"> {\n  size?: \"xx-small\" | \"x-small\" | \"small\" | \"large\";\n  type: string;\n  title?: string;\n  background?: boolean;\n  border?: boolean;\n  className?: string;\n}\n\nconst sizes = {\n  \"xx-small\": css`\n    width: 20px;\n    height: 20px;\n    border: 1px solid;\n    svg {\n      width: 10px;\n      height: 10x;\n    }\n  `,\n  \"x-small\": css`\n    width: 20px;\n    height: 20px;\n    border: 1px solid;\n    ${mq.range({ from: breakpoints.tablet })} {\n      height: 26px;\n      width: 26px;\n    }\n    svg {\n      width: 10px;\n      height: 10x;\n      ${mq.range({ from: breakpoints.tablet })} {\n        width: 12px;\n        height: 12px;\n      }\n    }\n  `,\n  small: \"\",\n  large: css`\n    width: 50px;\n    height: 50px;\n    svg {\n      width: 25px;\n      height: 25px;\n    }\n  `,\n} as const;\n\nconst BaseContentTypeBadge = styled.div`\n  display: inline-flex;\n  align-items: center;\n  justify-content: center;\n  border-radius: 100%;\n  width: 34px;\n  height: 34px;\n  color: var(--icon-color);\n`;\n\nconst borderStyle = css`\n  border: 2px solid;\n  border-color: var(--icon-color);\n`;\n\nconst backgroundStyle = css`\n  background-color: var(--background-color);\n`;\n\nconst iconMap = {\n  [contentTypes.SUBJECT_MATERIAL]: {\n    icon: SubjectMaterial,\n    iconColor: colors.subjectMaterial.dark,\n    backgroundColor: colors.subjectMaterial.light,\n  },\n  [contentTypes.TASKS_AND_ACTIVITIES]: {\n    icon: TasksAndActivities,\n    iconColor: colors.tasksAndActivities.dark,\n    backgroundColor: colors.tasksAndActivities.light,\n  },\n  [contentTypes.ASSESSMENT_RESOURCES]: {\n    icon: AssessmentResource,\n    iconColor: colors.assessmentResource.dark,\n    backgroundColor: colors.assessmentResource.light,\n  },\n  [contentTypes.SUBJECT]: {\n    icon: MenuBook,\n    iconColor: colors.subject.dark,\n    backgroundColor: colors.subject.light,\n  },\n  [contentTypes.SOURCE_MATERIAL]: {\n    icon: SharedResource,\n    iconColor: colors.sourceMaterial.dark,\n    backgroundColor: colors.sourceMaterial.light,\n  },\n  [contentTypes.LEARNING_PATH]: {\n    icon: LearningPath,\n    iconColor: colors.learningPath.dark,\n    backgroundColor: colors.learningPath.light,\n  },\n  [contentTypes.TOPIC]: {\n    icon: Subject,\n    iconColor: colors.subject.dark,\n    backgroundColor: colors.subject.light,\n  },\n  [contentTypes.MULTIDISCIPLINARY_TOPIC]: {\n    icon: MultidisciplinaryTopic,\n    backgroundColor: \"#b9b37b\",\n  },\n  [contentTypes.CONCEPT]: {\n    icon: Concept,\n    iconColor: colors.concept.text,\n    backgroundColor: colors.concept.light,\n  },\n  [contentTypes.EXTERNAL]: {\n    icon: ExternalLearningResource,\n    iconColor: colors.external.dark,\n    backgroundColor: colors.external.light,\n  },\n  [contentTypes.resourceEmbedTypeMapping.image]: {\n    icon: Media,\n    iconColor: colors.brand.grey,\n    backgroundColor: colors.brand.greyLight,\n  },\n  [contentTypes.resourceEmbedTypeMapping.audio]: {\n    icon: Audio,\n    iconColor: colors.brand.grey,\n    backgroundColor: colors.brand.greyLight,\n  },\n  [contentTypes.resourceEmbedTypeMapping.video]: {\n    icon: Video,\n    iconColor: colors.brand.grey,\n    backgroundColor: colors.brand.greyLight,\n  },\n} as const;\n\nexport const ContentTypeBadge = ({\n  type,\n  background,\n  title,\n  size = \"small\",\n  border = true,\n  className,\n  ...rest\n}: Props) => {\n  const { Icon, style } = useMemo(() => {\n    const fromMap = iconMap[type];\n    const style = {\n      \"--icon-color\": fromMap.iconColor,\n      \"--background-color\": fromMap.backgroundColor,\n    } as CSSProperties;\n    return { Icon: fromMap.icon, style };\n  }, [type]);\n\n  const cssStyles = useMemo(() => {\n    const styles = [sizes[size]];\n    if (background) {\n      styles.push(backgroundStyle);\n    }\n    if (border) {\n      styles.push(borderStyle);\n    }\n    return styles;\n  }, [background, border, size]);\n\n  return (\n    <BaseContentTypeBadge\n      css={cssStyles}\n      title={title}\n      style={style}\n      aria-label={title}\n      className={className}\n      data-badge=\"\"\n      data-type={type}\n      {...rest}\n    >\n      <Icon />\n    </BaseContentTypeBadge>\n  );\n};\n\nexport const SubjectMaterialBadge = (props: Omit<Props, \"type\">) => (\n  <ContentTypeBadge {...props} type={contentTypes.SUBJECT_MATERIAL} />\n);\nexport const TasksAndActivitiesBadge = (props: Omit<Props, \"type\">) => (\n  <ContentTypeBadge {...props} type={contentTypes.TASKS_AND_ACTIVITIES} />\n);\nexport const AssessmentResourcesBadge = (props: Omit<Props, \"type\">) => (\n  <ContentTypeBadge {...props} type={contentTypes.ASSESSMENT_RESOURCES} />\n);\nexport const SubjectBadge = (props: Omit<Props, \"type\">) => <ContentTypeBadge {...props} type={contentTypes.SUBJECT} />;\nexport const SourceMaterialBadge = (props: Omit<Props, \"type\">) => (\n  <ContentTypeBadge {...props} type={contentTypes.SOURCE_MATERIAL} />\n);\nexport const LearningPathBadge = (props: Omit<Props, \"type\">) => (\n  <ContentTypeBadge {...props} type={contentTypes.LEARNING_PATH} />\n);\nexport const MultidisciplinaryTopicBadge = (props: Omit<Props, \"type\">) => (\n  <ContentTypeBadge {...props} type={contentTypes.MULTIDISCIPLINARY_TOPIC} />\n);\nexport const ConceptBadge = (props: Omit<Props, \"type\">) => <ContentTypeBadge {...props} type={contentTypes.CONCEPT} />;\n"]} */",
28
28
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
29
29
  },
30
30
  "x-small": /*#__PURE__*/css("width:20px;height:20px;border:1px solid;", mq.range({
31
31
  from: breakpoints.tablet
32
32
  }), "{height:26px;width:26px;}svg{width:10px;height:10x;", mq.range({
33
33
  from: breakpoints.tablet
34
- }), "{width:12px;height:12px;}};label:x-small;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ContentTypeBadge.tsx"],"names":[],"mappings":"AAiDgB","file":"ContentTypeBadge.tsx","sourcesContent":["/**\n * Copyright (c) 2018-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 { CSSProperties, ComponentProps, useMemo } from \"react\";\n\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, mq } from \"@ndla/core\";\nimport { MenuBook } from \"@ndla/icons/action\";\nimport { Audio } from \"@ndla/icons/common\";\nimport {\n  SubjectMaterial,\n  TasksAndActivities,\n  AssessmentResource,\n  Subject,\n  ExternalLearningResource,\n  SharedResource,\n  LearningPath,\n  MultidisciplinaryTopic,\n} from \"@ndla/icons/contentType\";\n\nimport { Concept, Media, Video } from \"@ndla/icons/editor\";\n\nimport * as contentTypes from \"../model/ContentType\";\n\ninterface Props extends ComponentProps<\"div\"> {\n  size?: \"xx-small\" | \"x-small\" | \"small\" | \"large\";\n  type: string;\n  title?: string;\n  background?: boolean;\n  border?: boolean;\n  className?: string;\n}\n\nconst sizes = {\n  \"xx-small\": css`\n    width: 20px;\n    height: 20px;\n    border: 1px solid;\n    svg {\n      width: 10px;\n      height: 10x;\n    }\n  `,\n  \"x-small\": css`\n    width: 20px;\n    height: 20px;\n    border: 1px solid;\n    ${mq.range({ from: breakpoints.tablet })} {\n      height: 26px;\n      width: 26px;\n    }\n    svg {\n      width: 10px;\n      height: 10x;\n      ${mq.range({ from: breakpoints.tablet })} {\n        width: 12px;\n        height: 12px;\n      }\n    }\n  `,\n  small: \"\",\n  large: css`\n    width: 50px;\n    height: 50px;\n    svg {\n      width: 25px;\n      height: 25px;\n    }\n  `,\n} as const;\n\nconst BaseContentTypeBadge = styled.div`\n  display: inline-flex;\n  align-items: center;\n  justify-content: center;\n  border-radius: 100%;\n  width: 34px;\n  height: 34px;\n  color: var(--icon-color);\n`;\n\nconst borderStyle = css`\n  border: 2px solid;\n  border-color: var(--icon-color);\n`;\n\nconst backgroundStyle = css`\n  background-color: var(--background-color);\n`;\n\nconst iconMap = {\n  [contentTypes.SUBJECT_MATERIAL]: {\n    icon: SubjectMaterial,\n    iconColor: colors.subjectMaterial.dark,\n    backgroundColor: colors.subjectMaterial.light,\n  },\n  [contentTypes.TASKS_AND_ACTIVITIES]: {\n    icon: TasksAndActivities,\n    iconColor: colors.tasksAndActivities.dark,\n    backgroundColor: colors.tasksAndActivities.light,\n  },\n  [contentTypes.ASSESSMENT_RESOURCES]: {\n    icon: AssessmentResource,\n    iconColor: colors.assessmentResource.dark,\n    backgroundColor: colors.assessmentResource.light,\n  },\n  [contentTypes.SUBJECT]: {\n    icon: MenuBook,\n    iconColor: colors.subject.dark,\n    backgroundColor: colors.subject.light,\n  },\n  [contentTypes.EXTERNAL_LEARNING_RESOURCES]: {\n    icon: ExternalLearningResource,\n    iconColor: colors.externalLearningResource.dark,\n    backgroundColor: colors.externalLearningResource.light,\n  },\n  [contentTypes.SOURCE_MATERIAL]: {\n    icon: SharedResource,\n    iconColor: colors.sourceMaterial.dark,\n    backgroundColor: colors.sourceMaterial.light,\n  },\n  [contentTypes.LEARNING_PATH]: {\n    icon: LearningPath,\n    iconColor: colors.learningPath.dark,\n    backgroundColor: colors.learningPath.light,\n  },\n  [contentTypes.TOPIC]: {\n    icon: Subject,\n    iconColor: colors.subject.dark,\n    backgroundColor: colors.subject.light,\n  },\n  [contentTypes.MULTIDISCIPLINARY_TOPIC]: {\n    icon: MultidisciplinaryTopic,\n    backgroundColor: \"#b9b37b\",\n  },\n  [contentTypes.resourceEmbedTypeMapping.image]: {\n    icon: Media,\n    iconColor: colors.brand.grey,\n    backgroundColor: colors.brand.greyLight,\n  },\n  [contentTypes.resourceEmbedTypeMapping.audio]: {\n    icon: Audio,\n    iconColor: colors.brand.grey,\n    backgroundColor: colors.brand.greyLight,\n  },\n  [contentTypes.resourceEmbedTypeMapping.video]: {\n    icon: Video,\n    iconColor: colors.brand.grey,\n    backgroundColor: colors.brand.greyLight,\n  },\n  [contentTypes.resourceEmbedTypeMapping.concept]: {\n    icon: Concept,\n    iconColor: colors.brand.grey,\n    backgroundColor: colors.brand.greyLight,\n  },\n} as const;\n\nexport const ContentTypeBadge = ({\n  type,\n  background,\n  title,\n  size = \"small\",\n  border = true,\n  className,\n  ...rest\n}: Props) => {\n  const { Icon, style } = useMemo(() => {\n    const fromMap = iconMap[type];\n    const style = {\n      \"--icon-color\": fromMap.iconColor,\n      \"--background-color\": fromMap.backgroundColor,\n    } as CSSProperties;\n    return { Icon: fromMap.icon, style };\n  }, [type]);\n\n  const cssStyles = useMemo(() => {\n    const styles = [sizes[size]];\n    if (background) {\n      styles.push(backgroundStyle);\n    }\n    if (border) {\n      styles.push(borderStyle);\n    }\n    return styles;\n  }, [background, border, size]);\n\n  return (\n    <BaseContentTypeBadge\n      css={cssStyles}\n      title={title}\n      style={style}\n      aria-label={title}\n      className={className}\n      data-badge=\"\"\n      data-type={type}\n      {...rest}\n    >\n      <Icon />\n    </BaseContentTypeBadge>\n  );\n};\n\nexport const SubjectMaterialBadge = (props: Omit<Props, \"type\">) => (\n  <ContentTypeBadge {...props} type={contentTypes.SUBJECT_MATERIAL} />\n);\nexport const TasksAndActivitiesBadge = (props: Omit<Props, \"type\">) => (\n  <ContentTypeBadge {...props} type={contentTypes.TASKS_AND_ACTIVITIES} />\n);\nexport const AssessmentResourcesBadge = (props: Omit<Props, \"type\">) => (\n  <ContentTypeBadge {...props} type={contentTypes.ASSESSMENT_RESOURCES} />\n);\nexport const SubjectBadge = (props: Omit<Props, \"type\">) => <ContentTypeBadge {...props} type={contentTypes.SUBJECT} />;\nexport const ExternalLearningResourcesBadge = (props: Omit<Props, \"type\">) => (\n  <ContentTypeBadge {...props} type={contentTypes.EXTERNAL_LEARNING_RESOURCES} />\n);\nexport const SourceMaterialBadge = (props: Omit<Props, \"type\">) => (\n  <ContentTypeBadge {...props} type={contentTypes.SOURCE_MATERIAL} />\n);\n\nexport const LearningPathBadge = (props: Omit<Props, \"type\">) => (\n  <ContentTypeBadge {...props} type={contentTypes.LEARNING_PATH} />\n);\n\nexport const MultidisciplinaryTopicBadge = (props: Omit<Props, \"type\">) => (\n  <ContentTypeBadge {...props} type={contentTypes.MULTIDISCIPLINARY_TOPIC} />\n);\n"]} */")),
34
+ }), "{width:12px;height:12px;}};label:x-small;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ContentTypeBadge.tsx"],"names":[],"mappings":"AAiDgB","file":"ContentTypeBadge.tsx","sourcesContent":["/**\n * Copyright (c) 2018-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 { CSSProperties, ComponentProps, useMemo } from \"react\";\n\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, mq } from \"@ndla/core\";\nimport { MenuBook } from \"@ndla/icons/action\";\nimport { Audio } from \"@ndla/icons/common\";\nimport {\n  AssessmentResource,\n  ExternalLearningResource,\n  LearningPath,\n  MultidisciplinaryTopic,\n  SharedResource,\n  Subject,\n  SubjectMaterial,\n  TasksAndActivities,\n} from \"@ndla/icons/contentType\";\n\nimport { Concept, Media, Video } from \"@ndla/icons/editor\";\n\nimport * as contentTypes from \"../model/ContentType\";\n\ninterface Props extends ComponentProps<\"div\"> {\n  size?: \"xx-small\" | \"x-small\" | \"small\" | \"large\";\n  type: string;\n  title?: string;\n  background?: boolean;\n  border?: boolean;\n  className?: string;\n}\n\nconst sizes = {\n  \"xx-small\": css`\n    width: 20px;\n    height: 20px;\n    border: 1px solid;\n    svg {\n      width: 10px;\n      height: 10x;\n    }\n  `,\n  \"x-small\": css`\n    width: 20px;\n    height: 20px;\n    border: 1px solid;\n    ${mq.range({ from: breakpoints.tablet })} {\n      height: 26px;\n      width: 26px;\n    }\n    svg {\n      width: 10px;\n      height: 10x;\n      ${mq.range({ from: breakpoints.tablet })} {\n        width: 12px;\n        height: 12px;\n      }\n    }\n  `,\n  small: \"\",\n  large: css`\n    width: 50px;\n    height: 50px;\n    svg {\n      width: 25px;\n      height: 25px;\n    }\n  `,\n} as const;\n\nconst BaseContentTypeBadge = styled.div`\n  display: inline-flex;\n  align-items: center;\n  justify-content: center;\n  border-radius: 100%;\n  width: 34px;\n  height: 34px;\n  color: var(--icon-color);\n`;\n\nconst borderStyle = css`\n  border: 2px solid;\n  border-color: var(--icon-color);\n`;\n\nconst backgroundStyle = css`\n  background-color: var(--background-color);\n`;\n\nconst iconMap = {\n  [contentTypes.SUBJECT_MATERIAL]: {\n    icon: SubjectMaterial,\n    iconColor: colors.subjectMaterial.dark,\n    backgroundColor: colors.subjectMaterial.light,\n  },\n  [contentTypes.TASKS_AND_ACTIVITIES]: {\n    icon: TasksAndActivities,\n    iconColor: colors.tasksAndActivities.dark,\n    backgroundColor: colors.tasksAndActivities.light,\n  },\n  [contentTypes.ASSESSMENT_RESOURCES]: {\n    icon: AssessmentResource,\n    iconColor: colors.assessmentResource.dark,\n    backgroundColor: colors.assessmentResource.light,\n  },\n  [contentTypes.SUBJECT]: {\n    icon: MenuBook,\n    iconColor: colors.subject.dark,\n    backgroundColor: colors.subject.light,\n  },\n  [contentTypes.SOURCE_MATERIAL]: {\n    icon: SharedResource,\n    iconColor: colors.sourceMaterial.dark,\n    backgroundColor: colors.sourceMaterial.light,\n  },\n  [contentTypes.LEARNING_PATH]: {\n    icon: LearningPath,\n    iconColor: colors.learningPath.dark,\n    backgroundColor: colors.learningPath.light,\n  },\n  [contentTypes.TOPIC]: {\n    icon: Subject,\n    iconColor: colors.subject.dark,\n    backgroundColor: colors.subject.light,\n  },\n  [contentTypes.MULTIDISCIPLINARY_TOPIC]: {\n    icon: MultidisciplinaryTopic,\n    backgroundColor: \"#b9b37b\",\n  },\n  [contentTypes.CONCEPT]: {\n    icon: Concept,\n    iconColor: colors.concept.text,\n    backgroundColor: colors.concept.light,\n  },\n  [contentTypes.EXTERNAL]: {\n    icon: ExternalLearningResource,\n    iconColor: colors.external.dark,\n    backgroundColor: colors.external.light,\n  },\n  [contentTypes.resourceEmbedTypeMapping.image]: {\n    icon: Media,\n    iconColor: colors.brand.grey,\n    backgroundColor: colors.brand.greyLight,\n  },\n  [contentTypes.resourceEmbedTypeMapping.audio]: {\n    icon: Audio,\n    iconColor: colors.brand.grey,\n    backgroundColor: colors.brand.greyLight,\n  },\n  [contentTypes.resourceEmbedTypeMapping.video]: {\n    icon: Video,\n    iconColor: colors.brand.grey,\n    backgroundColor: colors.brand.greyLight,\n  },\n} as const;\n\nexport const ContentTypeBadge = ({\n  type,\n  background,\n  title,\n  size = \"small\",\n  border = true,\n  className,\n  ...rest\n}: Props) => {\n  const { Icon, style } = useMemo(() => {\n    const fromMap = iconMap[type];\n    const style = {\n      \"--icon-color\": fromMap.iconColor,\n      \"--background-color\": fromMap.backgroundColor,\n    } as CSSProperties;\n    return { Icon: fromMap.icon, style };\n  }, [type]);\n\n  const cssStyles = useMemo(() => {\n    const styles = [sizes[size]];\n    if (background) {\n      styles.push(backgroundStyle);\n    }\n    if (border) {\n      styles.push(borderStyle);\n    }\n    return styles;\n  }, [background, border, size]);\n\n  return (\n    <BaseContentTypeBadge\n      css={cssStyles}\n      title={title}\n      style={style}\n      aria-label={title}\n      className={className}\n      data-badge=\"\"\n      data-type={type}\n      {...rest}\n    >\n      <Icon />\n    </BaseContentTypeBadge>\n  );\n};\n\nexport const SubjectMaterialBadge = (props: Omit<Props, \"type\">) => (\n  <ContentTypeBadge {...props} type={contentTypes.SUBJECT_MATERIAL} />\n);\nexport const TasksAndActivitiesBadge = (props: Omit<Props, \"type\">) => (\n  <ContentTypeBadge {...props} type={contentTypes.TASKS_AND_ACTIVITIES} />\n);\nexport const AssessmentResourcesBadge = (props: Omit<Props, \"type\">) => (\n  <ContentTypeBadge {...props} type={contentTypes.ASSESSMENT_RESOURCES} />\n);\nexport const SubjectBadge = (props: Omit<Props, \"type\">) => <ContentTypeBadge {...props} type={contentTypes.SUBJECT} />;\nexport const SourceMaterialBadge = (props: Omit<Props, \"type\">) => (\n  <ContentTypeBadge {...props} type={contentTypes.SOURCE_MATERIAL} />\n);\nexport const LearningPathBadge = (props: Omit<Props, \"type\">) => (\n  <ContentTypeBadge {...props} type={contentTypes.LEARNING_PATH} />\n);\nexport const MultidisciplinaryTopicBadge = (props: Omit<Props, \"type\">) => (\n  <ContentTypeBadge {...props} type={contentTypes.MULTIDISCIPLINARY_TOPIC} />\n);\nexport const ConceptBadge = (props: Omit<Props, \"type\">) => <ContentTypeBadge {...props} type={contentTypes.CONCEPT} />;\n"]} */")),
35
35
  small: "",
36
36
  large: process.env.NODE_ENV === "production" ? {
37
37
  name: "1eyjjbh-large",
@@ -39,7 +39,7 @@ const sizes = {
39
39
  } : {
40
40
  name: "1eyjjbh-large",
41
41
  styles: "width:50px;height:50px;svg{width:25px;height:25px;};label:large;",
42
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ContentTypeBadge.tsx"],"names":[],"mappings":"AAmEY","file":"ContentTypeBadge.tsx","sourcesContent":["/**\n * Copyright (c) 2018-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 { CSSProperties, ComponentProps, useMemo } from \"react\";\n\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, mq } from \"@ndla/core\";\nimport { MenuBook } from \"@ndla/icons/action\";\nimport { Audio } from \"@ndla/icons/common\";\nimport {\n  SubjectMaterial,\n  TasksAndActivities,\n  AssessmentResource,\n  Subject,\n  ExternalLearningResource,\n  SharedResource,\n  LearningPath,\n  MultidisciplinaryTopic,\n} from \"@ndla/icons/contentType\";\n\nimport { Concept, Media, Video } from \"@ndla/icons/editor\";\n\nimport * as contentTypes from \"../model/ContentType\";\n\ninterface Props extends ComponentProps<\"div\"> {\n  size?: \"xx-small\" | \"x-small\" | \"small\" | \"large\";\n  type: string;\n  title?: string;\n  background?: boolean;\n  border?: boolean;\n  className?: string;\n}\n\nconst sizes = {\n  \"xx-small\": css`\n    width: 20px;\n    height: 20px;\n    border: 1px solid;\n    svg {\n      width: 10px;\n      height: 10x;\n    }\n  `,\n  \"x-small\": css`\n    width: 20px;\n    height: 20px;\n    border: 1px solid;\n    ${mq.range({ from: breakpoints.tablet })} {\n      height: 26px;\n      width: 26px;\n    }\n    svg {\n      width: 10px;\n      height: 10x;\n      ${mq.range({ from: breakpoints.tablet })} {\n        width: 12px;\n        height: 12px;\n      }\n    }\n  `,\n  small: \"\",\n  large: css`\n    width: 50px;\n    height: 50px;\n    svg {\n      width: 25px;\n      height: 25px;\n    }\n  `,\n} as const;\n\nconst BaseContentTypeBadge = styled.div`\n  display: inline-flex;\n  align-items: center;\n  justify-content: center;\n  border-radius: 100%;\n  width: 34px;\n  height: 34px;\n  color: var(--icon-color);\n`;\n\nconst borderStyle = css`\n  border: 2px solid;\n  border-color: var(--icon-color);\n`;\n\nconst backgroundStyle = css`\n  background-color: var(--background-color);\n`;\n\nconst iconMap = {\n  [contentTypes.SUBJECT_MATERIAL]: {\n    icon: SubjectMaterial,\n    iconColor: colors.subjectMaterial.dark,\n    backgroundColor: colors.subjectMaterial.light,\n  },\n  [contentTypes.TASKS_AND_ACTIVITIES]: {\n    icon: TasksAndActivities,\n    iconColor: colors.tasksAndActivities.dark,\n    backgroundColor: colors.tasksAndActivities.light,\n  },\n  [contentTypes.ASSESSMENT_RESOURCES]: {\n    icon: AssessmentResource,\n    iconColor: colors.assessmentResource.dark,\n    backgroundColor: colors.assessmentResource.light,\n  },\n  [contentTypes.SUBJECT]: {\n    icon: MenuBook,\n    iconColor: colors.subject.dark,\n    backgroundColor: colors.subject.light,\n  },\n  [contentTypes.EXTERNAL_LEARNING_RESOURCES]: {\n    icon: ExternalLearningResource,\n    iconColor: colors.externalLearningResource.dark,\n    backgroundColor: colors.externalLearningResource.light,\n  },\n  [contentTypes.SOURCE_MATERIAL]: {\n    icon: SharedResource,\n    iconColor: colors.sourceMaterial.dark,\n    backgroundColor: colors.sourceMaterial.light,\n  },\n  [contentTypes.LEARNING_PATH]: {\n    icon: LearningPath,\n    iconColor: colors.learningPath.dark,\n    backgroundColor: colors.learningPath.light,\n  },\n  [contentTypes.TOPIC]: {\n    icon: Subject,\n    iconColor: colors.subject.dark,\n    backgroundColor: colors.subject.light,\n  },\n  [contentTypes.MULTIDISCIPLINARY_TOPIC]: {\n    icon: MultidisciplinaryTopic,\n    backgroundColor: \"#b9b37b\",\n  },\n  [contentTypes.resourceEmbedTypeMapping.image]: {\n    icon: Media,\n    iconColor: colors.brand.grey,\n    backgroundColor: colors.brand.greyLight,\n  },\n  [contentTypes.resourceEmbedTypeMapping.audio]: {\n    icon: Audio,\n    iconColor: colors.brand.grey,\n    backgroundColor: colors.brand.greyLight,\n  },\n  [contentTypes.resourceEmbedTypeMapping.video]: {\n    icon: Video,\n    iconColor: colors.brand.grey,\n    backgroundColor: colors.brand.greyLight,\n  },\n  [contentTypes.resourceEmbedTypeMapping.concept]: {\n    icon: Concept,\n    iconColor: colors.brand.grey,\n    backgroundColor: colors.brand.greyLight,\n  },\n} as const;\n\nexport const ContentTypeBadge = ({\n  type,\n  background,\n  title,\n  size = \"small\",\n  border = true,\n  className,\n  ...rest\n}: Props) => {\n  const { Icon, style } = useMemo(() => {\n    const fromMap = iconMap[type];\n    const style = {\n      \"--icon-color\": fromMap.iconColor,\n      \"--background-color\": fromMap.backgroundColor,\n    } as CSSProperties;\n    return { Icon: fromMap.icon, style };\n  }, [type]);\n\n  const cssStyles = useMemo(() => {\n    const styles = [sizes[size]];\n    if (background) {\n      styles.push(backgroundStyle);\n    }\n    if (border) {\n      styles.push(borderStyle);\n    }\n    return styles;\n  }, [background, border, size]);\n\n  return (\n    <BaseContentTypeBadge\n      css={cssStyles}\n      title={title}\n      style={style}\n      aria-label={title}\n      className={className}\n      data-badge=\"\"\n      data-type={type}\n      {...rest}\n    >\n      <Icon />\n    </BaseContentTypeBadge>\n  );\n};\n\nexport const SubjectMaterialBadge = (props: Omit<Props, \"type\">) => (\n  <ContentTypeBadge {...props} type={contentTypes.SUBJECT_MATERIAL} />\n);\nexport const TasksAndActivitiesBadge = (props: Omit<Props, \"type\">) => (\n  <ContentTypeBadge {...props} type={contentTypes.TASKS_AND_ACTIVITIES} />\n);\nexport const AssessmentResourcesBadge = (props: Omit<Props, \"type\">) => (\n  <ContentTypeBadge {...props} type={contentTypes.ASSESSMENT_RESOURCES} />\n);\nexport const SubjectBadge = (props: Omit<Props, \"type\">) => <ContentTypeBadge {...props} type={contentTypes.SUBJECT} />;\nexport const ExternalLearningResourcesBadge = (props: Omit<Props, \"type\">) => (\n  <ContentTypeBadge {...props} type={contentTypes.EXTERNAL_LEARNING_RESOURCES} />\n);\nexport const SourceMaterialBadge = (props: Omit<Props, \"type\">) => (\n  <ContentTypeBadge {...props} type={contentTypes.SOURCE_MATERIAL} />\n);\n\nexport const LearningPathBadge = (props: Omit<Props, \"type\">) => (\n  <ContentTypeBadge {...props} type={contentTypes.LEARNING_PATH} />\n);\n\nexport const MultidisciplinaryTopicBadge = (props: Omit<Props, \"type\">) => (\n  <ContentTypeBadge {...props} type={contentTypes.MULTIDISCIPLINARY_TOPIC} />\n);\n"]} */",
42
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ContentTypeBadge.tsx"],"names":[],"mappings":"AAmEY","file":"ContentTypeBadge.tsx","sourcesContent":["/**\n * Copyright (c) 2018-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 { CSSProperties, ComponentProps, useMemo } from \"react\";\n\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, mq } from \"@ndla/core\";\nimport { MenuBook } from \"@ndla/icons/action\";\nimport { Audio } from \"@ndla/icons/common\";\nimport {\n  AssessmentResource,\n  ExternalLearningResource,\n  LearningPath,\n  MultidisciplinaryTopic,\n  SharedResource,\n  Subject,\n  SubjectMaterial,\n  TasksAndActivities,\n} from \"@ndla/icons/contentType\";\n\nimport { Concept, Media, Video } from \"@ndla/icons/editor\";\n\nimport * as contentTypes from \"../model/ContentType\";\n\ninterface Props extends ComponentProps<\"div\"> {\n  size?: \"xx-small\" | \"x-small\" | \"small\" | \"large\";\n  type: string;\n  title?: string;\n  background?: boolean;\n  border?: boolean;\n  className?: string;\n}\n\nconst sizes = {\n  \"xx-small\": css`\n    width: 20px;\n    height: 20px;\n    border: 1px solid;\n    svg {\n      width: 10px;\n      height: 10x;\n    }\n  `,\n  \"x-small\": css`\n    width: 20px;\n    height: 20px;\n    border: 1px solid;\n    ${mq.range({ from: breakpoints.tablet })} {\n      height: 26px;\n      width: 26px;\n    }\n    svg {\n      width: 10px;\n      height: 10x;\n      ${mq.range({ from: breakpoints.tablet })} {\n        width: 12px;\n        height: 12px;\n      }\n    }\n  `,\n  small: \"\",\n  large: css`\n    width: 50px;\n    height: 50px;\n    svg {\n      width: 25px;\n      height: 25px;\n    }\n  `,\n} as const;\n\nconst BaseContentTypeBadge = styled.div`\n  display: inline-flex;\n  align-items: center;\n  justify-content: center;\n  border-radius: 100%;\n  width: 34px;\n  height: 34px;\n  color: var(--icon-color);\n`;\n\nconst borderStyle = css`\n  border: 2px solid;\n  border-color: var(--icon-color);\n`;\n\nconst backgroundStyle = css`\n  background-color: var(--background-color);\n`;\n\nconst iconMap = {\n  [contentTypes.SUBJECT_MATERIAL]: {\n    icon: SubjectMaterial,\n    iconColor: colors.subjectMaterial.dark,\n    backgroundColor: colors.subjectMaterial.light,\n  },\n  [contentTypes.TASKS_AND_ACTIVITIES]: {\n    icon: TasksAndActivities,\n    iconColor: colors.tasksAndActivities.dark,\n    backgroundColor: colors.tasksAndActivities.light,\n  },\n  [contentTypes.ASSESSMENT_RESOURCES]: {\n    icon: AssessmentResource,\n    iconColor: colors.assessmentResource.dark,\n    backgroundColor: colors.assessmentResource.light,\n  },\n  [contentTypes.SUBJECT]: {\n    icon: MenuBook,\n    iconColor: colors.subject.dark,\n    backgroundColor: colors.subject.light,\n  },\n  [contentTypes.SOURCE_MATERIAL]: {\n    icon: SharedResource,\n    iconColor: colors.sourceMaterial.dark,\n    backgroundColor: colors.sourceMaterial.light,\n  },\n  [contentTypes.LEARNING_PATH]: {\n    icon: LearningPath,\n    iconColor: colors.learningPath.dark,\n    backgroundColor: colors.learningPath.light,\n  },\n  [contentTypes.TOPIC]: {\n    icon: Subject,\n    iconColor: colors.subject.dark,\n    backgroundColor: colors.subject.light,\n  },\n  [contentTypes.MULTIDISCIPLINARY_TOPIC]: {\n    icon: MultidisciplinaryTopic,\n    backgroundColor: \"#b9b37b\",\n  },\n  [contentTypes.CONCEPT]: {\n    icon: Concept,\n    iconColor: colors.concept.text,\n    backgroundColor: colors.concept.light,\n  },\n  [contentTypes.EXTERNAL]: {\n    icon: ExternalLearningResource,\n    iconColor: colors.external.dark,\n    backgroundColor: colors.external.light,\n  },\n  [contentTypes.resourceEmbedTypeMapping.image]: {\n    icon: Media,\n    iconColor: colors.brand.grey,\n    backgroundColor: colors.brand.greyLight,\n  },\n  [contentTypes.resourceEmbedTypeMapping.audio]: {\n    icon: Audio,\n    iconColor: colors.brand.grey,\n    backgroundColor: colors.brand.greyLight,\n  },\n  [contentTypes.resourceEmbedTypeMapping.video]: {\n    icon: Video,\n    iconColor: colors.brand.grey,\n    backgroundColor: colors.brand.greyLight,\n  },\n} as const;\n\nexport const ContentTypeBadge = ({\n  type,\n  background,\n  title,\n  size = \"small\",\n  border = true,\n  className,\n  ...rest\n}: Props) => {\n  const { Icon, style } = useMemo(() => {\n    const fromMap = iconMap[type];\n    const style = {\n      \"--icon-color\": fromMap.iconColor,\n      \"--background-color\": fromMap.backgroundColor,\n    } as CSSProperties;\n    return { Icon: fromMap.icon, style };\n  }, [type]);\n\n  const cssStyles = useMemo(() => {\n    const styles = [sizes[size]];\n    if (background) {\n      styles.push(backgroundStyle);\n    }\n    if (border) {\n      styles.push(borderStyle);\n    }\n    return styles;\n  }, [background, border, size]);\n\n  return (\n    <BaseContentTypeBadge\n      css={cssStyles}\n      title={title}\n      style={style}\n      aria-label={title}\n      className={className}\n      data-badge=\"\"\n      data-type={type}\n      {...rest}\n    >\n      <Icon />\n    </BaseContentTypeBadge>\n  );\n};\n\nexport const SubjectMaterialBadge = (props: Omit<Props, \"type\">) => (\n  <ContentTypeBadge {...props} type={contentTypes.SUBJECT_MATERIAL} />\n);\nexport const TasksAndActivitiesBadge = (props: Omit<Props, \"type\">) => (\n  <ContentTypeBadge {...props} type={contentTypes.TASKS_AND_ACTIVITIES} />\n);\nexport const AssessmentResourcesBadge = (props: Omit<Props, \"type\">) => (\n  <ContentTypeBadge {...props} type={contentTypes.ASSESSMENT_RESOURCES} />\n);\nexport const SubjectBadge = (props: Omit<Props, \"type\">) => <ContentTypeBadge {...props} type={contentTypes.SUBJECT} />;\nexport const SourceMaterialBadge = (props: Omit<Props, \"type\">) => (\n  <ContentTypeBadge {...props} type={contentTypes.SOURCE_MATERIAL} />\n);\nexport const LearningPathBadge = (props: Omit<Props, \"type\">) => (\n  <ContentTypeBadge {...props} type={contentTypes.LEARNING_PATH} />\n);\nexport const MultidisciplinaryTopicBadge = (props: Omit<Props, \"type\">) => (\n  <ContentTypeBadge {...props} type={contentTypes.MULTIDISCIPLINARY_TOPIC} />\n);\nexport const ConceptBadge = (props: Omit<Props, \"type\">) => <ContentTypeBadge {...props} type={contentTypes.CONCEPT} />;\n"]} */",
43
43
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
44
44
  }
45
45
  };
@@ -52,7 +52,7 @@ const BaseContentTypeBadge = /*#__PURE__*/_styled("div", {
52
52
  } : {
53
53
  name: "4p3gmo",
54
54
  styles: "display:inline-flex;align-items:center;justify-content:center;border-radius:100%;width:34px;height:34px;color:var(--icon-color)",
55
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ContentTypeBadge.tsx"],"names":[],"mappings":"AA6EuC","file":"ContentTypeBadge.tsx","sourcesContent":["/**\n * Copyright (c) 2018-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 { CSSProperties, ComponentProps, useMemo } from \"react\";\n\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, mq } from \"@ndla/core\";\nimport { MenuBook } from \"@ndla/icons/action\";\nimport { Audio } from \"@ndla/icons/common\";\nimport {\n  SubjectMaterial,\n  TasksAndActivities,\n  AssessmentResource,\n  Subject,\n  ExternalLearningResource,\n  SharedResource,\n  LearningPath,\n  MultidisciplinaryTopic,\n} from \"@ndla/icons/contentType\";\n\nimport { Concept, Media, Video } from \"@ndla/icons/editor\";\n\nimport * as contentTypes from \"../model/ContentType\";\n\ninterface Props extends ComponentProps<\"div\"> {\n  size?: \"xx-small\" | \"x-small\" | \"small\" | \"large\";\n  type: string;\n  title?: string;\n  background?: boolean;\n  border?: boolean;\n  className?: string;\n}\n\nconst sizes = {\n  \"xx-small\": css`\n    width: 20px;\n    height: 20px;\n    border: 1px solid;\n    svg {\n      width: 10px;\n      height: 10x;\n    }\n  `,\n  \"x-small\": css`\n    width: 20px;\n    height: 20px;\n    border: 1px solid;\n    ${mq.range({ from: breakpoints.tablet })} {\n      height: 26px;\n      width: 26px;\n    }\n    svg {\n      width: 10px;\n      height: 10x;\n      ${mq.range({ from: breakpoints.tablet })} {\n        width: 12px;\n        height: 12px;\n      }\n    }\n  `,\n  small: \"\",\n  large: css`\n    width: 50px;\n    height: 50px;\n    svg {\n      width: 25px;\n      height: 25px;\n    }\n  `,\n} as const;\n\nconst BaseContentTypeBadge = styled.div`\n  display: inline-flex;\n  align-items: center;\n  justify-content: center;\n  border-radius: 100%;\n  width: 34px;\n  height: 34px;\n  color: var(--icon-color);\n`;\n\nconst borderStyle = css`\n  border: 2px solid;\n  border-color: var(--icon-color);\n`;\n\nconst backgroundStyle = css`\n  background-color: var(--background-color);\n`;\n\nconst iconMap = {\n  [contentTypes.SUBJECT_MATERIAL]: {\n    icon: SubjectMaterial,\n    iconColor: colors.subjectMaterial.dark,\n    backgroundColor: colors.subjectMaterial.light,\n  },\n  [contentTypes.TASKS_AND_ACTIVITIES]: {\n    icon: TasksAndActivities,\n    iconColor: colors.tasksAndActivities.dark,\n    backgroundColor: colors.tasksAndActivities.light,\n  },\n  [contentTypes.ASSESSMENT_RESOURCES]: {\n    icon: AssessmentResource,\n    iconColor: colors.assessmentResource.dark,\n    backgroundColor: colors.assessmentResource.light,\n  },\n  [contentTypes.SUBJECT]: {\n    icon: MenuBook,\n    iconColor: colors.subject.dark,\n    backgroundColor: colors.subject.light,\n  },\n  [contentTypes.EXTERNAL_LEARNING_RESOURCES]: {\n    icon: ExternalLearningResource,\n    iconColor: colors.externalLearningResource.dark,\n    backgroundColor: colors.externalLearningResource.light,\n  },\n  [contentTypes.SOURCE_MATERIAL]: {\n    icon: SharedResource,\n    iconColor: colors.sourceMaterial.dark,\n    backgroundColor: colors.sourceMaterial.light,\n  },\n  [contentTypes.LEARNING_PATH]: {\n    icon: LearningPath,\n    iconColor: colors.learningPath.dark,\n    backgroundColor: colors.learningPath.light,\n  },\n  [contentTypes.TOPIC]: {\n    icon: Subject,\n    iconColor: colors.subject.dark,\n    backgroundColor: colors.subject.light,\n  },\n  [contentTypes.MULTIDISCIPLINARY_TOPIC]: {\n    icon: MultidisciplinaryTopic,\n    backgroundColor: \"#b9b37b\",\n  },\n  [contentTypes.resourceEmbedTypeMapping.image]: {\n    icon: Media,\n    iconColor: colors.brand.grey,\n    backgroundColor: colors.brand.greyLight,\n  },\n  [contentTypes.resourceEmbedTypeMapping.audio]: {\n    icon: Audio,\n    iconColor: colors.brand.grey,\n    backgroundColor: colors.brand.greyLight,\n  },\n  [contentTypes.resourceEmbedTypeMapping.video]: {\n    icon: Video,\n    iconColor: colors.brand.grey,\n    backgroundColor: colors.brand.greyLight,\n  },\n  [contentTypes.resourceEmbedTypeMapping.concept]: {\n    icon: Concept,\n    iconColor: colors.brand.grey,\n    backgroundColor: colors.brand.greyLight,\n  },\n} as const;\n\nexport const ContentTypeBadge = ({\n  type,\n  background,\n  title,\n  size = \"small\",\n  border = true,\n  className,\n  ...rest\n}: Props) => {\n  const { Icon, style } = useMemo(() => {\n    const fromMap = iconMap[type];\n    const style = {\n      \"--icon-color\": fromMap.iconColor,\n      \"--background-color\": fromMap.backgroundColor,\n    } as CSSProperties;\n    return { Icon: fromMap.icon, style };\n  }, [type]);\n\n  const cssStyles = useMemo(() => {\n    const styles = [sizes[size]];\n    if (background) {\n      styles.push(backgroundStyle);\n    }\n    if (border) {\n      styles.push(borderStyle);\n    }\n    return styles;\n  }, [background, border, size]);\n\n  return (\n    <BaseContentTypeBadge\n      css={cssStyles}\n      title={title}\n      style={style}\n      aria-label={title}\n      className={className}\n      data-badge=\"\"\n      data-type={type}\n      {...rest}\n    >\n      <Icon />\n    </BaseContentTypeBadge>\n  );\n};\n\nexport const SubjectMaterialBadge = (props: Omit<Props, \"type\">) => (\n  <ContentTypeBadge {...props} type={contentTypes.SUBJECT_MATERIAL} />\n);\nexport const TasksAndActivitiesBadge = (props: Omit<Props, \"type\">) => (\n  <ContentTypeBadge {...props} type={contentTypes.TASKS_AND_ACTIVITIES} />\n);\nexport const AssessmentResourcesBadge = (props: Omit<Props, \"type\">) => (\n  <ContentTypeBadge {...props} type={contentTypes.ASSESSMENT_RESOURCES} />\n);\nexport const SubjectBadge = (props: Omit<Props, \"type\">) => <ContentTypeBadge {...props} type={contentTypes.SUBJECT} />;\nexport const ExternalLearningResourcesBadge = (props: Omit<Props, \"type\">) => (\n  <ContentTypeBadge {...props} type={contentTypes.EXTERNAL_LEARNING_RESOURCES} />\n);\nexport const SourceMaterialBadge = (props: Omit<Props, \"type\">) => (\n  <ContentTypeBadge {...props} type={contentTypes.SOURCE_MATERIAL} />\n);\n\nexport const LearningPathBadge = (props: Omit<Props, \"type\">) => (\n  <ContentTypeBadge {...props} type={contentTypes.LEARNING_PATH} />\n);\n\nexport const MultidisciplinaryTopicBadge = (props: Omit<Props, \"type\">) => (\n  <ContentTypeBadge {...props} type={contentTypes.MULTIDISCIPLINARY_TOPIC} />\n);\n"]} */",
55
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ContentTypeBadge.tsx"],"names":[],"mappings":"AA6EuC","file":"ContentTypeBadge.tsx","sourcesContent":["/**\n * Copyright (c) 2018-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 { CSSProperties, ComponentProps, useMemo } from \"react\";\n\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, mq } from \"@ndla/core\";\nimport { MenuBook } from \"@ndla/icons/action\";\nimport { Audio } from \"@ndla/icons/common\";\nimport {\n  AssessmentResource,\n  ExternalLearningResource,\n  LearningPath,\n  MultidisciplinaryTopic,\n  SharedResource,\n  Subject,\n  SubjectMaterial,\n  TasksAndActivities,\n} from \"@ndla/icons/contentType\";\n\nimport { Concept, Media, Video } from \"@ndla/icons/editor\";\n\nimport * as contentTypes from \"../model/ContentType\";\n\ninterface Props extends ComponentProps<\"div\"> {\n  size?: \"xx-small\" | \"x-small\" | \"small\" | \"large\";\n  type: string;\n  title?: string;\n  background?: boolean;\n  border?: boolean;\n  className?: string;\n}\n\nconst sizes = {\n  \"xx-small\": css`\n    width: 20px;\n    height: 20px;\n    border: 1px solid;\n    svg {\n      width: 10px;\n      height: 10x;\n    }\n  `,\n  \"x-small\": css`\n    width: 20px;\n    height: 20px;\n    border: 1px solid;\n    ${mq.range({ from: breakpoints.tablet })} {\n      height: 26px;\n      width: 26px;\n    }\n    svg {\n      width: 10px;\n      height: 10x;\n      ${mq.range({ from: breakpoints.tablet })} {\n        width: 12px;\n        height: 12px;\n      }\n    }\n  `,\n  small: \"\",\n  large: css`\n    width: 50px;\n    height: 50px;\n    svg {\n      width: 25px;\n      height: 25px;\n    }\n  `,\n} as const;\n\nconst BaseContentTypeBadge = styled.div`\n  display: inline-flex;\n  align-items: center;\n  justify-content: center;\n  border-radius: 100%;\n  width: 34px;\n  height: 34px;\n  color: var(--icon-color);\n`;\n\nconst borderStyle = css`\n  border: 2px solid;\n  border-color: var(--icon-color);\n`;\n\nconst backgroundStyle = css`\n  background-color: var(--background-color);\n`;\n\nconst iconMap = {\n  [contentTypes.SUBJECT_MATERIAL]: {\n    icon: SubjectMaterial,\n    iconColor: colors.subjectMaterial.dark,\n    backgroundColor: colors.subjectMaterial.light,\n  },\n  [contentTypes.TASKS_AND_ACTIVITIES]: {\n    icon: TasksAndActivities,\n    iconColor: colors.tasksAndActivities.dark,\n    backgroundColor: colors.tasksAndActivities.light,\n  },\n  [contentTypes.ASSESSMENT_RESOURCES]: {\n    icon: AssessmentResource,\n    iconColor: colors.assessmentResource.dark,\n    backgroundColor: colors.assessmentResource.light,\n  },\n  [contentTypes.SUBJECT]: {\n    icon: MenuBook,\n    iconColor: colors.subject.dark,\n    backgroundColor: colors.subject.light,\n  },\n  [contentTypes.SOURCE_MATERIAL]: {\n    icon: SharedResource,\n    iconColor: colors.sourceMaterial.dark,\n    backgroundColor: colors.sourceMaterial.light,\n  },\n  [contentTypes.LEARNING_PATH]: {\n    icon: LearningPath,\n    iconColor: colors.learningPath.dark,\n    backgroundColor: colors.learningPath.light,\n  },\n  [contentTypes.TOPIC]: {\n    icon: Subject,\n    iconColor: colors.subject.dark,\n    backgroundColor: colors.subject.light,\n  },\n  [contentTypes.MULTIDISCIPLINARY_TOPIC]: {\n    icon: MultidisciplinaryTopic,\n    backgroundColor: \"#b9b37b\",\n  },\n  [contentTypes.CONCEPT]: {\n    icon: Concept,\n    iconColor: colors.concept.text,\n    backgroundColor: colors.concept.light,\n  },\n  [contentTypes.EXTERNAL]: {\n    icon: ExternalLearningResource,\n    iconColor: colors.external.dark,\n    backgroundColor: colors.external.light,\n  },\n  [contentTypes.resourceEmbedTypeMapping.image]: {\n    icon: Media,\n    iconColor: colors.brand.grey,\n    backgroundColor: colors.brand.greyLight,\n  },\n  [contentTypes.resourceEmbedTypeMapping.audio]: {\n    icon: Audio,\n    iconColor: colors.brand.grey,\n    backgroundColor: colors.brand.greyLight,\n  },\n  [contentTypes.resourceEmbedTypeMapping.video]: {\n    icon: Video,\n    iconColor: colors.brand.grey,\n    backgroundColor: colors.brand.greyLight,\n  },\n} as const;\n\nexport const ContentTypeBadge = ({\n  type,\n  background,\n  title,\n  size = \"small\",\n  border = true,\n  className,\n  ...rest\n}: Props) => {\n  const { Icon, style } = useMemo(() => {\n    const fromMap = iconMap[type];\n    const style = {\n      \"--icon-color\": fromMap.iconColor,\n      \"--background-color\": fromMap.backgroundColor,\n    } as CSSProperties;\n    return { Icon: fromMap.icon, style };\n  }, [type]);\n\n  const cssStyles = useMemo(() => {\n    const styles = [sizes[size]];\n    if (background) {\n      styles.push(backgroundStyle);\n    }\n    if (border) {\n      styles.push(borderStyle);\n    }\n    return styles;\n  }, [background, border, size]);\n\n  return (\n    <BaseContentTypeBadge\n      css={cssStyles}\n      title={title}\n      style={style}\n      aria-label={title}\n      className={className}\n      data-badge=\"\"\n      data-type={type}\n      {...rest}\n    >\n      <Icon />\n    </BaseContentTypeBadge>\n  );\n};\n\nexport const SubjectMaterialBadge = (props: Omit<Props, \"type\">) => (\n  <ContentTypeBadge {...props} type={contentTypes.SUBJECT_MATERIAL} />\n);\nexport const TasksAndActivitiesBadge = (props: Omit<Props, \"type\">) => (\n  <ContentTypeBadge {...props} type={contentTypes.TASKS_AND_ACTIVITIES} />\n);\nexport const AssessmentResourcesBadge = (props: Omit<Props, \"type\">) => (\n  <ContentTypeBadge {...props} type={contentTypes.ASSESSMENT_RESOURCES} />\n);\nexport const SubjectBadge = (props: Omit<Props, \"type\">) => <ContentTypeBadge {...props} type={contentTypes.SUBJECT} />;\nexport const SourceMaterialBadge = (props: Omit<Props, \"type\">) => (\n  <ContentTypeBadge {...props} type={contentTypes.SOURCE_MATERIAL} />\n);\nexport const LearningPathBadge = (props: Omit<Props, \"type\">) => (\n  <ContentTypeBadge {...props} type={contentTypes.LEARNING_PATH} />\n);\nexport const MultidisciplinaryTopicBadge = (props: Omit<Props, \"type\">) => (\n  <ContentTypeBadge {...props} type={contentTypes.MULTIDISCIPLINARY_TOPIC} />\n);\nexport const ConceptBadge = (props: Omit<Props, \"type\">) => <ContentTypeBadge {...props} type={contentTypes.CONCEPT} />;\n"]} */",
56
56
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
57
57
  });
58
58
  const borderStyle = process.env.NODE_ENV === "production" ? {
@@ -61,7 +61,7 @@ const borderStyle = process.env.NODE_ENV === "production" ? {
61
61
  } : {
62
62
  name: "195lw4v-borderStyle",
63
63
  styles: "border:2px solid;border-color:var(--icon-color);label:borderStyle;",
64
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ContentTypeBadge.tsx"],"names":[],"mappings":"AAuFuB","file":"ContentTypeBadge.tsx","sourcesContent":["/**\n * Copyright (c) 2018-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 { CSSProperties, ComponentProps, useMemo } from \"react\";\n\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, mq } from \"@ndla/core\";\nimport { MenuBook } from \"@ndla/icons/action\";\nimport { Audio } from \"@ndla/icons/common\";\nimport {\n  SubjectMaterial,\n  TasksAndActivities,\n  AssessmentResource,\n  Subject,\n  ExternalLearningResource,\n  SharedResource,\n  LearningPath,\n  MultidisciplinaryTopic,\n} from \"@ndla/icons/contentType\";\n\nimport { Concept, Media, Video } from \"@ndla/icons/editor\";\n\nimport * as contentTypes from \"../model/ContentType\";\n\ninterface Props extends ComponentProps<\"div\"> {\n  size?: \"xx-small\" | \"x-small\" | \"small\" | \"large\";\n  type: string;\n  title?: string;\n  background?: boolean;\n  border?: boolean;\n  className?: string;\n}\n\nconst sizes = {\n  \"xx-small\": css`\n    width: 20px;\n    height: 20px;\n    border: 1px solid;\n    svg {\n      width: 10px;\n      height: 10x;\n    }\n  `,\n  \"x-small\": css`\n    width: 20px;\n    height: 20px;\n    border: 1px solid;\n    ${mq.range({ from: breakpoints.tablet })} {\n      height: 26px;\n      width: 26px;\n    }\n    svg {\n      width: 10px;\n      height: 10x;\n      ${mq.range({ from: breakpoints.tablet })} {\n        width: 12px;\n        height: 12px;\n      }\n    }\n  `,\n  small: \"\",\n  large: css`\n    width: 50px;\n    height: 50px;\n    svg {\n      width: 25px;\n      height: 25px;\n    }\n  `,\n} as const;\n\nconst BaseContentTypeBadge = styled.div`\n  display: inline-flex;\n  align-items: center;\n  justify-content: center;\n  border-radius: 100%;\n  width: 34px;\n  height: 34px;\n  color: var(--icon-color);\n`;\n\nconst borderStyle = css`\n  border: 2px solid;\n  border-color: var(--icon-color);\n`;\n\nconst backgroundStyle = css`\n  background-color: var(--background-color);\n`;\n\nconst iconMap = {\n  [contentTypes.SUBJECT_MATERIAL]: {\n    icon: SubjectMaterial,\n    iconColor: colors.subjectMaterial.dark,\n    backgroundColor: colors.subjectMaterial.light,\n  },\n  [contentTypes.TASKS_AND_ACTIVITIES]: {\n    icon: TasksAndActivities,\n    iconColor: colors.tasksAndActivities.dark,\n    backgroundColor: colors.tasksAndActivities.light,\n  },\n  [contentTypes.ASSESSMENT_RESOURCES]: {\n    icon: AssessmentResource,\n    iconColor: colors.assessmentResource.dark,\n    backgroundColor: colors.assessmentResource.light,\n  },\n  [contentTypes.SUBJECT]: {\n    icon: MenuBook,\n    iconColor: colors.subject.dark,\n    backgroundColor: colors.subject.light,\n  },\n  [contentTypes.EXTERNAL_LEARNING_RESOURCES]: {\n    icon: ExternalLearningResource,\n    iconColor: colors.externalLearningResource.dark,\n    backgroundColor: colors.externalLearningResource.light,\n  },\n  [contentTypes.SOURCE_MATERIAL]: {\n    icon: SharedResource,\n    iconColor: colors.sourceMaterial.dark,\n    backgroundColor: colors.sourceMaterial.light,\n  },\n  [contentTypes.LEARNING_PATH]: {\n    icon: LearningPath,\n    iconColor: colors.learningPath.dark,\n    backgroundColor: colors.learningPath.light,\n  },\n  [contentTypes.TOPIC]: {\n    icon: Subject,\n    iconColor: colors.subject.dark,\n    backgroundColor: colors.subject.light,\n  },\n  [contentTypes.MULTIDISCIPLINARY_TOPIC]: {\n    icon: MultidisciplinaryTopic,\n    backgroundColor: \"#b9b37b\",\n  },\n  [contentTypes.resourceEmbedTypeMapping.image]: {\n    icon: Media,\n    iconColor: colors.brand.grey,\n    backgroundColor: colors.brand.greyLight,\n  },\n  [contentTypes.resourceEmbedTypeMapping.audio]: {\n    icon: Audio,\n    iconColor: colors.brand.grey,\n    backgroundColor: colors.brand.greyLight,\n  },\n  [contentTypes.resourceEmbedTypeMapping.video]: {\n    icon: Video,\n    iconColor: colors.brand.grey,\n    backgroundColor: colors.brand.greyLight,\n  },\n  [contentTypes.resourceEmbedTypeMapping.concept]: {\n    icon: Concept,\n    iconColor: colors.brand.grey,\n    backgroundColor: colors.brand.greyLight,\n  },\n} as const;\n\nexport const ContentTypeBadge = ({\n  type,\n  background,\n  title,\n  size = \"small\",\n  border = true,\n  className,\n  ...rest\n}: Props) => {\n  const { Icon, style } = useMemo(() => {\n    const fromMap = iconMap[type];\n    const style = {\n      \"--icon-color\": fromMap.iconColor,\n      \"--background-color\": fromMap.backgroundColor,\n    } as CSSProperties;\n    return { Icon: fromMap.icon, style };\n  }, [type]);\n\n  const cssStyles = useMemo(() => {\n    const styles = [sizes[size]];\n    if (background) {\n      styles.push(backgroundStyle);\n    }\n    if (border) {\n      styles.push(borderStyle);\n    }\n    return styles;\n  }, [background, border, size]);\n\n  return (\n    <BaseContentTypeBadge\n      css={cssStyles}\n      title={title}\n      style={style}\n      aria-label={title}\n      className={className}\n      data-badge=\"\"\n      data-type={type}\n      {...rest}\n    >\n      <Icon />\n    </BaseContentTypeBadge>\n  );\n};\n\nexport const SubjectMaterialBadge = (props: Omit<Props, \"type\">) => (\n  <ContentTypeBadge {...props} type={contentTypes.SUBJECT_MATERIAL} />\n);\nexport const TasksAndActivitiesBadge = (props: Omit<Props, \"type\">) => (\n  <ContentTypeBadge {...props} type={contentTypes.TASKS_AND_ACTIVITIES} />\n);\nexport const AssessmentResourcesBadge = (props: Omit<Props, \"type\">) => (\n  <ContentTypeBadge {...props} type={contentTypes.ASSESSMENT_RESOURCES} />\n);\nexport const SubjectBadge = (props: Omit<Props, \"type\">) => <ContentTypeBadge {...props} type={contentTypes.SUBJECT} />;\nexport const ExternalLearningResourcesBadge = (props: Omit<Props, \"type\">) => (\n  <ContentTypeBadge {...props} type={contentTypes.EXTERNAL_LEARNING_RESOURCES} />\n);\nexport const SourceMaterialBadge = (props: Omit<Props, \"type\">) => (\n  <ContentTypeBadge {...props} type={contentTypes.SOURCE_MATERIAL} />\n);\n\nexport const LearningPathBadge = (props: Omit<Props, \"type\">) => (\n  <ContentTypeBadge {...props} type={contentTypes.LEARNING_PATH} />\n);\n\nexport const MultidisciplinaryTopicBadge = (props: Omit<Props, \"type\">) => (\n  <ContentTypeBadge {...props} type={contentTypes.MULTIDISCIPLINARY_TOPIC} />\n);\n"]} */",
64
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ContentTypeBadge.tsx"],"names":[],"mappings":"AAuFuB","file":"ContentTypeBadge.tsx","sourcesContent":["/**\n * Copyright (c) 2018-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 { CSSProperties, ComponentProps, useMemo } from \"react\";\n\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, mq } from \"@ndla/core\";\nimport { MenuBook } from \"@ndla/icons/action\";\nimport { Audio } from \"@ndla/icons/common\";\nimport {\n  AssessmentResource,\n  ExternalLearningResource,\n  LearningPath,\n  MultidisciplinaryTopic,\n  SharedResource,\n  Subject,\n  SubjectMaterial,\n  TasksAndActivities,\n} from \"@ndla/icons/contentType\";\n\nimport { Concept, Media, Video } from \"@ndla/icons/editor\";\n\nimport * as contentTypes from \"../model/ContentType\";\n\ninterface Props extends ComponentProps<\"div\"> {\n  size?: \"xx-small\" | \"x-small\" | \"small\" | \"large\";\n  type: string;\n  title?: string;\n  background?: boolean;\n  border?: boolean;\n  className?: string;\n}\n\nconst sizes = {\n  \"xx-small\": css`\n    width: 20px;\n    height: 20px;\n    border: 1px solid;\n    svg {\n      width: 10px;\n      height: 10x;\n    }\n  `,\n  \"x-small\": css`\n    width: 20px;\n    height: 20px;\n    border: 1px solid;\n    ${mq.range({ from: breakpoints.tablet })} {\n      height: 26px;\n      width: 26px;\n    }\n    svg {\n      width: 10px;\n      height: 10x;\n      ${mq.range({ from: breakpoints.tablet })} {\n        width: 12px;\n        height: 12px;\n      }\n    }\n  `,\n  small: \"\",\n  large: css`\n    width: 50px;\n    height: 50px;\n    svg {\n      width: 25px;\n      height: 25px;\n    }\n  `,\n} as const;\n\nconst BaseContentTypeBadge = styled.div`\n  display: inline-flex;\n  align-items: center;\n  justify-content: center;\n  border-radius: 100%;\n  width: 34px;\n  height: 34px;\n  color: var(--icon-color);\n`;\n\nconst borderStyle = css`\n  border: 2px solid;\n  border-color: var(--icon-color);\n`;\n\nconst backgroundStyle = css`\n  background-color: var(--background-color);\n`;\n\nconst iconMap = {\n  [contentTypes.SUBJECT_MATERIAL]: {\n    icon: SubjectMaterial,\n    iconColor: colors.subjectMaterial.dark,\n    backgroundColor: colors.subjectMaterial.light,\n  },\n  [contentTypes.TASKS_AND_ACTIVITIES]: {\n    icon: TasksAndActivities,\n    iconColor: colors.tasksAndActivities.dark,\n    backgroundColor: colors.tasksAndActivities.light,\n  },\n  [contentTypes.ASSESSMENT_RESOURCES]: {\n    icon: AssessmentResource,\n    iconColor: colors.assessmentResource.dark,\n    backgroundColor: colors.assessmentResource.light,\n  },\n  [contentTypes.SUBJECT]: {\n    icon: MenuBook,\n    iconColor: colors.subject.dark,\n    backgroundColor: colors.subject.light,\n  },\n  [contentTypes.SOURCE_MATERIAL]: {\n    icon: SharedResource,\n    iconColor: colors.sourceMaterial.dark,\n    backgroundColor: colors.sourceMaterial.light,\n  },\n  [contentTypes.LEARNING_PATH]: {\n    icon: LearningPath,\n    iconColor: colors.learningPath.dark,\n    backgroundColor: colors.learningPath.light,\n  },\n  [contentTypes.TOPIC]: {\n    icon: Subject,\n    iconColor: colors.subject.dark,\n    backgroundColor: colors.subject.light,\n  },\n  [contentTypes.MULTIDISCIPLINARY_TOPIC]: {\n    icon: MultidisciplinaryTopic,\n    backgroundColor: \"#b9b37b\",\n  },\n  [contentTypes.CONCEPT]: {\n    icon: Concept,\n    iconColor: colors.concept.text,\n    backgroundColor: colors.concept.light,\n  },\n  [contentTypes.EXTERNAL]: {\n    icon: ExternalLearningResource,\n    iconColor: colors.external.dark,\n    backgroundColor: colors.external.light,\n  },\n  [contentTypes.resourceEmbedTypeMapping.image]: {\n    icon: Media,\n    iconColor: colors.brand.grey,\n    backgroundColor: colors.brand.greyLight,\n  },\n  [contentTypes.resourceEmbedTypeMapping.audio]: {\n    icon: Audio,\n    iconColor: colors.brand.grey,\n    backgroundColor: colors.brand.greyLight,\n  },\n  [contentTypes.resourceEmbedTypeMapping.video]: {\n    icon: Video,\n    iconColor: colors.brand.grey,\n    backgroundColor: colors.brand.greyLight,\n  },\n} as const;\n\nexport const ContentTypeBadge = ({\n  type,\n  background,\n  title,\n  size = \"small\",\n  border = true,\n  className,\n  ...rest\n}: Props) => {\n  const { Icon, style } = useMemo(() => {\n    const fromMap = iconMap[type];\n    const style = {\n      \"--icon-color\": fromMap.iconColor,\n      \"--background-color\": fromMap.backgroundColor,\n    } as CSSProperties;\n    return { Icon: fromMap.icon, style };\n  }, [type]);\n\n  const cssStyles = useMemo(() => {\n    const styles = [sizes[size]];\n    if (background) {\n      styles.push(backgroundStyle);\n    }\n    if (border) {\n      styles.push(borderStyle);\n    }\n    return styles;\n  }, [background, border, size]);\n\n  return (\n    <BaseContentTypeBadge\n      css={cssStyles}\n      title={title}\n      style={style}\n      aria-label={title}\n      className={className}\n      data-badge=\"\"\n      data-type={type}\n      {...rest}\n    >\n      <Icon />\n    </BaseContentTypeBadge>\n  );\n};\n\nexport const SubjectMaterialBadge = (props: Omit<Props, \"type\">) => (\n  <ContentTypeBadge {...props} type={contentTypes.SUBJECT_MATERIAL} />\n);\nexport const TasksAndActivitiesBadge = (props: Omit<Props, \"type\">) => (\n  <ContentTypeBadge {...props} type={contentTypes.TASKS_AND_ACTIVITIES} />\n);\nexport const AssessmentResourcesBadge = (props: Omit<Props, \"type\">) => (\n  <ContentTypeBadge {...props} type={contentTypes.ASSESSMENT_RESOURCES} />\n);\nexport const SubjectBadge = (props: Omit<Props, \"type\">) => <ContentTypeBadge {...props} type={contentTypes.SUBJECT} />;\nexport const SourceMaterialBadge = (props: Omit<Props, \"type\">) => (\n  <ContentTypeBadge {...props} type={contentTypes.SOURCE_MATERIAL} />\n);\nexport const LearningPathBadge = (props: Omit<Props, \"type\">) => (\n  <ContentTypeBadge {...props} type={contentTypes.LEARNING_PATH} />\n);\nexport const MultidisciplinaryTopicBadge = (props: Omit<Props, \"type\">) => (\n  <ContentTypeBadge {...props} type={contentTypes.MULTIDISCIPLINARY_TOPIC} />\n);\nexport const ConceptBadge = (props: Omit<Props, \"type\">) => <ContentTypeBadge {...props} type={contentTypes.CONCEPT} />;\n"]} */",
65
65
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
66
66
  };
67
67
  const backgroundStyle = process.env.NODE_ENV === "production" ? {
@@ -70,7 +70,7 @@ const backgroundStyle = process.env.NODE_ENV === "production" ? {
70
70
  } : {
71
71
  name: "103cks6-backgroundStyle",
72
72
  styles: "background-color:var(--background-color);label:backgroundStyle;",
73
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ContentTypeBadge.tsx"],"names":[],"mappings":"AA4F2B","file":"ContentTypeBadge.tsx","sourcesContent":["/**\n * Copyright (c) 2018-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 { CSSProperties, ComponentProps, useMemo } from \"react\";\n\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, mq } from \"@ndla/core\";\nimport { MenuBook } from \"@ndla/icons/action\";\nimport { Audio } from \"@ndla/icons/common\";\nimport {\n  SubjectMaterial,\n  TasksAndActivities,\n  AssessmentResource,\n  Subject,\n  ExternalLearningResource,\n  SharedResource,\n  LearningPath,\n  MultidisciplinaryTopic,\n} from \"@ndla/icons/contentType\";\n\nimport { Concept, Media, Video } from \"@ndla/icons/editor\";\n\nimport * as contentTypes from \"../model/ContentType\";\n\ninterface Props extends ComponentProps<\"div\"> {\n  size?: \"xx-small\" | \"x-small\" | \"small\" | \"large\";\n  type: string;\n  title?: string;\n  background?: boolean;\n  border?: boolean;\n  className?: string;\n}\n\nconst sizes = {\n  \"xx-small\": css`\n    width: 20px;\n    height: 20px;\n    border: 1px solid;\n    svg {\n      width: 10px;\n      height: 10x;\n    }\n  `,\n  \"x-small\": css`\n    width: 20px;\n    height: 20px;\n    border: 1px solid;\n    ${mq.range({ from: breakpoints.tablet })} {\n      height: 26px;\n      width: 26px;\n    }\n    svg {\n      width: 10px;\n      height: 10x;\n      ${mq.range({ from: breakpoints.tablet })} {\n        width: 12px;\n        height: 12px;\n      }\n    }\n  `,\n  small: \"\",\n  large: css`\n    width: 50px;\n    height: 50px;\n    svg {\n      width: 25px;\n      height: 25px;\n    }\n  `,\n} as const;\n\nconst BaseContentTypeBadge = styled.div`\n  display: inline-flex;\n  align-items: center;\n  justify-content: center;\n  border-radius: 100%;\n  width: 34px;\n  height: 34px;\n  color: var(--icon-color);\n`;\n\nconst borderStyle = css`\n  border: 2px solid;\n  border-color: var(--icon-color);\n`;\n\nconst backgroundStyle = css`\n  background-color: var(--background-color);\n`;\n\nconst iconMap = {\n  [contentTypes.SUBJECT_MATERIAL]: {\n    icon: SubjectMaterial,\n    iconColor: colors.subjectMaterial.dark,\n    backgroundColor: colors.subjectMaterial.light,\n  },\n  [contentTypes.TASKS_AND_ACTIVITIES]: {\n    icon: TasksAndActivities,\n    iconColor: colors.tasksAndActivities.dark,\n    backgroundColor: colors.tasksAndActivities.light,\n  },\n  [contentTypes.ASSESSMENT_RESOURCES]: {\n    icon: AssessmentResource,\n    iconColor: colors.assessmentResource.dark,\n    backgroundColor: colors.assessmentResource.light,\n  },\n  [contentTypes.SUBJECT]: {\n    icon: MenuBook,\n    iconColor: colors.subject.dark,\n    backgroundColor: colors.subject.light,\n  },\n  [contentTypes.EXTERNAL_LEARNING_RESOURCES]: {\n    icon: ExternalLearningResource,\n    iconColor: colors.externalLearningResource.dark,\n    backgroundColor: colors.externalLearningResource.light,\n  },\n  [contentTypes.SOURCE_MATERIAL]: {\n    icon: SharedResource,\n    iconColor: colors.sourceMaterial.dark,\n    backgroundColor: colors.sourceMaterial.light,\n  },\n  [contentTypes.LEARNING_PATH]: {\n    icon: LearningPath,\n    iconColor: colors.learningPath.dark,\n    backgroundColor: colors.learningPath.light,\n  },\n  [contentTypes.TOPIC]: {\n    icon: Subject,\n    iconColor: colors.subject.dark,\n    backgroundColor: colors.subject.light,\n  },\n  [contentTypes.MULTIDISCIPLINARY_TOPIC]: {\n    icon: MultidisciplinaryTopic,\n    backgroundColor: \"#b9b37b\",\n  },\n  [contentTypes.resourceEmbedTypeMapping.image]: {\n    icon: Media,\n    iconColor: colors.brand.grey,\n    backgroundColor: colors.brand.greyLight,\n  },\n  [contentTypes.resourceEmbedTypeMapping.audio]: {\n    icon: Audio,\n    iconColor: colors.brand.grey,\n    backgroundColor: colors.brand.greyLight,\n  },\n  [contentTypes.resourceEmbedTypeMapping.video]: {\n    icon: Video,\n    iconColor: colors.brand.grey,\n    backgroundColor: colors.brand.greyLight,\n  },\n  [contentTypes.resourceEmbedTypeMapping.concept]: {\n    icon: Concept,\n    iconColor: colors.brand.grey,\n    backgroundColor: colors.brand.greyLight,\n  },\n} as const;\n\nexport const ContentTypeBadge = ({\n  type,\n  background,\n  title,\n  size = \"small\",\n  border = true,\n  className,\n  ...rest\n}: Props) => {\n  const { Icon, style } = useMemo(() => {\n    const fromMap = iconMap[type];\n    const style = {\n      \"--icon-color\": fromMap.iconColor,\n      \"--background-color\": fromMap.backgroundColor,\n    } as CSSProperties;\n    return { Icon: fromMap.icon, style };\n  }, [type]);\n\n  const cssStyles = useMemo(() => {\n    const styles = [sizes[size]];\n    if (background) {\n      styles.push(backgroundStyle);\n    }\n    if (border) {\n      styles.push(borderStyle);\n    }\n    return styles;\n  }, [background, border, size]);\n\n  return (\n    <BaseContentTypeBadge\n      css={cssStyles}\n      title={title}\n      style={style}\n      aria-label={title}\n      className={className}\n      data-badge=\"\"\n      data-type={type}\n      {...rest}\n    >\n      <Icon />\n    </BaseContentTypeBadge>\n  );\n};\n\nexport const SubjectMaterialBadge = (props: Omit<Props, \"type\">) => (\n  <ContentTypeBadge {...props} type={contentTypes.SUBJECT_MATERIAL} />\n);\nexport const TasksAndActivitiesBadge = (props: Omit<Props, \"type\">) => (\n  <ContentTypeBadge {...props} type={contentTypes.TASKS_AND_ACTIVITIES} />\n);\nexport const AssessmentResourcesBadge = (props: Omit<Props, \"type\">) => (\n  <ContentTypeBadge {...props} type={contentTypes.ASSESSMENT_RESOURCES} />\n);\nexport const SubjectBadge = (props: Omit<Props, \"type\">) => <ContentTypeBadge {...props} type={contentTypes.SUBJECT} />;\nexport const ExternalLearningResourcesBadge = (props: Omit<Props, \"type\">) => (\n  <ContentTypeBadge {...props} type={contentTypes.EXTERNAL_LEARNING_RESOURCES} />\n);\nexport const SourceMaterialBadge = (props: Omit<Props, \"type\">) => (\n  <ContentTypeBadge {...props} type={contentTypes.SOURCE_MATERIAL} />\n);\n\nexport const LearningPathBadge = (props: Omit<Props, \"type\">) => (\n  <ContentTypeBadge {...props} type={contentTypes.LEARNING_PATH} />\n);\n\nexport const MultidisciplinaryTopicBadge = (props: Omit<Props, \"type\">) => (\n  <ContentTypeBadge {...props} type={contentTypes.MULTIDISCIPLINARY_TOPIC} />\n);\n"]} */",
73
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ContentTypeBadge.tsx"],"names":[],"mappings":"AA4F2B","file":"ContentTypeBadge.tsx","sourcesContent":["/**\n * Copyright (c) 2018-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 { CSSProperties, ComponentProps, useMemo } from \"react\";\n\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, mq } from \"@ndla/core\";\nimport { MenuBook } from \"@ndla/icons/action\";\nimport { Audio } from \"@ndla/icons/common\";\nimport {\n  AssessmentResource,\n  ExternalLearningResource,\n  LearningPath,\n  MultidisciplinaryTopic,\n  SharedResource,\n  Subject,\n  SubjectMaterial,\n  TasksAndActivities,\n} from \"@ndla/icons/contentType\";\n\nimport { Concept, Media, Video } from \"@ndla/icons/editor\";\n\nimport * as contentTypes from \"../model/ContentType\";\n\ninterface Props extends ComponentProps<\"div\"> {\n  size?: \"xx-small\" | \"x-small\" | \"small\" | \"large\";\n  type: string;\n  title?: string;\n  background?: boolean;\n  border?: boolean;\n  className?: string;\n}\n\nconst sizes = {\n  \"xx-small\": css`\n    width: 20px;\n    height: 20px;\n    border: 1px solid;\n    svg {\n      width: 10px;\n      height: 10x;\n    }\n  `,\n  \"x-small\": css`\n    width: 20px;\n    height: 20px;\n    border: 1px solid;\n    ${mq.range({ from: breakpoints.tablet })} {\n      height: 26px;\n      width: 26px;\n    }\n    svg {\n      width: 10px;\n      height: 10x;\n      ${mq.range({ from: breakpoints.tablet })} {\n        width: 12px;\n        height: 12px;\n      }\n    }\n  `,\n  small: \"\",\n  large: css`\n    width: 50px;\n    height: 50px;\n    svg {\n      width: 25px;\n      height: 25px;\n    }\n  `,\n} as const;\n\nconst BaseContentTypeBadge = styled.div`\n  display: inline-flex;\n  align-items: center;\n  justify-content: center;\n  border-radius: 100%;\n  width: 34px;\n  height: 34px;\n  color: var(--icon-color);\n`;\n\nconst borderStyle = css`\n  border: 2px solid;\n  border-color: var(--icon-color);\n`;\n\nconst backgroundStyle = css`\n  background-color: var(--background-color);\n`;\n\nconst iconMap = {\n  [contentTypes.SUBJECT_MATERIAL]: {\n    icon: SubjectMaterial,\n    iconColor: colors.subjectMaterial.dark,\n    backgroundColor: colors.subjectMaterial.light,\n  },\n  [contentTypes.TASKS_AND_ACTIVITIES]: {\n    icon: TasksAndActivities,\n    iconColor: colors.tasksAndActivities.dark,\n    backgroundColor: colors.tasksAndActivities.light,\n  },\n  [contentTypes.ASSESSMENT_RESOURCES]: {\n    icon: AssessmentResource,\n    iconColor: colors.assessmentResource.dark,\n    backgroundColor: colors.assessmentResource.light,\n  },\n  [contentTypes.SUBJECT]: {\n    icon: MenuBook,\n    iconColor: colors.subject.dark,\n    backgroundColor: colors.subject.light,\n  },\n  [contentTypes.SOURCE_MATERIAL]: {\n    icon: SharedResource,\n    iconColor: colors.sourceMaterial.dark,\n    backgroundColor: colors.sourceMaterial.light,\n  },\n  [contentTypes.LEARNING_PATH]: {\n    icon: LearningPath,\n    iconColor: colors.learningPath.dark,\n    backgroundColor: colors.learningPath.light,\n  },\n  [contentTypes.TOPIC]: {\n    icon: Subject,\n    iconColor: colors.subject.dark,\n    backgroundColor: colors.subject.light,\n  },\n  [contentTypes.MULTIDISCIPLINARY_TOPIC]: {\n    icon: MultidisciplinaryTopic,\n    backgroundColor: \"#b9b37b\",\n  },\n  [contentTypes.CONCEPT]: {\n    icon: Concept,\n    iconColor: colors.concept.text,\n    backgroundColor: colors.concept.light,\n  },\n  [contentTypes.EXTERNAL]: {\n    icon: ExternalLearningResource,\n    iconColor: colors.external.dark,\n    backgroundColor: colors.external.light,\n  },\n  [contentTypes.resourceEmbedTypeMapping.image]: {\n    icon: Media,\n    iconColor: colors.brand.grey,\n    backgroundColor: colors.brand.greyLight,\n  },\n  [contentTypes.resourceEmbedTypeMapping.audio]: {\n    icon: Audio,\n    iconColor: colors.brand.grey,\n    backgroundColor: colors.brand.greyLight,\n  },\n  [contentTypes.resourceEmbedTypeMapping.video]: {\n    icon: Video,\n    iconColor: colors.brand.grey,\n    backgroundColor: colors.brand.greyLight,\n  },\n} as const;\n\nexport const ContentTypeBadge = ({\n  type,\n  background,\n  title,\n  size = \"small\",\n  border = true,\n  className,\n  ...rest\n}: Props) => {\n  const { Icon, style } = useMemo(() => {\n    const fromMap = iconMap[type];\n    const style = {\n      \"--icon-color\": fromMap.iconColor,\n      \"--background-color\": fromMap.backgroundColor,\n    } as CSSProperties;\n    return { Icon: fromMap.icon, style };\n  }, [type]);\n\n  const cssStyles = useMemo(() => {\n    const styles = [sizes[size]];\n    if (background) {\n      styles.push(backgroundStyle);\n    }\n    if (border) {\n      styles.push(borderStyle);\n    }\n    return styles;\n  }, [background, border, size]);\n\n  return (\n    <BaseContentTypeBadge\n      css={cssStyles}\n      title={title}\n      style={style}\n      aria-label={title}\n      className={className}\n      data-badge=\"\"\n      data-type={type}\n      {...rest}\n    >\n      <Icon />\n    </BaseContentTypeBadge>\n  );\n};\n\nexport const SubjectMaterialBadge = (props: Omit<Props, \"type\">) => (\n  <ContentTypeBadge {...props} type={contentTypes.SUBJECT_MATERIAL} />\n);\nexport const TasksAndActivitiesBadge = (props: Omit<Props, \"type\">) => (\n  <ContentTypeBadge {...props} type={contentTypes.TASKS_AND_ACTIVITIES} />\n);\nexport const AssessmentResourcesBadge = (props: Omit<Props, \"type\">) => (\n  <ContentTypeBadge {...props} type={contentTypes.ASSESSMENT_RESOURCES} />\n);\nexport const SubjectBadge = (props: Omit<Props, \"type\">) => <ContentTypeBadge {...props} type={contentTypes.SUBJECT} />;\nexport const SourceMaterialBadge = (props: Omit<Props, \"type\">) => (\n  <ContentTypeBadge {...props} type={contentTypes.SOURCE_MATERIAL} />\n);\nexport const LearningPathBadge = (props: Omit<Props, \"type\">) => (\n  <ContentTypeBadge {...props} type={contentTypes.LEARNING_PATH} />\n);\nexport const MultidisciplinaryTopicBadge = (props: Omit<Props, \"type\">) => (\n  <ContentTypeBadge {...props} type={contentTypes.MULTIDISCIPLINARY_TOPIC} />\n);\nexport const ConceptBadge = (props: Omit<Props, \"type\">) => <ContentTypeBadge {...props} type={contentTypes.CONCEPT} />;\n"]} */",
74
74
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
75
75
  };
76
76
  const iconMap = {
@@ -94,11 +94,6 @@ const iconMap = {
94
94
  iconColor: colors.subject.dark,
95
95
  backgroundColor: colors.subject.light
96
96
  },
97
- [contentTypes.EXTERNAL_LEARNING_RESOURCES]: {
98
- icon: ExternalLearningResource,
99
- iconColor: colors.externalLearningResource.dark,
100
- backgroundColor: colors.externalLearningResource.light
101
- },
102
97
  [contentTypes.SOURCE_MATERIAL]: {
103
98
  icon: SharedResource,
104
99
  iconColor: colors.sourceMaterial.dark,
@@ -118,6 +113,16 @@ const iconMap = {
118
113
  icon: MultidisciplinaryTopic,
119
114
  backgroundColor: "#b9b37b"
120
115
  },
116
+ [contentTypes.CONCEPT]: {
117
+ icon: Concept,
118
+ iconColor: colors.concept.text,
119
+ backgroundColor: colors.concept.light
120
+ },
121
+ [contentTypes.EXTERNAL]: {
122
+ icon: ExternalLearningResource,
123
+ iconColor: colors.external.dark,
124
+ backgroundColor: colors.external.light
125
+ },
121
126
  [contentTypes.resourceEmbedTypeMapping.image]: {
122
127
  icon: Media,
123
128
  iconColor: colors.brand.grey,
@@ -132,11 +137,6 @@ const iconMap = {
132
137
  icon: Video,
133
138
  iconColor: colors.brand.grey,
134
139
  backgroundColor: colors.brand.greyLight
135
- },
136
- [contentTypes.resourceEmbedTypeMapping.concept]: {
137
- icon: Concept,
138
- iconColor: colors.brand.grey,
139
- backgroundColor: colors.brand.greyLight
140
140
  }
141
141
  };
142
142
  export const ContentTypeBadge = _ref => {
@@ -201,10 +201,6 @@ export const SubjectBadge = props => _jsx(ContentTypeBadge, {
201
201
  ...props,
202
202
  type: contentTypes.SUBJECT
203
203
  });
204
- export const ExternalLearningResourcesBadge = props => _jsx(ContentTypeBadge, {
205
- ...props,
206
- type: contentTypes.EXTERNAL_LEARNING_RESOURCES
207
- });
208
204
  export const SourceMaterialBadge = props => _jsx(ContentTypeBadge, {
209
205
  ...props,
210
206
  type: contentTypes.SOURCE_MATERIAL
@@ -216,4 +212,8 @@ export const LearningPathBadge = props => _jsx(ContentTypeBadge, {
216
212
  export const MultidisciplinaryTopicBadge = props => _jsx(ContentTypeBadge, {
217
213
  ...props,
218
214
  type: contentTypes.MULTIDISCIPLINARY_TOPIC
215
+ });
216
+ export const ConceptBadge = props => _jsx(ContentTypeBadge, {
217
+ ...props,
218
+ type: contentTypes.CONCEPT
219
219
  });
@@ -7,5 +7,5 @@
7
7
  */
8
8
 
9
9
  import { ContentTypeBadge } from "./ContentTypeBadge";
10
- export { SubjectMaterialBadge, TasksAndActivitiesBadge, AssessmentResourcesBadge, SubjectBadge, ExternalLearningResourcesBadge, SourceMaterialBadge, LearningPathBadge } from "./ContentTypeBadge";
10
+ export { SubjectMaterialBadge, TasksAndActivitiesBadge, AssessmentResourcesBadge, SubjectBadge, SourceMaterialBadge, LearningPathBadge, ConceptBadge } from "./ContentTypeBadge";
11
11
  export default ContentTypeBadge;