@ndla/ui 50.5.0 → 50.5.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/es/Aside/Aside.js +55 -17
- package/es/ContentTypeBadge/ContentTypeBadge.js +162 -83
- package/es/FramedContent/FramedContent.js +7 -11
- package/es/ResourceGroup/ResourceItem.js +9 -9
- package/es/SearchTypeResult/components/ItemResourceHeader.js +6 -6
- package/es/SearchTypeResult/components/ItemTopicHeader.js +4 -4
- package/es/all.css +1 -1
- package/es/locale/messages-en.js +8 -4
- package/es/locale/messages-nb.js +8 -4
- package/es/locale/messages-nn.js +8 -4
- package/es/locale/messages-se.js +8 -4
- package/es/locale/messages-sma.js +8 -4
- package/lib/Aside/Aside.d.ts +3 -7
- package/lib/Aside/Aside.js +55 -19
- package/lib/ContentTypeBadge/ContentTypeBadge.d.ts +3 -2
- package/lib/ContentTypeBadge/ContentTypeBadge.js +162 -85
- package/lib/FramedContent/FramedContent.d.ts +1 -1
- package/lib/FramedContent/FramedContent.js +8 -11
- package/lib/ResourceGroup/ResourceItem.js +9 -9
- package/lib/SearchTypeResult/components/ItemResourceHeader.js +6 -6
- package/lib/SearchTypeResult/components/ItemTopicHeader.js +4 -4
- package/lib/all.css +1 -1
- package/lib/locale/messages-en.d.ts +4 -0
- package/lib/locale/messages-en.js +8 -4
- package/lib/locale/messages-nb.d.ts +4 -0
- package/lib/locale/messages-nb.js +8 -4
- package/lib/locale/messages-nn.d.ts +4 -0
- package/lib/locale/messages-nn.js +8 -4
- package/lib/locale/messages-se.d.ts +4 -0
- package/lib/locale/messages-se.js +8 -4
- package/lib/locale/messages-sma.d.ts +4 -0
- package/lib/locale/messages-sma.js +8 -4
- package/package.json +2 -2
- package/src/Article/component.article.scss +1 -1
- package/src/Aside/Aside.tsx +95 -30
- package/src/ContentTypeBadge/ContentTypeBadge.stories.tsx +81 -0
- package/src/ContentTypeBadge/ContentTypeBadge.tsx +169 -71
- package/src/FramedContent/FramedContent.tsx +37 -14
- package/src/ResourceGroup/ResourceItem.tsx +5 -5
- package/src/SearchTypeResult/components/ItemResourceHeader.tsx +1 -1
- package/src/SearchTypeResult/components/ItemTopicHeader.tsx +1 -1
- package/src/locale/messages-en.ts +7 -4
- package/src/locale/messages-nb.ts +7 -4
- package/src/locale/messages-nn.ts +7 -4
- package/src/locale/messages-se.ts +7 -4
- package/src/locale/messages-sma.ts +7 -4
- package/src/main.scss +0 -3
- package/src/Aside/component.aside.scss +0 -91
- package/src/ContentTypeBadge/component.content-type-badge.scss +0 -223
- package/src/global/components/component.bodybox.scss +0 -60
|
@@ -4,7 +4,10 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
4
4
|
value: true
|
|
5
5
|
});
|
|
6
6
|
exports.TasksAndActivitiesBadge = exports.SubjectMaterialBadge = exports.SubjectBadge = exports.SourceMaterialBadge = exports.MultidisciplinaryTopicBadge = exports.LearningPathBadge = exports.ExternalLearningResourcesBadge = exports.ContentTypeBadge = exports.AssessmentResourcesBadge = void 0;
|
|
7
|
-
var
|
|
7
|
+
var _base = _interopRequireDefault(require("@emotion/styled/base"));
|
|
8
|
+
var _react = require("react");
|
|
9
|
+
var _react2 = require("@emotion/react");
|
|
10
|
+
var _core = require("@ndla/core");
|
|
8
11
|
var _action = require("@ndla/icons/action");
|
|
9
12
|
var _contentType = require("@ndla/icons/contentType");
|
|
10
13
|
var _editor = require("@ndla/icons/editor");
|
|
@@ -13,18 +16,135 @@ var _jsxRuntime = require("@emotion/react/jsx-runtime");
|
|
|
13
16
|
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); }
|
|
14
17
|
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && Object.prototype.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; }
|
|
15
18
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
16
|
-
/**
|
|
19
|
+
function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; } /**
|
|
17
20
|
* Copyright (c) 2018-present, NDLA.
|
|
18
21
|
*
|
|
19
22
|
* This source code is licensed under the GPLv3 license found in the
|
|
20
23
|
* LICENSE file in the root directory of this source tree.
|
|
21
24
|
*
|
|
22
25
|
*/
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
26
|
+
const sizes = {
|
|
27
|
+
'xx-small': process.env.NODE_ENV === "production" ? {
|
|
28
|
+
name: "1nlcfpk-xx-small",
|
|
29
|
+
styles: "width:20px;height:20px;border:1px solid;svg{width:10px;height:10x;};label:xx-small;"
|
|
30
|
+
} : {
|
|
31
|
+
name: "1nlcfpk-xx-small",
|
|
32
|
+
styles: "width:20px;height:20px;border:1px solid;svg{width:10px;height:10x;};label:xx-small;",
|
|
33
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ContentTypeBadge.tsx"],"names":[],"mappings":"AAuCiB","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 {\n  SubjectMaterial,\n  TasksAndActivities,\n  AssessmentResource,\n  Subject,\n  ExternalLearningResource,\n  SharedResource,\n  LearningPath,\n  MultidisciplinaryTopic,\n} from '@ndla/icons/contentType';\n\nimport { Concept, ImageNormal, SquareAudio, SquareVideo } 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: ImageNormal,\n    iconColor: colors.brand.grey,\n    backgroundColor: colors.brand.greyLight,\n  },\n  [contentTypes.resourceEmbedTypeMapping.audio]: {\n    icon: SquareAudio,\n    iconColor: colors.brand.grey,\n    backgroundColor: colors.brand.greyLight,\n  },\n  [contentTypes.resourceEmbedTypeMapping.video]: {\n    icon: SquareVideo,\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 = { '--icon-color': fromMap.iconColor, '--background-color': fromMap.backgroundColor } 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
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
35
|
+
},
|
|
36
|
+
'x-small': /*#__PURE__*/(0, _react2.css)("width:20px;height:20px;border:1px solid;", _core.mq.range({
|
|
37
|
+
from: _core.breakpoints.tablet
|
|
38
|
+
}), "{height:26px;width:26px;}svg{width:10px;height:10x;", _core.mq.range({
|
|
39
|
+
from: _core.breakpoints.tablet
|
|
40
|
+
}), "{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":"AAgDgB","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 {\n  SubjectMaterial,\n  TasksAndActivities,\n  AssessmentResource,\n  Subject,\n  ExternalLearningResource,\n  SharedResource,\n  LearningPath,\n  MultidisciplinaryTopic,\n} from '@ndla/icons/contentType';\n\nimport { Concept, ImageNormal, SquareAudio, SquareVideo } 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: ImageNormal,\n    iconColor: colors.brand.grey,\n    backgroundColor: colors.brand.greyLight,\n  },\n  [contentTypes.resourceEmbedTypeMapping.audio]: {\n    icon: SquareAudio,\n    iconColor: colors.brand.grey,\n    backgroundColor: colors.brand.greyLight,\n  },\n  [contentTypes.resourceEmbedTypeMapping.video]: {\n    icon: SquareVideo,\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 = { '--icon-color': fromMap.iconColor, '--background-color': fromMap.backgroundColor } 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"]} */")),
|
|
41
|
+
small: '',
|
|
42
|
+
large: process.env.NODE_ENV === "production" ? {
|
|
43
|
+
name: "1eyjjbh-large",
|
|
44
|
+
styles: "width:50px;height:50px;svg{width:25px;height:25px;};label:large;"
|
|
45
|
+
} : {
|
|
46
|
+
name: "1eyjjbh-large",
|
|
47
|
+
styles: "width:50px;height:50px;svg{width:25px;height:25px;};label:large;",
|
|
48
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ContentTypeBadge.tsx"],"names":[],"mappings":"AAkEY","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 {\n  SubjectMaterial,\n  TasksAndActivities,\n  AssessmentResource,\n  Subject,\n  ExternalLearningResource,\n  SharedResource,\n  LearningPath,\n  MultidisciplinaryTopic,\n} from '@ndla/icons/contentType';\n\nimport { Concept, ImageNormal, SquareAudio, SquareVideo } 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: ImageNormal,\n    iconColor: colors.brand.grey,\n    backgroundColor: colors.brand.greyLight,\n  },\n  [contentTypes.resourceEmbedTypeMapping.audio]: {\n    icon: SquareAudio,\n    iconColor: colors.brand.grey,\n    backgroundColor: colors.brand.greyLight,\n  },\n  [contentTypes.resourceEmbedTypeMapping.video]: {\n    icon: SquareVideo,\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 = { '--icon-color': fromMap.iconColor, '--background-color': fromMap.backgroundColor } 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"]} */",
|
|
49
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
50
|
+
}
|
|
51
|
+
};
|
|
52
|
+
const BaseContentTypeBadge = /*#__PURE__*/(0, _base.default)("div", {
|
|
53
|
+
target: "elguh1z0",
|
|
54
|
+
label: "BaseContentTypeBadge"
|
|
55
|
+
})(process.env.NODE_ENV === "production" ? {
|
|
56
|
+
name: "4p3gmo",
|
|
57
|
+
styles: "display:inline-flex;align-items:center;justify-content:center;border-radius:100%;width:34px;height:34px;color:var(--icon-color)"
|
|
58
|
+
} : {
|
|
59
|
+
name: "4p3gmo",
|
|
60
|
+
styles: "display:inline-flex;align-items:center;justify-content:center;border-radius:100%;width:34px;height:34px;color:var(--icon-color)",
|
|
61
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ContentTypeBadge.tsx"],"names":[],"mappings":"AA4EuC","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 {\n  SubjectMaterial,\n  TasksAndActivities,\n  AssessmentResource,\n  Subject,\n  ExternalLearningResource,\n  SharedResource,\n  LearningPath,\n  MultidisciplinaryTopic,\n} from '@ndla/icons/contentType';\n\nimport { Concept, ImageNormal, SquareAudio, SquareVideo } 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: ImageNormal,\n    iconColor: colors.brand.grey,\n    backgroundColor: colors.brand.greyLight,\n  },\n  [contentTypes.resourceEmbedTypeMapping.audio]: {\n    icon: SquareAudio,\n    iconColor: colors.brand.grey,\n    backgroundColor: colors.brand.greyLight,\n  },\n  [contentTypes.resourceEmbedTypeMapping.video]: {\n    icon: SquareVideo,\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 = { '--icon-color': fromMap.iconColor, '--background-color': fromMap.backgroundColor } 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"]} */",
|
|
62
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
27
63
|
});
|
|
64
|
+
const borderStyle = process.env.NODE_ENV === "production" ? {
|
|
65
|
+
name: "195lw4v-borderStyle",
|
|
66
|
+
styles: "border:2px solid;border-color:var(--icon-color);label:borderStyle;"
|
|
67
|
+
} : {
|
|
68
|
+
name: "195lw4v-borderStyle",
|
|
69
|
+
styles: "border:2px solid;border-color:var(--icon-color);label:borderStyle;",
|
|
70
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ContentTypeBadge.tsx"],"names":[],"mappings":"AAsFuB","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 {\n  SubjectMaterial,\n  TasksAndActivities,\n  AssessmentResource,\n  Subject,\n  ExternalLearningResource,\n  SharedResource,\n  LearningPath,\n  MultidisciplinaryTopic,\n} from '@ndla/icons/contentType';\n\nimport { Concept, ImageNormal, SquareAudio, SquareVideo } 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: ImageNormal,\n    iconColor: colors.brand.grey,\n    backgroundColor: colors.brand.greyLight,\n  },\n  [contentTypes.resourceEmbedTypeMapping.audio]: {\n    icon: SquareAudio,\n    iconColor: colors.brand.grey,\n    backgroundColor: colors.brand.greyLight,\n  },\n  [contentTypes.resourceEmbedTypeMapping.video]: {\n    icon: SquareVideo,\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 = { '--icon-color': fromMap.iconColor, '--background-color': fromMap.backgroundColor } 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"]} */",
|
|
71
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
72
|
+
};
|
|
73
|
+
const backgroundStyle = process.env.NODE_ENV === "production" ? {
|
|
74
|
+
name: "103cks6-backgroundStyle",
|
|
75
|
+
styles: "background-color:var(--background-color);label:backgroundStyle;"
|
|
76
|
+
} : {
|
|
77
|
+
name: "103cks6-backgroundStyle",
|
|
78
|
+
styles: "background-color:var(--background-color);label:backgroundStyle;",
|
|
79
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ContentTypeBadge.tsx"],"names":[],"mappings":"AA2F2B","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 {\n  SubjectMaterial,\n  TasksAndActivities,\n  AssessmentResource,\n  Subject,\n  ExternalLearningResource,\n  SharedResource,\n  LearningPath,\n  MultidisciplinaryTopic,\n} from '@ndla/icons/contentType';\n\nimport { Concept, ImageNormal, SquareAudio, SquareVideo } 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: ImageNormal,\n    iconColor: colors.brand.grey,\n    backgroundColor: colors.brand.greyLight,\n  },\n  [contentTypes.resourceEmbedTypeMapping.audio]: {\n    icon: SquareAudio,\n    iconColor: colors.brand.grey,\n    backgroundColor: colors.brand.greyLight,\n  },\n  [contentTypes.resourceEmbedTypeMapping.video]: {\n    icon: SquareVideo,\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 = { '--icon-color': fromMap.iconColor, '--background-color': fromMap.backgroundColor } 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"]} */",
|
|
80
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
81
|
+
};
|
|
82
|
+
const iconMap = {
|
|
83
|
+
[contentTypes.SUBJECT_MATERIAL]: {
|
|
84
|
+
icon: _contentType.SubjectMaterial,
|
|
85
|
+
iconColor: _core.colors.subjectMaterial.dark,
|
|
86
|
+
backgroundColor: _core.colors.subjectMaterial.light
|
|
87
|
+
},
|
|
88
|
+
[contentTypes.TASKS_AND_ACTIVITIES]: {
|
|
89
|
+
icon: _contentType.TasksAndActivities,
|
|
90
|
+
iconColor: _core.colors.tasksAndActivities.dark,
|
|
91
|
+
backgroundColor: _core.colors.tasksAndActivities.light
|
|
92
|
+
},
|
|
93
|
+
[contentTypes.ASSESSMENT_RESOURCES]: {
|
|
94
|
+
icon: _contentType.AssessmentResource,
|
|
95
|
+
iconColor: _core.colors.assessmentResource.dark,
|
|
96
|
+
backgroundColor: _core.colors.assessmentResource.light
|
|
97
|
+
},
|
|
98
|
+
[contentTypes.SUBJECT]: {
|
|
99
|
+
icon: _action.MenuBook,
|
|
100
|
+
iconColor: _core.colors.subject.dark,
|
|
101
|
+
backgroundColor: _core.colors.subject.light
|
|
102
|
+
},
|
|
103
|
+
[contentTypes.EXTERNAL_LEARNING_RESOURCES]: {
|
|
104
|
+
icon: _contentType.ExternalLearningResource,
|
|
105
|
+
iconColor: _core.colors.externalLearningResource.dark,
|
|
106
|
+
backgroundColor: _core.colors.externalLearningResource.light
|
|
107
|
+
},
|
|
108
|
+
[contentTypes.SOURCE_MATERIAL]: {
|
|
109
|
+
icon: _contentType.SharedResource,
|
|
110
|
+
iconColor: _core.colors.sourceMaterial.dark,
|
|
111
|
+
backgroundColor: _core.colors.sourceMaterial.light
|
|
112
|
+
},
|
|
113
|
+
[contentTypes.LEARNING_PATH]: {
|
|
114
|
+
icon: _contentType.LearningPath,
|
|
115
|
+
iconColor: _core.colors.learningPath.dark,
|
|
116
|
+
backgroundColor: _core.colors.learningPath.light
|
|
117
|
+
},
|
|
118
|
+
[contentTypes.TOPIC]: {
|
|
119
|
+
icon: _contentType.Subject,
|
|
120
|
+
iconColor: _core.colors.subject.dark,
|
|
121
|
+
backgroundColor: _core.colors.subject.light
|
|
122
|
+
},
|
|
123
|
+
[contentTypes.MULTIDISCIPLINARY_TOPIC]: {
|
|
124
|
+
icon: _contentType.MultidisciplinaryTopic,
|
|
125
|
+
backgroundColor: '#b9b37b'
|
|
126
|
+
},
|
|
127
|
+
[contentTypes.resourceEmbedTypeMapping.image]: {
|
|
128
|
+
icon: _editor.ImageNormal,
|
|
129
|
+
iconColor: _core.colors.brand.grey,
|
|
130
|
+
backgroundColor: _core.colors.brand.greyLight
|
|
131
|
+
},
|
|
132
|
+
[contentTypes.resourceEmbedTypeMapping.audio]: {
|
|
133
|
+
icon: _editor.SquareAudio,
|
|
134
|
+
iconColor: _core.colors.brand.grey,
|
|
135
|
+
backgroundColor: _core.colors.brand.greyLight
|
|
136
|
+
},
|
|
137
|
+
[contentTypes.resourceEmbedTypeMapping.video]: {
|
|
138
|
+
icon: _editor.SquareVideo,
|
|
139
|
+
iconColor: _core.colors.brand.grey,
|
|
140
|
+
backgroundColor: _core.colors.brand.greyLight
|
|
141
|
+
},
|
|
142
|
+
[contentTypes.resourceEmbedTypeMapping.concept]: {
|
|
143
|
+
icon: _editor.Concept,
|
|
144
|
+
iconColor: _core.colors.brand.grey,
|
|
145
|
+
backgroundColor: _core.colors.brand.greyLight
|
|
146
|
+
}
|
|
147
|
+
};
|
|
28
148
|
const ContentTypeBadge = _ref => {
|
|
29
149
|
let {
|
|
30
150
|
type,
|
|
@@ -32,86 +152,43 @@ const ContentTypeBadge = _ref => {
|
|
|
32
152
|
title,
|
|
33
153
|
size = 'small',
|
|
34
154
|
border = true,
|
|
35
|
-
className
|
|
155
|
+
className,
|
|
156
|
+
...rest
|
|
36
157
|
} = _ref;
|
|
37
|
-
const
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
case contentTypes.LEARNING_PATH:
|
|
72
|
-
icon = (0, _jsxRuntime.jsx)(_contentType.LearningPath, {
|
|
73
|
-
title: title
|
|
74
|
-
});
|
|
75
|
-
break;
|
|
76
|
-
case contentTypes.TOPIC:
|
|
77
|
-
icon = (0, _jsxRuntime.jsx)(_contentType.Subject, {
|
|
78
|
-
title: title
|
|
79
|
-
});
|
|
80
|
-
break;
|
|
81
|
-
case contentTypes.MULTIDISCIPLINARY_TOPIC:
|
|
82
|
-
icon = (0, _jsxRuntime.jsx)(_contentType.MultidisciplinaryTopic, {});
|
|
83
|
-
break;
|
|
84
|
-
case contentTypes.resourceEmbedTypeMapping.image:
|
|
85
|
-
icon = (0, _jsxRuntime.jsx)(_editor.ImageNormal, {});
|
|
86
|
-
embedResource = true;
|
|
87
|
-
break;
|
|
88
|
-
case contentTypes.resourceEmbedTypeMapping.audio:
|
|
89
|
-
icon = (0, _jsxRuntime.jsx)(_editor.SquareAudio, {});
|
|
90
|
-
embedResource = true;
|
|
91
|
-
break;
|
|
92
|
-
case contentTypes.resourceEmbedTypeMapping.video:
|
|
93
|
-
icon = (0, _jsxRuntime.jsx)(_editor.SquareVideo, {});
|
|
94
|
-
embedResource = true;
|
|
95
|
-
break;
|
|
96
|
-
case contentTypes.resourceEmbedTypeMapping.concept:
|
|
97
|
-
icon = (0, _jsxRuntime.jsx)(_editor.Concept, {});
|
|
98
|
-
embedResource = true;
|
|
99
|
-
break;
|
|
100
|
-
default:
|
|
101
|
-
break;
|
|
102
|
-
}
|
|
103
|
-
if (embedResource) {
|
|
104
|
-
modifiers.push('embed-resource');
|
|
105
|
-
}
|
|
106
|
-
if (background) {
|
|
107
|
-
modifiers.push('background');
|
|
108
|
-
}
|
|
109
|
-
if (border) {
|
|
110
|
-
modifiers.push('border');
|
|
111
|
-
}
|
|
112
|
-
return (0, _jsxRuntime.jsx)("div", {
|
|
113
|
-
...classes('', modifiers, className),
|
|
114
|
-
children: icon
|
|
158
|
+
const {
|
|
159
|
+
Icon,
|
|
160
|
+
style
|
|
161
|
+
} = (0, _react.useMemo)(() => {
|
|
162
|
+
const fromMap = iconMap[type];
|
|
163
|
+
const style = {
|
|
164
|
+
'--icon-color': fromMap.iconColor,
|
|
165
|
+
'--background-color': fromMap.backgroundColor
|
|
166
|
+
};
|
|
167
|
+
return {
|
|
168
|
+
Icon: fromMap.icon,
|
|
169
|
+
style
|
|
170
|
+
};
|
|
171
|
+
}, [type]);
|
|
172
|
+
const cssStyles = (0, _react.useMemo)(() => {
|
|
173
|
+
const styles = [sizes[size]];
|
|
174
|
+
if (background) {
|
|
175
|
+
styles.push(backgroundStyle);
|
|
176
|
+
}
|
|
177
|
+
if (border) {
|
|
178
|
+
styles.push(borderStyle);
|
|
179
|
+
}
|
|
180
|
+
return styles;
|
|
181
|
+
}, [background, border, size]);
|
|
182
|
+
return (0, _jsxRuntime.jsx)(BaseContentTypeBadge, {
|
|
183
|
+
css: cssStyles,
|
|
184
|
+
title: title,
|
|
185
|
+
style: style,
|
|
186
|
+
"aria-label": title,
|
|
187
|
+
className: className,
|
|
188
|
+
"data-badge": "",
|
|
189
|
+
"data-type": type,
|
|
190
|
+
...rest,
|
|
191
|
+
children: (0, _jsxRuntime.jsx)(Icon, {})
|
|
115
192
|
});
|
|
116
193
|
};
|
|
117
194
|
exports.ContentTypeBadge = ContentTypeBadge;
|
|
@@ -8,5 +8,5 @@
|
|
|
8
8
|
import { HTMLAttributes } from 'react';
|
|
9
9
|
interface Props extends HTMLAttributes<HTMLDivElement> {
|
|
10
10
|
}
|
|
11
|
-
declare const FramedContent: ({
|
|
11
|
+
declare const FramedContent: ({ children, ...rest }: Props) => import("@emotion/react/jsx-runtime").JSX.Element;
|
|
12
12
|
export default FramedContent;
|
|
@@ -4,8 +4,10 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
4
4
|
value: true
|
|
5
5
|
});
|
|
6
6
|
exports.default = void 0;
|
|
7
|
-
var
|
|
7
|
+
var _base = _interopRequireDefault(require("@emotion/styled/base"));
|
|
8
|
+
var _core = require("@ndla/core");
|
|
8
9
|
var _jsxRuntime = require("@emotion/react/jsx-runtime");
|
|
10
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
9
11
|
/**
|
|
10
12
|
* Copyright (c) 2023-present, NDLA.
|
|
11
13
|
*
|
|
@@ -14,21 +16,16 @@ var _jsxRuntime = require("@emotion/react/jsx-runtime");
|
|
|
14
16
|
*
|
|
15
17
|
*/
|
|
16
18
|
|
|
19
|
+
const StyledFramedContent = /*#__PURE__*/(0, _base.default)("div", {
|
|
20
|
+
target: "eg9ts460",
|
|
21
|
+
label: "StyledFramedContent"
|
|
22
|
+
})("padding:", _core.spacing.mediumlarge, ";margin:", _core.spacing.large, " 0;border:1px solid ", _core.colors.brand.tertiary, ";overflow:hidden;.c-figure{width:100%!important;left:auto!important;padding:0;&.u-float-right,&.u-float-small-right{width:50%!important;margin-right:0;}&.u-float-left,&.u-float-small-left{width:50%!important;margin-left:0;}}&:first-child{margin-top:0;}&:last-child{margin-bottom:0;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkZyYW1lZENvbnRlbnQudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWNzQyIsImZpbGUiOiJGcmFtZWRDb250ZW50LnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDIzLXByZXNlbnQsIE5ETEEuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgR1BMdjMgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqXG4gKi9cblxuaW1wb3J0IHsgSFRNTEF0dHJpYnV0ZXMgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBjb2xvcnMsIHNwYWNpbmcgfSBmcm9tICdAbmRsYS9jb3JlJztcblxuaW50ZXJmYWNlIFByb3BzIGV4dGVuZHMgSFRNTEF0dHJpYnV0ZXM8SFRNTERpdkVsZW1lbnQ+IHt9XG5cbmNvbnN0IFN0eWxlZEZyYW1lZENvbnRlbnQgPSBzdHlsZWQuZGl2YFxuICBwYWRkaW5nOiAke3NwYWNpbmcubWVkaXVtbGFyZ2V9O1xuICBtYXJnaW46ICR7c3BhY2luZy5sYXJnZX0gMDtcbiAgYm9yZGVyOiAxcHggc29saWQgJHtjb2xvcnMuYnJhbmQudGVydGlhcnl9O1xuICBvdmVyZmxvdzogaGlkZGVuO1xuXG4gIC5jLWZpZ3VyZSB7XG4gICAgd2lkdGg6IDEwMCUgIWltcG9ydGFudDtcbiAgICBsZWZ0OiBhdXRvICFpbXBvcnRhbnQ7XG4gICAgcGFkZGluZzogMDtcblxuICAgICYudS1mbG9hdC1yaWdodCxcbiAgICAmLnUtZmxvYXQtc21hbGwtcmlnaHQge1xuICAgICAgd2lkdGg6IDUwJSAhaW1wb3J0YW50O1xuICAgICAgbWFyZ2luLXJpZ2h0OiAwO1xuICAgIH1cblxuICAgICYudS1mbG9hdC1sZWZ0LFxuICAgICYudS1mbG9hdC1zbWFsbC1sZWZ0IHtcbiAgICAgIHdpZHRoOiA1MCUgIWltcG9ydGFudDtcbiAgICAgIG1hcmdpbi1sZWZ0OiAwO1xuICAgIH1cbiAgfVxuXG4gICY6Zmlyc3QtY2hpbGQge1xuICAgIG1hcmdpbi10b3A6IDA7XG4gIH1cblxuICAmOmxhc3QtY2hpbGQge1xuICAgIG1hcmdpbi1ib3R0b206IDA7XG4gIH1cbmA7XG5cbmNvbnN0IEZyYW1lZENvbnRlbnQgPSAoeyBjaGlsZHJlbiwgLi4ucmVzdCB9OiBQcm9wcykgPT4ge1xuICByZXR1cm4gPFN0eWxlZEZyYW1lZENvbnRlbnQgey4uLnJlc3R9PntjaGlsZHJlbn08L1N0eWxlZEZyYW1lZENvbnRlbnQ+O1xufTtcblxuZXhwb3J0IGRlZmF1bHQgRnJhbWVkQ29udGVudDtcbiJdfQ== */"));
|
|
17
23
|
const FramedContent = _ref => {
|
|
18
24
|
let {
|
|
19
|
-
className,
|
|
20
25
|
children,
|
|
21
26
|
...rest
|
|
22
27
|
} = _ref;
|
|
23
|
-
|
|
24
|
-
const classes = ['c-bodybox'];
|
|
25
|
-
if (className) {
|
|
26
|
-
classes.push(className);
|
|
27
|
-
}
|
|
28
|
-
return classes.join(' ');
|
|
29
|
-
}, [className]);
|
|
30
|
-
return (0, _jsxRuntime.jsx)("div", {
|
|
31
|
-
className: classes,
|
|
28
|
+
return (0, _jsxRuntime.jsx)(StyledFramedContent, {
|
|
32
29
|
...rest,
|
|
33
30
|
children: children
|
|
34
31
|
});
|