@ndla/ui 32.1.0 → 33.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/es/Article/Article.js +4 -4
- package/es/Frontpage/FrontpageAllSubjects.js +9 -17
- package/es/Image/Image.js +5 -5
- package/es/Image/ImageLink.js +5 -5
- package/es/SearchTypeResult/components/ItemTopicHeader.js +4 -4
- package/es/index.js +1 -0
- package/es/locale/messages-en.js +3 -2
- package/es/locale/messages-nb.js +3 -2
- package/es/locale/messages-nn.js +3 -2
- package/es/locale/messages-se.js +3 -2
- package/es/locale/messages-sma.js +3 -2
- package/es/model/SubjectCategories.js +2 -1
- package/lib/Article/Article.js +4 -4
- package/lib/Frontpage/FrontpageAllSubjects.d.ts +0 -2
- package/lib/Frontpage/FrontpageAllSubjects.js +9 -17
- package/lib/Image/Image.js +5 -5
- package/lib/Image/ImageLink.js +5 -5
- package/lib/SearchTypeResult/components/ItemTopicHeader.js +4 -4
- package/lib/index.d.ts +1 -0
- package/lib/index.js +8 -0
- package/lib/locale/messages-en.d.ts +3 -1
- package/lib/locale/messages-en.js +3 -2
- package/lib/locale/messages-nb.d.ts +3 -1
- package/lib/locale/messages-nb.js +3 -2
- package/lib/locale/messages-nn.d.ts +3 -1
- package/lib/locale/messages-nn.js +3 -2
- package/lib/locale/messages-se.d.ts +3 -1
- package/lib/locale/messages-se.js +3 -2
- package/lib/locale/messages-sma.d.ts +3 -1
- package/lib/locale/messages-sma.js +3 -2
- package/lib/model/SubjectCategories.d.ts +2 -1
- package/lib/model/SubjectCategories.js +5 -3
- package/package.json +4 -4
- package/src/Article/Article.tsx +2 -2
- package/src/Frontpage/FrontpageAllSubjects.tsx +2 -14
- package/src/Image/Image.tsx +2 -0
- package/src/Image/ImageLink.tsx +2 -0
- package/src/Image/__tests__/__snapshots__/Image-test.jsx.snap +6 -0
- package/src/MyNdla/Resource/Folder.stories.mdx +52 -0
- package/src/Resource/BlockResource.stories.mdx +58 -0
- package/src/Resource/Resource.stories.mdx +58 -0
- package/src/SearchTypeResult/components/ItemTopicHeader.tsx +1 -0
- package/src/index.ts +2 -0
- package/src/locale/messages-en.ts +4 -2
- package/src/locale/messages-nb.ts +4 -2
- package/src/locale/messages-nn.ts +4 -2
- package/src/locale/messages-se.ts +4 -2
- package/src/locale/messages-sma.ts +4 -2
- package/src/model/SubjectCategories.ts +2 -1
package/es/Article/Article.js
CHANGED
|
@@ -78,13 +78,13 @@ export var ArticleIntroduction = function ArticleIntroduction(_ref3) {
|
|
|
78
78
|
return text;
|
|
79
79
|
} : _ref3$renderMarkdown;
|
|
80
80
|
if (isString(children)) {
|
|
81
|
-
return _jsx("
|
|
81
|
+
return _jsx("div", {
|
|
82
82
|
className: "article_introduction",
|
|
83
83
|
children: parse(renderMarkdown(children))
|
|
84
84
|
});
|
|
85
85
|
}
|
|
86
86
|
if (children) {
|
|
87
|
-
return _jsx("
|
|
87
|
+
return _jsx("div", {
|
|
88
88
|
className: "article_introduction",
|
|
89
89
|
children: children
|
|
90
90
|
});
|
|
@@ -100,7 +100,7 @@ var MSGboxWrapper = /*#__PURE__*/_styled("div", {
|
|
|
100
100
|
} : {
|
|
101
101
|
name: "15u9bv0",
|
|
102
102
|
styles: "margin-bottom:50px",
|
|
103
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Article.tsx"],"names":[],"mappings":"AAgGgC","file":"Article.tsx","sourcesContent":["/**\n * Copyright (c) 2016-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { ComponentType, ReactNode, useEffect, useRef, useState, forwardRef } from 'react';\nimport BEMHelper from 'react-bem-helper';\nimport isString from 'lodash/isString';\nimport parse from 'html-react-parser';\nimport styled from '@emotion/styled';\n\nimport { useIntersectionObserver } from '@ndla/hooks';\nimport { resizeObserver } from '@ndla/util';\nimport { spacing, spacingUnit, mq, breakpoints } from '@ndla/core';\nimport { Article as ArticleType, Locale } from '../types';\nimport ArticleFootNotes from './ArticleFootNotes';\nimport ArticleContent from './ArticleContent';\nimport ArticleByline from './ArticleByline';\nimport LayoutItem from '../Layout';\nimport ArticleHeaderWrapper from './ArticleHeaderWrapper';\nimport ArticleNotions, { NotionRelatedContent } from './ArticleNotions';\nimport ArticleAccessMessage from './ArticleAccessMessage';\nimport MessageBox from '../Messages/MessageBox';\nimport { ConceptNotionType } from '../Notion/ConceptNotion';\n\nconst classes = new BEMHelper({\n  name: 'article',\n  prefix: 'c-',\n});\n\ntype ArticleWrapperProps = {\n  id: string;\n  modifier?: string;\n  children: ReactNode;\n};\n\nexport const ArticleWrapper = forwardRef<HTMLElement, ArticleWrapperProps>(({ children, modifier, id }, ref) => (\n  <article id={id} {...classes(undefined, modifier)} ref={ref}>\n    {children}\n  </article>\n));\n\ntype ArticleTitleProps = {\n  icon?: ReactNode;\n  label?: string;\n  children: ReactNode;\n};\n\nexport const ArticleTitle = ({ children, icon, label }: ArticleTitleProps) => {\n  const modifiers = [];\n  if (icon) {\n    modifiers.push('icon');\n  }\n\n  let labelView = null;\n\n  if (label) {\n    labelView = <p>{label}</p>;\n  }\n\n  return (\n    <div {...classes('title', modifiers)}>\n      {icon}\n      {labelView}\n      <h1 tabIndex={-1}>{children}</h1>\n    </div>\n  );\n};\n\ntype ArticleIntroductionProps = {\n  children: ReactNode;\n  renderMarkdown: (text: string) => string;\n};\n\nexport const ArticleIntroduction = ({\n  children,\n  renderMarkdown = (text) => {\n    return text;\n  },\n}: ArticleIntroductionProps) => {\n  if (isString(children)) {\n    return <p className=\"article_introduction\">{parse(renderMarkdown(children))}</p>;\n  }\n  if (children) {\n    return <p className=\"article_introduction\">{children}</p>;\n  }\n  return null;\n};\n\ntype Messages = {\n  label: string;\n  messageBox?: string;\n};\nconst MSGboxWrapper = styled.div`\n  margin-bottom: 50px;\n`;\n\nconst ArticleFavoritesButtonWrapper = styled.div`\n  display: flex;\n  justify-content: flex-end;\n  transform: translate(${spacing.xsmall}, -${spacing.normal});\n  height: 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    transform: translate(${spacing.normal}, -${spacing.medium});\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    transform: translate(${spacing.large}, -${spacing.medium});\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    transform: translate(${spacingUnit * 5.5}px, -${spacing.medium});\n  }\n`;\n\ntype Props = {\n  heartButton?: ReactNode;\n  article: ArticleType;\n  icon?: ReactNode;\n  licenseBox?: ReactNode;\n  modifier?: string;\n  children?: ReactNode;\n  messages: Messages;\n  locale: Locale;\n  messageBoxLinks?: [];\n  competenceGoals?:\n    | ((inp: { Dialog: ComponentType; dialogProps: { isOpen: boolean; onClose: () => void } }) => ReactNode)\n    | ReactNode\n    | null;\n  competenceGoalTypes?: string[];\n  id: string;\n  renderMarkdown: (text: string) => string;\n  copyPageUrlLink?: string;\n  printUrl?: string;\n  notions?: { list: ConceptNotionType[]; related: NotionRelatedContent[] };\n  accessMessage?: string;\n};\n\nconst getArticleContent = (content: any, locale: Locale) => {\n  switch (typeof content) {\n    case 'string':\n      return <ArticleContent content={content} locale={locale} />;\n    case 'function':\n      return content();\n    default:\n      return content;\n  }\n};\n\nexport const Article = ({\n  article,\n  icon,\n  licenseBox,\n  modifier,\n  messages,\n  messageBoxLinks,\n  children,\n  competenceGoals,\n  competenceGoalTypes,\n  copyPageUrlLink,\n  id,\n  locale,\n  notions,\n  printUrl,\n  renderMarkdown,\n  accessMessage,\n  heartButton,\n}: Props) => {\n  const [articleRef, { entry }] = useIntersectionObserver({\n    root: null,\n    rootMargin: '400px',\n    threshold: 0.1,\n  });\n  const [articlePositionRight, setArticlePositionRight] = useState(0);\n  const wrapperRef = useRef<HTMLDivElement>(null);\n\n  const showExplainNotions = entry && entry.isIntersecting;\n\n  useEffect(() => {\n    if (wrapperRef && wrapperRef.current) {\n      const handler = () => {\n        if (wrapperRef && wrapperRef.current) {\n          const offset =\n            wrapperRef.current.getBoundingClientRect().left + wrapperRef.current.getBoundingClientRect().width;\n          setArticlePositionRight(offset);\n        }\n      };\n      handler();\n\n      return resizeObserver(document.body, handler);\n    }\n  }, [wrapperRef]);\n\n  const {\n    title,\n    introduction,\n    published,\n    content,\n    footNotes,\n    copyright: { license: licenseObj, creators, rightsholders, processors },\n  } = article;\n\n  const authors = creators.length || rightsholders.length ? creators : processors;\n\n  return (\n    <div ref={wrapperRef}>\n      <ArticleWrapper modifier={modifier} id={id} ref={articleRef}>\n        <LayoutItem layout=\"center\">\n          {accessMessage && <ArticleAccessMessage message={accessMessage} />}\n\n          {messages.messageBox && (\n            <MSGboxWrapper>\n              <MessageBox links={messageBoxLinks}>{messages.messageBox}</MessageBox>\n            </MSGboxWrapper>\n          )}\n          <ArticleHeaderWrapper competenceGoals={competenceGoals} competenceGoalTypes={competenceGoalTypes}>\n            {heartButton ? <ArticleFavoritesButtonWrapper>{heartButton}</ArticleFavoritesButtonWrapper> : null}\n\n            <ArticleTitle icon={icon} label={messages.label}>\n              {title}\n            </ArticleTitle>\n            <ArticleIntroduction renderMarkdown={renderMarkdown}>{introduction}</ArticleIntroduction>\n          </ArticleHeaderWrapper>\n        </LayoutItem>\n        <LayoutItem layout=\"center\">\n          {notions && showExplainNotions && (\n            <ArticleNotions\n              notions={notions.list}\n              relatedContent={notions.related}\n              buttonOffsetRight={articlePositionRight}\n            />\n          )}\n          {getArticleContent(content, locale)}\n        </LayoutItem>\n\n        <LayoutItem layout=\"center\">\n          {footNotes && footNotes.length > 0 && <ArticleFootNotes footNotes={footNotes} />}\n          <ArticleByline\n            copyPageUrlLink={copyPageUrlLink}\n            authors={authors}\n            suppliers={rightsholders}\n            published={published}\n            license={licenseObj.license}\n            licenseBox={licenseBox}\n            printUrl={printUrl}\n          />\n        </LayoutItem>\n        <LayoutItem layout=\"extend\">{children}</LayoutItem>\n      </ArticleWrapper>\n    </div>\n  );\n};\n\nexport default Article;\n"]} */",
|
|
103
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Article.tsx"],"names":[],"mappings":"AAgGgC","file":"Article.tsx","sourcesContent":["/**\n * Copyright (c) 2016-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { ComponentType, ReactNode, useEffect, useRef, useState, forwardRef } from 'react';\nimport BEMHelper from 'react-bem-helper';\nimport isString from 'lodash/isString';\nimport parse from 'html-react-parser';\nimport styled from '@emotion/styled';\n\nimport { useIntersectionObserver } from '@ndla/hooks';\nimport { resizeObserver } from '@ndla/util';\nimport { spacing, spacingUnit, mq, breakpoints } from '@ndla/core';\nimport { Article as ArticleType, Locale } from '../types';\nimport ArticleFootNotes from './ArticleFootNotes';\nimport ArticleContent from './ArticleContent';\nimport ArticleByline from './ArticleByline';\nimport LayoutItem from '../Layout';\nimport ArticleHeaderWrapper from './ArticleHeaderWrapper';\nimport ArticleNotions, { NotionRelatedContent } from './ArticleNotions';\nimport ArticleAccessMessage from './ArticleAccessMessage';\nimport MessageBox from '../Messages/MessageBox';\nimport { ConceptNotionType } from '../Notion/ConceptNotion';\n\nconst classes = new BEMHelper({\n  name: 'article',\n  prefix: 'c-',\n});\n\ntype ArticleWrapperProps = {\n  id: string;\n  modifier?: string;\n  children: ReactNode;\n};\n\nexport const ArticleWrapper = forwardRef<HTMLElement, ArticleWrapperProps>(({ children, modifier, id }, ref) => (\n  <article id={id} {...classes(undefined, modifier)} ref={ref}>\n    {children}\n  </article>\n));\n\ntype ArticleTitleProps = {\n  icon?: ReactNode;\n  label?: string;\n  children: ReactNode;\n};\n\nexport const ArticleTitle = ({ children, icon, label }: ArticleTitleProps) => {\n  const modifiers = [];\n  if (icon) {\n    modifiers.push('icon');\n  }\n\n  let labelView = null;\n\n  if (label) {\n    labelView = <p>{label}</p>;\n  }\n\n  return (\n    <div {...classes('title', modifiers)}>\n      {icon}\n      {labelView}\n      <h1 tabIndex={-1}>{children}</h1>\n    </div>\n  );\n};\n\ntype ArticleIntroductionProps = {\n  children: ReactNode;\n  renderMarkdown: (text: string) => string;\n};\n\nexport const ArticleIntroduction = ({\n  children,\n  renderMarkdown = (text) => {\n    return text;\n  },\n}: ArticleIntroductionProps) => {\n  if (isString(children)) {\n    return <div className=\"article_introduction\">{parse(renderMarkdown(children))}</div>;\n  }\n  if (children) {\n    return <div className=\"article_introduction\">{children}</div>;\n  }\n  return null;\n};\n\ntype Messages = {\n  label: string;\n  messageBox?: string;\n};\nconst MSGboxWrapper = styled.div`\n  margin-bottom: 50px;\n`;\n\nconst ArticleFavoritesButtonWrapper = styled.div`\n  display: flex;\n  justify-content: flex-end;\n  transform: translate(${spacing.xsmall}, -${spacing.normal});\n  height: 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    transform: translate(${spacing.normal}, -${spacing.medium});\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    transform: translate(${spacing.large}, -${spacing.medium});\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    transform: translate(${spacingUnit * 5.5}px, -${spacing.medium});\n  }\n`;\n\ntype Props = {\n  heartButton?: ReactNode;\n  article: ArticleType;\n  icon?: ReactNode;\n  licenseBox?: ReactNode;\n  modifier?: string;\n  children?: ReactNode;\n  messages: Messages;\n  locale: Locale;\n  messageBoxLinks?: [];\n  competenceGoals?:\n    | ((inp: { Dialog: ComponentType; dialogProps: { isOpen: boolean; onClose: () => void } }) => ReactNode)\n    | ReactNode\n    | null;\n  competenceGoalTypes?: string[];\n  id: string;\n  renderMarkdown: (text: string) => string;\n  copyPageUrlLink?: string;\n  printUrl?: string;\n  notions?: { list: ConceptNotionType[]; related: NotionRelatedContent[] };\n  accessMessage?: string;\n};\n\nconst getArticleContent = (content: any, locale: Locale) => {\n  switch (typeof content) {\n    case 'string':\n      return <ArticleContent content={content} locale={locale} />;\n    case 'function':\n      return content();\n    default:\n      return content;\n  }\n};\n\nexport const Article = ({\n  article,\n  icon,\n  licenseBox,\n  modifier,\n  messages,\n  messageBoxLinks,\n  children,\n  competenceGoals,\n  competenceGoalTypes,\n  copyPageUrlLink,\n  id,\n  locale,\n  notions,\n  printUrl,\n  renderMarkdown,\n  accessMessage,\n  heartButton,\n}: Props) => {\n  const [articleRef, { entry }] = useIntersectionObserver({\n    root: null,\n    rootMargin: '400px',\n    threshold: 0.1,\n  });\n  const [articlePositionRight, setArticlePositionRight] = useState(0);\n  const wrapperRef = useRef<HTMLDivElement>(null);\n\n  const showExplainNotions = entry && entry.isIntersecting;\n\n  useEffect(() => {\n    if (wrapperRef && wrapperRef.current) {\n      const handler = () => {\n        if (wrapperRef && wrapperRef.current) {\n          const offset =\n            wrapperRef.current.getBoundingClientRect().left + wrapperRef.current.getBoundingClientRect().width;\n          setArticlePositionRight(offset);\n        }\n      };\n      handler();\n\n      return resizeObserver(document.body, handler);\n    }\n  }, [wrapperRef]);\n\n  const {\n    title,\n    introduction,\n    published,\n    content,\n    footNotes,\n    copyright: { license: licenseObj, creators, rightsholders, processors },\n  } = article;\n\n  const authors = creators.length || rightsholders.length ? creators : processors;\n\n  return (\n    <div ref={wrapperRef}>\n      <ArticleWrapper modifier={modifier} id={id} ref={articleRef}>\n        <LayoutItem layout=\"center\">\n          {accessMessage && <ArticleAccessMessage message={accessMessage} />}\n\n          {messages.messageBox && (\n            <MSGboxWrapper>\n              <MessageBox links={messageBoxLinks}>{messages.messageBox}</MessageBox>\n            </MSGboxWrapper>\n          )}\n          <ArticleHeaderWrapper competenceGoals={competenceGoals} competenceGoalTypes={competenceGoalTypes}>\n            {heartButton ? <ArticleFavoritesButtonWrapper>{heartButton}</ArticleFavoritesButtonWrapper> : null}\n\n            <ArticleTitle icon={icon} label={messages.label}>\n              {title}\n            </ArticleTitle>\n            <ArticleIntroduction renderMarkdown={renderMarkdown}>{introduction}</ArticleIntroduction>\n          </ArticleHeaderWrapper>\n        </LayoutItem>\n        <LayoutItem layout=\"center\">\n          {notions && showExplainNotions && (\n            <ArticleNotions\n              notions={notions.list}\n              relatedContent={notions.related}\n              buttonOffsetRight={articlePositionRight}\n            />\n          )}\n          {getArticleContent(content, locale)}\n        </LayoutItem>\n\n        <LayoutItem layout=\"center\">\n          {footNotes && footNotes.length > 0 && <ArticleFootNotes footNotes={footNotes} />}\n          <ArticleByline\n            copyPageUrlLink={copyPageUrlLink}\n            authors={authors}\n            suppliers={rightsholders}\n            published={published}\n            license={licenseObj.license}\n            licenseBox={licenseBox}\n            printUrl={printUrl}\n          />\n        </LayoutItem>\n        <LayoutItem layout=\"extend\">{children}</LayoutItem>\n      </ArticleWrapper>\n    </div>\n  );\n};\n\nexport default Article;\n"]} */",
|
|
104
104
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
105
105
|
});
|
|
106
106
|
var ArticleFavoritesButtonWrapper = /*#__PURE__*/_styled("div", {
|
|
@@ -112,7 +112,7 @@ var ArticleFavoritesButtonWrapper = /*#__PURE__*/_styled("div", {
|
|
|
112
112
|
from: breakpoints.tabletWide
|
|
113
113
|
}), "{transform:translate(", spacing.large, ", -", spacing.medium, ");}", mq.range({
|
|
114
114
|
from: breakpoints.desktop
|
|
115
|
-
}), "{transform:translate(", spacingUnit * 5.5, "px, -", spacing.medium, ");}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Article.tsx"],"names":[],"mappings":"AAoGgD","file":"Article.tsx","sourcesContent":["/**\n * Copyright (c) 2016-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { ComponentType, ReactNode, useEffect, useRef, useState, forwardRef } from 'react';\nimport BEMHelper from 'react-bem-helper';\nimport isString from 'lodash/isString';\nimport parse from 'html-react-parser';\nimport styled from '@emotion/styled';\n\nimport { useIntersectionObserver } from '@ndla/hooks';\nimport { resizeObserver } from '@ndla/util';\nimport { spacing, spacingUnit, mq, breakpoints } from '@ndla/core';\nimport { Article as ArticleType, Locale } from '../types';\nimport ArticleFootNotes from './ArticleFootNotes';\nimport ArticleContent from './ArticleContent';\nimport ArticleByline from './ArticleByline';\nimport LayoutItem from '../Layout';\nimport ArticleHeaderWrapper from './ArticleHeaderWrapper';\nimport ArticleNotions, { NotionRelatedContent } from './ArticleNotions';\nimport ArticleAccessMessage from './ArticleAccessMessage';\nimport MessageBox from '../Messages/MessageBox';\nimport { ConceptNotionType } from '../Notion/ConceptNotion';\n\nconst classes = new BEMHelper({\n  name: 'article',\n  prefix: 'c-',\n});\n\ntype ArticleWrapperProps = {\n  id: string;\n  modifier?: string;\n  children: ReactNode;\n};\n\nexport const ArticleWrapper = forwardRef<HTMLElement, ArticleWrapperProps>(({ children, modifier, id }, ref) => (\n  <article id={id} {...classes(undefined, modifier)} ref={ref}>\n    {children}\n  </article>\n));\n\ntype ArticleTitleProps = {\n  icon?: ReactNode;\n  label?: string;\n  children: ReactNode;\n};\n\nexport const ArticleTitle = ({ children, icon, label }: ArticleTitleProps) => {\n  const modifiers = [];\n  if (icon) {\n    modifiers.push('icon');\n  }\n\n  let labelView = null;\n\n  if (label) {\n    labelView = <p>{label}</p>;\n  }\n\n  return (\n    <div {...classes('title', modifiers)}>\n      {icon}\n      {labelView}\n      <h1 tabIndex={-1}>{children}</h1>\n    </div>\n  );\n};\n\ntype ArticleIntroductionProps = {\n  children: ReactNode;\n  renderMarkdown: (text: string) => string;\n};\n\nexport const ArticleIntroduction = ({\n  children,\n  renderMarkdown = (text) => {\n    return text;\n  },\n}: ArticleIntroductionProps) => {\n  if (isString(children)) {\n    return <p className=\"article_introduction\">{parse(renderMarkdown(children))}</p>;\n  }\n  if (children) {\n    return <p className=\"article_introduction\">{children}</p>;\n  }\n  return null;\n};\n\ntype Messages = {\n  label: string;\n  messageBox?: string;\n};\nconst MSGboxWrapper = styled.div`\n  margin-bottom: 50px;\n`;\n\nconst ArticleFavoritesButtonWrapper = styled.div`\n  display: flex;\n  justify-content: flex-end;\n  transform: translate(${spacing.xsmall}, -${spacing.normal});\n  height: 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    transform: translate(${spacing.normal}, -${spacing.medium});\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    transform: translate(${spacing.large}, -${spacing.medium});\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    transform: translate(${spacingUnit * 5.5}px, -${spacing.medium});\n  }\n`;\n\ntype Props = {\n  heartButton?: ReactNode;\n  article: ArticleType;\n  icon?: ReactNode;\n  licenseBox?: ReactNode;\n  modifier?: string;\n  children?: ReactNode;\n  messages: Messages;\n  locale: Locale;\n  messageBoxLinks?: [];\n  competenceGoals?:\n    | ((inp: { Dialog: ComponentType; dialogProps: { isOpen: boolean; onClose: () => void } }) => ReactNode)\n    | ReactNode\n    | null;\n  competenceGoalTypes?: string[];\n  id: string;\n  renderMarkdown: (text: string) => string;\n  copyPageUrlLink?: string;\n  printUrl?: string;\n  notions?: { list: ConceptNotionType[]; related: NotionRelatedContent[] };\n  accessMessage?: string;\n};\n\nconst getArticleContent = (content: any, locale: Locale) => {\n  switch (typeof content) {\n    case 'string':\n      return <ArticleContent content={content} locale={locale} />;\n    case 'function':\n      return content();\n    default:\n      return content;\n  }\n};\n\nexport const Article = ({\n  article,\n  icon,\n  licenseBox,\n  modifier,\n  messages,\n  messageBoxLinks,\n  children,\n  competenceGoals,\n  competenceGoalTypes,\n  copyPageUrlLink,\n  id,\n  locale,\n  notions,\n  printUrl,\n  renderMarkdown,\n  accessMessage,\n  heartButton,\n}: Props) => {\n  const [articleRef, { entry }] = useIntersectionObserver({\n    root: null,\n    rootMargin: '400px',\n    threshold: 0.1,\n  });\n  const [articlePositionRight, setArticlePositionRight] = useState(0);\n  const wrapperRef = useRef<HTMLDivElement>(null);\n\n  const showExplainNotions = entry && entry.isIntersecting;\n\n  useEffect(() => {\n    if (wrapperRef && wrapperRef.current) {\n      const handler = () => {\n        if (wrapperRef && wrapperRef.current) {\n          const offset =\n            wrapperRef.current.getBoundingClientRect().left + wrapperRef.current.getBoundingClientRect().width;\n          setArticlePositionRight(offset);\n        }\n      };\n      handler();\n\n      return resizeObserver(document.body, handler);\n    }\n  }, [wrapperRef]);\n\n  const {\n    title,\n    introduction,\n    published,\n    content,\n    footNotes,\n    copyright: { license: licenseObj, creators, rightsholders, processors },\n  } = article;\n\n  const authors = creators.length || rightsholders.length ? creators : processors;\n\n  return (\n    <div ref={wrapperRef}>\n      <ArticleWrapper modifier={modifier} id={id} ref={articleRef}>\n        <LayoutItem layout=\"center\">\n          {accessMessage && <ArticleAccessMessage message={accessMessage} />}\n\n          {messages.messageBox && (\n            <MSGboxWrapper>\n              <MessageBox links={messageBoxLinks}>{messages.messageBox}</MessageBox>\n            </MSGboxWrapper>\n          )}\n          <ArticleHeaderWrapper competenceGoals={competenceGoals} competenceGoalTypes={competenceGoalTypes}>\n            {heartButton ? <ArticleFavoritesButtonWrapper>{heartButton}</ArticleFavoritesButtonWrapper> : null}\n\n            <ArticleTitle icon={icon} label={messages.label}>\n              {title}\n            </ArticleTitle>\n            <ArticleIntroduction renderMarkdown={renderMarkdown}>{introduction}</ArticleIntroduction>\n          </ArticleHeaderWrapper>\n        </LayoutItem>\n        <LayoutItem layout=\"center\">\n          {notions && showExplainNotions && (\n            <ArticleNotions\n              notions={notions.list}\n              relatedContent={notions.related}\n              buttonOffsetRight={articlePositionRight}\n            />\n          )}\n          {getArticleContent(content, locale)}\n        </LayoutItem>\n\n        <LayoutItem layout=\"center\">\n          {footNotes && footNotes.length > 0 && <ArticleFootNotes footNotes={footNotes} />}\n          <ArticleByline\n            copyPageUrlLink={copyPageUrlLink}\n            authors={authors}\n            suppliers={rightsholders}\n            published={published}\n            license={licenseObj.license}\n            licenseBox={licenseBox}\n            printUrl={printUrl}\n          />\n        </LayoutItem>\n        <LayoutItem layout=\"extend\">{children}</LayoutItem>\n      </ArticleWrapper>\n    </div>\n  );\n};\n\nexport default Article;\n"]} */"));
|
|
115
|
+
}), "{transform:translate(", spacingUnit * 5.5, "px, -", spacing.medium, ");}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Article.tsx"],"names":[],"mappings":"AAoGgD","file":"Article.tsx","sourcesContent":["/**\n * Copyright (c) 2016-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { ComponentType, ReactNode, useEffect, useRef, useState, forwardRef } from 'react';\nimport BEMHelper from 'react-bem-helper';\nimport isString from 'lodash/isString';\nimport parse from 'html-react-parser';\nimport styled from '@emotion/styled';\n\nimport { useIntersectionObserver } from '@ndla/hooks';\nimport { resizeObserver } from '@ndla/util';\nimport { spacing, spacingUnit, mq, breakpoints } from '@ndla/core';\nimport { Article as ArticleType, Locale } from '../types';\nimport ArticleFootNotes from './ArticleFootNotes';\nimport ArticleContent from './ArticleContent';\nimport ArticleByline from './ArticleByline';\nimport LayoutItem from '../Layout';\nimport ArticleHeaderWrapper from './ArticleHeaderWrapper';\nimport ArticleNotions, { NotionRelatedContent } from './ArticleNotions';\nimport ArticleAccessMessage from './ArticleAccessMessage';\nimport MessageBox from '../Messages/MessageBox';\nimport { ConceptNotionType } from '../Notion/ConceptNotion';\n\nconst classes = new BEMHelper({\n  name: 'article',\n  prefix: 'c-',\n});\n\ntype ArticleWrapperProps = {\n  id: string;\n  modifier?: string;\n  children: ReactNode;\n};\n\nexport const ArticleWrapper = forwardRef<HTMLElement, ArticleWrapperProps>(({ children, modifier, id }, ref) => (\n  <article id={id} {...classes(undefined, modifier)} ref={ref}>\n    {children}\n  </article>\n));\n\ntype ArticleTitleProps = {\n  icon?: ReactNode;\n  label?: string;\n  children: ReactNode;\n};\n\nexport const ArticleTitle = ({ children, icon, label }: ArticleTitleProps) => {\n  const modifiers = [];\n  if (icon) {\n    modifiers.push('icon');\n  }\n\n  let labelView = null;\n\n  if (label) {\n    labelView = <p>{label}</p>;\n  }\n\n  return (\n    <div {...classes('title', modifiers)}>\n      {icon}\n      {labelView}\n      <h1 tabIndex={-1}>{children}</h1>\n    </div>\n  );\n};\n\ntype ArticleIntroductionProps = {\n  children: ReactNode;\n  renderMarkdown: (text: string) => string;\n};\n\nexport const ArticleIntroduction = ({\n  children,\n  renderMarkdown = (text) => {\n    return text;\n  },\n}: ArticleIntroductionProps) => {\n  if (isString(children)) {\n    return <div className=\"article_introduction\">{parse(renderMarkdown(children))}</div>;\n  }\n  if (children) {\n    return <div className=\"article_introduction\">{children}</div>;\n  }\n  return null;\n};\n\ntype Messages = {\n  label: string;\n  messageBox?: string;\n};\nconst MSGboxWrapper = styled.div`\n  margin-bottom: 50px;\n`;\n\nconst ArticleFavoritesButtonWrapper = styled.div`\n  display: flex;\n  justify-content: flex-end;\n  transform: translate(${spacing.xsmall}, -${spacing.normal});\n  height: 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    transform: translate(${spacing.normal}, -${spacing.medium});\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    transform: translate(${spacing.large}, -${spacing.medium});\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    transform: translate(${spacingUnit * 5.5}px, -${spacing.medium});\n  }\n`;\n\ntype Props = {\n  heartButton?: ReactNode;\n  article: ArticleType;\n  icon?: ReactNode;\n  licenseBox?: ReactNode;\n  modifier?: string;\n  children?: ReactNode;\n  messages: Messages;\n  locale: Locale;\n  messageBoxLinks?: [];\n  competenceGoals?:\n    | ((inp: { Dialog: ComponentType; dialogProps: { isOpen: boolean; onClose: () => void } }) => ReactNode)\n    | ReactNode\n    | null;\n  competenceGoalTypes?: string[];\n  id: string;\n  renderMarkdown: (text: string) => string;\n  copyPageUrlLink?: string;\n  printUrl?: string;\n  notions?: { list: ConceptNotionType[]; related: NotionRelatedContent[] };\n  accessMessage?: string;\n};\n\nconst getArticleContent = (content: any, locale: Locale) => {\n  switch (typeof content) {\n    case 'string':\n      return <ArticleContent content={content} locale={locale} />;\n    case 'function':\n      return content();\n    default:\n      return content;\n  }\n};\n\nexport const Article = ({\n  article,\n  icon,\n  licenseBox,\n  modifier,\n  messages,\n  messageBoxLinks,\n  children,\n  competenceGoals,\n  competenceGoalTypes,\n  copyPageUrlLink,\n  id,\n  locale,\n  notions,\n  printUrl,\n  renderMarkdown,\n  accessMessage,\n  heartButton,\n}: Props) => {\n  const [articleRef, { entry }] = useIntersectionObserver({\n    root: null,\n    rootMargin: '400px',\n    threshold: 0.1,\n  });\n  const [articlePositionRight, setArticlePositionRight] = useState(0);\n  const wrapperRef = useRef<HTMLDivElement>(null);\n\n  const showExplainNotions = entry && entry.isIntersecting;\n\n  useEffect(() => {\n    if (wrapperRef && wrapperRef.current) {\n      const handler = () => {\n        if (wrapperRef && wrapperRef.current) {\n          const offset =\n            wrapperRef.current.getBoundingClientRect().left + wrapperRef.current.getBoundingClientRect().width;\n          setArticlePositionRight(offset);\n        }\n      };\n      handler();\n\n      return resizeObserver(document.body, handler);\n    }\n  }, [wrapperRef]);\n\n  const {\n    title,\n    introduction,\n    published,\n    content,\n    footNotes,\n    copyright: { license: licenseObj, creators, rightsholders, processors },\n  } = article;\n\n  const authors = creators.length || rightsholders.length ? creators : processors;\n\n  return (\n    <div ref={wrapperRef}>\n      <ArticleWrapper modifier={modifier} id={id} ref={articleRef}>\n        <LayoutItem layout=\"center\">\n          {accessMessage && <ArticleAccessMessage message={accessMessage} />}\n\n          {messages.messageBox && (\n            <MSGboxWrapper>\n              <MessageBox links={messageBoxLinks}>{messages.messageBox}</MessageBox>\n            </MSGboxWrapper>\n          )}\n          <ArticleHeaderWrapper competenceGoals={competenceGoals} competenceGoalTypes={competenceGoalTypes}>\n            {heartButton ? <ArticleFavoritesButtonWrapper>{heartButton}</ArticleFavoritesButtonWrapper> : null}\n\n            <ArticleTitle icon={icon} label={messages.label}>\n              {title}\n            </ArticleTitle>\n            <ArticleIntroduction renderMarkdown={renderMarkdown}>{introduction}</ArticleIntroduction>\n          </ArticleHeaderWrapper>\n        </LayoutItem>\n        <LayoutItem layout=\"center\">\n          {notions && showExplainNotions && (\n            <ArticleNotions\n              notions={notions.list}\n              relatedContent={notions.related}\n              buttonOffsetRight={articlePositionRight}\n            />\n          )}\n          {getArticleContent(content, locale)}\n        </LayoutItem>\n\n        <LayoutItem layout=\"center\">\n          {footNotes && footNotes.length > 0 && <ArticleFootNotes footNotes={footNotes} />}\n          <ArticleByline\n            copyPageUrlLink={copyPageUrlLink}\n            authors={authors}\n            suppliers={rightsholders}\n            published={published}\n            license={licenseObj.license}\n            licenseBox={licenseBox}\n            printUrl={printUrl}\n          />\n        </LayoutItem>\n        <LayoutItem layout=\"extend\">{children}</LayoutItem>\n      </ArticleWrapper>\n    </div>\n  );\n};\n\nexport default Article;\n"]} */"));
|
|
116
116
|
var getArticleContent = function getArticleContent(content, locale) {
|
|
117
117
|
switch (_typeof(content)) {
|
|
118
118
|
case 'string':
|
|
@@ -22,7 +22,7 @@ var StyledWrapper = /*#__PURE__*/_styled("nav", {
|
|
|
22
22
|
label: "StyledWrapper"
|
|
23
23
|
})("margin:32px 0 0;.c-tabs--subjects{margin:0;}.c-tabs__list--subjects{margin:0;}.c-tabs__tab--subjects{", mq.range({
|
|
24
24
|
until: breakpoints.tablet
|
|
25
|
-
}), "{margin:0;font-size:12px;padding-left:8px;padding-right:8px;:first-of-type{padding-left:0;}:last-of-type{padding-right:0;}}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FrontpageAllSubjects.tsx"],"names":[],"mappings":"AAUgC","file":"FrontpageAllSubjects.tsx","sourcesContent":["import React, { Fragment } from 'react';\nimport styled from '@emotion/styled';\nimport { useTranslation } from 'react-i18next';\nimport Tabs from '@ndla/tabs';\nimport SafeLink from '@ndla/safelink';\nimport { colors, fonts, mq, breakpoints } from '@ndla/core';\nimport ContentLoader from '../ContentLoader';\nimport { MessageBox } from '../Messages';\nimport { ToggleItem } from '../Filter';\n\nconst StyledWrapper = styled.nav`\n  margin: 32px 0 0;\n  .c-tabs--subjects {\n    margin: 0;\n  }\n  .c-tabs__list--subjects {\n    margin: 0;\n  }\n  .c-tabs__tab--subjects {\n    ${mq.range({ until: breakpoints.tablet })} {\n      margin: 0;\n      font-size: 12px;\n      padding-left: 8px;\n      padding-right: 8px;\n      :first-of-type {\n        padding-left: 0;\n      }\n      :last-of-type {\n        padding-right: 0;\n      }\n    }\n  }\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  margin: 40px 0 0;\n  padding: 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    column-count: 2;\n    column-gap: 20px;\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    column-count: 3;\n    column-gap: 20px;\n  }\n`;\nconst StyledListItem = styled.li`\n  margin-bottom: 0;\n  break-inside: avoid;\n`;\n\nconst StyledLetterItem = styled.span<{ subjectViewType?: string }>`\n  display: block;\n  ${fonts.sizes(30, 1)};\n  font-weight: ${fonts.weight.bold};\n  color: ${colors.brand.primary};\n  margin-bottom: 8px;\n  ${(props) => props.subjectViewType === 'checkbox' && `margin-left:37px;`}\n`;\n\nconst StyledSpacingElement = styled.span`\n  display: block;\n  width: 100%;\n  height: 10px;\n`;\n\nconst StyledLetterSpacing = styled.span`\n  display: block;\n  height: 16px;\n`;\n\nconst MessageBoxWrapper = styled.div`\n  padding-top: 20px;\n`;\n\ntype subjectProps = {\n  name: string;\n  url?: string;\n  path?: string;\n  id?: string;\n};\ntype categoryProps = {\n  type?: string;\n  name?: string;\n  visible?: boolean;\n  message?: string;\n  subjects: subjectProps[];\n};\n\nexport type subjectsProps = {\n  categories: categoryProps[];\n  subjectViewType?: 'link' | 'checkbox';\n  onToggleSubject?: (id: string) => void;\n  onNavigate?: () => void;\n  selectedSubjects?: string[];\n};\n\ntype letterCategories = {\n  letter: string;\n  items: subjectProps[];\n};\n\nconst sortAlphabetically = (subjects: subjectProps[], locale: string = 'nb') => {\n  const subjectsSorted = subjects.sort((a, b) => a.name.localeCompare(b.name, locale));\n  const subjectsLetterCategories: letterCategories[] = [];\n  let previousLetter = '';\n  let letterItems: subjectProps[] = [];\n  subjectsSorted.forEach((subject: subjectProps) => {\n    const currentLetter = subject.name.substr(0, 1);\n    const isNewLetter = currentLetter.localeCompare(previousLetter, locale) === 1;\n    if (isNewLetter && letterItems.length) {\n      subjectsLetterCategories.push({\n        letter: previousLetter,\n        items: letterItems,\n      });\n      letterItems = [];\n    }\n    previousLetter = currentLetter;\n    letterItems.push(subject);\n  });\n  // Add last letter\n  if (previousLetter && letterItems.length) {\n    subjectsLetterCategories.push({\n      letter: previousLetter,\n      items: letterItems,\n    });\n  }\n  return subjectsLetterCategories;\n};\n\nconst renderList = (\n  subjects: subjectProps[],\n  onNavigate?: () => void,\n  onToggleSubject?: subjectsProps['onToggleSubject'],\n  subjectViewType?: subjectsProps['subjectViewType'],\n  selectedSubjects: subjectsProps['selectedSubjects'] = [],\n) => (\n  <StyledList>\n    {sortAlphabetically(subjects).map((letter: any) => {\n      return (\n        <Fragment key={letter.letter}>\n          {letter.items.map((subject: subjectProps, index: number) => (\n            <Fragment key={subject.name}>\n              <StyledListItem>\n                {index === 0 && <StyledLetterItem subjectViewType={subjectViewType}>{letter.letter}</StyledLetterItem>}\n                {subjectViewType === 'checkbox' && subject.id ? (\n                  <ToggleItem\n                    id={subject.id}\n                    value={subject.id}\n                    checked={selectedSubjects.includes(subject.id)}\n                    label={subject.name}\n                    component=\"div\"\n                    onChange={() => {\n                      if (onToggleSubject && subject.id) {\n                        onToggleSubject(subject.id);\n                      }\n                    }}\n                  />\n                ) : (\n                  <>\n                    <SafeLink\n                      onClick={() => {\n                        if (onNavigate) {\n                          onNavigate();\n                        }\n                      }}\n                      to={subject.url || subject.path || ''}>\n                      {subject.name}\n                    </SafeLink>\n                    <StyledSpacingElement />\n                  </>\n                )}\n                {letter.items.length - 1 === index && <StyledLetterSpacing />}\n              </StyledListItem>\n            </Fragment>\n          ))}\n        </Fragment>\n      );\n    })}\n  </StyledList>\n);\n\nconst FrontpageAllSubjects = ({\n  categories,\n  onNavigate,\n  onToggleSubject,\n  subjectViewType,\n  selectedSubjects,\n}: subjectsProps) => {\n  const allSubjects: subjectProps[] = [];\n  const data: any = [];\n  const { t } = useTranslation();\n\n  if (categories.flatMap((c) => c.subjects).length === 0) {\n    return (\n      <StyledWrapper>\n        <ContentLoader width={880} height={270}>\n          <rect x=\"0\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-1\" />\n          <rect x=\"110\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-2\" />\n          <rect x=\"220\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-3\" />\n          <rect x=\"330\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-4\" />\n\n          <rect x=\"0\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-1\" />\n          <rect x=\"300\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-2\" />\n          <rect x=\"600\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-3\" />\n        </ContentLoader>\n      </StyledWrapper>\n    );\n  }\n\n  categories.forEach((category: categoryProps) => {\n    allSubjects.push(...category.subjects);\n    category.visible &&\n      data.push({\n        title: category.name || t(`subjectCategories.${category.type}`),\n        content: (\n          <>\n            {category.message && (\n              <MessageBoxWrapper>\n                <MessageBox>{category.message}</MessageBox>\n              </MessageBoxWrapper>\n            )}\n            {category.name === t('subjectCategories.beta') && (\n              <MessageBoxWrapper>\n                <MessageBox>{t('messageBoxInfo.frontPageBeta')}</MessageBox>\n              </MessageBoxWrapper>\n            )}\n            {category.name === t('subjectCategories.archive') && (\n              <MessageBoxWrapper>\n                <MessageBox>{t('messageBoxInfo.frontPageExpired')}</MessageBox>\n              </MessageBoxWrapper>\n            )}\n            {renderList(category.subjects, onNavigate, onToggleSubject, subjectViewType, selectedSubjects)}\n          </>\n        ),\n      });\n  });\n\n  data.push({\n    title: t('frontpageMenu.allsubjects'),\n    content: renderList(allSubjects, onNavigate, onToggleSubject, subjectViewType, selectedSubjects),\n  });\n\n  return (\n    <StyledWrapper>\n      <Tabs modifier=\"subjects\" tabs={data} />\n    </StyledWrapper>\n  );\n};\n\nexport default FrontpageAllSubjects;\n"]} */"));
|
|
25
|
+
}), "{margin:0;font-size:12px;padding-left:8px;padding-right:8px;:first-of-type{padding-left:0;}:last-of-type{padding-right:0;}}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FrontpageAllSubjects.tsx"],"names":[],"mappings":"AAUgC","file":"FrontpageAllSubjects.tsx","sourcesContent":["import React, { Fragment } from 'react';\nimport styled from '@emotion/styled';\nimport { useTranslation } from 'react-i18next';\nimport Tabs from '@ndla/tabs';\nimport SafeLink from '@ndla/safelink';\nimport { colors, fonts, mq, breakpoints } from '@ndla/core';\nimport ContentLoader from '../ContentLoader';\nimport { MessageBox } from '../Messages';\nimport { ToggleItem } from '../Filter';\n\nconst StyledWrapper = styled.nav`\n  margin: 32px 0 0;\n  .c-tabs--subjects {\n    margin: 0;\n  }\n  .c-tabs__list--subjects {\n    margin: 0;\n  }\n  .c-tabs__tab--subjects {\n    ${mq.range({ until: breakpoints.tablet })} {\n      margin: 0;\n      font-size: 12px;\n      padding-left: 8px;\n      padding-right: 8px;\n      :first-of-type {\n        padding-left: 0;\n      }\n      :last-of-type {\n        padding-right: 0;\n      }\n    }\n  }\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  margin: 40px 0 0;\n  padding: 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    column-count: 2;\n    column-gap: 20px;\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    column-count: 3;\n    column-gap: 20px;\n  }\n`;\nconst StyledListItem = styled.li`\n  margin-bottom: 0;\n  break-inside: avoid;\n`;\n\nconst StyledLetterItem = styled.span<{ subjectViewType?: string }>`\n  display: block;\n  ${fonts.sizes(30, 1)};\n  font-weight: ${fonts.weight.bold};\n  color: ${colors.brand.primary};\n  margin-bottom: 8px;\n  ${(props) => props.subjectViewType === 'checkbox' && `margin-left:37px;`}\n`;\n\nconst StyledSpacingElement = styled.span`\n  display: block;\n  width: 100%;\n  height: 10px;\n`;\n\nconst StyledLetterSpacing = styled.span`\n  display: block;\n  height: 16px;\n`;\n\nconst MessageBoxWrapper = styled.div`\n  padding-top: 20px;\n`;\n\ntype subjectProps = {\n  name: string;\n  path?: string;\n  id?: string;\n};\ntype categoryProps = {\n  type?: string;\n  visible?: boolean;\n  message?: string;\n  subjects: subjectProps[];\n};\n\nexport type subjectsProps = {\n  categories: categoryProps[];\n  subjectViewType?: 'link' | 'checkbox';\n  onToggleSubject?: (id: string) => void;\n  onNavigate?: () => void;\n  selectedSubjects?: string[];\n};\n\ntype letterCategories = {\n  letter: string;\n  items: subjectProps[];\n};\n\nconst sortAlphabetically = (subjects: subjectProps[], locale: string = 'nb') => {\n  const subjectsSorted = subjects.sort((a, b) => a.name.localeCompare(b.name, locale));\n  const subjectsLetterCategories: letterCategories[] = [];\n  let previousLetter = '';\n  let letterItems: subjectProps[] = [];\n  subjectsSorted.forEach((subject: subjectProps) => {\n    const currentLetter = subject.name.substr(0, 1);\n    const isNewLetter = currentLetter.localeCompare(previousLetter, locale) === 1;\n    if (isNewLetter && letterItems.length) {\n      subjectsLetterCategories.push({\n        letter: previousLetter,\n        items: letterItems,\n      });\n      letterItems = [];\n    }\n    previousLetter = currentLetter;\n    letterItems.push(subject);\n  });\n  // Add last letter\n  if (previousLetter && letterItems.length) {\n    subjectsLetterCategories.push({\n      letter: previousLetter,\n      items: letterItems,\n    });\n  }\n  return subjectsLetterCategories;\n};\n\nconst renderList = (\n  subjects: subjectProps[],\n  onNavigate?: () => void,\n  onToggleSubject?: subjectsProps['onToggleSubject'],\n  subjectViewType?: subjectsProps['subjectViewType'],\n  selectedSubjects: subjectsProps['selectedSubjects'] = [],\n) => (\n  <StyledList>\n    {sortAlphabetically(subjects).map((letter: any) => {\n      return (\n        <Fragment key={letter.letter}>\n          {letter.items.map((subject: subjectProps, index: number) => (\n            <Fragment key={subject.name}>\n              <StyledListItem>\n                {index === 0 && <StyledLetterItem subjectViewType={subjectViewType}>{letter.letter}</StyledLetterItem>}\n                {subjectViewType === 'checkbox' && subject.id ? (\n                  <ToggleItem\n                    id={subject.id}\n                    value={subject.id}\n                    checked={selectedSubjects.includes(subject.id)}\n                    label={subject.name}\n                    component=\"div\"\n                    onChange={() => {\n                      if (onToggleSubject && subject.id) {\n                        onToggleSubject(subject.id);\n                      }\n                    }}\n                  />\n                ) : (\n                  <>\n                    <SafeLink\n                      onClick={() => {\n                        if (onNavigate) {\n                          onNavigate();\n                        }\n                      }}\n                      to={subject.path || ''}>\n                      {subject.name}\n                    </SafeLink>\n                    <StyledSpacingElement />\n                  </>\n                )}\n                {letter.items.length - 1 === index && <StyledLetterSpacing />}\n              </StyledListItem>\n            </Fragment>\n          ))}\n        </Fragment>\n      );\n    })}\n  </StyledList>\n);\n\nconst FrontpageAllSubjects = ({\n  categories,\n  onNavigate,\n  onToggleSubject,\n  subjectViewType,\n  selectedSubjects,\n}: subjectsProps) => {\n  const allSubjects: subjectProps[] = [];\n  const data: any = [];\n  const { t } = useTranslation();\n\n  if (categories.flatMap((c) => c.subjects).length === 0) {\n    return (\n      <StyledWrapper>\n        <ContentLoader width={880} height={270}>\n          <rect x=\"0\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-1\" />\n          <rect x=\"110\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-2\" />\n          <rect x=\"220\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-3\" />\n          <rect x=\"330\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-4\" />\n\n          <rect x=\"0\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-1\" />\n          <rect x=\"300\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-2\" />\n          <rect x=\"600\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-3\" />\n        </ContentLoader>\n      </StyledWrapper>\n    );\n  }\n\n  categories.forEach((category: categoryProps) => {\n    allSubjects.push(...category.subjects);\n    category.visible &&\n      data.push({\n        title: t(`subjectCategories.${category.type}`),\n        content: (\n          <>\n            {category.message && (\n              <MessageBoxWrapper>\n                <MessageBox>{category.message}</MessageBox>\n              </MessageBoxWrapper>\n            )}\n            {renderList(category.subjects, onNavigate, onToggleSubject, subjectViewType, selectedSubjects)}\n          </>\n        ),\n      });\n  });\n\n  data.push({\n    title: t('frontpageMenu.allsubjects'),\n    content: renderList(allSubjects, onNavigate, onToggleSubject, subjectViewType, selectedSubjects),\n  });\n\n  return (\n    <StyledWrapper>\n      <Tabs modifier=\"subjects\" tabs={data} />\n    </StyledWrapper>\n  );\n};\n\nexport default FrontpageAllSubjects;\n"]} */"));
|
|
26
26
|
var StyledList = /*#__PURE__*/_styled("ul", {
|
|
27
27
|
target: "e1kk5ejg5",
|
|
28
28
|
label: "StyledList"
|
|
@@ -30,7 +30,7 @@ var StyledList = /*#__PURE__*/_styled("ul", {
|
|
|
30
30
|
from: breakpoints.tablet
|
|
31
31
|
}), "{column-count:2;column-gap:20px;}", mq.range({
|
|
32
32
|
from: breakpoints.tabletWide
|
|
33
|
-
}), "{column-count:3;column-gap:20px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FrontpageAllSubjects.tsx"],"names":[],"mappings":"AAkC4B","file":"FrontpageAllSubjects.tsx","sourcesContent":["import React, { Fragment } from 'react';\nimport styled from '@emotion/styled';\nimport { useTranslation } from 'react-i18next';\nimport Tabs from '@ndla/tabs';\nimport SafeLink from '@ndla/safelink';\nimport { colors, fonts, mq, breakpoints } from '@ndla/core';\nimport ContentLoader from '../ContentLoader';\nimport { MessageBox } from '../Messages';\nimport { ToggleItem } from '../Filter';\n\nconst StyledWrapper = styled.nav`\n  margin: 32px 0 0;\n  .c-tabs--subjects {\n    margin: 0;\n  }\n  .c-tabs__list--subjects {\n    margin: 0;\n  }\n  .c-tabs__tab--subjects {\n    ${mq.range({ until: breakpoints.tablet })} {\n      margin: 0;\n      font-size: 12px;\n      padding-left: 8px;\n      padding-right: 8px;\n      :first-of-type {\n        padding-left: 0;\n      }\n      :last-of-type {\n        padding-right: 0;\n      }\n    }\n  }\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  margin: 40px 0 0;\n  padding: 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    column-count: 2;\n    column-gap: 20px;\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    column-count: 3;\n    column-gap: 20px;\n  }\n`;\nconst StyledListItem = styled.li`\n  margin-bottom: 0;\n  break-inside: avoid;\n`;\n\nconst StyledLetterItem = styled.span<{ subjectViewType?: string }>`\n  display: block;\n  ${fonts.sizes(30, 1)};\n  font-weight: ${fonts.weight.bold};\n  color: ${colors.brand.primary};\n  margin-bottom: 8px;\n  ${(props) => props.subjectViewType === 'checkbox' && `margin-left:37px;`}\n`;\n\nconst StyledSpacingElement = styled.span`\n  display: block;\n  width: 100%;\n  height: 10px;\n`;\n\nconst StyledLetterSpacing = styled.span`\n  display: block;\n  height: 16px;\n`;\n\nconst MessageBoxWrapper = styled.div`\n  padding-top: 20px;\n`;\n\ntype subjectProps = {\n  name: string;\n  url?: string;\n  path?: string;\n  id?: string;\n};\ntype categoryProps = {\n  type?: string;\n  name?: string;\n  visible?: boolean;\n  message?: string;\n  subjects: subjectProps[];\n};\n\nexport type subjectsProps = {\n  categories: categoryProps[];\n  subjectViewType?: 'link' | 'checkbox';\n  onToggleSubject?: (id: string) => void;\n  onNavigate?: () => void;\n  selectedSubjects?: string[];\n};\n\ntype letterCategories = {\n  letter: string;\n  items: subjectProps[];\n};\n\nconst sortAlphabetically = (subjects: subjectProps[], locale: string = 'nb') => {\n  const subjectsSorted = subjects.sort((a, b) => a.name.localeCompare(b.name, locale));\n  const subjectsLetterCategories: letterCategories[] = [];\n  let previousLetter = '';\n  let letterItems: subjectProps[] = [];\n  subjectsSorted.forEach((subject: subjectProps) => {\n    const currentLetter = subject.name.substr(0, 1);\n    const isNewLetter = currentLetter.localeCompare(previousLetter, locale) === 1;\n    if (isNewLetter && letterItems.length) {\n      subjectsLetterCategories.push({\n        letter: previousLetter,\n        items: letterItems,\n      });\n      letterItems = [];\n    }\n    previousLetter = currentLetter;\n    letterItems.push(subject);\n  });\n  // Add last letter\n  if (previousLetter && letterItems.length) {\n    subjectsLetterCategories.push({\n      letter: previousLetter,\n      items: letterItems,\n    });\n  }\n  return subjectsLetterCategories;\n};\n\nconst renderList = (\n  subjects: subjectProps[],\n  onNavigate?: () => void,\n  onToggleSubject?: subjectsProps['onToggleSubject'],\n  subjectViewType?: subjectsProps['subjectViewType'],\n  selectedSubjects: subjectsProps['selectedSubjects'] = [],\n) => (\n  <StyledList>\n    {sortAlphabetically(subjects).map((letter: any) => {\n      return (\n        <Fragment key={letter.letter}>\n          {letter.items.map((subject: subjectProps, index: number) => (\n            <Fragment key={subject.name}>\n              <StyledListItem>\n                {index === 0 && <StyledLetterItem subjectViewType={subjectViewType}>{letter.letter}</StyledLetterItem>}\n                {subjectViewType === 'checkbox' && subject.id ? (\n                  <ToggleItem\n                    id={subject.id}\n                    value={subject.id}\n                    checked={selectedSubjects.includes(subject.id)}\n                    label={subject.name}\n                    component=\"div\"\n                    onChange={() => {\n                      if (onToggleSubject && subject.id) {\n                        onToggleSubject(subject.id);\n                      }\n                    }}\n                  />\n                ) : (\n                  <>\n                    <SafeLink\n                      onClick={() => {\n                        if (onNavigate) {\n                          onNavigate();\n                        }\n                      }}\n                      to={subject.url || subject.path || ''}>\n                      {subject.name}\n                    </SafeLink>\n                    <StyledSpacingElement />\n                  </>\n                )}\n                {letter.items.length - 1 === index && <StyledLetterSpacing />}\n              </StyledListItem>\n            </Fragment>\n          ))}\n        </Fragment>\n      );\n    })}\n  </StyledList>\n);\n\nconst FrontpageAllSubjects = ({\n  categories,\n  onNavigate,\n  onToggleSubject,\n  subjectViewType,\n  selectedSubjects,\n}: subjectsProps) => {\n  const allSubjects: subjectProps[] = [];\n  const data: any = [];\n  const { t } = useTranslation();\n\n  if (categories.flatMap((c) => c.subjects).length === 0) {\n    return (\n      <StyledWrapper>\n        <ContentLoader width={880} height={270}>\n          <rect x=\"0\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-1\" />\n          <rect x=\"110\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-2\" />\n          <rect x=\"220\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-3\" />\n          <rect x=\"330\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-4\" />\n\n          <rect x=\"0\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-1\" />\n          <rect x=\"300\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-2\" />\n          <rect x=\"600\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-3\" />\n        </ContentLoader>\n      </StyledWrapper>\n    );\n  }\n\n  categories.forEach((category: categoryProps) => {\n    allSubjects.push(...category.subjects);\n    category.visible &&\n      data.push({\n        title: category.name || t(`subjectCategories.${category.type}`),\n        content: (\n          <>\n            {category.message && (\n              <MessageBoxWrapper>\n                <MessageBox>{category.message}</MessageBox>\n              </MessageBoxWrapper>\n            )}\n            {category.name === t('subjectCategories.beta') && (\n              <MessageBoxWrapper>\n                <MessageBox>{t('messageBoxInfo.frontPageBeta')}</MessageBox>\n              </MessageBoxWrapper>\n            )}\n            {category.name === t('subjectCategories.archive') && (\n              <MessageBoxWrapper>\n                <MessageBox>{t('messageBoxInfo.frontPageExpired')}</MessageBox>\n              </MessageBoxWrapper>\n            )}\n            {renderList(category.subjects, onNavigate, onToggleSubject, subjectViewType, selectedSubjects)}\n          </>\n        ),\n      });\n  });\n\n  data.push({\n    title: t('frontpageMenu.allsubjects'),\n    content: renderList(allSubjects, onNavigate, onToggleSubject, subjectViewType, selectedSubjects),\n  });\n\n  return (\n    <StyledWrapper>\n      <Tabs modifier=\"subjects\" tabs={data} />\n    </StyledWrapper>\n  );\n};\n\nexport default FrontpageAllSubjects;\n"]} */"));
|
|
33
|
+
}), "{column-count:3;column-gap:20px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FrontpageAllSubjects.tsx"],"names":[],"mappings":"AAkC4B","file":"FrontpageAllSubjects.tsx","sourcesContent":["import React, { Fragment } from 'react';\nimport styled from '@emotion/styled';\nimport { useTranslation } from 'react-i18next';\nimport Tabs from '@ndla/tabs';\nimport SafeLink from '@ndla/safelink';\nimport { colors, fonts, mq, breakpoints } from '@ndla/core';\nimport ContentLoader from '../ContentLoader';\nimport { MessageBox } from '../Messages';\nimport { ToggleItem } from '../Filter';\n\nconst StyledWrapper = styled.nav`\n  margin: 32px 0 0;\n  .c-tabs--subjects {\n    margin: 0;\n  }\n  .c-tabs__list--subjects {\n    margin: 0;\n  }\n  .c-tabs__tab--subjects {\n    ${mq.range({ until: breakpoints.tablet })} {\n      margin: 0;\n      font-size: 12px;\n      padding-left: 8px;\n      padding-right: 8px;\n      :first-of-type {\n        padding-left: 0;\n      }\n      :last-of-type {\n        padding-right: 0;\n      }\n    }\n  }\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  margin: 40px 0 0;\n  padding: 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    column-count: 2;\n    column-gap: 20px;\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    column-count: 3;\n    column-gap: 20px;\n  }\n`;\nconst StyledListItem = styled.li`\n  margin-bottom: 0;\n  break-inside: avoid;\n`;\n\nconst StyledLetterItem = styled.span<{ subjectViewType?: string }>`\n  display: block;\n  ${fonts.sizes(30, 1)};\n  font-weight: ${fonts.weight.bold};\n  color: ${colors.brand.primary};\n  margin-bottom: 8px;\n  ${(props) => props.subjectViewType === 'checkbox' && `margin-left:37px;`}\n`;\n\nconst StyledSpacingElement = styled.span`\n  display: block;\n  width: 100%;\n  height: 10px;\n`;\n\nconst StyledLetterSpacing = styled.span`\n  display: block;\n  height: 16px;\n`;\n\nconst MessageBoxWrapper = styled.div`\n  padding-top: 20px;\n`;\n\ntype subjectProps = {\n  name: string;\n  path?: string;\n  id?: string;\n};\ntype categoryProps = {\n  type?: string;\n  visible?: boolean;\n  message?: string;\n  subjects: subjectProps[];\n};\n\nexport type subjectsProps = {\n  categories: categoryProps[];\n  subjectViewType?: 'link' | 'checkbox';\n  onToggleSubject?: (id: string) => void;\n  onNavigate?: () => void;\n  selectedSubjects?: string[];\n};\n\ntype letterCategories = {\n  letter: string;\n  items: subjectProps[];\n};\n\nconst sortAlphabetically = (subjects: subjectProps[], locale: string = 'nb') => {\n  const subjectsSorted = subjects.sort((a, b) => a.name.localeCompare(b.name, locale));\n  const subjectsLetterCategories: letterCategories[] = [];\n  let previousLetter = '';\n  let letterItems: subjectProps[] = [];\n  subjectsSorted.forEach((subject: subjectProps) => {\n    const currentLetter = subject.name.substr(0, 1);\n    const isNewLetter = currentLetter.localeCompare(previousLetter, locale) === 1;\n    if (isNewLetter && letterItems.length) {\n      subjectsLetterCategories.push({\n        letter: previousLetter,\n        items: letterItems,\n      });\n      letterItems = [];\n    }\n    previousLetter = currentLetter;\n    letterItems.push(subject);\n  });\n  // Add last letter\n  if (previousLetter && letterItems.length) {\n    subjectsLetterCategories.push({\n      letter: previousLetter,\n      items: letterItems,\n    });\n  }\n  return subjectsLetterCategories;\n};\n\nconst renderList = (\n  subjects: subjectProps[],\n  onNavigate?: () => void,\n  onToggleSubject?: subjectsProps['onToggleSubject'],\n  subjectViewType?: subjectsProps['subjectViewType'],\n  selectedSubjects: subjectsProps['selectedSubjects'] = [],\n) => (\n  <StyledList>\n    {sortAlphabetically(subjects).map((letter: any) => {\n      return (\n        <Fragment key={letter.letter}>\n          {letter.items.map((subject: subjectProps, index: number) => (\n            <Fragment key={subject.name}>\n              <StyledListItem>\n                {index === 0 && <StyledLetterItem subjectViewType={subjectViewType}>{letter.letter}</StyledLetterItem>}\n                {subjectViewType === 'checkbox' && subject.id ? (\n                  <ToggleItem\n                    id={subject.id}\n                    value={subject.id}\n                    checked={selectedSubjects.includes(subject.id)}\n                    label={subject.name}\n                    component=\"div\"\n                    onChange={() => {\n                      if (onToggleSubject && subject.id) {\n                        onToggleSubject(subject.id);\n                      }\n                    }}\n                  />\n                ) : (\n                  <>\n                    <SafeLink\n                      onClick={() => {\n                        if (onNavigate) {\n                          onNavigate();\n                        }\n                      }}\n                      to={subject.path || ''}>\n                      {subject.name}\n                    </SafeLink>\n                    <StyledSpacingElement />\n                  </>\n                )}\n                {letter.items.length - 1 === index && <StyledLetterSpacing />}\n              </StyledListItem>\n            </Fragment>\n          ))}\n        </Fragment>\n      );\n    })}\n  </StyledList>\n);\n\nconst FrontpageAllSubjects = ({\n  categories,\n  onNavigate,\n  onToggleSubject,\n  subjectViewType,\n  selectedSubjects,\n}: subjectsProps) => {\n  const allSubjects: subjectProps[] = [];\n  const data: any = [];\n  const { t } = useTranslation();\n\n  if (categories.flatMap((c) => c.subjects).length === 0) {\n    return (\n      <StyledWrapper>\n        <ContentLoader width={880} height={270}>\n          <rect x=\"0\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-1\" />\n          <rect x=\"110\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-2\" />\n          <rect x=\"220\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-3\" />\n          <rect x=\"330\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-4\" />\n\n          <rect x=\"0\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-1\" />\n          <rect x=\"300\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-2\" />\n          <rect x=\"600\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-3\" />\n        </ContentLoader>\n      </StyledWrapper>\n    );\n  }\n\n  categories.forEach((category: categoryProps) => {\n    allSubjects.push(...category.subjects);\n    category.visible &&\n      data.push({\n        title: t(`subjectCategories.${category.type}`),\n        content: (\n          <>\n            {category.message && (\n              <MessageBoxWrapper>\n                <MessageBox>{category.message}</MessageBox>\n              </MessageBoxWrapper>\n            )}\n            {renderList(category.subjects, onNavigate, onToggleSubject, subjectViewType, selectedSubjects)}\n          </>\n        ),\n      });\n  });\n\n  data.push({\n    title: t('frontpageMenu.allsubjects'),\n    content: renderList(allSubjects, onNavigate, onToggleSubject, subjectViewType, selectedSubjects),\n  });\n\n  return (\n    <StyledWrapper>\n      <Tabs modifier=\"subjects\" tabs={data} />\n    </StyledWrapper>\n  );\n};\n\nexport default FrontpageAllSubjects;\n"]} */"));
|
|
34
34
|
var StyledListItem = /*#__PURE__*/_styled("li", {
|
|
35
35
|
target: "e1kk5ejg4",
|
|
36
36
|
label: "StyledListItem"
|
|
@@ -40,7 +40,7 @@ var StyledListItem = /*#__PURE__*/_styled("li", {
|
|
|
40
40
|
} : {
|
|
41
41
|
name: "19qqojn",
|
|
42
42
|
styles: "margin-bottom:0;break-inside:avoid",
|
|
43
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FrontpageAllSubjects.tsx"],"names":[],"mappings":"AA+CgC","file":"FrontpageAllSubjects.tsx","sourcesContent":["import React, { Fragment } from 'react';\nimport styled from '@emotion/styled';\nimport { useTranslation } from 'react-i18next';\nimport Tabs from '@ndla/tabs';\nimport SafeLink from '@ndla/safelink';\nimport { colors, fonts, mq, breakpoints } from '@ndla/core';\nimport ContentLoader from '../ContentLoader';\nimport { MessageBox } from '../Messages';\nimport { ToggleItem } from '../Filter';\n\nconst StyledWrapper = styled.nav`\n  margin: 32px 0 0;\n  .c-tabs--subjects {\n    margin: 0;\n  }\n  .c-tabs__list--subjects {\n    margin: 0;\n  }\n  .c-tabs__tab--subjects {\n    ${mq.range({ until: breakpoints.tablet })} {\n      margin: 0;\n      font-size: 12px;\n      padding-left: 8px;\n      padding-right: 8px;\n      :first-of-type {\n        padding-left: 0;\n      }\n      :last-of-type {\n        padding-right: 0;\n      }\n    }\n  }\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  margin: 40px 0 0;\n  padding: 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    column-count: 2;\n    column-gap: 20px;\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    column-count: 3;\n    column-gap: 20px;\n  }\n`;\nconst StyledListItem = styled.li`\n  margin-bottom: 0;\n  break-inside: avoid;\n`;\n\nconst StyledLetterItem = styled.span<{ subjectViewType?: string }>`\n  display: block;\n  ${fonts.sizes(30, 1)};\n  font-weight: ${fonts.weight.bold};\n  color: ${colors.brand.primary};\n  margin-bottom: 8px;\n  ${(props) => props.subjectViewType === 'checkbox' && `margin-left:37px;`}\n`;\n\nconst StyledSpacingElement = styled.span`\n  display: block;\n  width: 100%;\n  height: 10px;\n`;\n\nconst StyledLetterSpacing = styled.span`\n  display: block;\n  height: 16px;\n`;\n\nconst MessageBoxWrapper = styled.div`\n  padding-top: 20px;\n`;\n\ntype subjectProps = {\n  name: string;\n  url?: string;\n  path?: string;\n  id?: string;\n};\ntype categoryProps = {\n  type?: string;\n  name?: string;\n  visible?: boolean;\n  message?: string;\n  subjects: subjectProps[];\n};\n\nexport type subjectsProps = {\n  categories: categoryProps[];\n  subjectViewType?: 'link' | 'checkbox';\n  onToggleSubject?: (id: string) => void;\n  onNavigate?: () => void;\n  selectedSubjects?: string[];\n};\n\ntype letterCategories = {\n  letter: string;\n  items: subjectProps[];\n};\n\nconst sortAlphabetically = (subjects: subjectProps[], locale: string = 'nb') => {\n  const subjectsSorted = subjects.sort((a, b) => a.name.localeCompare(b.name, locale));\n  const subjectsLetterCategories: letterCategories[] = [];\n  let previousLetter = '';\n  let letterItems: subjectProps[] = [];\n  subjectsSorted.forEach((subject: subjectProps) => {\n    const currentLetter = subject.name.substr(0, 1);\n    const isNewLetter = currentLetter.localeCompare(previousLetter, locale) === 1;\n    if (isNewLetter && letterItems.length) {\n      subjectsLetterCategories.push({\n        letter: previousLetter,\n        items: letterItems,\n      });\n      letterItems = [];\n    }\n    previousLetter = currentLetter;\n    letterItems.push(subject);\n  });\n  // Add last letter\n  if (previousLetter && letterItems.length) {\n    subjectsLetterCategories.push({\n      letter: previousLetter,\n      items: letterItems,\n    });\n  }\n  return subjectsLetterCategories;\n};\n\nconst renderList = (\n  subjects: subjectProps[],\n  onNavigate?: () => void,\n  onToggleSubject?: subjectsProps['onToggleSubject'],\n  subjectViewType?: subjectsProps['subjectViewType'],\n  selectedSubjects: subjectsProps['selectedSubjects'] = [],\n) => (\n  <StyledList>\n    {sortAlphabetically(subjects).map((letter: any) => {\n      return (\n        <Fragment key={letter.letter}>\n          {letter.items.map((subject: subjectProps, index: number) => (\n            <Fragment key={subject.name}>\n              <StyledListItem>\n                {index === 0 && <StyledLetterItem subjectViewType={subjectViewType}>{letter.letter}</StyledLetterItem>}\n                {subjectViewType === 'checkbox' && subject.id ? (\n                  <ToggleItem\n                    id={subject.id}\n                    value={subject.id}\n                    checked={selectedSubjects.includes(subject.id)}\n                    label={subject.name}\n                    component=\"div\"\n                    onChange={() => {\n                      if (onToggleSubject && subject.id) {\n                        onToggleSubject(subject.id);\n                      }\n                    }}\n                  />\n                ) : (\n                  <>\n                    <SafeLink\n                      onClick={() => {\n                        if (onNavigate) {\n                          onNavigate();\n                        }\n                      }}\n                      to={subject.url || subject.path || ''}>\n                      {subject.name}\n                    </SafeLink>\n                    <StyledSpacingElement />\n                  </>\n                )}\n                {letter.items.length - 1 === index && <StyledLetterSpacing />}\n              </StyledListItem>\n            </Fragment>\n          ))}\n        </Fragment>\n      );\n    })}\n  </StyledList>\n);\n\nconst FrontpageAllSubjects = ({\n  categories,\n  onNavigate,\n  onToggleSubject,\n  subjectViewType,\n  selectedSubjects,\n}: subjectsProps) => {\n  const allSubjects: subjectProps[] = [];\n  const data: any = [];\n  const { t } = useTranslation();\n\n  if (categories.flatMap((c) => c.subjects).length === 0) {\n    return (\n      <StyledWrapper>\n        <ContentLoader width={880} height={270}>\n          <rect x=\"0\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-1\" />\n          <rect x=\"110\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-2\" />\n          <rect x=\"220\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-3\" />\n          <rect x=\"330\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-4\" />\n\n          <rect x=\"0\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-1\" />\n          <rect x=\"300\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-2\" />\n          <rect x=\"600\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-3\" />\n        </ContentLoader>\n      </StyledWrapper>\n    );\n  }\n\n  categories.forEach((category: categoryProps) => {\n    allSubjects.push(...category.subjects);\n    category.visible &&\n      data.push({\n        title: category.name || t(`subjectCategories.${category.type}`),\n        content: (\n          <>\n            {category.message && (\n              <MessageBoxWrapper>\n                <MessageBox>{category.message}</MessageBox>\n              </MessageBoxWrapper>\n            )}\n            {category.name === t('subjectCategories.beta') && (\n              <MessageBoxWrapper>\n                <MessageBox>{t('messageBoxInfo.frontPageBeta')}</MessageBox>\n              </MessageBoxWrapper>\n            )}\n            {category.name === t('subjectCategories.archive') && (\n              <MessageBoxWrapper>\n                <MessageBox>{t('messageBoxInfo.frontPageExpired')}</MessageBox>\n              </MessageBoxWrapper>\n            )}\n            {renderList(category.subjects, onNavigate, onToggleSubject, subjectViewType, selectedSubjects)}\n          </>\n        ),\n      });\n  });\n\n  data.push({\n    title: t('frontpageMenu.allsubjects'),\n    content: renderList(allSubjects, onNavigate, onToggleSubject, subjectViewType, selectedSubjects),\n  });\n\n  return (\n    <StyledWrapper>\n      <Tabs modifier=\"subjects\" tabs={data} />\n    </StyledWrapper>\n  );\n};\n\nexport default FrontpageAllSubjects;\n"]} */",
|
|
43
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FrontpageAllSubjects.tsx"],"names":[],"mappings":"AA+CgC","file":"FrontpageAllSubjects.tsx","sourcesContent":["import React, { Fragment } from 'react';\nimport styled from '@emotion/styled';\nimport { useTranslation } from 'react-i18next';\nimport Tabs from '@ndla/tabs';\nimport SafeLink from '@ndla/safelink';\nimport { colors, fonts, mq, breakpoints } from '@ndla/core';\nimport ContentLoader from '../ContentLoader';\nimport { MessageBox } from '../Messages';\nimport { ToggleItem } from '../Filter';\n\nconst StyledWrapper = styled.nav`\n  margin: 32px 0 0;\n  .c-tabs--subjects {\n    margin: 0;\n  }\n  .c-tabs__list--subjects {\n    margin: 0;\n  }\n  .c-tabs__tab--subjects {\n    ${mq.range({ until: breakpoints.tablet })} {\n      margin: 0;\n      font-size: 12px;\n      padding-left: 8px;\n      padding-right: 8px;\n      :first-of-type {\n        padding-left: 0;\n      }\n      :last-of-type {\n        padding-right: 0;\n      }\n    }\n  }\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  margin: 40px 0 0;\n  padding: 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    column-count: 2;\n    column-gap: 20px;\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    column-count: 3;\n    column-gap: 20px;\n  }\n`;\nconst StyledListItem = styled.li`\n  margin-bottom: 0;\n  break-inside: avoid;\n`;\n\nconst StyledLetterItem = styled.span<{ subjectViewType?: string }>`\n  display: block;\n  ${fonts.sizes(30, 1)};\n  font-weight: ${fonts.weight.bold};\n  color: ${colors.brand.primary};\n  margin-bottom: 8px;\n  ${(props) => props.subjectViewType === 'checkbox' && `margin-left:37px;`}\n`;\n\nconst StyledSpacingElement = styled.span`\n  display: block;\n  width: 100%;\n  height: 10px;\n`;\n\nconst StyledLetterSpacing = styled.span`\n  display: block;\n  height: 16px;\n`;\n\nconst MessageBoxWrapper = styled.div`\n  padding-top: 20px;\n`;\n\ntype subjectProps = {\n  name: string;\n  path?: string;\n  id?: string;\n};\ntype categoryProps = {\n  type?: string;\n  visible?: boolean;\n  message?: string;\n  subjects: subjectProps[];\n};\n\nexport type subjectsProps = {\n  categories: categoryProps[];\n  subjectViewType?: 'link' | 'checkbox';\n  onToggleSubject?: (id: string) => void;\n  onNavigate?: () => void;\n  selectedSubjects?: string[];\n};\n\ntype letterCategories = {\n  letter: string;\n  items: subjectProps[];\n};\n\nconst sortAlphabetically = (subjects: subjectProps[], locale: string = 'nb') => {\n  const subjectsSorted = subjects.sort((a, b) => a.name.localeCompare(b.name, locale));\n  const subjectsLetterCategories: letterCategories[] = [];\n  let previousLetter = '';\n  let letterItems: subjectProps[] = [];\n  subjectsSorted.forEach((subject: subjectProps) => {\n    const currentLetter = subject.name.substr(0, 1);\n    const isNewLetter = currentLetter.localeCompare(previousLetter, locale) === 1;\n    if (isNewLetter && letterItems.length) {\n      subjectsLetterCategories.push({\n        letter: previousLetter,\n        items: letterItems,\n      });\n      letterItems = [];\n    }\n    previousLetter = currentLetter;\n    letterItems.push(subject);\n  });\n  // Add last letter\n  if (previousLetter && letterItems.length) {\n    subjectsLetterCategories.push({\n      letter: previousLetter,\n      items: letterItems,\n    });\n  }\n  return subjectsLetterCategories;\n};\n\nconst renderList = (\n  subjects: subjectProps[],\n  onNavigate?: () => void,\n  onToggleSubject?: subjectsProps['onToggleSubject'],\n  subjectViewType?: subjectsProps['subjectViewType'],\n  selectedSubjects: subjectsProps['selectedSubjects'] = [],\n) => (\n  <StyledList>\n    {sortAlphabetically(subjects).map((letter: any) => {\n      return (\n        <Fragment key={letter.letter}>\n          {letter.items.map((subject: subjectProps, index: number) => (\n            <Fragment key={subject.name}>\n              <StyledListItem>\n                {index === 0 && <StyledLetterItem subjectViewType={subjectViewType}>{letter.letter}</StyledLetterItem>}\n                {subjectViewType === 'checkbox' && subject.id ? (\n                  <ToggleItem\n                    id={subject.id}\n                    value={subject.id}\n                    checked={selectedSubjects.includes(subject.id)}\n                    label={subject.name}\n                    component=\"div\"\n                    onChange={() => {\n                      if (onToggleSubject && subject.id) {\n                        onToggleSubject(subject.id);\n                      }\n                    }}\n                  />\n                ) : (\n                  <>\n                    <SafeLink\n                      onClick={() => {\n                        if (onNavigate) {\n                          onNavigate();\n                        }\n                      }}\n                      to={subject.path || ''}>\n                      {subject.name}\n                    </SafeLink>\n                    <StyledSpacingElement />\n                  </>\n                )}\n                {letter.items.length - 1 === index && <StyledLetterSpacing />}\n              </StyledListItem>\n            </Fragment>\n          ))}\n        </Fragment>\n      );\n    })}\n  </StyledList>\n);\n\nconst FrontpageAllSubjects = ({\n  categories,\n  onNavigate,\n  onToggleSubject,\n  subjectViewType,\n  selectedSubjects,\n}: subjectsProps) => {\n  const allSubjects: subjectProps[] = [];\n  const data: any = [];\n  const { t } = useTranslation();\n\n  if (categories.flatMap((c) => c.subjects).length === 0) {\n    return (\n      <StyledWrapper>\n        <ContentLoader width={880} height={270}>\n          <rect x=\"0\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-1\" />\n          <rect x=\"110\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-2\" />\n          <rect x=\"220\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-3\" />\n          <rect x=\"330\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-4\" />\n\n          <rect x=\"0\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-1\" />\n          <rect x=\"300\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-2\" />\n          <rect x=\"600\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-3\" />\n        </ContentLoader>\n      </StyledWrapper>\n    );\n  }\n\n  categories.forEach((category: categoryProps) => {\n    allSubjects.push(...category.subjects);\n    category.visible &&\n      data.push({\n        title: t(`subjectCategories.${category.type}`),\n        content: (\n          <>\n            {category.message && (\n              <MessageBoxWrapper>\n                <MessageBox>{category.message}</MessageBox>\n              </MessageBoxWrapper>\n            )}\n            {renderList(category.subjects, onNavigate, onToggleSubject, subjectViewType, selectedSubjects)}\n          </>\n        ),\n      });\n  });\n\n  data.push({\n    title: t('frontpageMenu.allsubjects'),\n    content: renderList(allSubjects, onNavigate, onToggleSubject, subjectViewType, selectedSubjects),\n  });\n\n  return (\n    <StyledWrapper>\n      <Tabs modifier=\"subjects\" tabs={data} />\n    </StyledWrapper>\n  );\n};\n\nexport default FrontpageAllSubjects;\n"]} */",
|
|
44
44
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
45
45
|
});
|
|
46
46
|
var StyledLetterItem = /*#__PURE__*/_styled("span", {
|
|
@@ -48,7 +48,7 @@ var StyledLetterItem = /*#__PURE__*/_styled("span", {
|
|
|
48
48
|
label: "StyledLetterItem"
|
|
49
49
|
})("display:block;", fonts.sizes(30, 1), ";font-weight:", fonts.weight.bold, ";color:", colors.brand.primary, ";margin-bottom:8px;", function (props) {
|
|
50
50
|
return props.subjectViewType === 'checkbox' && "margin-left:37px;";
|
|
51
|
-
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FrontpageAllSubjects.tsx"],"names":[],"mappings":"AAoDkE","file":"FrontpageAllSubjects.tsx","sourcesContent":["import React, { Fragment } from 'react';\nimport styled from '@emotion/styled';\nimport { useTranslation } from 'react-i18next';\nimport Tabs from '@ndla/tabs';\nimport SafeLink from '@ndla/safelink';\nimport { colors, fonts, mq, breakpoints } from '@ndla/core';\nimport ContentLoader from '../ContentLoader';\nimport { MessageBox } from '../Messages';\nimport { ToggleItem } from '../Filter';\n\nconst StyledWrapper = styled.nav`\n  margin: 32px 0 0;\n  .c-tabs--subjects {\n    margin: 0;\n  }\n  .c-tabs__list--subjects {\n    margin: 0;\n  }\n  .c-tabs__tab--subjects {\n    ${mq.range({ until: breakpoints.tablet })} {\n      margin: 0;\n      font-size: 12px;\n      padding-left: 8px;\n      padding-right: 8px;\n      :first-of-type {\n        padding-left: 0;\n      }\n      :last-of-type {\n        padding-right: 0;\n      }\n    }\n  }\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  margin: 40px 0 0;\n  padding: 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    column-count: 2;\n    column-gap: 20px;\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    column-count: 3;\n    column-gap: 20px;\n  }\n`;\nconst StyledListItem = styled.li`\n  margin-bottom: 0;\n  break-inside: avoid;\n`;\n\nconst StyledLetterItem = styled.span<{ subjectViewType?: string }>`\n  display: block;\n  ${fonts.sizes(30, 1)};\n  font-weight: ${fonts.weight.bold};\n  color: ${colors.brand.primary};\n  margin-bottom: 8px;\n  ${(props) => props.subjectViewType === 'checkbox' && `margin-left:37px;`}\n`;\n\nconst StyledSpacingElement = styled.span`\n  display: block;\n  width: 100%;\n  height: 10px;\n`;\n\nconst StyledLetterSpacing = styled.span`\n  display: block;\n  height: 16px;\n`;\n\nconst MessageBoxWrapper = styled.div`\n  padding-top: 20px;\n`;\n\ntype subjectProps = {\n  name: string;\n  url?: string;\n  path?: string;\n  id?: string;\n};\ntype categoryProps = {\n  type?: string;\n  name?: string;\n  visible?: boolean;\n  message?: string;\n  subjects: subjectProps[];\n};\n\nexport type subjectsProps = {\n  categories: categoryProps[];\n  subjectViewType?: 'link' | 'checkbox';\n  onToggleSubject?: (id: string) => void;\n  onNavigate?: () => void;\n  selectedSubjects?: string[];\n};\n\ntype letterCategories = {\n  letter: string;\n  items: subjectProps[];\n};\n\nconst sortAlphabetically = (subjects: subjectProps[], locale: string = 'nb') => {\n  const subjectsSorted = subjects.sort((a, b) => a.name.localeCompare(b.name, locale));\n  const subjectsLetterCategories: letterCategories[] = [];\n  let previousLetter = '';\n  let letterItems: subjectProps[] = [];\n  subjectsSorted.forEach((subject: subjectProps) => {\n    const currentLetter = subject.name.substr(0, 1);\n    const isNewLetter = currentLetter.localeCompare(previousLetter, locale) === 1;\n    if (isNewLetter && letterItems.length) {\n      subjectsLetterCategories.push({\n        letter: previousLetter,\n        items: letterItems,\n      });\n      letterItems = [];\n    }\n    previousLetter = currentLetter;\n    letterItems.push(subject);\n  });\n  // Add last letter\n  if (previousLetter && letterItems.length) {\n    subjectsLetterCategories.push({\n      letter: previousLetter,\n      items: letterItems,\n    });\n  }\n  return subjectsLetterCategories;\n};\n\nconst renderList = (\n  subjects: subjectProps[],\n  onNavigate?: () => void,\n  onToggleSubject?: subjectsProps['onToggleSubject'],\n  subjectViewType?: subjectsProps['subjectViewType'],\n  selectedSubjects: subjectsProps['selectedSubjects'] = [],\n) => (\n  <StyledList>\n    {sortAlphabetically(subjects).map((letter: any) => {\n      return (\n        <Fragment key={letter.letter}>\n          {letter.items.map((subject: subjectProps, index: number) => (\n            <Fragment key={subject.name}>\n              <StyledListItem>\n                {index === 0 && <StyledLetterItem subjectViewType={subjectViewType}>{letter.letter}</StyledLetterItem>}\n                {subjectViewType === 'checkbox' && subject.id ? (\n                  <ToggleItem\n                    id={subject.id}\n                    value={subject.id}\n                    checked={selectedSubjects.includes(subject.id)}\n                    label={subject.name}\n                    component=\"div\"\n                    onChange={() => {\n                      if (onToggleSubject && subject.id) {\n                        onToggleSubject(subject.id);\n                      }\n                    }}\n                  />\n                ) : (\n                  <>\n                    <SafeLink\n                      onClick={() => {\n                        if (onNavigate) {\n                          onNavigate();\n                        }\n                      }}\n                      to={subject.url || subject.path || ''}>\n                      {subject.name}\n                    </SafeLink>\n                    <StyledSpacingElement />\n                  </>\n                )}\n                {letter.items.length - 1 === index && <StyledLetterSpacing />}\n              </StyledListItem>\n            </Fragment>\n          ))}\n        </Fragment>\n      );\n    })}\n  </StyledList>\n);\n\nconst FrontpageAllSubjects = ({\n  categories,\n  onNavigate,\n  onToggleSubject,\n  subjectViewType,\n  selectedSubjects,\n}: subjectsProps) => {\n  const allSubjects: subjectProps[] = [];\n  const data: any = [];\n  const { t } = useTranslation();\n\n  if (categories.flatMap((c) => c.subjects).length === 0) {\n    return (\n      <StyledWrapper>\n        <ContentLoader width={880} height={270}>\n          <rect x=\"0\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-1\" />\n          <rect x=\"110\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-2\" />\n          <rect x=\"220\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-3\" />\n          <rect x=\"330\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-4\" />\n\n          <rect x=\"0\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-1\" />\n          <rect x=\"300\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-2\" />\n          <rect x=\"600\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-3\" />\n        </ContentLoader>\n      </StyledWrapper>\n    );\n  }\n\n  categories.forEach((category: categoryProps) => {\n    allSubjects.push(...category.subjects);\n    category.visible &&\n      data.push({\n        title: category.name || t(`subjectCategories.${category.type}`),\n        content: (\n          <>\n            {category.message && (\n              <MessageBoxWrapper>\n                <MessageBox>{category.message}</MessageBox>\n              </MessageBoxWrapper>\n            )}\n            {category.name === t('subjectCategories.beta') && (\n              <MessageBoxWrapper>\n                <MessageBox>{t('messageBoxInfo.frontPageBeta')}</MessageBox>\n              </MessageBoxWrapper>\n            )}\n            {category.name === t('subjectCategories.archive') && (\n              <MessageBoxWrapper>\n                <MessageBox>{t('messageBoxInfo.frontPageExpired')}</MessageBox>\n              </MessageBoxWrapper>\n            )}\n            {renderList(category.subjects, onNavigate, onToggleSubject, subjectViewType, selectedSubjects)}\n          </>\n        ),\n      });\n  });\n\n  data.push({\n    title: t('frontpageMenu.allsubjects'),\n    content: renderList(allSubjects, onNavigate, onToggleSubject, subjectViewType, selectedSubjects),\n  });\n\n  return (\n    <StyledWrapper>\n      <Tabs modifier=\"subjects\" tabs={data} />\n    </StyledWrapper>\n  );\n};\n\nexport default FrontpageAllSubjects;\n"]} */"));
|
|
51
|
+
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FrontpageAllSubjects.tsx"],"names":[],"mappings":"AAoDkE","file":"FrontpageAllSubjects.tsx","sourcesContent":["import React, { Fragment } from 'react';\nimport styled from '@emotion/styled';\nimport { useTranslation } from 'react-i18next';\nimport Tabs from '@ndla/tabs';\nimport SafeLink from '@ndla/safelink';\nimport { colors, fonts, mq, breakpoints } from '@ndla/core';\nimport ContentLoader from '../ContentLoader';\nimport { MessageBox } from '../Messages';\nimport { ToggleItem } from '../Filter';\n\nconst StyledWrapper = styled.nav`\n  margin: 32px 0 0;\n  .c-tabs--subjects {\n    margin: 0;\n  }\n  .c-tabs__list--subjects {\n    margin: 0;\n  }\n  .c-tabs__tab--subjects {\n    ${mq.range({ until: breakpoints.tablet })} {\n      margin: 0;\n      font-size: 12px;\n      padding-left: 8px;\n      padding-right: 8px;\n      :first-of-type {\n        padding-left: 0;\n      }\n      :last-of-type {\n        padding-right: 0;\n      }\n    }\n  }\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  margin: 40px 0 0;\n  padding: 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    column-count: 2;\n    column-gap: 20px;\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    column-count: 3;\n    column-gap: 20px;\n  }\n`;\nconst StyledListItem = styled.li`\n  margin-bottom: 0;\n  break-inside: avoid;\n`;\n\nconst StyledLetterItem = styled.span<{ subjectViewType?: string }>`\n  display: block;\n  ${fonts.sizes(30, 1)};\n  font-weight: ${fonts.weight.bold};\n  color: ${colors.brand.primary};\n  margin-bottom: 8px;\n  ${(props) => props.subjectViewType === 'checkbox' && `margin-left:37px;`}\n`;\n\nconst StyledSpacingElement = styled.span`\n  display: block;\n  width: 100%;\n  height: 10px;\n`;\n\nconst StyledLetterSpacing = styled.span`\n  display: block;\n  height: 16px;\n`;\n\nconst MessageBoxWrapper = styled.div`\n  padding-top: 20px;\n`;\n\ntype subjectProps = {\n  name: string;\n  path?: string;\n  id?: string;\n};\ntype categoryProps = {\n  type?: string;\n  visible?: boolean;\n  message?: string;\n  subjects: subjectProps[];\n};\n\nexport type subjectsProps = {\n  categories: categoryProps[];\n  subjectViewType?: 'link' | 'checkbox';\n  onToggleSubject?: (id: string) => void;\n  onNavigate?: () => void;\n  selectedSubjects?: string[];\n};\n\ntype letterCategories = {\n  letter: string;\n  items: subjectProps[];\n};\n\nconst sortAlphabetically = (subjects: subjectProps[], locale: string = 'nb') => {\n  const subjectsSorted = subjects.sort((a, b) => a.name.localeCompare(b.name, locale));\n  const subjectsLetterCategories: letterCategories[] = [];\n  let previousLetter = '';\n  let letterItems: subjectProps[] = [];\n  subjectsSorted.forEach((subject: subjectProps) => {\n    const currentLetter = subject.name.substr(0, 1);\n    const isNewLetter = currentLetter.localeCompare(previousLetter, locale) === 1;\n    if (isNewLetter && letterItems.length) {\n      subjectsLetterCategories.push({\n        letter: previousLetter,\n        items: letterItems,\n      });\n      letterItems = [];\n    }\n    previousLetter = currentLetter;\n    letterItems.push(subject);\n  });\n  // Add last letter\n  if (previousLetter && letterItems.length) {\n    subjectsLetterCategories.push({\n      letter: previousLetter,\n      items: letterItems,\n    });\n  }\n  return subjectsLetterCategories;\n};\n\nconst renderList = (\n  subjects: subjectProps[],\n  onNavigate?: () => void,\n  onToggleSubject?: subjectsProps['onToggleSubject'],\n  subjectViewType?: subjectsProps['subjectViewType'],\n  selectedSubjects: subjectsProps['selectedSubjects'] = [],\n) => (\n  <StyledList>\n    {sortAlphabetically(subjects).map((letter: any) => {\n      return (\n        <Fragment key={letter.letter}>\n          {letter.items.map((subject: subjectProps, index: number) => (\n            <Fragment key={subject.name}>\n              <StyledListItem>\n                {index === 0 && <StyledLetterItem subjectViewType={subjectViewType}>{letter.letter}</StyledLetterItem>}\n                {subjectViewType === 'checkbox' && subject.id ? (\n                  <ToggleItem\n                    id={subject.id}\n                    value={subject.id}\n                    checked={selectedSubjects.includes(subject.id)}\n                    label={subject.name}\n                    component=\"div\"\n                    onChange={() => {\n                      if (onToggleSubject && subject.id) {\n                        onToggleSubject(subject.id);\n                      }\n                    }}\n                  />\n                ) : (\n                  <>\n                    <SafeLink\n                      onClick={() => {\n                        if (onNavigate) {\n                          onNavigate();\n                        }\n                      }}\n                      to={subject.path || ''}>\n                      {subject.name}\n                    </SafeLink>\n                    <StyledSpacingElement />\n                  </>\n                )}\n                {letter.items.length - 1 === index && <StyledLetterSpacing />}\n              </StyledListItem>\n            </Fragment>\n          ))}\n        </Fragment>\n      );\n    })}\n  </StyledList>\n);\n\nconst FrontpageAllSubjects = ({\n  categories,\n  onNavigate,\n  onToggleSubject,\n  subjectViewType,\n  selectedSubjects,\n}: subjectsProps) => {\n  const allSubjects: subjectProps[] = [];\n  const data: any = [];\n  const { t } = useTranslation();\n\n  if (categories.flatMap((c) => c.subjects).length === 0) {\n    return (\n      <StyledWrapper>\n        <ContentLoader width={880} height={270}>\n          <rect x=\"0\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-1\" />\n          <rect x=\"110\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-2\" />\n          <rect x=\"220\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-3\" />\n          <rect x=\"330\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-4\" />\n\n          <rect x=\"0\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-1\" />\n          <rect x=\"300\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-2\" />\n          <rect x=\"600\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-3\" />\n        </ContentLoader>\n      </StyledWrapper>\n    );\n  }\n\n  categories.forEach((category: categoryProps) => {\n    allSubjects.push(...category.subjects);\n    category.visible &&\n      data.push({\n        title: t(`subjectCategories.${category.type}`),\n        content: (\n          <>\n            {category.message && (\n              <MessageBoxWrapper>\n                <MessageBox>{category.message}</MessageBox>\n              </MessageBoxWrapper>\n            )}\n            {renderList(category.subjects, onNavigate, onToggleSubject, subjectViewType, selectedSubjects)}\n          </>\n        ),\n      });\n  });\n\n  data.push({\n    title: t('frontpageMenu.allsubjects'),\n    content: renderList(allSubjects, onNavigate, onToggleSubject, subjectViewType, selectedSubjects),\n  });\n\n  return (\n    <StyledWrapper>\n      <Tabs modifier=\"subjects\" tabs={data} />\n    </StyledWrapper>\n  );\n};\n\nexport default FrontpageAllSubjects;\n"]} */"));
|
|
52
52
|
var StyledSpacingElement = /*#__PURE__*/_styled("span", {
|
|
53
53
|
target: "e1kk5ejg2",
|
|
54
54
|
label: "StyledSpacingElement"
|
|
@@ -58,7 +58,7 @@ var StyledSpacingElement = /*#__PURE__*/_styled("span", {
|
|
|
58
58
|
} : {
|
|
59
59
|
name: "wzb9li",
|
|
60
60
|
styles: "display:block;width:100%;height:10px",
|
|
61
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FrontpageAllSubjects.tsx"],"names":[],"mappings":"AA6DwC","file":"FrontpageAllSubjects.tsx","sourcesContent":["import React, { Fragment } from 'react';\nimport styled from '@emotion/styled';\nimport { useTranslation } from 'react-i18next';\nimport Tabs from '@ndla/tabs';\nimport SafeLink from '@ndla/safelink';\nimport { colors, fonts, mq, breakpoints } from '@ndla/core';\nimport ContentLoader from '../ContentLoader';\nimport { MessageBox } from '../Messages';\nimport { ToggleItem } from '../Filter';\n\nconst StyledWrapper = styled.nav`\n  margin: 32px 0 0;\n  .c-tabs--subjects {\n    margin: 0;\n  }\n  .c-tabs__list--subjects {\n    margin: 0;\n  }\n  .c-tabs__tab--subjects {\n    ${mq.range({ until: breakpoints.tablet })} {\n      margin: 0;\n      font-size: 12px;\n      padding-left: 8px;\n      padding-right: 8px;\n      :first-of-type {\n        padding-left: 0;\n      }\n      :last-of-type {\n        padding-right: 0;\n      }\n    }\n  }\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  margin: 40px 0 0;\n  padding: 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    column-count: 2;\n    column-gap: 20px;\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    column-count: 3;\n    column-gap: 20px;\n  }\n`;\nconst StyledListItem = styled.li`\n  margin-bottom: 0;\n  break-inside: avoid;\n`;\n\nconst StyledLetterItem = styled.span<{ subjectViewType?: string }>`\n  display: block;\n  ${fonts.sizes(30, 1)};\n  font-weight: ${fonts.weight.bold};\n  color: ${colors.brand.primary};\n  margin-bottom: 8px;\n  ${(props) => props.subjectViewType === 'checkbox' && `margin-left:37px;`}\n`;\n\nconst StyledSpacingElement = styled.span`\n  display: block;\n  width: 100%;\n  height: 10px;\n`;\n\nconst StyledLetterSpacing = styled.span`\n  display: block;\n  height: 16px;\n`;\n\nconst MessageBoxWrapper = styled.div`\n  padding-top: 20px;\n`;\n\ntype subjectProps = {\n  name: string;\n  url?: string;\n  path?: string;\n  id?: string;\n};\ntype categoryProps = {\n  type?: string;\n  name?: string;\n  visible?: boolean;\n  message?: string;\n  subjects: subjectProps[];\n};\n\nexport type subjectsProps = {\n  categories: categoryProps[];\n  subjectViewType?: 'link' | 'checkbox';\n  onToggleSubject?: (id: string) => void;\n  onNavigate?: () => void;\n  selectedSubjects?: string[];\n};\n\ntype letterCategories = {\n  letter: string;\n  items: subjectProps[];\n};\n\nconst sortAlphabetically = (subjects: subjectProps[], locale: string = 'nb') => {\n  const subjectsSorted = subjects.sort((a, b) => a.name.localeCompare(b.name, locale));\n  const subjectsLetterCategories: letterCategories[] = [];\n  let previousLetter = '';\n  let letterItems: subjectProps[] = [];\n  subjectsSorted.forEach((subject: subjectProps) => {\n    const currentLetter = subject.name.substr(0, 1);\n    const isNewLetter = currentLetter.localeCompare(previousLetter, locale) === 1;\n    if (isNewLetter && letterItems.length) {\n      subjectsLetterCategories.push({\n        letter: previousLetter,\n        items: letterItems,\n      });\n      letterItems = [];\n    }\n    previousLetter = currentLetter;\n    letterItems.push(subject);\n  });\n  // Add last letter\n  if (previousLetter && letterItems.length) {\n    subjectsLetterCategories.push({\n      letter: previousLetter,\n      items: letterItems,\n    });\n  }\n  return subjectsLetterCategories;\n};\n\nconst renderList = (\n  subjects: subjectProps[],\n  onNavigate?: () => void,\n  onToggleSubject?: subjectsProps['onToggleSubject'],\n  subjectViewType?: subjectsProps['subjectViewType'],\n  selectedSubjects: subjectsProps['selectedSubjects'] = [],\n) => (\n  <StyledList>\n    {sortAlphabetically(subjects).map((letter: any) => {\n      return (\n        <Fragment key={letter.letter}>\n          {letter.items.map((subject: subjectProps, index: number) => (\n            <Fragment key={subject.name}>\n              <StyledListItem>\n                {index === 0 && <StyledLetterItem subjectViewType={subjectViewType}>{letter.letter}</StyledLetterItem>}\n                {subjectViewType === 'checkbox' && subject.id ? (\n                  <ToggleItem\n                    id={subject.id}\n                    value={subject.id}\n                    checked={selectedSubjects.includes(subject.id)}\n                    label={subject.name}\n                    component=\"div\"\n                    onChange={() => {\n                      if (onToggleSubject && subject.id) {\n                        onToggleSubject(subject.id);\n                      }\n                    }}\n                  />\n                ) : (\n                  <>\n                    <SafeLink\n                      onClick={() => {\n                        if (onNavigate) {\n                          onNavigate();\n                        }\n                      }}\n                      to={subject.url || subject.path || ''}>\n                      {subject.name}\n                    </SafeLink>\n                    <StyledSpacingElement />\n                  </>\n                )}\n                {letter.items.length - 1 === index && <StyledLetterSpacing />}\n              </StyledListItem>\n            </Fragment>\n          ))}\n        </Fragment>\n      );\n    })}\n  </StyledList>\n);\n\nconst FrontpageAllSubjects = ({\n  categories,\n  onNavigate,\n  onToggleSubject,\n  subjectViewType,\n  selectedSubjects,\n}: subjectsProps) => {\n  const allSubjects: subjectProps[] = [];\n  const data: any = [];\n  const { t } = useTranslation();\n\n  if (categories.flatMap((c) => c.subjects).length === 0) {\n    return (\n      <StyledWrapper>\n        <ContentLoader width={880} height={270}>\n          <rect x=\"0\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-1\" />\n          <rect x=\"110\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-2\" />\n          <rect x=\"220\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-3\" />\n          <rect x=\"330\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-4\" />\n\n          <rect x=\"0\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-1\" />\n          <rect x=\"300\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-2\" />\n          <rect x=\"600\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-3\" />\n        </ContentLoader>\n      </StyledWrapper>\n    );\n  }\n\n  categories.forEach((category: categoryProps) => {\n    allSubjects.push(...category.subjects);\n    category.visible &&\n      data.push({\n        title: category.name || t(`subjectCategories.${category.type}`),\n        content: (\n          <>\n            {category.message && (\n              <MessageBoxWrapper>\n                <MessageBox>{category.message}</MessageBox>\n              </MessageBoxWrapper>\n            )}\n            {category.name === t('subjectCategories.beta') && (\n              <MessageBoxWrapper>\n                <MessageBox>{t('messageBoxInfo.frontPageBeta')}</MessageBox>\n              </MessageBoxWrapper>\n            )}\n            {category.name === t('subjectCategories.archive') && (\n              <MessageBoxWrapper>\n                <MessageBox>{t('messageBoxInfo.frontPageExpired')}</MessageBox>\n              </MessageBoxWrapper>\n            )}\n            {renderList(category.subjects, onNavigate, onToggleSubject, subjectViewType, selectedSubjects)}\n          </>\n        ),\n      });\n  });\n\n  data.push({\n    title: t('frontpageMenu.allsubjects'),\n    content: renderList(allSubjects, onNavigate, onToggleSubject, subjectViewType, selectedSubjects),\n  });\n\n  return (\n    <StyledWrapper>\n      <Tabs modifier=\"subjects\" tabs={data} />\n    </StyledWrapper>\n  );\n};\n\nexport default FrontpageAllSubjects;\n"]} */",
|
|
61
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FrontpageAllSubjects.tsx"],"names":[],"mappings":"AA6DwC","file":"FrontpageAllSubjects.tsx","sourcesContent":["import React, { Fragment } from 'react';\nimport styled from '@emotion/styled';\nimport { useTranslation } from 'react-i18next';\nimport Tabs from '@ndla/tabs';\nimport SafeLink from '@ndla/safelink';\nimport { colors, fonts, mq, breakpoints } from '@ndla/core';\nimport ContentLoader from '../ContentLoader';\nimport { MessageBox } from '../Messages';\nimport { ToggleItem } from '../Filter';\n\nconst StyledWrapper = styled.nav`\n  margin: 32px 0 0;\n  .c-tabs--subjects {\n    margin: 0;\n  }\n  .c-tabs__list--subjects {\n    margin: 0;\n  }\n  .c-tabs__tab--subjects {\n    ${mq.range({ until: breakpoints.tablet })} {\n      margin: 0;\n      font-size: 12px;\n      padding-left: 8px;\n      padding-right: 8px;\n      :first-of-type {\n        padding-left: 0;\n      }\n      :last-of-type {\n        padding-right: 0;\n      }\n    }\n  }\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  margin: 40px 0 0;\n  padding: 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    column-count: 2;\n    column-gap: 20px;\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    column-count: 3;\n    column-gap: 20px;\n  }\n`;\nconst StyledListItem = styled.li`\n  margin-bottom: 0;\n  break-inside: avoid;\n`;\n\nconst StyledLetterItem = styled.span<{ subjectViewType?: string }>`\n  display: block;\n  ${fonts.sizes(30, 1)};\n  font-weight: ${fonts.weight.bold};\n  color: ${colors.brand.primary};\n  margin-bottom: 8px;\n  ${(props) => props.subjectViewType === 'checkbox' && `margin-left:37px;`}\n`;\n\nconst StyledSpacingElement = styled.span`\n  display: block;\n  width: 100%;\n  height: 10px;\n`;\n\nconst StyledLetterSpacing = styled.span`\n  display: block;\n  height: 16px;\n`;\n\nconst MessageBoxWrapper = styled.div`\n  padding-top: 20px;\n`;\n\ntype subjectProps = {\n  name: string;\n  path?: string;\n  id?: string;\n};\ntype categoryProps = {\n  type?: string;\n  visible?: boolean;\n  message?: string;\n  subjects: subjectProps[];\n};\n\nexport type subjectsProps = {\n  categories: categoryProps[];\n  subjectViewType?: 'link' | 'checkbox';\n  onToggleSubject?: (id: string) => void;\n  onNavigate?: () => void;\n  selectedSubjects?: string[];\n};\n\ntype letterCategories = {\n  letter: string;\n  items: subjectProps[];\n};\n\nconst sortAlphabetically = (subjects: subjectProps[], locale: string = 'nb') => {\n  const subjectsSorted = subjects.sort((a, b) => a.name.localeCompare(b.name, locale));\n  const subjectsLetterCategories: letterCategories[] = [];\n  let previousLetter = '';\n  let letterItems: subjectProps[] = [];\n  subjectsSorted.forEach((subject: subjectProps) => {\n    const currentLetter = subject.name.substr(0, 1);\n    const isNewLetter = currentLetter.localeCompare(previousLetter, locale) === 1;\n    if (isNewLetter && letterItems.length) {\n      subjectsLetterCategories.push({\n        letter: previousLetter,\n        items: letterItems,\n      });\n      letterItems = [];\n    }\n    previousLetter = currentLetter;\n    letterItems.push(subject);\n  });\n  // Add last letter\n  if (previousLetter && letterItems.length) {\n    subjectsLetterCategories.push({\n      letter: previousLetter,\n      items: letterItems,\n    });\n  }\n  return subjectsLetterCategories;\n};\n\nconst renderList = (\n  subjects: subjectProps[],\n  onNavigate?: () => void,\n  onToggleSubject?: subjectsProps['onToggleSubject'],\n  subjectViewType?: subjectsProps['subjectViewType'],\n  selectedSubjects: subjectsProps['selectedSubjects'] = [],\n) => (\n  <StyledList>\n    {sortAlphabetically(subjects).map((letter: any) => {\n      return (\n        <Fragment key={letter.letter}>\n          {letter.items.map((subject: subjectProps, index: number) => (\n            <Fragment key={subject.name}>\n              <StyledListItem>\n                {index === 0 && <StyledLetterItem subjectViewType={subjectViewType}>{letter.letter}</StyledLetterItem>}\n                {subjectViewType === 'checkbox' && subject.id ? (\n                  <ToggleItem\n                    id={subject.id}\n                    value={subject.id}\n                    checked={selectedSubjects.includes(subject.id)}\n                    label={subject.name}\n                    component=\"div\"\n                    onChange={() => {\n                      if (onToggleSubject && subject.id) {\n                        onToggleSubject(subject.id);\n                      }\n                    }}\n                  />\n                ) : (\n                  <>\n                    <SafeLink\n                      onClick={() => {\n                        if (onNavigate) {\n                          onNavigate();\n                        }\n                      }}\n                      to={subject.path || ''}>\n                      {subject.name}\n                    </SafeLink>\n                    <StyledSpacingElement />\n                  </>\n                )}\n                {letter.items.length - 1 === index && <StyledLetterSpacing />}\n              </StyledListItem>\n            </Fragment>\n          ))}\n        </Fragment>\n      );\n    })}\n  </StyledList>\n);\n\nconst FrontpageAllSubjects = ({\n  categories,\n  onNavigate,\n  onToggleSubject,\n  subjectViewType,\n  selectedSubjects,\n}: subjectsProps) => {\n  const allSubjects: subjectProps[] = [];\n  const data: any = [];\n  const { t } = useTranslation();\n\n  if (categories.flatMap((c) => c.subjects).length === 0) {\n    return (\n      <StyledWrapper>\n        <ContentLoader width={880} height={270}>\n          <rect x=\"0\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-1\" />\n          <rect x=\"110\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-2\" />\n          <rect x=\"220\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-3\" />\n          <rect x=\"330\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-4\" />\n\n          <rect x=\"0\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-1\" />\n          <rect x=\"300\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-2\" />\n          <rect x=\"600\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-3\" />\n        </ContentLoader>\n      </StyledWrapper>\n    );\n  }\n\n  categories.forEach((category: categoryProps) => {\n    allSubjects.push(...category.subjects);\n    category.visible &&\n      data.push({\n        title: t(`subjectCategories.${category.type}`),\n        content: (\n          <>\n            {category.message && (\n              <MessageBoxWrapper>\n                <MessageBox>{category.message}</MessageBox>\n              </MessageBoxWrapper>\n            )}\n            {renderList(category.subjects, onNavigate, onToggleSubject, subjectViewType, selectedSubjects)}\n          </>\n        ),\n      });\n  });\n\n  data.push({\n    title: t('frontpageMenu.allsubjects'),\n    content: renderList(allSubjects, onNavigate, onToggleSubject, subjectViewType, selectedSubjects),\n  });\n\n  return (\n    <StyledWrapper>\n      <Tabs modifier=\"subjects\" tabs={data} />\n    </StyledWrapper>\n  );\n};\n\nexport default FrontpageAllSubjects;\n"]} */",
|
|
62
62
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
63
63
|
});
|
|
64
64
|
var StyledLetterSpacing = /*#__PURE__*/_styled("span", {
|
|
@@ -70,7 +70,7 @@ var StyledLetterSpacing = /*#__PURE__*/_styled("span", {
|
|
|
70
70
|
} : {
|
|
71
71
|
name: "197vhxd",
|
|
72
72
|
styles: "display:block;height:16px",
|
|
73
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FrontpageAllSubjects.tsx"],"names":[],"mappings":"AAmEuC","file":"FrontpageAllSubjects.tsx","sourcesContent":["import React, { Fragment } from 'react';\nimport styled from '@emotion/styled';\nimport { useTranslation } from 'react-i18next';\nimport Tabs from '@ndla/tabs';\nimport SafeLink from '@ndla/safelink';\nimport { colors, fonts, mq, breakpoints } from '@ndla/core';\nimport ContentLoader from '../ContentLoader';\nimport { MessageBox } from '../Messages';\nimport { ToggleItem } from '../Filter';\n\nconst StyledWrapper = styled.nav`\n  margin: 32px 0 0;\n  .c-tabs--subjects {\n    margin: 0;\n  }\n  .c-tabs__list--subjects {\n    margin: 0;\n  }\n  .c-tabs__tab--subjects {\n    ${mq.range({ until: breakpoints.tablet })} {\n      margin: 0;\n      font-size: 12px;\n      padding-left: 8px;\n      padding-right: 8px;\n      :first-of-type {\n        padding-left: 0;\n      }\n      :last-of-type {\n        padding-right: 0;\n      }\n    }\n  }\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  margin: 40px 0 0;\n  padding: 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    column-count: 2;\n    column-gap: 20px;\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    column-count: 3;\n    column-gap: 20px;\n  }\n`;\nconst StyledListItem = styled.li`\n  margin-bottom: 0;\n  break-inside: avoid;\n`;\n\nconst StyledLetterItem = styled.span<{ subjectViewType?: string }>`\n  display: block;\n  ${fonts.sizes(30, 1)};\n  font-weight: ${fonts.weight.bold};\n  color: ${colors.brand.primary};\n  margin-bottom: 8px;\n  ${(props) => props.subjectViewType === 'checkbox' && `margin-left:37px;`}\n`;\n\nconst StyledSpacingElement = styled.span`\n  display: block;\n  width: 100%;\n  height: 10px;\n`;\n\nconst StyledLetterSpacing = styled.span`\n  display: block;\n  height: 16px;\n`;\n\nconst MessageBoxWrapper = styled.div`\n  padding-top: 20px;\n`;\n\ntype subjectProps = {\n  name: string;\n  url?: string;\n  path?: string;\n  id?: string;\n};\ntype categoryProps = {\n  type?: string;\n  name?: string;\n  visible?: boolean;\n  message?: string;\n  subjects: subjectProps[];\n};\n\nexport type subjectsProps = {\n  categories: categoryProps[];\n  subjectViewType?: 'link' | 'checkbox';\n  onToggleSubject?: (id: string) => void;\n  onNavigate?: () => void;\n  selectedSubjects?: string[];\n};\n\ntype letterCategories = {\n  letter: string;\n  items: subjectProps[];\n};\n\nconst sortAlphabetically = (subjects: subjectProps[], locale: string = 'nb') => {\n  const subjectsSorted = subjects.sort((a, b) => a.name.localeCompare(b.name, locale));\n  const subjectsLetterCategories: letterCategories[] = [];\n  let previousLetter = '';\n  let letterItems: subjectProps[] = [];\n  subjectsSorted.forEach((subject: subjectProps) => {\n    const currentLetter = subject.name.substr(0, 1);\n    const isNewLetter = currentLetter.localeCompare(previousLetter, locale) === 1;\n    if (isNewLetter && letterItems.length) {\n      subjectsLetterCategories.push({\n        letter: previousLetter,\n        items: letterItems,\n      });\n      letterItems = [];\n    }\n    previousLetter = currentLetter;\n    letterItems.push(subject);\n  });\n  // Add last letter\n  if (previousLetter && letterItems.length) {\n    subjectsLetterCategories.push({\n      letter: previousLetter,\n      items: letterItems,\n    });\n  }\n  return subjectsLetterCategories;\n};\n\nconst renderList = (\n  subjects: subjectProps[],\n  onNavigate?: () => void,\n  onToggleSubject?: subjectsProps['onToggleSubject'],\n  subjectViewType?: subjectsProps['subjectViewType'],\n  selectedSubjects: subjectsProps['selectedSubjects'] = [],\n) => (\n  <StyledList>\n    {sortAlphabetically(subjects).map((letter: any) => {\n      return (\n        <Fragment key={letter.letter}>\n          {letter.items.map((subject: subjectProps, index: number) => (\n            <Fragment key={subject.name}>\n              <StyledListItem>\n                {index === 0 && <StyledLetterItem subjectViewType={subjectViewType}>{letter.letter}</StyledLetterItem>}\n                {subjectViewType === 'checkbox' && subject.id ? (\n                  <ToggleItem\n                    id={subject.id}\n                    value={subject.id}\n                    checked={selectedSubjects.includes(subject.id)}\n                    label={subject.name}\n                    component=\"div\"\n                    onChange={() => {\n                      if (onToggleSubject && subject.id) {\n                        onToggleSubject(subject.id);\n                      }\n                    }}\n                  />\n                ) : (\n                  <>\n                    <SafeLink\n                      onClick={() => {\n                        if (onNavigate) {\n                          onNavigate();\n                        }\n                      }}\n                      to={subject.url || subject.path || ''}>\n                      {subject.name}\n                    </SafeLink>\n                    <StyledSpacingElement />\n                  </>\n                )}\n                {letter.items.length - 1 === index && <StyledLetterSpacing />}\n              </StyledListItem>\n            </Fragment>\n          ))}\n        </Fragment>\n      );\n    })}\n  </StyledList>\n);\n\nconst FrontpageAllSubjects = ({\n  categories,\n  onNavigate,\n  onToggleSubject,\n  subjectViewType,\n  selectedSubjects,\n}: subjectsProps) => {\n  const allSubjects: subjectProps[] = [];\n  const data: any = [];\n  const { t } = useTranslation();\n\n  if (categories.flatMap((c) => c.subjects).length === 0) {\n    return (\n      <StyledWrapper>\n        <ContentLoader width={880} height={270}>\n          <rect x=\"0\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-1\" />\n          <rect x=\"110\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-2\" />\n          <rect x=\"220\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-3\" />\n          <rect x=\"330\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-4\" />\n\n          <rect x=\"0\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-1\" />\n          <rect x=\"300\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-2\" />\n          <rect x=\"600\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-3\" />\n        </ContentLoader>\n      </StyledWrapper>\n    );\n  }\n\n  categories.forEach((category: categoryProps) => {\n    allSubjects.push(...category.subjects);\n    category.visible &&\n      data.push({\n        title: category.name || t(`subjectCategories.${category.type}`),\n        content: (\n          <>\n            {category.message && (\n              <MessageBoxWrapper>\n                <MessageBox>{category.message}</MessageBox>\n              </MessageBoxWrapper>\n            )}\n            {category.name === t('subjectCategories.beta') && (\n              <MessageBoxWrapper>\n                <MessageBox>{t('messageBoxInfo.frontPageBeta')}</MessageBox>\n              </MessageBoxWrapper>\n            )}\n            {category.name === t('subjectCategories.archive') && (\n              <MessageBoxWrapper>\n                <MessageBox>{t('messageBoxInfo.frontPageExpired')}</MessageBox>\n              </MessageBoxWrapper>\n            )}\n            {renderList(category.subjects, onNavigate, onToggleSubject, subjectViewType, selectedSubjects)}\n          </>\n        ),\n      });\n  });\n\n  data.push({\n    title: t('frontpageMenu.allsubjects'),\n    content: renderList(allSubjects, onNavigate, onToggleSubject, subjectViewType, selectedSubjects),\n  });\n\n  return (\n    <StyledWrapper>\n      <Tabs modifier=\"subjects\" tabs={data} />\n    </StyledWrapper>\n  );\n};\n\nexport default FrontpageAllSubjects;\n"]} */",
|
|
73
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FrontpageAllSubjects.tsx"],"names":[],"mappings":"AAmEuC","file":"FrontpageAllSubjects.tsx","sourcesContent":["import React, { Fragment } from 'react';\nimport styled from '@emotion/styled';\nimport { useTranslation } from 'react-i18next';\nimport Tabs from '@ndla/tabs';\nimport SafeLink from '@ndla/safelink';\nimport { colors, fonts, mq, breakpoints } from '@ndla/core';\nimport ContentLoader from '../ContentLoader';\nimport { MessageBox } from '../Messages';\nimport { ToggleItem } from '../Filter';\n\nconst StyledWrapper = styled.nav`\n  margin: 32px 0 0;\n  .c-tabs--subjects {\n    margin: 0;\n  }\n  .c-tabs__list--subjects {\n    margin: 0;\n  }\n  .c-tabs__tab--subjects {\n    ${mq.range({ until: breakpoints.tablet })} {\n      margin: 0;\n      font-size: 12px;\n      padding-left: 8px;\n      padding-right: 8px;\n      :first-of-type {\n        padding-left: 0;\n      }\n      :last-of-type {\n        padding-right: 0;\n      }\n    }\n  }\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  margin: 40px 0 0;\n  padding: 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    column-count: 2;\n    column-gap: 20px;\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    column-count: 3;\n    column-gap: 20px;\n  }\n`;\nconst StyledListItem = styled.li`\n  margin-bottom: 0;\n  break-inside: avoid;\n`;\n\nconst StyledLetterItem = styled.span<{ subjectViewType?: string }>`\n  display: block;\n  ${fonts.sizes(30, 1)};\n  font-weight: ${fonts.weight.bold};\n  color: ${colors.brand.primary};\n  margin-bottom: 8px;\n  ${(props) => props.subjectViewType === 'checkbox' && `margin-left:37px;`}\n`;\n\nconst StyledSpacingElement = styled.span`\n  display: block;\n  width: 100%;\n  height: 10px;\n`;\n\nconst StyledLetterSpacing = styled.span`\n  display: block;\n  height: 16px;\n`;\n\nconst MessageBoxWrapper = styled.div`\n  padding-top: 20px;\n`;\n\ntype subjectProps = {\n  name: string;\n  path?: string;\n  id?: string;\n};\ntype categoryProps = {\n  type?: string;\n  visible?: boolean;\n  message?: string;\n  subjects: subjectProps[];\n};\n\nexport type subjectsProps = {\n  categories: categoryProps[];\n  subjectViewType?: 'link' | 'checkbox';\n  onToggleSubject?: (id: string) => void;\n  onNavigate?: () => void;\n  selectedSubjects?: string[];\n};\n\ntype letterCategories = {\n  letter: string;\n  items: subjectProps[];\n};\n\nconst sortAlphabetically = (subjects: subjectProps[], locale: string = 'nb') => {\n  const subjectsSorted = subjects.sort((a, b) => a.name.localeCompare(b.name, locale));\n  const subjectsLetterCategories: letterCategories[] = [];\n  let previousLetter = '';\n  let letterItems: subjectProps[] = [];\n  subjectsSorted.forEach((subject: subjectProps) => {\n    const currentLetter = subject.name.substr(0, 1);\n    const isNewLetter = currentLetter.localeCompare(previousLetter, locale) === 1;\n    if (isNewLetter && letterItems.length) {\n      subjectsLetterCategories.push({\n        letter: previousLetter,\n        items: letterItems,\n      });\n      letterItems = [];\n    }\n    previousLetter = currentLetter;\n    letterItems.push(subject);\n  });\n  // Add last letter\n  if (previousLetter && letterItems.length) {\n    subjectsLetterCategories.push({\n      letter: previousLetter,\n      items: letterItems,\n    });\n  }\n  return subjectsLetterCategories;\n};\n\nconst renderList = (\n  subjects: subjectProps[],\n  onNavigate?: () => void,\n  onToggleSubject?: subjectsProps['onToggleSubject'],\n  subjectViewType?: subjectsProps['subjectViewType'],\n  selectedSubjects: subjectsProps['selectedSubjects'] = [],\n) => (\n  <StyledList>\n    {sortAlphabetically(subjects).map((letter: any) => {\n      return (\n        <Fragment key={letter.letter}>\n          {letter.items.map((subject: subjectProps, index: number) => (\n            <Fragment key={subject.name}>\n              <StyledListItem>\n                {index === 0 && <StyledLetterItem subjectViewType={subjectViewType}>{letter.letter}</StyledLetterItem>}\n                {subjectViewType === 'checkbox' && subject.id ? (\n                  <ToggleItem\n                    id={subject.id}\n                    value={subject.id}\n                    checked={selectedSubjects.includes(subject.id)}\n                    label={subject.name}\n                    component=\"div\"\n                    onChange={() => {\n                      if (onToggleSubject && subject.id) {\n                        onToggleSubject(subject.id);\n                      }\n                    }}\n                  />\n                ) : (\n                  <>\n                    <SafeLink\n                      onClick={() => {\n                        if (onNavigate) {\n                          onNavigate();\n                        }\n                      }}\n                      to={subject.path || ''}>\n                      {subject.name}\n                    </SafeLink>\n                    <StyledSpacingElement />\n                  </>\n                )}\n                {letter.items.length - 1 === index && <StyledLetterSpacing />}\n              </StyledListItem>\n            </Fragment>\n          ))}\n        </Fragment>\n      );\n    })}\n  </StyledList>\n);\n\nconst FrontpageAllSubjects = ({\n  categories,\n  onNavigate,\n  onToggleSubject,\n  subjectViewType,\n  selectedSubjects,\n}: subjectsProps) => {\n  const allSubjects: subjectProps[] = [];\n  const data: any = [];\n  const { t } = useTranslation();\n\n  if (categories.flatMap((c) => c.subjects).length === 0) {\n    return (\n      <StyledWrapper>\n        <ContentLoader width={880} height={270}>\n          <rect x=\"0\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-1\" />\n          <rect x=\"110\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-2\" />\n          <rect x=\"220\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-3\" />\n          <rect x=\"330\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-4\" />\n\n          <rect x=\"0\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-1\" />\n          <rect x=\"300\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-2\" />\n          <rect x=\"600\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-3\" />\n        </ContentLoader>\n      </StyledWrapper>\n    );\n  }\n\n  categories.forEach((category: categoryProps) => {\n    allSubjects.push(...category.subjects);\n    category.visible &&\n      data.push({\n        title: t(`subjectCategories.${category.type}`),\n        content: (\n          <>\n            {category.message && (\n              <MessageBoxWrapper>\n                <MessageBox>{category.message}</MessageBox>\n              </MessageBoxWrapper>\n            )}\n            {renderList(category.subjects, onNavigate, onToggleSubject, subjectViewType, selectedSubjects)}\n          </>\n        ),\n      });\n  });\n\n  data.push({\n    title: t('frontpageMenu.allsubjects'),\n    content: renderList(allSubjects, onNavigate, onToggleSubject, subjectViewType, selectedSubjects),\n  });\n\n  return (\n    <StyledWrapper>\n      <Tabs modifier=\"subjects\" tabs={data} />\n    </StyledWrapper>\n  );\n};\n\nexport default FrontpageAllSubjects;\n"]} */",
|
|
74
74
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
75
75
|
});
|
|
76
76
|
var MessageBoxWrapper = /*#__PURE__*/_styled("div", {
|
|
@@ -82,7 +82,7 @@ var MessageBoxWrapper = /*#__PURE__*/_styled("div", {
|
|
|
82
82
|
} : {
|
|
83
83
|
name: "8qz8ia",
|
|
84
84
|
styles: "padding-top:20px",
|
|
85
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FrontpageAllSubjects.tsx"],"names":[],"mappings":"AAwEoC","file":"FrontpageAllSubjects.tsx","sourcesContent":["import React, { Fragment } from 'react';\nimport styled from '@emotion/styled';\nimport { useTranslation } from 'react-i18next';\nimport Tabs from '@ndla/tabs';\nimport SafeLink from '@ndla/safelink';\nimport { colors, fonts, mq, breakpoints } from '@ndla/core';\nimport ContentLoader from '../ContentLoader';\nimport { MessageBox } from '../Messages';\nimport { ToggleItem } from '../Filter';\n\nconst StyledWrapper = styled.nav`\n  margin: 32px 0 0;\n  .c-tabs--subjects {\n    margin: 0;\n  }\n  .c-tabs__list--subjects {\n    margin: 0;\n  }\n  .c-tabs__tab--subjects {\n    ${mq.range({ until: breakpoints.tablet })} {\n      margin: 0;\n      font-size: 12px;\n      padding-left: 8px;\n      padding-right: 8px;\n      :first-of-type {\n        padding-left: 0;\n      }\n      :last-of-type {\n        padding-right: 0;\n      }\n    }\n  }\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  margin: 40px 0 0;\n  padding: 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    column-count: 2;\n    column-gap: 20px;\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    column-count: 3;\n    column-gap: 20px;\n  }\n`;\nconst StyledListItem = styled.li`\n  margin-bottom: 0;\n  break-inside: avoid;\n`;\n\nconst StyledLetterItem = styled.span<{ subjectViewType?: string }>`\n  display: block;\n  ${fonts.sizes(30, 1)};\n  font-weight: ${fonts.weight.bold};\n  color: ${colors.brand.primary};\n  margin-bottom: 8px;\n  ${(props) => props.subjectViewType === 'checkbox' && `margin-left:37px;`}\n`;\n\nconst StyledSpacingElement = styled.span`\n  display: block;\n  width: 100%;\n  height: 10px;\n`;\n\nconst StyledLetterSpacing = styled.span`\n  display: block;\n  height: 16px;\n`;\n\nconst MessageBoxWrapper = styled.div`\n  padding-top: 20px;\n`;\n\ntype subjectProps = {\n  name: string;\n  url?: string;\n  path?: string;\n  id?: string;\n};\ntype categoryProps = {\n  type?: string;\n  name?: string;\n  visible?: boolean;\n  message?: string;\n  subjects: subjectProps[];\n};\n\nexport type subjectsProps = {\n  categories: categoryProps[];\n  subjectViewType?: 'link' | 'checkbox';\n  onToggleSubject?: (id: string) => void;\n  onNavigate?: () => void;\n  selectedSubjects?: string[];\n};\n\ntype letterCategories = {\n  letter: string;\n  items: subjectProps[];\n};\n\nconst sortAlphabetically = (subjects: subjectProps[], locale: string = 'nb') => {\n  const subjectsSorted = subjects.sort((a, b) => a.name.localeCompare(b.name, locale));\n  const subjectsLetterCategories: letterCategories[] = [];\n  let previousLetter = '';\n  let letterItems: subjectProps[] = [];\n  subjectsSorted.forEach((subject: subjectProps) => {\n    const currentLetter = subject.name.substr(0, 1);\n    const isNewLetter = currentLetter.localeCompare(previousLetter, locale) === 1;\n    if (isNewLetter && letterItems.length) {\n      subjectsLetterCategories.push({\n        letter: previousLetter,\n        items: letterItems,\n      });\n      letterItems = [];\n    }\n    previousLetter = currentLetter;\n    letterItems.push(subject);\n  });\n  // Add last letter\n  if (previousLetter && letterItems.length) {\n    subjectsLetterCategories.push({\n      letter: previousLetter,\n      items: letterItems,\n    });\n  }\n  return subjectsLetterCategories;\n};\n\nconst renderList = (\n  subjects: subjectProps[],\n  onNavigate?: () => void,\n  onToggleSubject?: subjectsProps['onToggleSubject'],\n  subjectViewType?: subjectsProps['subjectViewType'],\n  selectedSubjects: subjectsProps['selectedSubjects'] = [],\n) => (\n  <StyledList>\n    {sortAlphabetically(subjects).map((letter: any) => {\n      return (\n        <Fragment key={letter.letter}>\n          {letter.items.map((subject: subjectProps, index: number) => (\n            <Fragment key={subject.name}>\n              <StyledListItem>\n                {index === 0 && <StyledLetterItem subjectViewType={subjectViewType}>{letter.letter}</StyledLetterItem>}\n                {subjectViewType === 'checkbox' && subject.id ? (\n                  <ToggleItem\n                    id={subject.id}\n                    value={subject.id}\n                    checked={selectedSubjects.includes(subject.id)}\n                    label={subject.name}\n                    component=\"div\"\n                    onChange={() => {\n                      if (onToggleSubject && subject.id) {\n                        onToggleSubject(subject.id);\n                      }\n                    }}\n                  />\n                ) : (\n                  <>\n                    <SafeLink\n                      onClick={() => {\n                        if (onNavigate) {\n                          onNavigate();\n                        }\n                      }}\n                      to={subject.url || subject.path || ''}>\n                      {subject.name}\n                    </SafeLink>\n                    <StyledSpacingElement />\n                  </>\n                )}\n                {letter.items.length - 1 === index && <StyledLetterSpacing />}\n              </StyledListItem>\n            </Fragment>\n          ))}\n        </Fragment>\n      );\n    })}\n  </StyledList>\n);\n\nconst FrontpageAllSubjects = ({\n  categories,\n  onNavigate,\n  onToggleSubject,\n  subjectViewType,\n  selectedSubjects,\n}: subjectsProps) => {\n  const allSubjects: subjectProps[] = [];\n  const data: any = [];\n  const { t } = useTranslation();\n\n  if (categories.flatMap((c) => c.subjects).length === 0) {\n    return (\n      <StyledWrapper>\n        <ContentLoader width={880} height={270}>\n          <rect x=\"0\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-1\" />\n          <rect x=\"110\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-2\" />\n          <rect x=\"220\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-3\" />\n          <rect x=\"330\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-4\" />\n\n          <rect x=\"0\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-1\" />\n          <rect x=\"300\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-2\" />\n          <rect x=\"600\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-3\" />\n        </ContentLoader>\n      </StyledWrapper>\n    );\n  }\n\n  categories.forEach((category: categoryProps) => {\n    allSubjects.push(...category.subjects);\n    category.visible &&\n      data.push({\n        title: category.name || t(`subjectCategories.${category.type}`),\n        content: (\n          <>\n            {category.message && (\n              <MessageBoxWrapper>\n                <MessageBox>{category.message}</MessageBox>\n              </MessageBoxWrapper>\n            )}\n            {category.name === t('subjectCategories.beta') && (\n              <MessageBoxWrapper>\n                <MessageBox>{t('messageBoxInfo.frontPageBeta')}</MessageBox>\n              </MessageBoxWrapper>\n            )}\n            {category.name === t('subjectCategories.archive') && (\n              <MessageBoxWrapper>\n                <MessageBox>{t('messageBoxInfo.frontPageExpired')}</MessageBox>\n              </MessageBoxWrapper>\n            )}\n            {renderList(category.subjects, onNavigate, onToggleSubject, subjectViewType, selectedSubjects)}\n          </>\n        ),\n      });\n  });\n\n  data.push({\n    title: t('frontpageMenu.allsubjects'),\n    content: renderList(allSubjects, onNavigate, onToggleSubject, subjectViewType, selectedSubjects),\n  });\n\n  return (\n    <StyledWrapper>\n      <Tabs modifier=\"subjects\" tabs={data} />\n    </StyledWrapper>\n  );\n};\n\nexport default FrontpageAllSubjects;\n"]} */",
|
|
85
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FrontpageAllSubjects.tsx"],"names":[],"mappings":"AAwEoC","file":"FrontpageAllSubjects.tsx","sourcesContent":["import React, { Fragment } from 'react';\nimport styled from '@emotion/styled';\nimport { useTranslation } from 'react-i18next';\nimport Tabs from '@ndla/tabs';\nimport SafeLink from '@ndla/safelink';\nimport { colors, fonts, mq, breakpoints } from '@ndla/core';\nimport ContentLoader from '../ContentLoader';\nimport { MessageBox } from '../Messages';\nimport { ToggleItem } from '../Filter';\n\nconst StyledWrapper = styled.nav`\n  margin: 32px 0 0;\n  .c-tabs--subjects {\n    margin: 0;\n  }\n  .c-tabs__list--subjects {\n    margin: 0;\n  }\n  .c-tabs__tab--subjects {\n    ${mq.range({ until: breakpoints.tablet })} {\n      margin: 0;\n      font-size: 12px;\n      padding-left: 8px;\n      padding-right: 8px;\n      :first-of-type {\n        padding-left: 0;\n      }\n      :last-of-type {\n        padding-right: 0;\n      }\n    }\n  }\n`;\n\nconst StyledList = styled.ul`\n  list-style: none;\n  margin: 40px 0 0;\n  padding: 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    column-count: 2;\n    column-gap: 20px;\n  }\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    column-count: 3;\n    column-gap: 20px;\n  }\n`;\nconst StyledListItem = styled.li`\n  margin-bottom: 0;\n  break-inside: avoid;\n`;\n\nconst StyledLetterItem = styled.span<{ subjectViewType?: string }>`\n  display: block;\n  ${fonts.sizes(30, 1)};\n  font-weight: ${fonts.weight.bold};\n  color: ${colors.brand.primary};\n  margin-bottom: 8px;\n  ${(props) => props.subjectViewType === 'checkbox' && `margin-left:37px;`}\n`;\n\nconst StyledSpacingElement = styled.span`\n  display: block;\n  width: 100%;\n  height: 10px;\n`;\n\nconst StyledLetterSpacing = styled.span`\n  display: block;\n  height: 16px;\n`;\n\nconst MessageBoxWrapper = styled.div`\n  padding-top: 20px;\n`;\n\ntype subjectProps = {\n  name: string;\n  path?: string;\n  id?: string;\n};\ntype categoryProps = {\n  type?: string;\n  visible?: boolean;\n  message?: string;\n  subjects: subjectProps[];\n};\n\nexport type subjectsProps = {\n  categories: categoryProps[];\n  subjectViewType?: 'link' | 'checkbox';\n  onToggleSubject?: (id: string) => void;\n  onNavigate?: () => void;\n  selectedSubjects?: string[];\n};\n\ntype letterCategories = {\n  letter: string;\n  items: subjectProps[];\n};\n\nconst sortAlphabetically = (subjects: subjectProps[], locale: string = 'nb') => {\n  const subjectsSorted = subjects.sort((a, b) => a.name.localeCompare(b.name, locale));\n  const subjectsLetterCategories: letterCategories[] = [];\n  let previousLetter = '';\n  let letterItems: subjectProps[] = [];\n  subjectsSorted.forEach((subject: subjectProps) => {\n    const currentLetter = subject.name.substr(0, 1);\n    const isNewLetter = currentLetter.localeCompare(previousLetter, locale) === 1;\n    if (isNewLetter && letterItems.length) {\n      subjectsLetterCategories.push({\n        letter: previousLetter,\n        items: letterItems,\n      });\n      letterItems = [];\n    }\n    previousLetter = currentLetter;\n    letterItems.push(subject);\n  });\n  // Add last letter\n  if (previousLetter && letterItems.length) {\n    subjectsLetterCategories.push({\n      letter: previousLetter,\n      items: letterItems,\n    });\n  }\n  return subjectsLetterCategories;\n};\n\nconst renderList = (\n  subjects: subjectProps[],\n  onNavigate?: () => void,\n  onToggleSubject?: subjectsProps['onToggleSubject'],\n  subjectViewType?: subjectsProps['subjectViewType'],\n  selectedSubjects: subjectsProps['selectedSubjects'] = [],\n) => (\n  <StyledList>\n    {sortAlphabetically(subjects).map((letter: any) => {\n      return (\n        <Fragment key={letter.letter}>\n          {letter.items.map((subject: subjectProps, index: number) => (\n            <Fragment key={subject.name}>\n              <StyledListItem>\n                {index === 0 && <StyledLetterItem subjectViewType={subjectViewType}>{letter.letter}</StyledLetterItem>}\n                {subjectViewType === 'checkbox' && subject.id ? (\n                  <ToggleItem\n                    id={subject.id}\n                    value={subject.id}\n                    checked={selectedSubjects.includes(subject.id)}\n                    label={subject.name}\n                    component=\"div\"\n                    onChange={() => {\n                      if (onToggleSubject && subject.id) {\n                        onToggleSubject(subject.id);\n                      }\n                    }}\n                  />\n                ) : (\n                  <>\n                    <SafeLink\n                      onClick={() => {\n                        if (onNavigate) {\n                          onNavigate();\n                        }\n                      }}\n                      to={subject.path || ''}>\n                      {subject.name}\n                    </SafeLink>\n                    <StyledSpacingElement />\n                  </>\n                )}\n                {letter.items.length - 1 === index && <StyledLetterSpacing />}\n              </StyledListItem>\n            </Fragment>\n          ))}\n        </Fragment>\n      );\n    })}\n  </StyledList>\n);\n\nconst FrontpageAllSubjects = ({\n  categories,\n  onNavigate,\n  onToggleSubject,\n  subjectViewType,\n  selectedSubjects,\n}: subjectsProps) => {\n  const allSubjects: subjectProps[] = [];\n  const data: any = [];\n  const { t } = useTranslation();\n\n  if (categories.flatMap((c) => c.subjects).length === 0) {\n    return (\n      <StyledWrapper>\n        <ContentLoader width={880} height={270}>\n          <rect x=\"0\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-1\" />\n          <rect x=\"110\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-2\" />\n          <rect x=\"220\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-3\" />\n          <rect x=\"330\" y=\"10\" rx=\"3\" ry=\"3\" width=\"90\" height=\"35\" key=\"rect-1-4\" />\n\n          <rect x=\"0\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-1\" />\n          <rect x=\"300\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-2\" />\n          <rect x=\"600\" y=\"70\" rx=\"3\" ry=\"3\" width=\"280\" height=\"200\" key=\"rect-2-3\" />\n        </ContentLoader>\n      </StyledWrapper>\n    );\n  }\n\n  categories.forEach((category: categoryProps) => {\n    allSubjects.push(...category.subjects);\n    category.visible &&\n      data.push({\n        title: t(`subjectCategories.${category.type}`),\n        content: (\n          <>\n            {category.message && (\n              <MessageBoxWrapper>\n                <MessageBox>{category.message}</MessageBox>\n              </MessageBoxWrapper>\n            )}\n            {renderList(category.subjects, onNavigate, onToggleSubject, subjectViewType, selectedSubjects)}\n          </>\n        ),\n      });\n  });\n\n  data.push({\n    title: t('frontpageMenu.allsubjects'),\n    content: renderList(allSubjects, onNavigate, onToggleSubject, subjectViewType, selectedSubjects),\n  });\n\n  return (\n    <StyledWrapper>\n      <Tabs modifier=\"subjects\" tabs={data} />\n    </StyledWrapper>\n  );\n};\n\nexport default FrontpageAllSubjects;\n"]} */",
|
|
86
86
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
87
87
|
});
|
|
88
88
|
var sortAlphabetically = function sortAlphabetically(subjects) {
|
|
@@ -144,7 +144,7 @@ var renderList = function renderList(subjects, onNavigate, onToggleSubject, subj
|
|
|
144
144
|
onNavigate();
|
|
145
145
|
}
|
|
146
146
|
},
|
|
147
|
-
to: subject.
|
|
147
|
+
to: subject.path || '',
|
|
148
148
|
children: subject.name
|
|
149
149
|
}), _jsx(StyledSpacingElement, {})]
|
|
150
150
|
}), letter.items.length - 1 === index && _jsx(StyledLetterSpacing, {})]
|
|
@@ -228,20 +228,12 @@ var FrontpageAllSubjects = function FrontpageAllSubjects(_ref) {
|
|
|
228
228
|
categories.forEach(function (category) {
|
|
229
229
|
allSubjects.push.apply(allSubjects, _toConsumableArray(category.subjects));
|
|
230
230
|
category.visible && data.push({
|
|
231
|
-
title:
|
|
231
|
+
title: t("subjectCategories.".concat(category.type)),
|
|
232
232
|
content: _jsxs(_Fragment, {
|
|
233
233
|
children: [category.message && _jsx(MessageBoxWrapper, {
|
|
234
234
|
children: _jsx(MessageBox, {
|
|
235
235
|
children: category.message
|
|
236
236
|
})
|
|
237
|
-
}), category.name === t('subjectCategories.beta') && _jsx(MessageBoxWrapper, {
|
|
238
|
-
children: _jsx(MessageBox, {
|
|
239
|
-
children: t('messageBoxInfo.frontPageBeta')
|
|
240
|
-
})
|
|
241
|
-
}), category.name === t('subjectCategories.archive') && _jsx(MessageBoxWrapper, {
|
|
242
|
-
children: _jsx(MessageBox, {
|
|
243
|
-
children: t('messageBoxInfo.frontPageExpired')
|
|
244
|
-
})
|
|
245
237
|
}), renderList(category.subjects, onNavigate, onToggleSubject, subjectViewType, selectedSubjects)]
|
|
246
238
|
})
|
|
247
239
|
});
|
package/es/Image/Image.js
CHANGED
|
@@ -37,12 +37,12 @@ var StyledImageWrapper = /*#__PURE__*/_styled("div", {
|
|
|
37
37
|
target: "ejtxxex0",
|
|
38
38
|
label: "StyledImageWrapper"
|
|
39
39
|
})(process.env.NODE_ENV === "production" ? {
|
|
40
|
-
name: "
|
|
41
|
-
styles: "position:relative"
|
|
40
|
+
name: "zxsb69",
|
|
41
|
+
styles: "position:relative;width:100%;height:100%"
|
|
42
42
|
} : {
|
|
43
|
-
name: "
|
|
44
|
-
styles: "position:relative",
|
|
45
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkltYWdlLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF1Q3FDIiwiZmlsZSI6IkltYWdlLnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDE3LXByZXNlbnQsIE5ETEEuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgR1BMdjMgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqXG4gKi9cblxuaW1wb3J0IFJlYWN0LCB7IFJlYWN0Tm9kZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCBMYXp5TG9hZEltYWdlIGZyb20gJy4vTGF6eUxvYWRJbWFnZSc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgSW1hZ2VDcm9wIHtcbiAgc3RhcnRYOiBudW1iZXI7XG4gIHN0YXJ0WTogbnVtYmVyO1xuICBlbmRYOiBudW1iZXI7XG4gIGVuZFk6IG51bWJlcjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBJbWFnZUZvY2FsUG9pbnQge1xuICB4OiBudW1iZXI7XG4gIHk6IG51bWJlcjtcbn1cblxuZXhwb3J0IGNvbnN0IG1ha2VTcmNRdWVyeVN0cmluZyA9ICh3aWR0aDogbnVtYmVyIHwgdW5kZWZpbmVkLCBjcm9wPzogSW1hZ2VDcm9wLCBmb2NhbFBvaW50PzogSW1hZ2VGb2NhbFBvaW50KSA9PiB7XG4gIGNvbnN0IHdpZHRoUGFyYW1zID0gd2lkdGggJiYgYHdpZHRoPSR7d2lkdGh9YDtcbiAgY29uc3QgY3JvcFBhcmFtcyA9XG4gICAgY3JvcCAmJiBgY3JvcFN0YXJ0WD0ke2Nyb3Auc3RhcnRYfSZjcm9wRW5kWD0ke2Nyb3AuZW5kWH0mY3JvcFN0YXJ0WT0ke2Nyb3Auc3RhcnRZfSZjcm9wRW5kWT0ke2Nyb3AuZW5kWX1gO1xuICBjb25zdCBmb2NhbFBvaW50UGFyYW1zID0gZm9jYWxQb2ludCAmJiBgZm9jYWxYPSR7Zm9jYWxQb2ludC54fSZmb2NhbFk9JHtmb2NhbFBvaW50Lnl9YDtcbiAgY29uc3QgcGFyYW1zID0gW3dpZHRoUGFyYW1zLCBjcm9wUGFyYW1zLCBmb2NhbFBvaW50UGFyYW1zXS5maWx0ZXIoKHApID0+
|
|
43
|
+
name: "zxsb69",
|
|
44
|
+
styles: "position:relative;width:100%;height:100%",
|
|
45
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkltYWdlLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF1Q3FDIiwiZmlsZSI6IkltYWdlLnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDE3LXByZXNlbnQsIE5ETEEuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgR1BMdjMgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqXG4gKi9cblxuaW1wb3J0IFJlYWN0LCB7IFJlYWN0Tm9kZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCBMYXp5TG9hZEltYWdlIGZyb20gJy4vTGF6eUxvYWRJbWFnZSc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgSW1hZ2VDcm9wIHtcbiAgc3RhcnRYOiBudW1iZXI7XG4gIHN0YXJ0WTogbnVtYmVyO1xuICBlbmRYOiBudW1iZXI7XG4gIGVuZFk6IG51bWJlcjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBJbWFnZUZvY2FsUG9pbnQge1xuICB4OiBudW1iZXI7XG4gIHk6IG51bWJlcjtcbn1cblxuZXhwb3J0IGNvbnN0IG1ha2VTcmNRdWVyeVN0cmluZyA9ICh3aWR0aDogbnVtYmVyIHwgdW5kZWZpbmVkLCBjcm9wPzogSW1hZ2VDcm9wLCBmb2NhbFBvaW50PzogSW1hZ2VGb2NhbFBvaW50KSA9PiB7XG4gIGNvbnN0IHdpZHRoUGFyYW1zID0gd2lkdGggJiYgYHdpZHRoPSR7d2lkdGh9YDtcbiAgY29uc3QgY3JvcFBhcmFtcyA9XG4gICAgY3JvcCAmJiBgY3JvcFN0YXJ0WD0ke2Nyb3Auc3RhcnRYfSZjcm9wRW5kWD0ke2Nyb3AuZW5kWH0mY3JvcFN0YXJ0WT0ke2Nyb3Auc3RhcnRZfSZjcm9wRW5kWT0ke2Nyb3AuZW5kWX1gO1xuICBjb25zdCBmb2NhbFBvaW50UGFyYW1zID0gZm9jYWxQb2ludCAmJiBgZm9jYWxYPSR7Zm9jYWxQb2ludC54fSZmb2NhbFk9JHtmb2NhbFBvaW50Lnl9YDtcbiAgY29uc3QgcGFyYW1zID0gW3dpZHRoUGFyYW1zLCBjcm9wUGFyYW1zLCBmb2NhbFBvaW50UGFyYW1zXS5maWx0ZXIoKHApID0+IHApLmpvaW4oJyYnKTtcblxuICByZXR1cm4gcGFyYW1zO1xufTtcblxuY29uc3QgZ2V0U3JjU2V0ID0gKHNyYzogc3RyaW5nLCBjcm9wOiBJbWFnZUNyb3AgfCB1bmRlZmluZWQsIGZvY2FsUG9pbnQ6IEltYWdlRm9jYWxQb2ludCB8IHVuZGVmaW5lZCkgPT4ge1xuICBjb25zdCB3aWR0aHMgPSBbMjcyMCwgMjA4MCwgMTc2MCwgMTQ0MCwgMTEyMCwgMTAwMCwgOTYwLCA4MDAsIDY0MCwgNDgwLCAzMjAsIDI0MCwgMTgwXTtcbiAgcmV0dXJuIHdpZHRocy5tYXAoKHdpZHRoKSA9PiBgJHtzcmN9PyR7bWFrZVNyY1F1ZXJ5U3RyaW5nKHdpZHRoLCBjcm9wLCBmb2NhbFBvaW50KX0gJHt3aWR0aH13YCkuam9pbignLCAnKTtcbn07XG5cbmNvbnN0IFN0eWxlZEltYWdlV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgd2lkdGg6IDEwMCU7XG4gIGhlaWdodDogMTAwJTtcbmA7XG5pbnRlcmZhY2UgUHJvcHMge1xuICBhbHQ6IHN0cmluZztcbiAgc3JjOiBzdHJpbmc7XG4gIHNpemVzPzogc3RyaW5nO1xuICBmYWxsYmFja1dpZHRoPzogbnVtYmVyO1xuICBjb250ZW50VHlwZT86IHN0cmluZztcbiAgc3JjU2V0Pzogc3RyaW5nO1xuICBsYXp5TG9hZD86IGJvb2xlYW47XG4gIGxhenlMb2FkU3JjPzogc3RyaW5nO1xuICBleHBhbmRCdXR0b24/OiBSZWFjdE5vZGU7XG4gIGNyb3A/OiBJbWFnZUNyb3A7XG4gIGZvY2FsUG9pbnQ/OiBJbWFnZUZvY2FsUG9pbnQ7XG59XG5cbmNvbnN0IEltYWdlID0gKHtcbiAgYWx0LFxuICBzcmMsXG4gIGxhenlMb2FkLFxuICBsYXp5TG9hZFNyYyxcbiAgY3JvcCxcbiAgZm9jYWxQb2ludCxcbiAgY29udGVudFR5cGUsXG4gIHNpemVzID0gJyhtaW4td2lkdGg6IDEwMjRweCkgMTAyNHB4LCAxMDB2dycsXG4gIGV4cGFuZEJ1dHRvbixcbiAgZmFsbGJhY2tXaWR0aCA9IDEwMjQsXG4gIC4uLnJlc3Rcbn06IFByb3BzKSA9PiB7XG4gIGNvbnN0IHNyY1NldCA9IHJlc3Quc3JjU2V0ID8/IGdldFNyY1NldChzcmMsIGNyb3AsIGZvY2FsUG9pbnQpO1xuICBjb25zdCBxdWVyeVN0cmluZyA9IG1ha2VTcmNRdWVyeVN0cmluZyhmYWxsYmFja1dpZHRoLCBjcm9wLCBmb2NhbFBvaW50KTtcblxuICBpZiAoY29udGVudFR5cGUgJiYgY29udGVudFR5cGUgPT09ICdpbWFnZS9naWYnKSB7XG4gICAgcmV0dXJuIChcbiAgICAgIDxTdHlsZWRJbWFnZVdyYXBwZXI+XG4gICAgICAgIDxpbWcgYWx0PXthbHR9IHNyYz17YCR7c3JjfWB9IHsuLi5yZXN0fSAvPlxuICAgICAgPC9TdHlsZWRJbWFnZVdyYXBwZXI+XG4gICAgKTtcbiAgfVxuXG4gIGlmIChsYXp5TG9hZCkge1xuICAgIHJldHVybiAoXG4gICAgICA8U3R5bGVkSW1hZ2VXcmFwcGVyPlxuICAgICAgICA8TGF6eUxvYWRJbWFnZVxuICAgICAgICAgIGFsdD17YWx0fVxuICAgICAgICAgIHNyYz17YCR7c3JjfT8ke3F1ZXJ5U3RyaW5nfWB9XG4gICAgICAgICAgc3JjU2V0PXtzcmNTZXR9XG4gICAgICAgICAgc2l6ZXM9e3NpemVzfVxuICAgICAgICAgIGxhenlMb2FkU3JjPXtsYXp5TG9hZFNyY31cbiAgICAgICAgLz5cbiAgICAgIDwvU3R5bGVkSW1hZ2VXcmFwcGVyPlxuICAgICk7XG4gIH1cblxuICByZXR1cm4gKFxuICAgIDxTdHlsZWRJbWFnZVdyYXBwZXI+XG4gICAgICA8cGljdHVyZT5cbiAgICAgICAgPHNvdXJjZSB0eXBlPXtjb250ZW50VHlwZX0gc3JjU2V0PXtzcmNTZXR9IHNpemVzPXtzaXplc30gLz5cbiAgICAgICAgPGltZyBhbHQ9e2FsdH0gc3JjPXtgJHtzcmN9PyR7cXVlcnlTdHJpbmd9YH0gey4uLnJlc3R9IC8+XG4gICAgICA8L3BpY3R1cmU+XG4gICAgICB7ZXhwYW5kQnV0dG9ufVxuICAgIDwvU3R5bGVkSW1hZ2VXcmFwcGVyPlxuICApO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgSW1hZ2U7XG4iXX0= */",
|
|
46
46
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
47
47
|
});
|
|
48
48
|
var Image = function Image(_ref) {
|
package/es/Image/ImageLink.js
CHANGED
|
@@ -21,12 +21,12 @@ var StyledLink = /*#__PURE__*/_styled("a", {
|
|
|
21
21
|
target: "eo3pjlm0",
|
|
22
22
|
label: "StyledLink"
|
|
23
23
|
})(process.env.NODE_ENV === "production" ? {
|
|
24
|
-
name: "
|
|
25
|
-
styles: "box-shadow:inset 0 0"
|
|
24
|
+
name: "68s54g",
|
|
25
|
+
styles: "box-shadow:inset 0 0;width:100%;height:100%"
|
|
26
26
|
} : {
|
|
27
|
-
name: "
|
|
28
|
-
styles: "box-shadow:inset 0 0",
|
|
29
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
27
|
+
name: "68s54g",
|
|
28
|
+
styles: "box-shadow:inset 0 0;width:100%;height:100%",
|
|
29
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkltYWdlTGluay50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBYTJCIiwiZmlsZSI6IkltYWdlTGluay50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAxOS1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCBSZWFjdCwgeyBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBtYWtlU3JjUXVlcnlTdHJpbmcgfSBmcm9tICcuL0ltYWdlJztcbmltcG9ydCB7IEltYWdlQ3JvcCwgSW1hZ2VGb2NhbFBvaW50IH0gZnJvbSAnLic7XG5cbmNvbnN0IFN0eWxlZExpbmsgPSBzdHlsZWQuYWBcbiAgYm94LXNoYWRvdzogaW5zZXQgMCAwO1xuICB3aWR0aDogMTAwJTtcbiAgaGVpZ2h0OiAxMDAlO1xuYDtcblxuaW50ZXJmYWNlIFByb3BzIHtcbiAgc3JjOiBzdHJpbmc7XG4gIGNoaWxkcmVuOiBSZWFjdE5vZGU7XG4gIHNpemVzPzogc3RyaW5nO1xuICBjcm9wPzogSW1hZ2VDcm9wO1xuICBmb2NhbFBvaW50PzogSW1hZ2VGb2NhbFBvaW50O1xufVxuXG5leHBvcnQgZnVuY3Rpb24gSW1hZ2VMaW5rKHsgc3JjLCBjcm9wLCBjaGlsZHJlbiwgLi4ucmVzdCB9OiBQcm9wcykge1xuICByZXR1cm4gKFxuICAgIDxTdHlsZWRMaW5rXG4gICAgICB0YXJnZXQ9XCJfYmxhbmtcIlxuICAgICAgaHJlZj17YCR7c3JjfT8ke21ha2VTcmNRdWVyeVN0cmluZyh1bmRlZmluZWQsIGNyb3ApfWB9XG4gICAgICByZWw9XCJub29wZW5lciBub3JlZmVycmVyXCJcbiAgICAgIHsuLi5yZXN0fT5cbiAgICAgIHtjaGlsZHJlbn1cbiAgICA8L1N0eWxlZExpbms+XG4gICk7XG59XG4iXX0= */",
|
|
30
30
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
31
31
|
});
|
|
32
32
|
export function ImageLink(_ref) {
|