@ndla/ui 50.5.0 → 50.5.1

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