@ndla/ui 6.2.2 → 7.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.
@@ -43,6 +43,7 @@ export var Masthead = function Masthead(_ref3) {
43
43
  ndlaFilm = _ref3.ndlaFilm,
44
44
  skipToMainContentId = _ref3.skipToMainContentId,
45
45
  messages = _ref3.messages,
46
+ onCloseAlert = _ref3.onCloseAlert,
46
47
  t = _ref3.t;
47
48
  var mastheadRef = useRef(null);
48
49
 
@@ -75,8 +76,12 @@ export var Masthead = function Masthead(_ref3) {
75
76
  ndlaFilm: !!ndlaFilm
76
77
  })), messages === null || messages === void 0 ? void 0 : messages.map(function (message) {
77
78
  return ___EmotionJSX(MessageBox, {
78
- type: MessageBoxType.masthead
79
- }, message);
79
+ type: MessageBoxType.masthead,
80
+ showCloseButton: message.closable,
81
+ onClose: function onClose() {
82
+ return onCloseAlert === null || onCloseAlert === void 0 ? void 0 : onCloseAlert(message.number);
83
+ }
84
+ }, message.content);
80
85
  }), infoContent && ___EmotionJSX(DisplayOnPageYOffset, {
81
86
  yOffsetMin: 0,
82
87
  yOffsetMax: 90
@@ -25,7 +25,9 @@ import React, { useState } from 'react';
25
25
  import Sticky from 'react-sticky-el';
26
26
  import { breakpoints, fonts, mq, spacing } from '@ndla/core';
27
27
  import { InformationOutline, HumanMaleBoard } from '@ndla/icons/common';
28
- import { withTranslation } from 'react-i18next';
28
+ import { withTranslation } from 'react-i18next'; // @ts-ignore
29
+
30
+ import { Remarkable } from 'remarkable';
29
31
  import { CloseButton } from '../CloseButton';
30
32
  import { jsx as ___EmotionJSX } from "@emotion/core";
31
33
  export var MessageBoxType;
@@ -59,6 +61,7 @@ var StyleByType = function StyleByType(type) {
59
61
  styles.width = '100vw';
60
62
  styles.position = 'relative';
61
63
  styles.left = '50%';
64
+ styles.padding = '0';
62
65
  styles.transform = 'translateX(-50%)';
63
66
  break;
64
67
 
@@ -102,7 +105,7 @@ var Wrapper = _styled("div", {
102
105
  return StyleByType(props.boxType).left;
103
106
  }, ";z-index:10;width:", function (props) {
104
107
  return StyleByType(props.boxType).width;
105
- }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIk1lc3NhZ2VCb3gudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQW1Fd0MiLCJmaWxlIjoiTWVzc2FnZUJveC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAyMi1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCBSZWFjdCwgeyBIVE1MQXR0cmlidXRlcywgdXNlU3RhdGUgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgU3RpY2t5IGZyb20gJ3JlYWN0LXN0aWNreS1lbCc7XG5pbXBvcnQgeyBicmVha3BvaW50cywgZm9udHMsIG1xLCBzcGFjaW5nIH0gZnJvbSAnQG5kbGEvY29yZSc7XG5pbXBvcnQgeyBJbmZvcm1hdGlvbk91dGxpbmUsIEh1bWFuTWFsZUJvYXJkIH0gZnJvbSAnQG5kbGEvaWNvbnMvY29tbW9uJztcbmltcG9ydCB7IFdpdGhUcmFuc2xhdGlvbiwgd2l0aFRyYW5zbGF0aW9uIH0gZnJvbSAncmVhY3QtaTE4bmV4dCc7XG5pbXBvcnQgeyBDbG9zZUJ1dHRvbiB9IGZyb20gJy4uL0Nsb3NlQnV0dG9uJztcblxuZXhwb3J0IGVudW0gTWVzc2FnZUJveFR5cGUge1xuICBnaG9zdCA9ICdnaG9zdCcsXG4gIGZ1bGxwYWdlID0gJ2Z1bGxwYWdlJyxcbiAgbWVkaXVtID0gJ21lZGl1bScsXG4gIG1hc3RoZWFkID0gJ21hc3RoZWFkJyxcbn1cbnR5cGUgV3JhcHBlclByb3BzID0ge1xuICBib3hUeXBlPzogTWVzc2FnZUJveFR5cGU7XG59O1xuXG5jb25zdCBTdHlsZUJ5VHlwZSA9ICh0eXBlOiBXcmFwcGVyUHJvcHNbJ2JveFR5cGUnXSkgPT4ge1xuICBjb25zdCBzdHlsZXM6IEhUTUxBdHRyaWJ1dGVzPEhUTUxFbGVtZW50Plsnc3R5bGUnXSA9IHtcbiAgICBtYXJnaW46ICcxcHgnLFxuICAgIGNvbG9yOiAnIzQ0NDQ0NCcsXG4gICAgYmFja2dyb3VuZENvbG9yOiAnI2Y5ZjRjOCcsXG4gICAgYm9yZGVyOiAnbm9uZScsXG4gICAgZGlzcGxheTogJ2ZsZXgnLFxuICAgIHBhZGRpbmc6ICcxMHB4JyxcbiAgICB3aWR0aDogJ2F1dG8nLFxuICAgIGJvcmRlclJhZGl1czogJzVweCcsXG4gICAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gICAgdHJhbnNmb3JtOiAnYXV0bycsXG4gICAgbGVmdDogJ2F1dG8nLFxuICB9OyAvL0RpZmZlcmVudCBDU1MgcHJvcGVydGllcyBmb3IgZGlmZmVyZW50IHR5cGVzIG9mIG1lc3NhZ2UtYm94ZXNcbiAgc3dpdGNoICh0eXBlKSB7XG4gICAgY2FzZSAnZnVsbHBhZ2UnOlxuICAgICAgc3R5bGVzLm1hcmdpbiA9ICcwIGF1dG8nO1xuICAgICAgc3R5bGVzLmRpc3BsYXkgPSAnbm9uZSc7XG4gICAgICBzdHlsZXMud2lkdGggPSAnMTAwdncnO1xuICAgICAgc3R5bGVzLnBvc2l0aW9uID0gJ3JlbGF0aXZlJztcbiAgICAgIHN0eWxlcy5sZWZ0ID0gJzUwJSc7XG4gICAgICBzdHlsZXMudHJhbnNmb3JtID0gJ3RyYW5zbGF0ZVgoLTUwJSknO1xuICAgICAgYnJlYWs7XG4gICAgY2FzZSAnbWVkaXVtJzpcbiAgICAgIHN0eWxlcy5tYXJnaW4gPSAnMHB4JztcbiAgICAgIGJyZWFrO1xuICAgIGNhc2UgJ2dob3N0JzpcbiAgICAgIHN0eWxlcy5iYWNrZ3JvdW5kQ29sb3IgPSAndHJhbnNwYXJlbnQnO1xuICAgICAgc3R5bGVzLmJvcmRlciA9ICcxcHggc29saWQgI0QxRDZEQic7XG4gICAgICBzdHlsZXMuY29sb3IgPSAnIzQ0NDQ0NCc7XG4gICAgICBicmVhaztcbiAgICBjYXNlICdtYXN0aGVhZCc6XG4gICAgICBzdHlsZXMubWFyZ2luID0gJzAgYXV0byc7XG4gICAgICBzdHlsZXMuZGlzcGxheSA9ICdub25lJztcbiAgICAgIHN0eWxlcy5wYWRkaW5nID0gJzAnO1xuICAgICAgc3R5bGVzLmJvcmRlclJhZGl1cyA9ICcwJztcbiAgICAgIGJyZWFrO1xuICB9XG4gIHJldHVybiBzdHlsZXM7XG59O1xuXG5jb25zdCBXcmFwcGVyID0gc3R5bGVkLmRpdjxXcmFwcGVyUHJvcHM+YFxuICBiYWNrZ3JvdW5kOiAkeyhwcm9wcykgPT4gU3R5bGVCeVR5cGUocHJvcHMuYm94VHlwZSkuYmFja2dyb3VuZENvbG9yfTtcbiAgY29sb3I6ICR7KHByb3BzKSA9PiBTdHlsZUJ5VHlwZShwcm9wcy5ib3hUeXBlKS5jb2xvcn07XG4gIGZvbnQtc2l6ZTogMThweDtcbiAgbGluZS1oZWlnaHQ6IDMycHg7XG4gIGZvbnQtZmFtaWx5OiAke2ZvbnRzLnNhbnN9O1xuICBkaXNwbGF5OiBmbGV4O1xuICBwYWRkaW5nOiAke3NwYWNpbmcuc21hbGx9O1xuICBwb3NpdGlvbjogJHsocHJvcHMpID0+IFN0eWxlQnlUeXBlKHByb3BzLmJveFR5cGUpLnBvc2l0aW9ufTtcbiAgYm9yZGVyOiAkeyhwcm9wcykgPT4gU3R5bGVCeVR5cGUocHJvcHMuYm94VHlwZSkuYm9yZGVyfTtcbiAgYm9yZGVyLXJhZGl1czogJHsocHJvcHMpID0+IFN0eWxlQnlUeXBlKHByb3BzLmJveFR5cGUpLmJvcmRlclJhZGl1c307XG4gIHRyYW5zZm9ybTogJHsocHJvcHMpID0+IFN0eWxlQnlUeXBlKHByb3BzLmJveFR5cGUpLnRyYW5zZm9ybX07XG4gIGxlZnQ6ICR7KHByb3BzKSA9PiBTdHlsZUJ5VHlwZShwcm9wcy5ib3hUeXBlKS5sZWZ0fTtcbiAgei1pbmRleDogMTA7XG4gIHdpZHRoOiAkeyhwcm9wcykgPT4gU3R5bGVCeVR5cGUocHJvcHMuYm94VHlwZSkud2lkdGh9O1xuYDtcblxuY29uc3QgSW5mb1dyYXBwZXIgPSBzdHlsZWQuZGl2PFdyYXBwZXJQcm9wcz5gXG4gIG1hcmdpbjogJHsocHJvcHMpID0+IFN0eWxlQnlUeXBlKHByb3BzLmJveFR5cGUpLm1hcmdpbn07XG4gIHBhZGRpbmc6ICR7KHByb3BzKSA9PiBTdHlsZUJ5VHlwZShwcm9wcy5ib3hUeXBlKS5wYWRkaW5nfTtcbiAgZGlzcGxheTogZmxleDtcbiAgJHttcS5yYW5nZSh7IHVudGlsOiBicmVha3BvaW50cy50YWJsZXRXaWRlIH0pfSB7XG4gICAgcGFkZGluZzogMCA5MHB4IDAgMDtcbiAgfVxuICAke21xLnJhbmdlKHsgdW50aWw6IGJyZWFrcG9pbnRzLm1vYmlsZVdpZGUgfSl9IHtcbiAgICBwYWRkaW5nOiAwIDVweCAwIDA7XG4gICAgZm9udC1zaXplOiAxNnB4O1xuICB9XG5gO1xuY29uc3QgVGV4dFdyYXBwZXIgPSBzdHlsZWQuZGl2PFdyYXBwZXJQcm9wcz5gXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGZsZXgtd3JhcDogd3JhcDtcbiAgJHttcS5yYW5nZSh7IHVudGlsOiBicmVha3BvaW50cy50YWJsZXRXaWRlIH0pfSB7XG4gICAgbGluZS1oZWlnaHQ6IDI0cHg7XG4gICAgZm9udC1zaXplOiAxNnB4O1xuICB9XG5gO1xuXG5jb25zdCBJY29uV3JhcHBlciA9IHN0eWxlZC5kaXY8V3JhcHBlclByb3BzPmBcbiAgcGFkZGluZy1yaWdodDogJHtzcGFjaW5nLnNtYWxsfTtcbiAgZGlzcGxheTogJHsocHJvcHMpID0+IFN0eWxlQnlUeXBlKHByb3BzLmJveFR5cGUpLmRpc3BsYXl9O1xuICBhbGlnbi1pdGVtczogZmxleC1zdGFydDtcbiAgJHttcS5yYW5nZSh7IGZyb206IGJyZWFrcG9pbnRzLnRhYmxldFdpZGUgfSl9IHtcbiAgICBwYWRkaW5nLXRvcDogNHB4O1xuICB9XG5gO1xuXG5jb25zdCBMaW5rV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIGRpc3BsYXk6IGJsb2NrO1xuICB3aWR0aDogMTAwJTtcbiAgYmFja2dyb3VuZC1jb2xvcjogI2Y5ZjRjODtcbiAgcGFkZGluZy1ib3R0b206IDIwcHg7XG4gIG1hcmdpbi10b3A6IC0ycHg7XG4gIHBhZGRpbmctbGVmdDogNThweDtcbiAgYm9yZGVyLXJhZGl1czogMHB4IDBweCA1cHggNXB4O1xuICAke21xLnJhbmdlKHsgdW50aWw6IGJyZWFrcG9pbnRzLm1vYmlsZVdpZGUgfSl9IHtcbiAgICBwYWRkaW5nLWxlZnQ6IDQ1cHg7XG4gIH1cbmA7XG5jb25zdCBMaW5rID0gc3R5bGVkLmFgXG4gIGNvbG9yOiAjMjA1ODhmO1xuICBmb250LXNpemU6IDE2cHg7XG4gIHBhZGRpbmctYm90dG9tOiAxcHg7XG4gIG1hcmdpbjogMHB4IDQwcHggMXB4IDJweDtcbiAgZm9udC1mYW1pbHk6ICR7Zm9udHMuc2Fuc307XG4gICR7bXEucmFuZ2UoeyB1bnRpbDogYnJlYWtwb2ludHMubW9iaWxlV2lkZSB9KX0ge1xuICAgIG1hcmdpbjogMHB4IDE1cHggMXB4IDVweDtcbiAgICBib3gtc2hhZG93OiBub25lO1xuICB9XG5gO1xuY29uc3QgQ2xvc2VCdXR0b25XcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgcG9zaXRpb246IGFic29sdXRlO1xuICB0b3A6IDEwcHg7XG4gIHJpZ2h0OiAxcHg7XG5gO1xuXG50eXBlIExpbmtQcm9wcyA9IHtcbiAgaHJlZj86IHN0cmluZztcbiAgdGV4dD86IHN0cmluZztcbn07XG50eXBlIFByb3BzID0ge1xuICB0eXBlPzogV3JhcHBlclByb3BzWydib3hUeXBlJ107XG4gIHN0aWNreT86IGJvb2xlYW47XG4gIGNoaWxkcmVuPzogc3RyaW5nO1xuICBsaW5rcz86IExpbmtQcm9wc1tdO1xuICBzaG93Q2xvc2VCdXR0b24/OiBib29sZWFuO1xufTtcblxuZXhwb3J0IGNvbnN0IE1lc3NhZ2VCb3ggPSAoeyB0eXBlLCBzdGlja3kgPSBmYWxzZSwgY2hpbGRyZW4sIGxpbmtzLCB0LCBzaG93Q2xvc2VCdXR0b24gfTogUHJvcHMgJiBXaXRoVHJhbnNsYXRpb24pID0+IHtcbiAgY29uc3QgW2hpZGVNZXNzYWdlQm94LCBzZXRIaWRlTWVzc2FnZUJveF0gPSB1c2VTdGF0ZShmYWxzZSk7XG4gIGNvbnN0IG9uQ2xvc2VNZXNzYWdlQm94ID0gKCkgPT4ge1xuICAgIHNldEhpZGVNZXNzYWdlQm94KHRydWUpO1xuICB9O1xuICBjb25zdCBJY29uID0gdHlwZSA9PT0gJ2dob3N0JyA/IEh1bWFuTWFsZUJvYXJkIDogSW5mb3JtYXRpb25PdXRsaW5lO1xuICByZXR1cm4gKFxuICAgIC8vU3RpY2t5U3R5bGUgdG9wOjg0IG1ha2VzIHN1cmUgdGhhdCB0aGUgbWVzc2FnZWJveCBzaXRzIGJlbmVhdGggdGhlIG1hc3RoZWFkIChoZWFkZXIgKSBhbmQgdGhlIHRvcE9mZnNldHQgc2V0cyBpdCBzbyB0aGF0IGl0IGFwcGxpZXMgd2hlbiByZWFjaGluZyB0aGUgdG9wIG9mIHRoZSBtZXNzYWdlYm94XG4gICAgPFN0aWNreSBkaXNhYmxlZD17IXN0aWNreX0gc3RpY2t5U3R5bGU9e3sgekluZGV4OiA5OTk4LCB0b3A6IDg0IH19IHRvcE9mZnNldD17LTg0fT5cbiAgICAgIDxXcmFwcGVyIGJveFR5cGU9e3R5cGV9IHN0eWxlPXt7IGRpc3BsYXk6IGhpZGVNZXNzYWdlQm94ID8gJ25vbmUnIDogJ2ZsZXgnIH19PlxuICAgICAgICA8SW5mb1dyYXBwZXIgYm94VHlwZT17dHlwZX0+XG4gICAgICAgICAgPEljb25XcmFwcGVyIGJveFR5cGU9e3R5cGV9PlxuICAgICAgICAgICAgPEljb24gc3R5bGU9e3sgd2lkdGg6ICcyNHB4JywgaGVpZ2h0OiAnMjRweCcgfX0gLz5cbiAgICAgICAgICA8L0ljb25XcmFwcGVyPlxuICAgICAgICAgIDxUZXh0V3JhcHBlcj57Y2hpbGRyZW59PC9UZXh0V3JhcHBlcj5cbiAgICAgICAgPC9JbmZvV3JhcHBlcj5cbiAgICAgICAge3Nob3dDbG9zZUJ1dHRvbiAmJiAoXG4gICAgICAgICAgPENsb3NlQnV0dG9uV3JhcHBlcj5cbiAgICAgICAgICAgIDxDbG9zZUJ1dHRvbiBvbkNsaWNrPXtvbkNsb3NlTWVzc2FnZUJveH0gLz5cbiAgICAgICAgICA8L0Nsb3NlQnV0dG9uV3JhcHBlcj5cbiAgICAgICAgKX1cbiAgICAgIDwvV3JhcHBlcj5cblxuICAgICAge2xpbmtzICYmIChcbiAgICAgICAgLy9sb29wcyB0aHJvdWdoIHRoZSBsaW5rcyBwYXNzZWQgaW4gYXMgcHJvcGVydGllcyBpZiB0aGVyZSBhcmUgYW55IGFuZCBjcmVhdGVzIGEgd29ya2luZyBsaW5rIGZvciBlYWNoIG9mIHRoZW1cbiAgICAgICAgPExpbmtXcmFwcGVyIHN0eWxlPXt7IGRpc3BsYXk6IGhpZGVNZXNzYWdlQm94ID8gJ25vbmUnIDogJ2ZsZXgnIH19PlxuICAgICAgICAgIHtsaW5rcy5tYXAoKHgpID0+IChcbiAgICAgICAgICAgIDxMaW5rIGhyZWY9e3guaHJlZn0+e3gudGV4dH08L0xpbms+XG4gICAgICAgICAgKSl9XG4gICAgICAgIDwvTGlua1dyYXBwZXI+XG4gICAgICApfVxuICAgIDwvU3RpY2t5PlxuICApO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgd2l0aFRyYW5zbGF0aW9uKCkoTWVzc2FnZUJveCk7XG4iXX0= */"));
108
+ }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["MessageBox.tsx"],"names":[],"mappings":"AAuEwC","file":"MessageBox.tsx","sourcesContent":["/**\n * Copyright (c) 2022-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, { HTMLAttributes, useState } from 'react';\nimport styled from '@emotion/styled';\nimport Sticky from 'react-sticky-el';\nimport { breakpoints, fonts, mq, spacing } from '@ndla/core';\nimport { InformationOutline, HumanMaleBoard } from '@ndla/icons/common';\nimport { WithTranslation, withTranslation } from 'react-i18next';\n\n// @ts-ignore\nimport { Remarkable } from 'remarkable';\nimport { CloseButton } from '../CloseButton';\n\nexport enum MessageBoxType {\n  ghost = 'ghost',\n  fullpage = 'fullpage',\n  medium = 'medium',\n  masthead = 'masthead',\n}\ntype WrapperProps = {\n  boxType?: MessageBoxType;\n};\n\nconst StyleByType = (type: WrapperProps['boxType']) => {\n  const styles: HTMLAttributes<HTMLElement>['style'] = {\n    margin: '1px',\n    color: '#444444',\n    backgroundColor: '#f9f4c8',\n    border: 'none',\n    display: 'flex',\n    padding: '10px',\n    width: 'auto',\n    borderRadius: '5px',\n    position: 'relative',\n    transform: 'auto',\n    left: 'auto',\n  }; //Different CSS properties for different types of message-boxes\n  switch (type) {\n    case 'fullpage':\n      styles.margin = '0 auto';\n      styles.display = 'none';\n      styles.width = '100vw';\n      styles.position = 'relative';\n      styles.left = '50%';\n      styles.padding = '0';\n      styles.transform = 'translateX(-50%)';\n      break;\n    case 'medium':\n      styles.margin = '0px';\n      break;\n    case 'ghost':\n      styles.backgroundColor = 'transparent';\n      styles.border = '1px solid #D1D6DB';\n      styles.color = '#444444';\n      break;\n    case 'masthead':\n      styles.margin = '0 auto';\n      styles.display = 'none';\n      styles.padding = '0';\n      styles.borderRadius = '0';\n      break;\n  }\n  return styles;\n};\n\nconst Wrapper = styled.div<WrapperProps>`\n  background: ${(props) => StyleByType(props.boxType).backgroundColor};\n  color: ${(props) => StyleByType(props.boxType).color};\n  font-size: 18px;\n  line-height: 32px;\n  font-family: ${fonts.sans};\n  display: flex;\n  padding: ${spacing.small};\n  position: ${(props) => StyleByType(props.boxType).position};\n  border: ${(props) => StyleByType(props.boxType).border};\n  border-radius: ${(props) => StyleByType(props.boxType).borderRadius};\n  transform: ${(props) => StyleByType(props.boxType).transform};\n  left: ${(props) => StyleByType(props.boxType).left};\n  z-index: 10;\n  width: ${(props) => StyleByType(props.boxType).width};\n`;\n\nconst InfoWrapper = styled.div<WrapperProps>`\n  margin: ${(props) => StyleByType(props.boxType).margin};\n  padding: ${(props) => StyleByType(props.boxType).padding};\n  display: flex;\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    padding: 0 90px 0 0;\n  }\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    padding: 0 5px 0 0;\n    font-size: 16px;\n  }\n`;\nconst TextWrapper = styled.div<WrapperProps>`\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    line-height: 24px;\n    font-size: 16px;\n  }\n  & p {\n    margin: 0;\n  }\n`;\n\nconst IconWrapper = styled.div<WrapperProps>`\n  padding-right: ${spacing.small};\n  display: ${(props) => StyleByType(props.boxType).display};\n  align-items: flex-start;\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding-top: 4px;\n  }\n`;\n\nconst LinkWrapper = styled.div`\n  display: block;\n  width: 100%;\n  background-color: #f9f4c8;\n  padding-bottom: 20px;\n  margin-top: -2px;\n  padding-left: 58px;\n  border-radius: 0px 0px 5px 5px;\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    padding-left: 45px;\n  }\n`;\nconst Link = styled.a`\n  color: #20588f;\n  font-size: 16px;\n  padding-bottom: 1px;\n  margin: 0px 40px 1px 2px;\n  font-family: ${fonts.sans};\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    margin: 0px 15px 1px 5px;\n    box-shadow: none;\n  }\n`;\nconst CloseButtonWrapper = styled.div`\n  position: absolute;\n  top: 10px;\n  right: 1px;\n`;\n\ntype LinkProps = {\n  href?: string;\n  text?: string;\n};\ntype Props = {\n  type?: WrapperProps['boxType'];\n  sticky?: boolean;\n  children?: string;\n  links?: LinkProps[];\n  showCloseButton?: boolean;\n  onClose?: () => void;\n};\n\nconst markdown = new Remarkable({ breaks: true });\nmarkdown.inline.ruler.enable(['sub', 'sup']);\nmarkdown.block.ruler.disable(['list', 'table']);\n\nexport const MessageBox = ({\n  type,\n  sticky = false,\n  children = '',\n  links,\n  showCloseButton,\n  onClose,\n}: Props & WithTranslation) => {\n  const [hideMessageBox, setHideMessageBox] = useState(false);\n  const onCloseMessageBox = () => {\n    setHideMessageBox(true);\n    onClose?.();\n  };\n  const Icon = type === 'ghost' ? HumanMaleBoard : InformationOutline;\n  return (\n    //StickyStyle top:84 makes sure that the messagebox sits beneath the masthead (header ) and the topOffsett sets it so that it applies when reaching the top of the messagebox\n    <Sticky disabled={!sticky} stickyStyle={{ zIndex: 9998, top: 84 }} topOffset={-84}>\n      <Wrapper boxType={type} style={{ display: hideMessageBox ? 'none' : 'flex' }}>\n        <InfoWrapper boxType={type}>\n          <IconWrapper boxType={type}>\n            <Icon style={{ width: '24px', height: '24px' }} />\n          </IconWrapper>\n          <TextWrapper dangerouslySetInnerHTML={{ __html: markdown.render(children) }}></TextWrapper>\n        </InfoWrapper>\n        {showCloseButton && (\n          <CloseButtonWrapper>\n            <CloseButton onClick={onCloseMessageBox} />\n          </CloseButtonWrapper>\n        )}\n      </Wrapper>\n\n      {links && (\n        //loops through the links passed in as properties if there are any and creates a working link for each of them\n        <LinkWrapper style={{ display: hideMessageBox ? 'none' : 'flex' }}>\n          {links.map((x) => (\n            <Link href={x.href}>{x.text}</Link>\n          ))}\n        </LinkWrapper>\n      )}\n    </Sticky>\n  );\n};\n\nexport default withTranslation()(MessageBox);\n"]} */"));
106
109
 
107
110
  var InfoWrapper = _styled("div", {
108
111
  target: "e1ckcvyi1",
@@ -115,14 +118,14 @@ var InfoWrapper = _styled("div", {
115
118
  until: breakpoints.tabletWide
116
119
  }), "{padding:0 90px 0 0;}", mq.range({
117
120
  until: breakpoints.mobileWide
118
- }), "{padding:0 5px 0 0;font-size:16px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIk1lc3NhZ2VCb3gudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQW9GNEMiLCJmaWxlIjoiTWVzc2FnZUJveC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAyMi1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCBSZWFjdCwgeyBIVE1MQXR0cmlidXRlcywgdXNlU3RhdGUgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgU3RpY2t5IGZyb20gJ3JlYWN0LXN0aWNreS1lbCc7XG5pbXBvcnQgeyBicmVha3BvaW50cywgZm9udHMsIG1xLCBzcGFjaW5nIH0gZnJvbSAnQG5kbGEvY29yZSc7XG5pbXBvcnQgeyBJbmZvcm1hdGlvbk91dGxpbmUsIEh1bWFuTWFsZUJvYXJkIH0gZnJvbSAnQG5kbGEvaWNvbnMvY29tbW9uJztcbmltcG9ydCB7IFdpdGhUcmFuc2xhdGlvbiwgd2l0aFRyYW5zbGF0aW9uIH0gZnJvbSAncmVhY3QtaTE4bmV4dCc7XG5pbXBvcnQgeyBDbG9zZUJ1dHRvbiB9IGZyb20gJy4uL0Nsb3NlQnV0dG9uJztcblxuZXhwb3J0IGVudW0gTWVzc2FnZUJveFR5cGUge1xuICBnaG9zdCA9ICdnaG9zdCcsXG4gIGZ1bGxwYWdlID0gJ2Z1bGxwYWdlJyxcbiAgbWVkaXVtID0gJ21lZGl1bScsXG4gIG1hc3RoZWFkID0gJ21hc3RoZWFkJyxcbn1cbnR5cGUgV3JhcHBlclByb3BzID0ge1xuICBib3hUeXBlPzogTWVzc2FnZUJveFR5cGU7XG59O1xuXG5jb25zdCBTdHlsZUJ5VHlwZSA9ICh0eXBlOiBXcmFwcGVyUHJvcHNbJ2JveFR5cGUnXSkgPT4ge1xuICBjb25zdCBzdHlsZXM6IEhUTUxBdHRyaWJ1dGVzPEhUTUxFbGVtZW50Plsnc3R5bGUnXSA9IHtcbiAgICBtYXJnaW46ICcxcHgnLFxuICAgIGNvbG9yOiAnIzQ0NDQ0NCcsXG4gICAgYmFja2dyb3VuZENvbG9yOiAnI2Y5ZjRjOCcsXG4gICAgYm9yZGVyOiAnbm9uZScsXG4gICAgZGlzcGxheTogJ2ZsZXgnLFxuICAgIHBhZGRpbmc6ICcxMHB4JyxcbiAgICB3aWR0aDogJ2F1dG8nLFxuICAgIGJvcmRlclJhZGl1czogJzVweCcsXG4gICAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gICAgdHJhbnNmb3JtOiAnYXV0bycsXG4gICAgbGVmdDogJ2F1dG8nLFxuICB9OyAvL0RpZmZlcmVudCBDU1MgcHJvcGVydGllcyBmb3IgZGlmZmVyZW50IHR5cGVzIG9mIG1lc3NhZ2UtYm94ZXNcbiAgc3dpdGNoICh0eXBlKSB7XG4gICAgY2FzZSAnZnVsbHBhZ2UnOlxuICAgICAgc3R5bGVzLm1hcmdpbiA9ICcwIGF1dG8nO1xuICAgICAgc3R5bGVzLmRpc3BsYXkgPSAnbm9uZSc7XG4gICAgICBzdHlsZXMud2lkdGggPSAnMTAwdncnO1xuICAgICAgc3R5bGVzLnBvc2l0aW9uID0gJ3JlbGF0aXZlJztcbiAgICAgIHN0eWxlcy5sZWZ0ID0gJzUwJSc7XG4gICAgICBzdHlsZXMudHJhbnNmb3JtID0gJ3RyYW5zbGF0ZVgoLTUwJSknO1xuICAgICAgYnJlYWs7XG4gICAgY2FzZSAnbWVkaXVtJzpcbiAgICAgIHN0eWxlcy5tYXJnaW4gPSAnMHB4JztcbiAgICAgIGJyZWFrO1xuICAgIGNhc2UgJ2dob3N0JzpcbiAgICAgIHN0eWxlcy5iYWNrZ3JvdW5kQ29sb3IgPSAndHJhbnNwYXJlbnQnO1xuICAgICAgc3R5bGVzLmJvcmRlciA9ICcxcHggc29saWQgI0QxRDZEQic7XG4gICAgICBzdHlsZXMuY29sb3IgPSAnIzQ0NDQ0NCc7XG4gICAgICBicmVhaztcbiAgICBjYXNlICdtYXN0aGVhZCc6XG4gICAgICBzdHlsZXMubWFyZ2luID0gJzAgYXV0byc7XG4gICAgICBzdHlsZXMuZGlzcGxheSA9ICdub25lJztcbiAgICAgIHN0eWxlcy5wYWRkaW5nID0gJzAnO1xuICAgICAgc3R5bGVzLmJvcmRlclJhZGl1cyA9ICcwJztcbiAgICAgIGJyZWFrO1xuICB9XG4gIHJldHVybiBzdHlsZXM7XG59O1xuXG5jb25zdCBXcmFwcGVyID0gc3R5bGVkLmRpdjxXcmFwcGVyUHJvcHM+YFxuICBiYWNrZ3JvdW5kOiAkeyhwcm9wcykgPT4gU3R5bGVCeVR5cGUocHJvcHMuYm94VHlwZSkuYmFja2dyb3VuZENvbG9yfTtcbiAgY29sb3I6ICR7KHByb3BzKSA9PiBTdHlsZUJ5VHlwZShwcm9wcy5ib3hUeXBlKS5jb2xvcn07XG4gIGZvbnQtc2l6ZTogMThweDtcbiAgbGluZS1oZWlnaHQ6IDMycHg7XG4gIGZvbnQtZmFtaWx5OiAke2ZvbnRzLnNhbnN9O1xuICBkaXNwbGF5OiBmbGV4O1xuICBwYWRkaW5nOiAke3NwYWNpbmcuc21hbGx9O1xuICBwb3NpdGlvbjogJHsocHJvcHMpID0+IFN0eWxlQnlUeXBlKHByb3BzLmJveFR5cGUpLnBvc2l0aW9ufTtcbiAgYm9yZGVyOiAkeyhwcm9wcykgPT4gU3R5bGVCeVR5cGUocHJvcHMuYm94VHlwZSkuYm9yZGVyfTtcbiAgYm9yZGVyLXJhZGl1czogJHsocHJvcHMpID0+IFN0eWxlQnlUeXBlKHByb3BzLmJveFR5cGUpLmJvcmRlclJhZGl1c307XG4gIHRyYW5zZm9ybTogJHsocHJvcHMpID0+IFN0eWxlQnlUeXBlKHByb3BzLmJveFR5cGUpLnRyYW5zZm9ybX07XG4gIGxlZnQ6ICR7KHByb3BzKSA9PiBTdHlsZUJ5VHlwZShwcm9wcy5ib3hUeXBlKS5sZWZ0fTtcbiAgei1pbmRleDogMTA7XG4gIHdpZHRoOiAkeyhwcm9wcykgPT4gU3R5bGVCeVR5cGUocHJvcHMuYm94VHlwZSkud2lkdGh9O1xuYDtcblxuY29uc3QgSW5mb1dyYXBwZXIgPSBzdHlsZWQuZGl2PFdyYXBwZXJQcm9wcz5gXG4gIG1hcmdpbjogJHsocHJvcHMpID0+IFN0eWxlQnlUeXBlKHByb3BzLmJveFR5cGUpLm1hcmdpbn07XG4gIHBhZGRpbmc6ICR7KHByb3BzKSA9PiBTdHlsZUJ5VHlwZShwcm9wcy5ib3hUeXBlKS5wYWRkaW5nfTtcbiAgZGlzcGxheTogZmxleDtcbiAgJHttcS5yYW5nZSh7IHVudGlsOiBicmVha3BvaW50cy50YWJsZXRXaWRlIH0pfSB7XG4gICAgcGFkZGluZzogMCA5MHB4IDAgMDtcbiAgfVxuICAke21xLnJhbmdlKHsgdW50aWw6IGJyZWFrcG9pbnRzLm1vYmlsZVdpZGUgfSl9IHtcbiAgICBwYWRkaW5nOiAwIDVweCAwIDA7XG4gICAgZm9udC1zaXplOiAxNnB4O1xuICB9XG5gO1xuY29uc3QgVGV4dFdyYXBwZXIgPSBzdHlsZWQuZGl2PFdyYXBwZXJQcm9wcz5gXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGZsZXgtd3JhcDogd3JhcDtcbiAgJHttcS5yYW5nZSh7IHVudGlsOiBicmVha3BvaW50cy50YWJsZXRXaWRlIH0pfSB7XG4gICAgbGluZS1oZWlnaHQ6IDI0cHg7XG4gICAgZm9udC1zaXplOiAxNnB4O1xuICB9XG5gO1xuXG5jb25zdCBJY29uV3JhcHBlciA9IHN0eWxlZC5kaXY8V3JhcHBlclByb3BzPmBcbiAgcGFkZGluZy1yaWdodDogJHtzcGFjaW5nLnNtYWxsfTtcbiAgZGlzcGxheTogJHsocHJvcHMpID0+IFN0eWxlQnlUeXBlKHByb3BzLmJveFR5cGUpLmRpc3BsYXl9O1xuICBhbGlnbi1pdGVtczogZmxleC1zdGFydDtcbiAgJHttcS5yYW5nZSh7IGZyb206IGJyZWFrcG9pbnRzLnRhYmxldFdpZGUgfSl9IHtcbiAgICBwYWRkaW5nLXRvcDogNHB4O1xuICB9XG5gO1xuXG5jb25zdCBMaW5rV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIGRpc3BsYXk6IGJsb2NrO1xuICB3aWR0aDogMTAwJTtcbiAgYmFja2dyb3VuZC1jb2xvcjogI2Y5ZjRjODtcbiAgcGFkZGluZy1ib3R0b206IDIwcHg7XG4gIG1hcmdpbi10b3A6IC0ycHg7XG4gIHBhZGRpbmctbGVmdDogNThweDtcbiAgYm9yZGVyLXJhZGl1czogMHB4IDBweCA1cHggNXB4O1xuICAke21xLnJhbmdlKHsgdW50aWw6IGJyZWFrcG9pbnRzLm1vYmlsZVdpZGUgfSl9IHtcbiAgICBwYWRkaW5nLWxlZnQ6IDQ1cHg7XG4gIH1cbmA7XG5jb25zdCBMaW5rID0gc3R5bGVkLmFgXG4gIGNvbG9yOiAjMjA1ODhmO1xuICBmb250LXNpemU6IDE2cHg7XG4gIHBhZGRpbmctYm90dG9tOiAxcHg7XG4gIG1hcmdpbjogMHB4IDQwcHggMXB4IDJweDtcbiAgZm9udC1mYW1pbHk6ICR7Zm9udHMuc2Fuc307XG4gICR7bXEucmFuZ2UoeyB1bnRpbDogYnJlYWtwb2ludHMubW9iaWxlV2lkZSB9KX0ge1xuICAgIG1hcmdpbjogMHB4IDE1cHggMXB4IDVweDtcbiAgICBib3gtc2hhZG93OiBub25lO1xuICB9XG5gO1xuY29uc3QgQ2xvc2VCdXR0b25XcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgcG9zaXRpb246IGFic29sdXRlO1xuICB0b3A6IDEwcHg7XG4gIHJpZ2h0OiAxcHg7XG5gO1xuXG50eXBlIExpbmtQcm9wcyA9IHtcbiAgaHJlZj86IHN0cmluZztcbiAgdGV4dD86IHN0cmluZztcbn07XG50eXBlIFByb3BzID0ge1xuICB0eXBlPzogV3JhcHBlclByb3BzWydib3hUeXBlJ107XG4gIHN0aWNreT86IGJvb2xlYW47XG4gIGNoaWxkcmVuPzogc3RyaW5nO1xuICBsaW5rcz86IExpbmtQcm9wc1tdO1xuICBzaG93Q2xvc2VCdXR0b24/OiBib29sZWFuO1xufTtcblxuZXhwb3J0IGNvbnN0IE1lc3NhZ2VCb3ggPSAoeyB0eXBlLCBzdGlja3kgPSBmYWxzZSwgY2hpbGRyZW4sIGxpbmtzLCB0LCBzaG93Q2xvc2VCdXR0b24gfTogUHJvcHMgJiBXaXRoVHJhbnNsYXRpb24pID0+IHtcbiAgY29uc3QgW2hpZGVNZXNzYWdlQm94LCBzZXRIaWRlTWVzc2FnZUJveF0gPSB1c2VTdGF0ZShmYWxzZSk7XG4gIGNvbnN0IG9uQ2xvc2VNZXNzYWdlQm94ID0gKCkgPT4ge1xuICAgIHNldEhpZGVNZXNzYWdlQm94KHRydWUpO1xuICB9O1xuICBjb25zdCBJY29uID0gdHlwZSA9PT0gJ2dob3N0JyA/IEh1bWFuTWFsZUJvYXJkIDogSW5mb3JtYXRpb25PdXRsaW5lO1xuICByZXR1cm4gKFxuICAgIC8vU3RpY2t5U3R5bGUgdG9wOjg0IG1ha2VzIHN1cmUgdGhhdCB0aGUgbWVzc2FnZWJveCBzaXRzIGJlbmVhdGggdGhlIG1hc3RoZWFkIChoZWFkZXIgKSBhbmQgdGhlIHRvcE9mZnNldHQgc2V0cyBpdCBzbyB0aGF0IGl0IGFwcGxpZXMgd2hlbiByZWFjaGluZyB0aGUgdG9wIG9mIHRoZSBtZXNzYWdlYm94XG4gICAgPFN0aWNreSBkaXNhYmxlZD17IXN0aWNreX0gc3RpY2t5U3R5bGU9e3sgekluZGV4OiA5OTk4LCB0b3A6IDg0IH19IHRvcE9mZnNldD17LTg0fT5cbiAgICAgIDxXcmFwcGVyIGJveFR5cGU9e3R5cGV9IHN0eWxlPXt7IGRpc3BsYXk6IGhpZGVNZXNzYWdlQm94ID8gJ25vbmUnIDogJ2ZsZXgnIH19PlxuICAgICAgICA8SW5mb1dyYXBwZXIgYm94VHlwZT17dHlwZX0+XG4gICAgICAgICAgPEljb25XcmFwcGVyIGJveFR5cGU9e3R5cGV9PlxuICAgICAgICAgICAgPEljb24gc3R5bGU9e3sgd2lkdGg6ICcyNHB4JywgaGVpZ2h0OiAnMjRweCcgfX0gLz5cbiAgICAgICAgICA8L0ljb25XcmFwcGVyPlxuICAgICAgICAgIDxUZXh0V3JhcHBlcj57Y2hpbGRyZW59PC9UZXh0V3JhcHBlcj5cbiAgICAgICAgPC9JbmZvV3JhcHBlcj5cbiAgICAgICAge3Nob3dDbG9zZUJ1dHRvbiAmJiAoXG4gICAgICAgICAgPENsb3NlQnV0dG9uV3JhcHBlcj5cbiAgICAgICAgICAgIDxDbG9zZUJ1dHRvbiBvbkNsaWNrPXtvbkNsb3NlTWVzc2FnZUJveH0gLz5cbiAgICAgICAgICA8L0Nsb3NlQnV0dG9uV3JhcHBlcj5cbiAgICAgICAgKX1cbiAgICAgIDwvV3JhcHBlcj5cblxuICAgICAge2xpbmtzICYmIChcbiAgICAgICAgLy9sb29wcyB0aHJvdWdoIHRoZSBsaW5rcyBwYXNzZWQgaW4gYXMgcHJvcGVydGllcyBpZiB0aGVyZSBhcmUgYW55IGFuZCBjcmVhdGVzIGEgd29ya2luZyBsaW5rIGZvciBlYWNoIG9mIHRoZW1cbiAgICAgICAgPExpbmtXcmFwcGVyIHN0eWxlPXt7IGRpc3BsYXk6IGhpZGVNZXNzYWdlQm94ID8gJ25vbmUnIDogJ2ZsZXgnIH19PlxuICAgICAgICAgIHtsaW5rcy5tYXAoKHgpID0+IChcbiAgICAgICAgICAgIDxMaW5rIGhyZWY9e3guaHJlZn0+e3gudGV4dH08L0xpbms+XG4gICAgICAgICAgKSl9XG4gICAgICAgIDwvTGlua1dyYXBwZXI+XG4gICAgICApfVxuICAgIDwvU3RpY2t5PlxuICApO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgd2l0aFRyYW5zbGF0aW9uKCkoTWVzc2FnZUJveCk7XG4iXX0= */"));
121
+ }), "{padding:0 5px 0 0;font-size:16px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["MessageBox.tsx"],"names":[],"mappings":"AAwF4C","file":"MessageBox.tsx","sourcesContent":["/**\n * Copyright (c) 2022-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, { HTMLAttributes, useState } from 'react';\nimport styled from '@emotion/styled';\nimport Sticky from 'react-sticky-el';\nimport { breakpoints, fonts, mq, spacing } from '@ndla/core';\nimport { InformationOutline, HumanMaleBoard } from '@ndla/icons/common';\nimport { WithTranslation, withTranslation } from 'react-i18next';\n\n// @ts-ignore\nimport { Remarkable } from 'remarkable';\nimport { CloseButton } from '../CloseButton';\n\nexport enum MessageBoxType {\n  ghost = 'ghost',\n  fullpage = 'fullpage',\n  medium = 'medium',\n  masthead = 'masthead',\n}\ntype WrapperProps = {\n  boxType?: MessageBoxType;\n};\n\nconst StyleByType = (type: WrapperProps['boxType']) => {\n  const styles: HTMLAttributes<HTMLElement>['style'] = {\n    margin: '1px',\n    color: '#444444',\n    backgroundColor: '#f9f4c8',\n    border: 'none',\n    display: 'flex',\n    padding: '10px',\n    width: 'auto',\n    borderRadius: '5px',\n    position: 'relative',\n    transform: 'auto',\n    left: 'auto',\n  }; //Different CSS properties for different types of message-boxes\n  switch (type) {\n    case 'fullpage':\n      styles.margin = '0 auto';\n      styles.display = 'none';\n      styles.width = '100vw';\n      styles.position = 'relative';\n      styles.left = '50%';\n      styles.padding = '0';\n      styles.transform = 'translateX(-50%)';\n      break;\n    case 'medium':\n      styles.margin = '0px';\n      break;\n    case 'ghost':\n      styles.backgroundColor = 'transparent';\n      styles.border = '1px solid #D1D6DB';\n      styles.color = '#444444';\n      break;\n    case 'masthead':\n      styles.margin = '0 auto';\n      styles.display = 'none';\n      styles.padding = '0';\n      styles.borderRadius = '0';\n      break;\n  }\n  return styles;\n};\n\nconst Wrapper = styled.div<WrapperProps>`\n  background: ${(props) => StyleByType(props.boxType).backgroundColor};\n  color: ${(props) => StyleByType(props.boxType).color};\n  font-size: 18px;\n  line-height: 32px;\n  font-family: ${fonts.sans};\n  display: flex;\n  padding: ${spacing.small};\n  position: ${(props) => StyleByType(props.boxType).position};\n  border: ${(props) => StyleByType(props.boxType).border};\n  border-radius: ${(props) => StyleByType(props.boxType).borderRadius};\n  transform: ${(props) => StyleByType(props.boxType).transform};\n  left: ${(props) => StyleByType(props.boxType).left};\n  z-index: 10;\n  width: ${(props) => StyleByType(props.boxType).width};\n`;\n\nconst InfoWrapper = styled.div<WrapperProps>`\n  margin: ${(props) => StyleByType(props.boxType).margin};\n  padding: ${(props) => StyleByType(props.boxType).padding};\n  display: flex;\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    padding: 0 90px 0 0;\n  }\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    padding: 0 5px 0 0;\n    font-size: 16px;\n  }\n`;\nconst TextWrapper = styled.div<WrapperProps>`\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    line-height: 24px;\n    font-size: 16px;\n  }\n  & p {\n    margin: 0;\n  }\n`;\n\nconst IconWrapper = styled.div<WrapperProps>`\n  padding-right: ${spacing.small};\n  display: ${(props) => StyleByType(props.boxType).display};\n  align-items: flex-start;\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding-top: 4px;\n  }\n`;\n\nconst LinkWrapper = styled.div`\n  display: block;\n  width: 100%;\n  background-color: #f9f4c8;\n  padding-bottom: 20px;\n  margin-top: -2px;\n  padding-left: 58px;\n  border-radius: 0px 0px 5px 5px;\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    padding-left: 45px;\n  }\n`;\nconst Link = styled.a`\n  color: #20588f;\n  font-size: 16px;\n  padding-bottom: 1px;\n  margin: 0px 40px 1px 2px;\n  font-family: ${fonts.sans};\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    margin: 0px 15px 1px 5px;\n    box-shadow: none;\n  }\n`;\nconst CloseButtonWrapper = styled.div`\n  position: absolute;\n  top: 10px;\n  right: 1px;\n`;\n\ntype LinkProps = {\n  href?: string;\n  text?: string;\n};\ntype Props = {\n  type?: WrapperProps['boxType'];\n  sticky?: boolean;\n  children?: string;\n  links?: LinkProps[];\n  showCloseButton?: boolean;\n  onClose?: () => void;\n};\n\nconst markdown = new Remarkable({ breaks: true });\nmarkdown.inline.ruler.enable(['sub', 'sup']);\nmarkdown.block.ruler.disable(['list', 'table']);\n\nexport const MessageBox = ({\n  type,\n  sticky = false,\n  children = '',\n  links,\n  showCloseButton,\n  onClose,\n}: Props & WithTranslation) => {\n  const [hideMessageBox, setHideMessageBox] = useState(false);\n  const onCloseMessageBox = () => {\n    setHideMessageBox(true);\n    onClose?.();\n  };\n  const Icon = type === 'ghost' ? HumanMaleBoard : InformationOutline;\n  return (\n    //StickyStyle top:84 makes sure that the messagebox sits beneath the masthead (header ) and the topOffsett sets it so that it applies when reaching the top of the messagebox\n    <Sticky disabled={!sticky} stickyStyle={{ zIndex: 9998, top: 84 }} topOffset={-84}>\n      <Wrapper boxType={type} style={{ display: hideMessageBox ? 'none' : 'flex' }}>\n        <InfoWrapper boxType={type}>\n          <IconWrapper boxType={type}>\n            <Icon style={{ width: '24px', height: '24px' }} />\n          </IconWrapper>\n          <TextWrapper dangerouslySetInnerHTML={{ __html: markdown.render(children) }}></TextWrapper>\n        </InfoWrapper>\n        {showCloseButton && (\n          <CloseButtonWrapper>\n            <CloseButton onClick={onCloseMessageBox} />\n          </CloseButtonWrapper>\n        )}\n      </Wrapper>\n\n      {links && (\n        //loops through the links passed in as properties if there are any and creates a working link for each of them\n        <LinkWrapper style={{ display: hideMessageBox ? 'none' : 'flex' }}>\n          {links.map((x) => (\n            <Link href={x.href}>{x.text}</Link>\n          ))}\n        </LinkWrapper>\n      )}\n    </Sticky>\n  );\n};\n\nexport default withTranslation()(MessageBox);\n"]} */"));
119
122
 
120
123
  var TextWrapper = _styled("div", {
121
124
  target: "e1ckcvyi2",
122
125
  label: "TextWrapper"
123
126
  })("display:flex;align-items:center;flex-wrap:wrap;", mq.range({
124
127
  until: breakpoints.tabletWide
125
- }), "{line-height:24px;font-size:16px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIk1lc3NhZ2VCb3gudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWdHNEMiLCJmaWxlIjoiTWVzc2FnZUJveC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAyMi1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCBSZWFjdCwgeyBIVE1MQXR0cmlidXRlcywgdXNlU3RhdGUgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgU3RpY2t5IGZyb20gJ3JlYWN0LXN0aWNreS1lbCc7XG5pbXBvcnQgeyBicmVha3BvaW50cywgZm9udHMsIG1xLCBzcGFjaW5nIH0gZnJvbSAnQG5kbGEvY29yZSc7XG5pbXBvcnQgeyBJbmZvcm1hdGlvbk91dGxpbmUsIEh1bWFuTWFsZUJvYXJkIH0gZnJvbSAnQG5kbGEvaWNvbnMvY29tbW9uJztcbmltcG9ydCB7IFdpdGhUcmFuc2xhdGlvbiwgd2l0aFRyYW5zbGF0aW9uIH0gZnJvbSAncmVhY3QtaTE4bmV4dCc7XG5pbXBvcnQgeyBDbG9zZUJ1dHRvbiB9IGZyb20gJy4uL0Nsb3NlQnV0dG9uJztcblxuZXhwb3J0IGVudW0gTWVzc2FnZUJveFR5cGUge1xuICBnaG9zdCA9ICdnaG9zdCcsXG4gIGZ1bGxwYWdlID0gJ2Z1bGxwYWdlJyxcbiAgbWVkaXVtID0gJ21lZGl1bScsXG4gIG1hc3RoZWFkID0gJ21hc3RoZWFkJyxcbn1cbnR5cGUgV3JhcHBlclByb3BzID0ge1xuICBib3hUeXBlPzogTWVzc2FnZUJveFR5cGU7XG59O1xuXG5jb25zdCBTdHlsZUJ5VHlwZSA9ICh0eXBlOiBXcmFwcGVyUHJvcHNbJ2JveFR5cGUnXSkgPT4ge1xuICBjb25zdCBzdHlsZXM6IEhUTUxBdHRyaWJ1dGVzPEhUTUxFbGVtZW50Plsnc3R5bGUnXSA9IHtcbiAgICBtYXJnaW46ICcxcHgnLFxuICAgIGNvbG9yOiAnIzQ0NDQ0NCcsXG4gICAgYmFja2dyb3VuZENvbG9yOiAnI2Y5ZjRjOCcsXG4gICAgYm9yZGVyOiAnbm9uZScsXG4gICAgZGlzcGxheTogJ2ZsZXgnLFxuICAgIHBhZGRpbmc6ICcxMHB4JyxcbiAgICB3aWR0aDogJ2F1dG8nLFxuICAgIGJvcmRlclJhZGl1czogJzVweCcsXG4gICAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gICAgdHJhbnNmb3JtOiAnYXV0bycsXG4gICAgbGVmdDogJ2F1dG8nLFxuICB9OyAvL0RpZmZlcmVudCBDU1MgcHJvcGVydGllcyBmb3IgZGlmZmVyZW50IHR5cGVzIG9mIG1lc3NhZ2UtYm94ZXNcbiAgc3dpdGNoICh0eXBlKSB7XG4gICAgY2FzZSAnZnVsbHBhZ2UnOlxuICAgICAgc3R5bGVzLm1hcmdpbiA9ICcwIGF1dG8nO1xuICAgICAgc3R5bGVzLmRpc3BsYXkgPSAnbm9uZSc7XG4gICAgICBzdHlsZXMud2lkdGggPSAnMTAwdncnO1xuICAgICAgc3R5bGVzLnBvc2l0aW9uID0gJ3JlbGF0aXZlJztcbiAgICAgIHN0eWxlcy5sZWZ0ID0gJzUwJSc7XG4gICAgICBzdHlsZXMudHJhbnNmb3JtID0gJ3RyYW5zbGF0ZVgoLTUwJSknO1xuICAgICAgYnJlYWs7XG4gICAgY2FzZSAnbWVkaXVtJzpcbiAgICAgIHN0eWxlcy5tYXJnaW4gPSAnMHB4JztcbiAgICAgIGJyZWFrO1xuICAgIGNhc2UgJ2dob3N0JzpcbiAgICAgIHN0eWxlcy5iYWNrZ3JvdW5kQ29sb3IgPSAndHJhbnNwYXJlbnQnO1xuICAgICAgc3R5bGVzLmJvcmRlciA9ICcxcHggc29saWQgI0QxRDZEQic7XG4gICAgICBzdHlsZXMuY29sb3IgPSAnIzQ0NDQ0NCc7XG4gICAgICBicmVhaztcbiAgICBjYXNlICdtYXN0aGVhZCc6XG4gICAgICBzdHlsZXMubWFyZ2luID0gJzAgYXV0byc7XG4gICAgICBzdHlsZXMuZGlzcGxheSA9ICdub25lJztcbiAgICAgIHN0eWxlcy5wYWRkaW5nID0gJzAnO1xuICAgICAgc3R5bGVzLmJvcmRlclJhZGl1cyA9ICcwJztcbiAgICAgIGJyZWFrO1xuICB9XG4gIHJldHVybiBzdHlsZXM7XG59O1xuXG5jb25zdCBXcmFwcGVyID0gc3R5bGVkLmRpdjxXcmFwcGVyUHJvcHM+YFxuICBiYWNrZ3JvdW5kOiAkeyhwcm9wcykgPT4gU3R5bGVCeVR5cGUocHJvcHMuYm94VHlwZSkuYmFja2dyb3VuZENvbG9yfTtcbiAgY29sb3I6ICR7KHByb3BzKSA9PiBTdHlsZUJ5VHlwZShwcm9wcy5ib3hUeXBlKS5jb2xvcn07XG4gIGZvbnQtc2l6ZTogMThweDtcbiAgbGluZS1oZWlnaHQ6IDMycHg7XG4gIGZvbnQtZmFtaWx5OiAke2ZvbnRzLnNhbnN9O1xuICBkaXNwbGF5OiBmbGV4O1xuICBwYWRkaW5nOiAke3NwYWNpbmcuc21hbGx9O1xuICBwb3NpdGlvbjogJHsocHJvcHMpID0+IFN0eWxlQnlUeXBlKHByb3BzLmJveFR5cGUpLnBvc2l0aW9ufTtcbiAgYm9yZGVyOiAkeyhwcm9wcykgPT4gU3R5bGVCeVR5cGUocHJvcHMuYm94VHlwZSkuYm9yZGVyfTtcbiAgYm9yZGVyLXJhZGl1czogJHsocHJvcHMpID0+IFN0eWxlQnlUeXBlKHByb3BzLmJveFR5cGUpLmJvcmRlclJhZGl1c307XG4gIHRyYW5zZm9ybTogJHsocHJvcHMpID0+IFN0eWxlQnlUeXBlKHByb3BzLmJveFR5cGUpLnRyYW5zZm9ybX07XG4gIGxlZnQ6ICR7KHByb3BzKSA9PiBTdHlsZUJ5VHlwZShwcm9wcy5ib3hUeXBlKS5sZWZ0fTtcbiAgei1pbmRleDogMTA7XG4gIHdpZHRoOiAkeyhwcm9wcykgPT4gU3R5bGVCeVR5cGUocHJvcHMuYm94VHlwZSkud2lkdGh9O1xuYDtcblxuY29uc3QgSW5mb1dyYXBwZXIgPSBzdHlsZWQuZGl2PFdyYXBwZXJQcm9wcz5gXG4gIG1hcmdpbjogJHsocHJvcHMpID0+IFN0eWxlQnlUeXBlKHByb3BzLmJveFR5cGUpLm1hcmdpbn07XG4gIHBhZGRpbmc6ICR7KHByb3BzKSA9PiBTdHlsZUJ5VHlwZShwcm9wcy5ib3hUeXBlKS5wYWRkaW5nfTtcbiAgZGlzcGxheTogZmxleDtcbiAgJHttcS5yYW5nZSh7IHVudGlsOiBicmVha3BvaW50cy50YWJsZXRXaWRlIH0pfSB7XG4gICAgcGFkZGluZzogMCA5MHB4IDAgMDtcbiAgfVxuICAke21xLnJhbmdlKHsgdW50aWw6IGJyZWFrcG9pbnRzLm1vYmlsZVdpZGUgfSl9IHtcbiAgICBwYWRkaW5nOiAwIDVweCAwIDA7XG4gICAgZm9udC1zaXplOiAxNnB4O1xuICB9XG5gO1xuY29uc3QgVGV4dFdyYXBwZXIgPSBzdHlsZWQuZGl2PFdyYXBwZXJQcm9wcz5gXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGZsZXgtd3JhcDogd3JhcDtcbiAgJHttcS5yYW5nZSh7IHVudGlsOiBicmVha3BvaW50cy50YWJsZXRXaWRlIH0pfSB7XG4gICAgbGluZS1oZWlnaHQ6IDI0cHg7XG4gICAgZm9udC1zaXplOiAxNnB4O1xuICB9XG5gO1xuXG5jb25zdCBJY29uV3JhcHBlciA9IHN0eWxlZC5kaXY8V3JhcHBlclByb3BzPmBcbiAgcGFkZGluZy1yaWdodDogJHtzcGFjaW5nLnNtYWxsfTtcbiAgZGlzcGxheTogJHsocHJvcHMpID0+IFN0eWxlQnlUeXBlKHByb3BzLmJveFR5cGUpLmRpc3BsYXl9O1xuICBhbGlnbi1pdGVtczogZmxleC1zdGFydDtcbiAgJHttcS5yYW5nZSh7IGZyb206IGJyZWFrcG9pbnRzLnRhYmxldFdpZGUgfSl9IHtcbiAgICBwYWRkaW5nLXRvcDogNHB4O1xuICB9XG5gO1xuXG5jb25zdCBMaW5rV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIGRpc3BsYXk6IGJsb2NrO1xuICB3aWR0aDogMTAwJTtcbiAgYmFja2dyb3VuZC1jb2xvcjogI2Y5ZjRjODtcbiAgcGFkZGluZy1ib3R0b206IDIwcHg7XG4gIG1hcmdpbi10b3A6IC0ycHg7XG4gIHBhZGRpbmctbGVmdDogNThweDtcbiAgYm9yZGVyLXJhZGl1czogMHB4IDBweCA1cHggNXB4O1xuICAke21xLnJhbmdlKHsgdW50aWw6IGJyZWFrcG9pbnRzLm1vYmlsZVdpZGUgfSl9IHtcbiAgICBwYWRkaW5nLWxlZnQ6IDQ1cHg7XG4gIH1cbmA7XG5jb25zdCBMaW5rID0gc3R5bGVkLmFgXG4gIGNvbG9yOiAjMjA1ODhmO1xuICBmb250LXNpemU6IDE2cHg7XG4gIHBhZGRpbmctYm90dG9tOiAxcHg7XG4gIG1hcmdpbjogMHB4IDQwcHggMXB4IDJweDtcbiAgZm9udC1mYW1pbHk6ICR7Zm9udHMuc2Fuc307XG4gICR7bXEucmFuZ2UoeyB1bnRpbDogYnJlYWtwb2ludHMubW9iaWxlV2lkZSB9KX0ge1xuICAgIG1hcmdpbjogMHB4IDE1cHggMXB4IDVweDtcbiAgICBib3gtc2hhZG93OiBub25lO1xuICB9XG5gO1xuY29uc3QgQ2xvc2VCdXR0b25XcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgcG9zaXRpb246IGFic29sdXRlO1xuICB0b3A6IDEwcHg7XG4gIHJpZ2h0OiAxcHg7XG5gO1xuXG50eXBlIExpbmtQcm9wcyA9IHtcbiAgaHJlZj86IHN0cmluZztcbiAgdGV4dD86IHN0cmluZztcbn07XG50eXBlIFByb3BzID0ge1xuICB0eXBlPzogV3JhcHBlclByb3BzWydib3hUeXBlJ107XG4gIHN0aWNreT86IGJvb2xlYW47XG4gIGNoaWxkcmVuPzogc3RyaW5nO1xuICBsaW5rcz86IExpbmtQcm9wc1tdO1xuICBzaG93Q2xvc2VCdXR0b24/OiBib29sZWFuO1xufTtcblxuZXhwb3J0IGNvbnN0IE1lc3NhZ2VCb3ggPSAoeyB0eXBlLCBzdGlja3kgPSBmYWxzZSwgY2hpbGRyZW4sIGxpbmtzLCB0LCBzaG93Q2xvc2VCdXR0b24gfTogUHJvcHMgJiBXaXRoVHJhbnNsYXRpb24pID0+IHtcbiAgY29uc3QgW2hpZGVNZXNzYWdlQm94LCBzZXRIaWRlTWVzc2FnZUJveF0gPSB1c2VTdGF0ZShmYWxzZSk7XG4gIGNvbnN0IG9uQ2xvc2VNZXNzYWdlQm94ID0gKCkgPT4ge1xuICAgIHNldEhpZGVNZXNzYWdlQm94KHRydWUpO1xuICB9O1xuICBjb25zdCBJY29uID0gdHlwZSA9PT0gJ2dob3N0JyA/IEh1bWFuTWFsZUJvYXJkIDogSW5mb3JtYXRpb25PdXRsaW5lO1xuICByZXR1cm4gKFxuICAgIC8vU3RpY2t5U3R5bGUgdG9wOjg0IG1ha2VzIHN1cmUgdGhhdCB0aGUgbWVzc2FnZWJveCBzaXRzIGJlbmVhdGggdGhlIG1hc3RoZWFkIChoZWFkZXIgKSBhbmQgdGhlIHRvcE9mZnNldHQgc2V0cyBpdCBzbyB0aGF0IGl0IGFwcGxpZXMgd2hlbiByZWFjaGluZyB0aGUgdG9wIG9mIHRoZSBtZXNzYWdlYm94XG4gICAgPFN0aWNreSBkaXNhYmxlZD17IXN0aWNreX0gc3RpY2t5U3R5bGU9e3sgekluZGV4OiA5OTk4LCB0b3A6IDg0IH19IHRvcE9mZnNldD17LTg0fT5cbiAgICAgIDxXcmFwcGVyIGJveFR5cGU9e3R5cGV9IHN0eWxlPXt7IGRpc3BsYXk6IGhpZGVNZXNzYWdlQm94ID8gJ25vbmUnIDogJ2ZsZXgnIH19PlxuICAgICAgICA8SW5mb1dyYXBwZXIgYm94VHlwZT17dHlwZX0+XG4gICAgICAgICAgPEljb25XcmFwcGVyIGJveFR5cGU9e3R5cGV9PlxuICAgICAgICAgICAgPEljb24gc3R5bGU9e3sgd2lkdGg6ICcyNHB4JywgaGVpZ2h0OiAnMjRweCcgfX0gLz5cbiAgICAgICAgICA8L0ljb25XcmFwcGVyPlxuICAgICAgICAgIDxUZXh0V3JhcHBlcj57Y2hpbGRyZW59PC9UZXh0V3JhcHBlcj5cbiAgICAgICAgPC9JbmZvV3JhcHBlcj5cbiAgICAgICAge3Nob3dDbG9zZUJ1dHRvbiAmJiAoXG4gICAgICAgICAgPENsb3NlQnV0dG9uV3JhcHBlcj5cbiAgICAgICAgICAgIDxDbG9zZUJ1dHRvbiBvbkNsaWNrPXtvbkNsb3NlTWVzc2FnZUJveH0gLz5cbiAgICAgICAgICA8L0Nsb3NlQnV0dG9uV3JhcHBlcj5cbiAgICAgICAgKX1cbiAgICAgIDwvV3JhcHBlcj5cblxuICAgICAge2xpbmtzICYmIChcbiAgICAgICAgLy9sb29wcyB0aHJvdWdoIHRoZSBsaW5rcyBwYXNzZWQgaW4gYXMgcHJvcGVydGllcyBpZiB0aGVyZSBhcmUgYW55IGFuZCBjcmVhdGVzIGEgd29ya2luZyBsaW5rIGZvciBlYWNoIG9mIHRoZW1cbiAgICAgICAgPExpbmtXcmFwcGVyIHN0eWxlPXt7IGRpc3BsYXk6IGhpZGVNZXNzYWdlQm94ID8gJ25vbmUnIDogJ2ZsZXgnIH19PlxuICAgICAgICAgIHtsaW5rcy5tYXAoKHgpID0+IChcbiAgICAgICAgICAgIDxMaW5rIGhyZWY9e3guaHJlZn0+e3gudGV4dH08L0xpbms+XG4gICAgICAgICAgKSl9XG4gICAgICAgIDwvTGlua1dyYXBwZXI+XG4gICAgICApfVxuICAgIDwvU3RpY2t5PlxuICApO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgd2l0aFRyYW5zbGF0aW9uKCkoTWVzc2FnZUJveCk7XG4iXX0= */"));
128
+ }), "{line-height:24px;font-size:16px;}& p{margin:0;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["MessageBox.tsx"],"names":[],"mappings":"AAoG4C","file":"MessageBox.tsx","sourcesContent":["/**\n * Copyright (c) 2022-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, { HTMLAttributes, useState } from 'react';\nimport styled from '@emotion/styled';\nimport Sticky from 'react-sticky-el';\nimport { breakpoints, fonts, mq, spacing } from '@ndla/core';\nimport { InformationOutline, HumanMaleBoard } from '@ndla/icons/common';\nimport { WithTranslation, withTranslation } from 'react-i18next';\n\n// @ts-ignore\nimport { Remarkable } from 'remarkable';\nimport { CloseButton } from '../CloseButton';\n\nexport enum MessageBoxType {\n  ghost = 'ghost',\n  fullpage = 'fullpage',\n  medium = 'medium',\n  masthead = 'masthead',\n}\ntype WrapperProps = {\n  boxType?: MessageBoxType;\n};\n\nconst StyleByType = (type: WrapperProps['boxType']) => {\n  const styles: HTMLAttributes<HTMLElement>['style'] = {\n    margin: '1px',\n    color: '#444444',\n    backgroundColor: '#f9f4c8',\n    border: 'none',\n    display: 'flex',\n    padding: '10px',\n    width: 'auto',\n    borderRadius: '5px',\n    position: 'relative',\n    transform: 'auto',\n    left: 'auto',\n  }; //Different CSS properties for different types of message-boxes\n  switch (type) {\n    case 'fullpage':\n      styles.margin = '0 auto';\n      styles.display = 'none';\n      styles.width = '100vw';\n      styles.position = 'relative';\n      styles.left = '50%';\n      styles.padding = '0';\n      styles.transform = 'translateX(-50%)';\n      break;\n    case 'medium':\n      styles.margin = '0px';\n      break;\n    case 'ghost':\n      styles.backgroundColor = 'transparent';\n      styles.border = '1px solid #D1D6DB';\n      styles.color = '#444444';\n      break;\n    case 'masthead':\n      styles.margin = '0 auto';\n      styles.display = 'none';\n      styles.padding = '0';\n      styles.borderRadius = '0';\n      break;\n  }\n  return styles;\n};\n\nconst Wrapper = styled.div<WrapperProps>`\n  background: ${(props) => StyleByType(props.boxType).backgroundColor};\n  color: ${(props) => StyleByType(props.boxType).color};\n  font-size: 18px;\n  line-height: 32px;\n  font-family: ${fonts.sans};\n  display: flex;\n  padding: ${spacing.small};\n  position: ${(props) => StyleByType(props.boxType).position};\n  border: ${(props) => StyleByType(props.boxType).border};\n  border-radius: ${(props) => StyleByType(props.boxType).borderRadius};\n  transform: ${(props) => StyleByType(props.boxType).transform};\n  left: ${(props) => StyleByType(props.boxType).left};\n  z-index: 10;\n  width: ${(props) => StyleByType(props.boxType).width};\n`;\n\nconst InfoWrapper = styled.div<WrapperProps>`\n  margin: ${(props) => StyleByType(props.boxType).margin};\n  padding: ${(props) => StyleByType(props.boxType).padding};\n  display: flex;\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    padding: 0 90px 0 0;\n  }\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    padding: 0 5px 0 0;\n    font-size: 16px;\n  }\n`;\nconst TextWrapper = styled.div<WrapperProps>`\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    line-height: 24px;\n    font-size: 16px;\n  }\n  & p {\n    margin: 0;\n  }\n`;\n\nconst IconWrapper = styled.div<WrapperProps>`\n  padding-right: ${spacing.small};\n  display: ${(props) => StyleByType(props.boxType).display};\n  align-items: flex-start;\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding-top: 4px;\n  }\n`;\n\nconst LinkWrapper = styled.div`\n  display: block;\n  width: 100%;\n  background-color: #f9f4c8;\n  padding-bottom: 20px;\n  margin-top: -2px;\n  padding-left: 58px;\n  border-radius: 0px 0px 5px 5px;\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    padding-left: 45px;\n  }\n`;\nconst Link = styled.a`\n  color: #20588f;\n  font-size: 16px;\n  padding-bottom: 1px;\n  margin: 0px 40px 1px 2px;\n  font-family: ${fonts.sans};\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    margin: 0px 15px 1px 5px;\n    box-shadow: none;\n  }\n`;\nconst CloseButtonWrapper = styled.div`\n  position: absolute;\n  top: 10px;\n  right: 1px;\n`;\n\ntype LinkProps = {\n  href?: string;\n  text?: string;\n};\ntype Props = {\n  type?: WrapperProps['boxType'];\n  sticky?: boolean;\n  children?: string;\n  links?: LinkProps[];\n  showCloseButton?: boolean;\n  onClose?: () => void;\n};\n\nconst markdown = new Remarkable({ breaks: true });\nmarkdown.inline.ruler.enable(['sub', 'sup']);\nmarkdown.block.ruler.disable(['list', 'table']);\n\nexport const MessageBox = ({\n  type,\n  sticky = false,\n  children = '',\n  links,\n  showCloseButton,\n  onClose,\n}: Props & WithTranslation) => {\n  const [hideMessageBox, setHideMessageBox] = useState(false);\n  const onCloseMessageBox = () => {\n    setHideMessageBox(true);\n    onClose?.();\n  };\n  const Icon = type === 'ghost' ? HumanMaleBoard : InformationOutline;\n  return (\n    //StickyStyle top:84 makes sure that the messagebox sits beneath the masthead (header ) and the topOffsett sets it so that it applies when reaching the top of the messagebox\n    <Sticky disabled={!sticky} stickyStyle={{ zIndex: 9998, top: 84 }} topOffset={-84}>\n      <Wrapper boxType={type} style={{ display: hideMessageBox ? 'none' : 'flex' }}>\n        <InfoWrapper boxType={type}>\n          <IconWrapper boxType={type}>\n            <Icon style={{ width: '24px', height: '24px' }} />\n          </IconWrapper>\n          <TextWrapper dangerouslySetInnerHTML={{ __html: markdown.render(children) }}></TextWrapper>\n        </InfoWrapper>\n        {showCloseButton && (\n          <CloseButtonWrapper>\n            <CloseButton onClick={onCloseMessageBox} />\n          </CloseButtonWrapper>\n        )}\n      </Wrapper>\n\n      {links && (\n        //loops through the links passed in as properties if there are any and creates a working link for each of them\n        <LinkWrapper style={{ display: hideMessageBox ? 'none' : 'flex' }}>\n          {links.map((x) => (\n            <Link href={x.href}>{x.text}</Link>\n          ))}\n        </LinkWrapper>\n      )}\n    </Sticky>\n  );\n};\n\nexport default withTranslation()(MessageBox);\n"]} */"));
126
129
 
127
130
  var IconWrapper = _styled("div", {
128
131
  target: "e1ckcvyi3",
@@ -131,21 +134,21 @@ var IconWrapper = _styled("div", {
131
134
  return StyleByType(props.boxType).display;
132
135
  }, ";align-items:flex-start;", mq.range({
133
136
  from: breakpoints.tabletWide
134
- }), "{padding-top:4px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIk1lc3NhZ2VCb3gudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTBHNEMiLCJmaWxlIjoiTWVzc2FnZUJveC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAyMi1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCBSZWFjdCwgeyBIVE1MQXR0cmlidXRlcywgdXNlU3RhdGUgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgU3RpY2t5IGZyb20gJ3JlYWN0LXN0aWNreS1lbCc7XG5pbXBvcnQgeyBicmVha3BvaW50cywgZm9udHMsIG1xLCBzcGFjaW5nIH0gZnJvbSAnQG5kbGEvY29yZSc7XG5pbXBvcnQgeyBJbmZvcm1hdGlvbk91dGxpbmUsIEh1bWFuTWFsZUJvYXJkIH0gZnJvbSAnQG5kbGEvaWNvbnMvY29tbW9uJztcbmltcG9ydCB7IFdpdGhUcmFuc2xhdGlvbiwgd2l0aFRyYW5zbGF0aW9uIH0gZnJvbSAncmVhY3QtaTE4bmV4dCc7XG5pbXBvcnQgeyBDbG9zZUJ1dHRvbiB9IGZyb20gJy4uL0Nsb3NlQnV0dG9uJztcblxuZXhwb3J0IGVudW0gTWVzc2FnZUJveFR5cGUge1xuICBnaG9zdCA9ICdnaG9zdCcsXG4gIGZ1bGxwYWdlID0gJ2Z1bGxwYWdlJyxcbiAgbWVkaXVtID0gJ21lZGl1bScsXG4gIG1hc3RoZWFkID0gJ21hc3RoZWFkJyxcbn1cbnR5cGUgV3JhcHBlclByb3BzID0ge1xuICBib3hUeXBlPzogTWVzc2FnZUJveFR5cGU7XG59O1xuXG5jb25zdCBTdHlsZUJ5VHlwZSA9ICh0eXBlOiBXcmFwcGVyUHJvcHNbJ2JveFR5cGUnXSkgPT4ge1xuICBjb25zdCBzdHlsZXM6IEhUTUxBdHRyaWJ1dGVzPEhUTUxFbGVtZW50Plsnc3R5bGUnXSA9IHtcbiAgICBtYXJnaW46ICcxcHgnLFxuICAgIGNvbG9yOiAnIzQ0NDQ0NCcsXG4gICAgYmFja2dyb3VuZENvbG9yOiAnI2Y5ZjRjOCcsXG4gICAgYm9yZGVyOiAnbm9uZScsXG4gICAgZGlzcGxheTogJ2ZsZXgnLFxuICAgIHBhZGRpbmc6ICcxMHB4JyxcbiAgICB3aWR0aDogJ2F1dG8nLFxuICAgIGJvcmRlclJhZGl1czogJzVweCcsXG4gICAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gICAgdHJhbnNmb3JtOiAnYXV0bycsXG4gICAgbGVmdDogJ2F1dG8nLFxuICB9OyAvL0RpZmZlcmVudCBDU1MgcHJvcGVydGllcyBmb3IgZGlmZmVyZW50IHR5cGVzIG9mIG1lc3NhZ2UtYm94ZXNcbiAgc3dpdGNoICh0eXBlKSB7XG4gICAgY2FzZSAnZnVsbHBhZ2UnOlxuICAgICAgc3R5bGVzLm1hcmdpbiA9ICcwIGF1dG8nO1xuICAgICAgc3R5bGVzLmRpc3BsYXkgPSAnbm9uZSc7XG4gICAgICBzdHlsZXMud2lkdGggPSAnMTAwdncnO1xuICAgICAgc3R5bGVzLnBvc2l0aW9uID0gJ3JlbGF0aXZlJztcbiAgICAgIHN0eWxlcy5sZWZ0ID0gJzUwJSc7XG4gICAgICBzdHlsZXMudHJhbnNmb3JtID0gJ3RyYW5zbGF0ZVgoLTUwJSknO1xuICAgICAgYnJlYWs7XG4gICAgY2FzZSAnbWVkaXVtJzpcbiAgICAgIHN0eWxlcy5tYXJnaW4gPSAnMHB4JztcbiAgICAgIGJyZWFrO1xuICAgIGNhc2UgJ2dob3N0JzpcbiAgICAgIHN0eWxlcy5iYWNrZ3JvdW5kQ29sb3IgPSAndHJhbnNwYXJlbnQnO1xuICAgICAgc3R5bGVzLmJvcmRlciA9ICcxcHggc29saWQgI0QxRDZEQic7XG4gICAgICBzdHlsZXMuY29sb3IgPSAnIzQ0NDQ0NCc7XG4gICAgICBicmVhaztcbiAgICBjYXNlICdtYXN0aGVhZCc6XG4gICAgICBzdHlsZXMubWFyZ2luID0gJzAgYXV0byc7XG4gICAgICBzdHlsZXMuZGlzcGxheSA9ICdub25lJztcbiAgICAgIHN0eWxlcy5wYWRkaW5nID0gJzAnO1xuICAgICAgc3R5bGVzLmJvcmRlclJhZGl1cyA9ICcwJztcbiAgICAgIGJyZWFrO1xuICB9XG4gIHJldHVybiBzdHlsZXM7XG59O1xuXG5jb25zdCBXcmFwcGVyID0gc3R5bGVkLmRpdjxXcmFwcGVyUHJvcHM+YFxuICBiYWNrZ3JvdW5kOiAkeyhwcm9wcykgPT4gU3R5bGVCeVR5cGUocHJvcHMuYm94VHlwZSkuYmFja2dyb3VuZENvbG9yfTtcbiAgY29sb3I6ICR7KHByb3BzKSA9PiBTdHlsZUJ5VHlwZShwcm9wcy5ib3hUeXBlKS5jb2xvcn07XG4gIGZvbnQtc2l6ZTogMThweDtcbiAgbGluZS1oZWlnaHQ6IDMycHg7XG4gIGZvbnQtZmFtaWx5OiAke2ZvbnRzLnNhbnN9O1xuICBkaXNwbGF5OiBmbGV4O1xuICBwYWRkaW5nOiAke3NwYWNpbmcuc21hbGx9O1xuICBwb3NpdGlvbjogJHsocHJvcHMpID0+IFN0eWxlQnlUeXBlKHByb3BzLmJveFR5cGUpLnBvc2l0aW9ufTtcbiAgYm9yZGVyOiAkeyhwcm9wcykgPT4gU3R5bGVCeVR5cGUocHJvcHMuYm94VHlwZSkuYm9yZGVyfTtcbiAgYm9yZGVyLXJhZGl1czogJHsocHJvcHMpID0+IFN0eWxlQnlUeXBlKHByb3BzLmJveFR5cGUpLmJvcmRlclJhZGl1c307XG4gIHRyYW5zZm9ybTogJHsocHJvcHMpID0+IFN0eWxlQnlUeXBlKHByb3BzLmJveFR5cGUpLnRyYW5zZm9ybX07XG4gIGxlZnQ6ICR7KHByb3BzKSA9PiBTdHlsZUJ5VHlwZShwcm9wcy5ib3hUeXBlKS5sZWZ0fTtcbiAgei1pbmRleDogMTA7XG4gIHdpZHRoOiAkeyhwcm9wcykgPT4gU3R5bGVCeVR5cGUocHJvcHMuYm94VHlwZSkud2lkdGh9O1xuYDtcblxuY29uc3QgSW5mb1dyYXBwZXIgPSBzdHlsZWQuZGl2PFdyYXBwZXJQcm9wcz5gXG4gIG1hcmdpbjogJHsocHJvcHMpID0+IFN0eWxlQnlUeXBlKHByb3BzLmJveFR5cGUpLm1hcmdpbn07XG4gIHBhZGRpbmc6ICR7KHByb3BzKSA9PiBTdHlsZUJ5VHlwZShwcm9wcy5ib3hUeXBlKS5wYWRkaW5nfTtcbiAgZGlzcGxheTogZmxleDtcbiAgJHttcS5yYW5nZSh7IHVudGlsOiBicmVha3BvaW50cy50YWJsZXRXaWRlIH0pfSB7XG4gICAgcGFkZGluZzogMCA5MHB4IDAgMDtcbiAgfVxuICAke21xLnJhbmdlKHsgdW50aWw6IGJyZWFrcG9pbnRzLm1vYmlsZVdpZGUgfSl9IHtcbiAgICBwYWRkaW5nOiAwIDVweCAwIDA7XG4gICAgZm9udC1zaXplOiAxNnB4O1xuICB9XG5gO1xuY29uc3QgVGV4dFdyYXBwZXIgPSBzdHlsZWQuZGl2PFdyYXBwZXJQcm9wcz5gXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGZsZXgtd3JhcDogd3JhcDtcbiAgJHttcS5yYW5nZSh7IHVudGlsOiBicmVha3BvaW50cy50YWJsZXRXaWRlIH0pfSB7XG4gICAgbGluZS1oZWlnaHQ6IDI0cHg7XG4gICAgZm9udC1zaXplOiAxNnB4O1xuICB9XG5gO1xuXG5jb25zdCBJY29uV3JhcHBlciA9IHN0eWxlZC5kaXY8V3JhcHBlclByb3BzPmBcbiAgcGFkZGluZy1yaWdodDogJHtzcGFjaW5nLnNtYWxsfTtcbiAgZGlzcGxheTogJHsocHJvcHMpID0+IFN0eWxlQnlUeXBlKHByb3BzLmJveFR5cGUpLmRpc3BsYXl9O1xuICBhbGlnbi1pdGVtczogZmxleC1zdGFydDtcbiAgJHttcS5yYW5nZSh7IGZyb206IGJyZWFrcG9pbnRzLnRhYmxldFdpZGUgfSl9IHtcbiAgICBwYWRkaW5nLXRvcDogNHB4O1xuICB9XG5gO1xuXG5jb25zdCBMaW5rV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIGRpc3BsYXk6IGJsb2NrO1xuICB3aWR0aDogMTAwJTtcbiAgYmFja2dyb3VuZC1jb2xvcjogI2Y5ZjRjODtcbiAgcGFkZGluZy1ib3R0b206IDIwcHg7XG4gIG1hcmdpbi10b3A6IC0ycHg7XG4gIHBhZGRpbmctbGVmdDogNThweDtcbiAgYm9yZGVyLXJhZGl1czogMHB4IDBweCA1cHggNXB4O1xuICAke21xLnJhbmdlKHsgdW50aWw6IGJyZWFrcG9pbnRzLm1vYmlsZVdpZGUgfSl9IHtcbiAgICBwYWRkaW5nLWxlZnQ6IDQ1cHg7XG4gIH1cbmA7XG5jb25zdCBMaW5rID0gc3R5bGVkLmFgXG4gIGNvbG9yOiAjMjA1ODhmO1xuICBmb250LXNpemU6IDE2cHg7XG4gIHBhZGRpbmctYm90dG9tOiAxcHg7XG4gIG1hcmdpbjogMHB4IDQwcHggMXB4IDJweDtcbiAgZm9udC1mYW1pbHk6ICR7Zm9udHMuc2Fuc307XG4gICR7bXEucmFuZ2UoeyB1bnRpbDogYnJlYWtwb2ludHMubW9iaWxlV2lkZSB9KX0ge1xuICAgIG1hcmdpbjogMHB4IDE1cHggMXB4IDVweDtcbiAgICBib3gtc2hhZG93OiBub25lO1xuICB9XG5gO1xuY29uc3QgQ2xvc2VCdXR0b25XcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgcG9zaXRpb246IGFic29sdXRlO1xuICB0b3A6IDEwcHg7XG4gIHJpZ2h0OiAxcHg7XG5gO1xuXG50eXBlIExpbmtQcm9wcyA9IHtcbiAgaHJlZj86IHN0cmluZztcbiAgdGV4dD86IHN0cmluZztcbn07XG50eXBlIFByb3BzID0ge1xuICB0eXBlPzogV3JhcHBlclByb3BzWydib3hUeXBlJ107XG4gIHN0aWNreT86IGJvb2xlYW47XG4gIGNoaWxkcmVuPzogc3RyaW5nO1xuICBsaW5rcz86IExpbmtQcm9wc1tdO1xuICBzaG93Q2xvc2VCdXR0b24/OiBib29sZWFuO1xufTtcblxuZXhwb3J0IGNvbnN0IE1lc3NhZ2VCb3ggPSAoeyB0eXBlLCBzdGlja3kgPSBmYWxzZSwgY2hpbGRyZW4sIGxpbmtzLCB0LCBzaG93Q2xvc2VCdXR0b24gfTogUHJvcHMgJiBXaXRoVHJhbnNsYXRpb24pID0+IHtcbiAgY29uc3QgW2hpZGVNZXNzYWdlQm94LCBzZXRIaWRlTWVzc2FnZUJveF0gPSB1c2VTdGF0ZShmYWxzZSk7XG4gIGNvbnN0IG9uQ2xvc2VNZXNzYWdlQm94ID0gKCkgPT4ge1xuICAgIHNldEhpZGVNZXNzYWdlQm94KHRydWUpO1xuICB9O1xuICBjb25zdCBJY29uID0gdHlwZSA9PT0gJ2dob3N0JyA/IEh1bWFuTWFsZUJvYXJkIDogSW5mb3JtYXRpb25PdXRsaW5lO1xuICByZXR1cm4gKFxuICAgIC8vU3RpY2t5U3R5bGUgdG9wOjg0IG1ha2VzIHN1cmUgdGhhdCB0aGUgbWVzc2FnZWJveCBzaXRzIGJlbmVhdGggdGhlIG1hc3RoZWFkIChoZWFkZXIgKSBhbmQgdGhlIHRvcE9mZnNldHQgc2V0cyBpdCBzbyB0aGF0IGl0IGFwcGxpZXMgd2hlbiByZWFjaGluZyB0aGUgdG9wIG9mIHRoZSBtZXNzYWdlYm94XG4gICAgPFN0aWNreSBkaXNhYmxlZD17IXN0aWNreX0gc3RpY2t5U3R5bGU9e3sgekluZGV4OiA5OTk4LCB0b3A6IDg0IH19IHRvcE9mZnNldD17LTg0fT5cbiAgICAgIDxXcmFwcGVyIGJveFR5cGU9e3R5cGV9IHN0eWxlPXt7IGRpc3BsYXk6IGhpZGVNZXNzYWdlQm94ID8gJ25vbmUnIDogJ2ZsZXgnIH19PlxuICAgICAgICA8SW5mb1dyYXBwZXIgYm94VHlwZT17dHlwZX0+XG4gICAgICAgICAgPEljb25XcmFwcGVyIGJveFR5cGU9e3R5cGV9PlxuICAgICAgICAgICAgPEljb24gc3R5bGU9e3sgd2lkdGg6ICcyNHB4JywgaGVpZ2h0OiAnMjRweCcgfX0gLz5cbiAgICAgICAgICA8L0ljb25XcmFwcGVyPlxuICAgICAgICAgIDxUZXh0V3JhcHBlcj57Y2hpbGRyZW59PC9UZXh0V3JhcHBlcj5cbiAgICAgICAgPC9JbmZvV3JhcHBlcj5cbiAgICAgICAge3Nob3dDbG9zZUJ1dHRvbiAmJiAoXG4gICAgICAgICAgPENsb3NlQnV0dG9uV3JhcHBlcj5cbiAgICAgICAgICAgIDxDbG9zZUJ1dHRvbiBvbkNsaWNrPXtvbkNsb3NlTWVzc2FnZUJveH0gLz5cbiAgICAgICAgICA8L0Nsb3NlQnV0dG9uV3JhcHBlcj5cbiAgICAgICAgKX1cbiAgICAgIDwvV3JhcHBlcj5cblxuICAgICAge2xpbmtzICYmIChcbiAgICAgICAgLy9sb29wcyB0aHJvdWdoIHRoZSBsaW5rcyBwYXNzZWQgaW4gYXMgcHJvcGVydGllcyBpZiB0aGVyZSBhcmUgYW55IGFuZCBjcmVhdGVzIGEgd29ya2luZyBsaW5rIGZvciBlYWNoIG9mIHRoZW1cbiAgICAgICAgPExpbmtXcmFwcGVyIHN0eWxlPXt7IGRpc3BsYXk6IGhpZGVNZXNzYWdlQm94ID8gJ25vbmUnIDogJ2ZsZXgnIH19PlxuICAgICAgICAgIHtsaW5rcy5tYXAoKHgpID0+IChcbiAgICAgICAgICAgIDxMaW5rIGhyZWY9e3guaHJlZn0+e3gudGV4dH08L0xpbms+XG4gICAgICAgICAgKSl9XG4gICAgICAgIDwvTGlua1dyYXBwZXI+XG4gICAgICApfVxuICAgIDwvU3RpY2t5PlxuICApO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgd2l0aFRyYW5zbGF0aW9uKCkoTWVzc2FnZUJveCk7XG4iXX0= */"));
137
+ }), "{padding-top:4px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["MessageBox.tsx"],"names":[],"mappings":"AAiH4C","file":"MessageBox.tsx","sourcesContent":["/**\n * Copyright (c) 2022-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, { HTMLAttributes, useState } from 'react';\nimport styled from '@emotion/styled';\nimport Sticky from 'react-sticky-el';\nimport { breakpoints, fonts, mq, spacing } from '@ndla/core';\nimport { InformationOutline, HumanMaleBoard } from '@ndla/icons/common';\nimport { WithTranslation, withTranslation } from 'react-i18next';\n\n// @ts-ignore\nimport { Remarkable } from 'remarkable';\nimport { CloseButton } from '../CloseButton';\n\nexport enum MessageBoxType {\n  ghost = 'ghost',\n  fullpage = 'fullpage',\n  medium = 'medium',\n  masthead = 'masthead',\n}\ntype WrapperProps = {\n  boxType?: MessageBoxType;\n};\n\nconst StyleByType = (type: WrapperProps['boxType']) => {\n  const styles: HTMLAttributes<HTMLElement>['style'] = {\n    margin: '1px',\n    color: '#444444',\n    backgroundColor: '#f9f4c8',\n    border: 'none',\n    display: 'flex',\n    padding: '10px',\n    width: 'auto',\n    borderRadius: '5px',\n    position: 'relative',\n    transform: 'auto',\n    left: 'auto',\n  }; //Different CSS properties for different types of message-boxes\n  switch (type) {\n    case 'fullpage':\n      styles.margin = '0 auto';\n      styles.display = 'none';\n      styles.width = '100vw';\n      styles.position = 'relative';\n      styles.left = '50%';\n      styles.padding = '0';\n      styles.transform = 'translateX(-50%)';\n      break;\n    case 'medium':\n      styles.margin = '0px';\n      break;\n    case 'ghost':\n      styles.backgroundColor = 'transparent';\n      styles.border = '1px solid #D1D6DB';\n      styles.color = '#444444';\n      break;\n    case 'masthead':\n      styles.margin = '0 auto';\n      styles.display = 'none';\n      styles.padding = '0';\n      styles.borderRadius = '0';\n      break;\n  }\n  return styles;\n};\n\nconst Wrapper = styled.div<WrapperProps>`\n  background: ${(props) => StyleByType(props.boxType).backgroundColor};\n  color: ${(props) => StyleByType(props.boxType).color};\n  font-size: 18px;\n  line-height: 32px;\n  font-family: ${fonts.sans};\n  display: flex;\n  padding: ${spacing.small};\n  position: ${(props) => StyleByType(props.boxType).position};\n  border: ${(props) => StyleByType(props.boxType).border};\n  border-radius: ${(props) => StyleByType(props.boxType).borderRadius};\n  transform: ${(props) => StyleByType(props.boxType).transform};\n  left: ${(props) => StyleByType(props.boxType).left};\n  z-index: 10;\n  width: ${(props) => StyleByType(props.boxType).width};\n`;\n\nconst InfoWrapper = styled.div<WrapperProps>`\n  margin: ${(props) => StyleByType(props.boxType).margin};\n  padding: ${(props) => StyleByType(props.boxType).padding};\n  display: flex;\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    padding: 0 90px 0 0;\n  }\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    padding: 0 5px 0 0;\n    font-size: 16px;\n  }\n`;\nconst TextWrapper = styled.div<WrapperProps>`\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    line-height: 24px;\n    font-size: 16px;\n  }\n  & p {\n    margin: 0;\n  }\n`;\n\nconst IconWrapper = styled.div<WrapperProps>`\n  padding-right: ${spacing.small};\n  display: ${(props) => StyleByType(props.boxType).display};\n  align-items: flex-start;\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding-top: 4px;\n  }\n`;\n\nconst LinkWrapper = styled.div`\n  display: block;\n  width: 100%;\n  background-color: #f9f4c8;\n  padding-bottom: 20px;\n  margin-top: -2px;\n  padding-left: 58px;\n  border-radius: 0px 0px 5px 5px;\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    padding-left: 45px;\n  }\n`;\nconst Link = styled.a`\n  color: #20588f;\n  font-size: 16px;\n  padding-bottom: 1px;\n  margin: 0px 40px 1px 2px;\n  font-family: ${fonts.sans};\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    margin: 0px 15px 1px 5px;\n    box-shadow: none;\n  }\n`;\nconst CloseButtonWrapper = styled.div`\n  position: absolute;\n  top: 10px;\n  right: 1px;\n`;\n\ntype LinkProps = {\n  href?: string;\n  text?: string;\n};\ntype Props = {\n  type?: WrapperProps['boxType'];\n  sticky?: boolean;\n  children?: string;\n  links?: LinkProps[];\n  showCloseButton?: boolean;\n  onClose?: () => void;\n};\n\nconst markdown = new Remarkable({ breaks: true });\nmarkdown.inline.ruler.enable(['sub', 'sup']);\nmarkdown.block.ruler.disable(['list', 'table']);\n\nexport const MessageBox = ({\n  type,\n  sticky = false,\n  children = '',\n  links,\n  showCloseButton,\n  onClose,\n}: Props & WithTranslation) => {\n  const [hideMessageBox, setHideMessageBox] = useState(false);\n  const onCloseMessageBox = () => {\n    setHideMessageBox(true);\n    onClose?.();\n  };\n  const Icon = type === 'ghost' ? HumanMaleBoard : InformationOutline;\n  return (\n    //StickyStyle top:84 makes sure that the messagebox sits beneath the masthead (header ) and the topOffsett sets it so that it applies when reaching the top of the messagebox\n    <Sticky disabled={!sticky} stickyStyle={{ zIndex: 9998, top: 84 }} topOffset={-84}>\n      <Wrapper boxType={type} style={{ display: hideMessageBox ? 'none' : 'flex' }}>\n        <InfoWrapper boxType={type}>\n          <IconWrapper boxType={type}>\n            <Icon style={{ width: '24px', height: '24px' }} />\n          </IconWrapper>\n          <TextWrapper dangerouslySetInnerHTML={{ __html: markdown.render(children) }}></TextWrapper>\n        </InfoWrapper>\n        {showCloseButton && (\n          <CloseButtonWrapper>\n            <CloseButton onClick={onCloseMessageBox} />\n          </CloseButtonWrapper>\n        )}\n      </Wrapper>\n\n      {links && (\n        //loops through the links passed in as properties if there are any and creates a working link for each of them\n        <LinkWrapper style={{ display: hideMessageBox ? 'none' : 'flex' }}>\n          {links.map((x) => (\n            <Link href={x.href}>{x.text}</Link>\n          ))}\n        </LinkWrapper>\n      )}\n    </Sticky>\n  );\n};\n\nexport default withTranslation()(MessageBox);\n"]} */"));
135
138
 
136
139
  var LinkWrapper = _styled("div", {
137
140
  target: "e1ckcvyi4",
138
141
  label: "LinkWrapper"
139
142
  })("display:block;width:100%;background-color:#f9f4c8;padding-bottom:20px;margin-top:-2px;padding-left:58px;border-radius:0px 0px 5px 5px;", mq.range({
140
143
  until: breakpoints.mobileWide
141
- }), "{padding-left:45px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIk1lc3NhZ2VCb3gudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQW1IOEIiLCJmaWxlIjoiTWVzc2FnZUJveC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAyMi1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCBSZWFjdCwgeyBIVE1MQXR0cmlidXRlcywgdXNlU3RhdGUgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgU3RpY2t5IGZyb20gJ3JlYWN0LXN0aWNreS1lbCc7XG5pbXBvcnQgeyBicmVha3BvaW50cywgZm9udHMsIG1xLCBzcGFjaW5nIH0gZnJvbSAnQG5kbGEvY29yZSc7XG5pbXBvcnQgeyBJbmZvcm1hdGlvbk91dGxpbmUsIEh1bWFuTWFsZUJvYXJkIH0gZnJvbSAnQG5kbGEvaWNvbnMvY29tbW9uJztcbmltcG9ydCB7IFdpdGhUcmFuc2xhdGlvbiwgd2l0aFRyYW5zbGF0aW9uIH0gZnJvbSAncmVhY3QtaTE4bmV4dCc7XG5pbXBvcnQgeyBDbG9zZUJ1dHRvbiB9IGZyb20gJy4uL0Nsb3NlQnV0dG9uJztcblxuZXhwb3J0IGVudW0gTWVzc2FnZUJveFR5cGUge1xuICBnaG9zdCA9ICdnaG9zdCcsXG4gIGZ1bGxwYWdlID0gJ2Z1bGxwYWdlJyxcbiAgbWVkaXVtID0gJ21lZGl1bScsXG4gIG1hc3RoZWFkID0gJ21hc3RoZWFkJyxcbn1cbnR5cGUgV3JhcHBlclByb3BzID0ge1xuICBib3hUeXBlPzogTWVzc2FnZUJveFR5cGU7XG59O1xuXG5jb25zdCBTdHlsZUJ5VHlwZSA9ICh0eXBlOiBXcmFwcGVyUHJvcHNbJ2JveFR5cGUnXSkgPT4ge1xuICBjb25zdCBzdHlsZXM6IEhUTUxBdHRyaWJ1dGVzPEhUTUxFbGVtZW50Plsnc3R5bGUnXSA9IHtcbiAgICBtYXJnaW46ICcxcHgnLFxuICAgIGNvbG9yOiAnIzQ0NDQ0NCcsXG4gICAgYmFja2dyb3VuZENvbG9yOiAnI2Y5ZjRjOCcsXG4gICAgYm9yZGVyOiAnbm9uZScsXG4gICAgZGlzcGxheTogJ2ZsZXgnLFxuICAgIHBhZGRpbmc6ICcxMHB4JyxcbiAgICB3aWR0aDogJ2F1dG8nLFxuICAgIGJvcmRlclJhZGl1czogJzVweCcsXG4gICAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gICAgdHJhbnNmb3JtOiAnYXV0bycsXG4gICAgbGVmdDogJ2F1dG8nLFxuICB9OyAvL0RpZmZlcmVudCBDU1MgcHJvcGVydGllcyBmb3IgZGlmZmVyZW50IHR5cGVzIG9mIG1lc3NhZ2UtYm94ZXNcbiAgc3dpdGNoICh0eXBlKSB7XG4gICAgY2FzZSAnZnVsbHBhZ2UnOlxuICAgICAgc3R5bGVzLm1hcmdpbiA9ICcwIGF1dG8nO1xuICAgICAgc3R5bGVzLmRpc3BsYXkgPSAnbm9uZSc7XG4gICAgICBzdHlsZXMud2lkdGggPSAnMTAwdncnO1xuICAgICAgc3R5bGVzLnBvc2l0aW9uID0gJ3JlbGF0aXZlJztcbiAgICAgIHN0eWxlcy5sZWZ0ID0gJzUwJSc7XG4gICAgICBzdHlsZXMudHJhbnNmb3JtID0gJ3RyYW5zbGF0ZVgoLTUwJSknO1xuICAgICAgYnJlYWs7XG4gICAgY2FzZSAnbWVkaXVtJzpcbiAgICAgIHN0eWxlcy5tYXJnaW4gPSAnMHB4JztcbiAgICAgIGJyZWFrO1xuICAgIGNhc2UgJ2dob3N0JzpcbiAgICAgIHN0eWxlcy5iYWNrZ3JvdW5kQ29sb3IgPSAndHJhbnNwYXJlbnQnO1xuICAgICAgc3R5bGVzLmJvcmRlciA9ICcxcHggc29saWQgI0QxRDZEQic7XG4gICAgICBzdHlsZXMuY29sb3IgPSAnIzQ0NDQ0NCc7XG4gICAgICBicmVhaztcbiAgICBjYXNlICdtYXN0aGVhZCc6XG4gICAgICBzdHlsZXMubWFyZ2luID0gJzAgYXV0byc7XG4gICAgICBzdHlsZXMuZGlzcGxheSA9ICdub25lJztcbiAgICAgIHN0eWxlcy5wYWRkaW5nID0gJzAnO1xuICAgICAgc3R5bGVzLmJvcmRlclJhZGl1cyA9ICcwJztcbiAgICAgIGJyZWFrO1xuICB9XG4gIHJldHVybiBzdHlsZXM7XG59O1xuXG5jb25zdCBXcmFwcGVyID0gc3R5bGVkLmRpdjxXcmFwcGVyUHJvcHM+YFxuICBiYWNrZ3JvdW5kOiAkeyhwcm9wcykgPT4gU3R5bGVCeVR5cGUocHJvcHMuYm94VHlwZSkuYmFja2dyb3VuZENvbG9yfTtcbiAgY29sb3I6ICR7KHByb3BzKSA9PiBTdHlsZUJ5VHlwZShwcm9wcy5ib3hUeXBlKS5jb2xvcn07XG4gIGZvbnQtc2l6ZTogMThweDtcbiAgbGluZS1oZWlnaHQ6IDMycHg7XG4gIGZvbnQtZmFtaWx5OiAke2ZvbnRzLnNhbnN9O1xuICBkaXNwbGF5OiBmbGV4O1xuICBwYWRkaW5nOiAke3NwYWNpbmcuc21hbGx9O1xuICBwb3NpdGlvbjogJHsocHJvcHMpID0+IFN0eWxlQnlUeXBlKHByb3BzLmJveFR5cGUpLnBvc2l0aW9ufTtcbiAgYm9yZGVyOiAkeyhwcm9wcykgPT4gU3R5bGVCeVR5cGUocHJvcHMuYm94VHlwZSkuYm9yZGVyfTtcbiAgYm9yZGVyLXJhZGl1czogJHsocHJvcHMpID0+IFN0eWxlQnlUeXBlKHByb3BzLmJveFR5cGUpLmJvcmRlclJhZGl1c307XG4gIHRyYW5zZm9ybTogJHsocHJvcHMpID0+IFN0eWxlQnlUeXBlKHByb3BzLmJveFR5cGUpLnRyYW5zZm9ybX07XG4gIGxlZnQ6ICR7KHByb3BzKSA9PiBTdHlsZUJ5VHlwZShwcm9wcy5ib3hUeXBlKS5sZWZ0fTtcbiAgei1pbmRleDogMTA7XG4gIHdpZHRoOiAkeyhwcm9wcykgPT4gU3R5bGVCeVR5cGUocHJvcHMuYm94VHlwZSkud2lkdGh9O1xuYDtcblxuY29uc3QgSW5mb1dyYXBwZXIgPSBzdHlsZWQuZGl2PFdyYXBwZXJQcm9wcz5gXG4gIG1hcmdpbjogJHsocHJvcHMpID0+IFN0eWxlQnlUeXBlKHByb3BzLmJveFR5cGUpLm1hcmdpbn07XG4gIHBhZGRpbmc6ICR7KHByb3BzKSA9PiBTdHlsZUJ5VHlwZShwcm9wcy5ib3hUeXBlKS5wYWRkaW5nfTtcbiAgZGlzcGxheTogZmxleDtcbiAgJHttcS5yYW5nZSh7IHVudGlsOiBicmVha3BvaW50cy50YWJsZXRXaWRlIH0pfSB7XG4gICAgcGFkZGluZzogMCA5MHB4IDAgMDtcbiAgfVxuICAke21xLnJhbmdlKHsgdW50aWw6IGJyZWFrcG9pbnRzLm1vYmlsZVdpZGUgfSl9IHtcbiAgICBwYWRkaW5nOiAwIDVweCAwIDA7XG4gICAgZm9udC1zaXplOiAxNnB4O1xuICB9XG5gO1xuY29uc3QgVGV4dFdyYXBwZXIgPSBzdHlsZWQuZGl2PFdyYXBwZXJQcm9wcz5gXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGZsZXgtd3JhcDogd3JhcDtcbiAgJHttcS5yYW5nZSh7IHVudGlsOiBicmVha3BvaW50cy50YWJsZXRXaWRlIH0pfSB7XG4gICAgbGluZS1oZWlnaHQ6IDI0cHg7XG4gICAgZm9udC1zaXplOiAxNnB4O1xuICB9XG5gO1xuXG5jb25zdCBJY29uV3JhcHBlciA9IHN0eWxlZC5kaXY8V3JhcHBlclByb3BzPmBcbiAgcGFkZGluZy1yaWdodDogJHtzcGFjaW5nLnNtYWxsfTtcbiAgZGlzcGxheTogJHsocHJvcHMpID0+IFN0eWxlQnlUeXBlKHByb3BzLmJveFR5cGUpLmRpc3BsYXl9O1xuICBhbGlnbi1pdGVtczogZmxleC1zdGFydDtcbiAgJHttcS5yYW5nZSh7IGZyb206IGJyZWFrcG9pbnRzLnRhYmxldFdpZGUgfSl9IHtcbiAgICBwYWRkaW5nLXRvcDogNHB4O1xuICB9XG5gO1xuXG5jb25zdCBMaW5rV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIGRpc3BsYXk6IGJsb2NrO1xuICB3aWR0aDogMTAwJTtcbiAgYmFja2dyb3VuZC1jb2xvcjogI2Y5ZjRjODtcbiAgcGFkZGluZy1ib3R0b206IDIwcHg7XG4gIG1hcmdpbi10b3A6IC0ycHg7XG4gIHBhZGRpbmctbGVmdDogNThweDtcbiAgYm9yZGVyLXJhZGl1czogMHB4IDBweCA1cHggNXB4O1xuICAke21xLnJhbmdlKHsgdW50aWw6IGJyZWFrcG9pbnRzLm1vYmlsZVdpZGUgfSl9IHtcbiAgICBwYWRkaW5nLWxlZnQ6IDQ1cHg7XG4gIH1cbmA7XG5jb25zdCBMaW5rID0gc3R5bGVkLmFgXG4gIGNvbG9yOiAjMjA1ODhmO1xuICBmb250LXNpemU6IDE2cHg7XG4gIHBhZGRpbmctYm90dG9tOiAxcHg7XG4gIG1hcmdpbjogMHB4IDQwcHggMXB4IDJweDtcbiAgZm9udC1mYW1pbHk6ICR7Zm9udHMuc2Fuc307XG4gICR7bXEucmFuZ2UoeyB1bnRpbDogYnJlYWtwb2ludHMubW9iaWxlV2lkZSB9KX0ge1xuICAgIG1hcmdpbjogMHB4IDE1cHggMXB4IDVweDtcbiAgICBib3gtc2hhZG93OiBub25lO1xuICB9XG5gO1xuY29uc3QgQ2xvc2VCdXR0b25XcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgcG9zaXRpb246IGFic29sdXRlO1xuICB0b3A6IDEwcHg7XG4gIHJpZ2h0OiAxcHg7XG5gO1xuXG50eXBlIExpbmtQcm9wcyA9IHtcbiAgaHJlZj86IHN0cmluZztcbiAgdGV4dD86IHN0cmluZztcbn07XG50eXBlIFByb3BzID0ge1xuICB0eXBlPzogV3JhcHBlclByb3BzWydib3hUeXBlJ107XG4gIHN0aWNreT86IGJvb2xlYW47XG4gIGNoaWxkcmVuPzogc3RyaW5nO1xuICBsaW5rcz86IExpbmtQcm9wc1tdO1xuICBzaG93Q2xvc2VCdXR0b24/OiBib29sZWFuO1xufTtcblxuZXhwb3J0IGNvbnN0IE1lc3NhZ2VCb3ggPSAoeyB0eXBlLCBzdGlja3kgPSBmYWxzZSwgY2hpbGRyZW4sIGxpbmtzLCB0LCBzaG93Q2xvc2VCdXR0b24gfTogUHJvcHMgJiBXaXRoVHJhbnNsYXRpb24pID0+IHtcbiAgY29uc3QgW2hpZGVNZXNzYWdlQm94LCBzZXRIaWRlTWVzc2FnZUJveF0gPSB1c2VTdGF0ZShmYWxzZSk7XG4gIGNvbnN0IG9uQ2xvc2VNZXNzYWdlQm94ID0gKCkgPT4ge1xuICAgIHNldEhpZGVNZXNzYWdlQm94KHRydWUpO1xuICB9O1xuICBjb25zdCBJY29uID0gdHlwZSA9PT0gJ2dob3N0JyA/IEh1bWFuTWFsZUJvYXJkIDogSW5mb3JtYXRpb25PdXRsaW5lO1xuICByZXR1cm4gKFxuICAgIC8vU3RpY2t5U3R5bGUgdG9wOjg0IG1ha2VzIHN1cmUgdGhhdCB0aGUgbWVzc2FnZWJveCBzaXRzIGJlbmVhdGggdGhlIG1hc3RoZWFkIChoZWFkZXIgKSBhbmQgdGhlIHRvcE9mZnNldHQgc2V0cyBpdCBzbyB0aGF0IGl0IGFwcGxpZXMgd2hlbiByZWFjaGluZyB0aGUgdG9wIG9mIHRoZSBtZXNzYWdlYm94XG4gICAgPFN0aWNreSBkaXNhYmxlZD17IXN0aWNreX0gc3RpY2t5U3R5bGU9e3sgekluZGV4OiA5OTk4LCB0b3A6IDg0IH19IHRvcE9mZnNldD17LTg0fT5cbiAgICAgIDxXcmFwcGVyIGJveFR5cGU9e3R5cGV9IHN0eWxlPXt7IGRpc3BsYXk6IGhpZGVNZXNzYWdlQm94ID8gJ25vbmUnIDogJ2ZsZXgnIH19PlxuICAgICAgICA8SW5mb1dyYXBwZXIgYm94VHlwZT17dHlwZX0+XG4gICAgICAgICAgPEljb25XcmFwcGVyIGJveFR5cGU9e3R5cGV9PlxuICAgICAgICAgICAgPEljb24gc3R5bGU9e3sgd2lkdGg6ICcyNHB4JywgaGVpZ2h0OiAnMjRweCcgfX0gLz5cbiAgICAgICAgICA8L0ljb25XcmFwcGVyPlxuICAgICAgICAgIDxUZXh0V3JhcHBlcj57Y2hpbGRyZW59PC9UZXh0V3JhcHBlcj5cbiAgICAgICAgPC9JbmZvV3JhcHBlcj5cbiAgICAgICAge3Nob3dDbG9zZUJ1dHRvbiAmJiAoXG4gICAgICAgICAgPENsb3NlQnV0dG9uV3JhcHBlcj5cbiAgICAgICAgICAgIDxDbG9zZUJ1dHRvbiBvbkNsaWNrPXtvbkNsb3NlTWVzc2FnZUJveH0gLz5cbiAgICAgICAgICA8L0Nsb3NlQnV0dG9uV3JhcHBlcj5cbiAgICAgICAgKX1cbiAgICAgIDwvV3JhcHBlcj5cblxuICAgICAge2xpbmtzICYmIChcbiAgICAgICAgLy9sb29wcyB0aHJvdWdoIHRoZSBsaW5rcyBwYXNzZWQgaW4gYXMgcHJvcGVydGllcyBpZiB0aGVyZSBhcmUgYW55IGFuZCBjcmVhdGVzIGEgd29ya2luZyBsaW5rIGZvciBlYWNoIG9mIHRoZW1cbiAgICAgICAgPExpbmtXcmFwcGVyIHN0eWxlPXt7IGRpc3BsYXk6IGhpZGVNZXNzYWdlQm94ID8gJ25vbmUnIDogJ2ZsZXgnIH19PlxuICAgICAgICAgIHtsaW5rcy5tYXAoKHgpID0+IChcbiAgICAgICAgICAgIDxMaW5rIGhyZWY9e3guaHJlZn0+e3gudGV4dH08L0xpbms+XG4gICAgICAgICAgKSl9XG4gICAgICAgIDwvTGlua1dyYXBwZXI+XG4gICAgICApfVxuICAgIDwvU3RpY2t5PlxuICApO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgd2l0aFRyYW5zbGF0aW9uKCkoTWVzc2FnZUJveCk7XG4iXX0= */"));
144
+ }), "{padding-left:45px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["MessageBox.tsx"],"names":[],"mappings":"AA0H8B","file":"MessageBox.tsx","sourcesContent":["/**\n * Copyright (c) 2022-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, { HTMLAttributes, useState } from 'react';\nimport styled from '@emotion/styled';\nimport Sticky from 'react-sticky-el';\nimport { breakpoints, fonts, mq, spacing } from '@ndla/core';\nimport { InformationOutline, HumanMaleBoard } from '@ndla/icons/common';\nimport { WithTranslation, withTranslation } from 'react-i18next';\n\n// @ts-ignore\nimport { Remarkable } from 'remarkable';\nimport { CloseButton } from '../CloseButton';\n\nexport enum MessageBoxType {\n  ghost = 'ghost',\n  fullpage = 'fullpage',\n  medium = 'medium',\n  masthead = 'masthead',\n}\ntype WrapperProps = {\n  boxType?: MessageBoxType;\n};\n\nconst StyleByType = (type: WrapperProps['boxType']) => {\n  const styles: HTMLAttributes<HTMLElement>['style'] = {\n    margin: '1px',\n    color: '#444444',\n    backgroundColor: '#f9f4c8',\n    border: 'none',\n    display: 'flex',\n    padding: '10px',\n    width: 'auto',\n    borderRadius: '5px',\n    position: 'relative',\n    transform: 'auto',\n    left: 'auto',\n  }; //Different CSS properties for different types of message-boxes\n  switch (type) {\n    case 'fullpage':\n      styles.margin = '0 auto';\n      styles.display = 'none';\n      styles.width = '100vw';\n      styles.position = 'relative';\n      styles.left = '50%';\n      styles.padding = '0';\n      styles.transform = 'translateX(-50%)';\n      break;\n    case 'medium':\n      styles.margin = '0px';\n      break;\n    case 'ghost':\n      styles.backgroundColor = 'transparent';\n      styles.border = '1px solid #D1D6DB';\n      styles.color = '#444444';\n      break;\n    case 'masthead':\n      styles.margin = '0 auto';\n      styles.display = 'none';\n      styles.padding = '0';\n      styles.borderRadius = '0';\n      break;\n  }\n  return styles;\n};\n\nconst Wrapper = styled.div<WrapperProps>`\n  background: ${(props) => StyleByType(props.boxType).backgroundColor};\n  color: ${(props) => StyleByType(props.boxType).color};\n  font-size: 18px;\n  line-height: 32px;\n  font-family: ${fonts.sans};\n  display: flex;\n  padding: ${spacing.small};\n  position: ${(props) => StyleByType(props.boxType).position};\n  border: ${(props) => StyleByType(props.boxType).border};\n  border-radius: ${(props) => StyleByType(props.boxType).borderRadius};\n  transform: ${(props) => StyleByType(props.boxType).transform};\n  left: ${(props) => StyleByType(props.boxType).left};\n  z-index: 10;\n  width: ${(props) => StyleByType(props.boxType).width};\n`;\n\nconst InfoWrapper = styled.div<WrapperProps>`\n  margin: ${(props) => StyleByType(props.boxType).margin};\n  padding: ${(props) => StyleByType(props.boxType).padding};\n  display: flex;\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    padding: 0 90px 0 0;\n  }\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    padding: 0 5px 0 0;\n    font-size: 16px;\n  }\n`;\nconst TextWrapper = styled.div<WrapperProps>`\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    line-height: 24px;\n    font-size: 16px;\n  }\n  & p {\n    margin: 0;\n  }\n`;\n\nconst IconWrapper = styled.div<WrapperProps>`\n  padding-right: ${spacing.small};\n  display: ${(props) => StyleByType(props.boxType).display};\n  align-items: flex-start;\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding-top: 4px;\n  }\n`;\n\nconst LinkWrapper = styled.div`\n  display: block;\n  width: 100%;\n  background-color: #f9f4c8;\n  padding-bottom: 20px;\n  margin-top: -2px;\n  padding-left: 58px;\n  border-radius: 0px 0px 5px 5px;\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    padding-left: 45px;\n  }\n`;\nconst Link = styled.a`\n  color: #20588f;\n  font-size: 16px;\n  padding-bottom: 1px;\n  margin: 0px 40px 1px 2px;\n  font-family: ${fonts.sans};\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    margin: 0px 15px 1px 5px;\n    box-shadow: none;\n  }\n`;\nconst CloseButtonWrapper = styled.div`\n  position: absolute;\n  top: 10px;\n  right: 1px;\n`;\n\ntype LinkProps = {\n  href?: string;\n  text?: string;\n};\ntype Props = {\n  type?: WrapperProps['boxType'];\n  sticky?: boolean;\n  children?: string;\n  links?: LinkProps[];\n  showCloseButton?: boolean;\n  onClose?: () => void;\n};\n\nconst markdown = new Remarkable({ breaks: true });\nmarkdown.inline.ruler.enable(['sub', 'sup']);\nmarkdown.block.ruler.disable(['list', 'table']);\n\nexport const MessageBox = ({\n  type,\n  sticky = false,\n  children = '',\n  links,\n  showCloseButton,\n  onClose,\n}: Props & WithTranslation) => {\n  const [hideMessageBox, setHideMessageBox] = useState(false);\n  const onCloseMessageBox = () => {\n    setHideMessageBox(true);\n    onClose?.();\n  };\n  const Icon = type === 'ghost' ? HumanMaleBoard : InformationOutline;\n  return (\n    //StickyStyle top:84 makes sure that the messagebox sits beneath the masthead (header ) and the topOffsett sets it so that it applies when reaching the top of the messagebox\n    <Sticky disabled={!sticky} stickyStyle={{ zIndex: 9998, top: 84 }} topOffset={-84}>\n      <Wrapper boxType={type} style={{ display: hideMessageBox ? 'none' : 'flex' }}>\n        <InfoWrapper boxType={type}>\n          <IconWrapper boxType={type}>\n            <Icon style={{ width: '24px', height: '24px' }} />\n          </IconWrapper>\n          <TextWrapper dangerouslySetInnerHTML={{ __html: markdown.render(children) }}></TextWrapper>\n        </InfoWrapper>\n        {showCloseButton && (\n          <CloseButtonWrapper>\n            <CloseButton onClick={onCloseMessageBox} />\n          </CloseButtonWrapper>\n        )}\n      </Wrapper>\n\n      {links && (\n        //loops through the links passed in as properties if there are any and creates a working link for each of them\n        <LinkWrapper style={{ display: hideMessageBox ? 'none' : 'flex' }}>\n          {links.map((x) => (\n            <Link href={x.href}>{x.text}</Link>\n          ))}\n        </LinkWrapper>\n      )}\n    </Sticky>\n  );\n};\n\nexport default withTranslation()(MessageBox);\n"]} */"));
142
145
 
143
146
  var Link = _styled("a", {
144
147
  target: "e1ckcvyi5",
145
148
  label: "Link"
146
149
  })("color:#20588f;font-size:16px;padding-bottom:1px;margin:0px 40px 1px 2px;font-family:", fonts.sans, ";", mq.range({
147
150
  until: breakpoints.mobileWide
148
- }), "{margin:0px 15px 1px 5px;box-shadow:none;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIk1lc3NhZ2VCb3gudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQStIcUIiLCJmaWxlIjoiTWVzc2FnZUJveC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAyMi1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCBSZWFjdCwgeyBIVE1MQXR0cmlidXRlcywgdXNlU3RhdGUgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgU3RpY2t5IGZyb20gJ3JlYWN0LXN0aWNreS1lbCc7XG5pbXBvcnQgeyBicmVha3BvaW50cywgZm9udHMsIG1xLCBzcGFjaW5nIH0gZnJvbSAnQG5kbGEvY29yZSc7XG5pbXBvcnQgeyBJbmZvcm1hdGlvbk91dGxpbmUsIEh1bWFuTWFsZUJvYXJkIH0gZnJvbSAnQG5kbGEvaWNvbnMvY29tbW9uJztcbmltcG9ydCB7IFdpdGhUcmFuc2xhdGlvbiwgd2l0aFRyYW5zbGF0aW9uIH0gZnJvbSAncmVhY3QtaTE4bmV4dCc7XG5pbXBvcnQgeyBDbG9zZUJ1dHRvbiB9IGZyb20gJy4uL0Nsb3NlQnV0dG9uJztcblxuZXhwb3J0IGVudW0gTWVzc2FnZUJveFR5cGUge1xuICBnaG9zdCA9ICdnaG9zdCcsXG4gIGZ1bGxwYWdlID0gJ2Z1bGxwYWdlJyxcbiAgbWVkaXVtID0gJ21lZGl1bScsXG4gIG1hc3RoZWFkID0gJ21hc3RoZWFkJyxcbn1cbnR5cGUgV3JhcHBlclByb3BzID0ge1xuICBib3hUeXBlPzogTWVzc2FnZUJveFR5cGU7XG59O1xuXG5jb25zdCBTdHlsZUJ5VHlwZSA9ICh0eXBlOiBXcmFwcGVyUHJvcHNbJ2JveFR5cGUnXSkgPT4ge1xuICBjb25zdCBzdHlsZXM6IEhUTUxBdHRyaWJ1dGVzPEhUTUxFbGVtZW50Plsnc3R5bGUnXSA9IHtcbiAgICBtYXJnaW46ICcxcHgnLFxuICAgIGNvbG9yOiAnIzQ0NDQ0NCcsXG4gICAgYmFja2dyb3VuZENvbG9yOiAnI2Y5ZjRjOCcsXG4gICAgYm9yZGVyOiAnbm9uZScsXG4gICAgZGlzcGxheTogJ2ZsZXgnLFxuICAgIHBhZGRpbmc6ICcxMHB4JyxcbiAgICB3aWR0aDogJ2F1dG8nLFxuICAgIGJvcmRlclJhZGl1czogJzVweCcsXG4gICAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gICAgdHJhbnNmb3JtOiAnYXV0bycsXG4gICAgbGVmdDogJ2F1dG8nLFxuICB9OyAvL0RpZmZlcmVudCBDU1MgcHJvcGVydGllcyBmb3IgZGlmZmVyZW50IHR5cGVzIG9mIG1lc3NhZ2UtYm94ZXNcbiAgc3dpdGNoICh0eXBlKSB7XG4gICAgY2FzZSAnZnVsbHBhZ2UnOlxuICAgICAgc3R5bGVzLm1hcmdpbiA9ICcwIGF1dG8nO1xuICAgICAgc3R5bGVzLmRpc3BsYXkgPSAnbm9uZSc7XG4gICAgICBzdHlsZXMud2lkdGggPSAnMTAwdncnO1xuICAgICAgc3R5bGVzLnBvc2l0aW9uID0gJ3JlbGF0aXZlJztcbiAgICAgIHN0eWxlcy5sZWZ0ID0gJzUwJSc7XG4gICAgICBzdHlsZXMudHJhbnNmb3JtID0gJ3RyYW5zbGF0ZVgoLTUwJSknO1xuICAgICAgYnJlYWs7XG4gICAgY2FzZSAnbWVkaXVtJzpcbiAgICAgIHN0eWxlcy5tYXJnaW4gPSAnMHB4JztcbiAgICAgIGJyZWFrO1xuICAgIGNhc2UgJ2dob3N0JzpcbiAgICAgIHN0eWxlcy5iYWNrZ3JvdW5kQ29sb3IgPSAndHJhbnNwYXJlbnQnO1xuICAgICAgc3R5bGVzLmJvcmRlciA9ICcxcHggc29saWQgI0QxRDZEQic7XG4gICAgICBzdHlsZXMuY29sb3IgPSAnIzQ0NDQ0NCc7XG4gICAgICBicmVhaztcbiAgICBjYXNlICdtYXN0aGVhZCc6XG4gICAgICBzdHlsZXMubWFyZ2luID0gJzAgYXV0byc7XG4gICAgICBzdHlsZXMuZGlzcGxheSA9ICdub25lJztcbiAgICAgIHN0eWxlcy5wYWRkaW5nID0gJzAnO1xuICAgICAgc3R5bGVzLmJvcmRlclJhZGl1cyA9ICcwJztcbiAgICAgIGJyZWFrO1xuICB9XG4gIHJldHVybiBzdHlsZXM7XG59O1xuXG5jb25zdCBXcmFwcGVyID0gc3R5bGVkLmRpdjxXcmFwcGVyUHJvcHM+YFxuICBiYWNrZ3JvdW5kOiAkeyhwcm9wcykgPT4gU3R5bGVCeVR5cGUocHJvcHMuYm94VHlwZSkuYmFja2dyb3VuZENvbG9yfTtcbiAgY29sb3I6ICR7KHByb3BzKSA9PiBTdHlsZUJ5VHlwZShwcm9wcy5ib3hUeXBlKS5jb2xvcn07XG4gIGZvbnQtc2l6ZTogMThweDtcbiAgbGluZS1oZWlnaHQ6IDMycHg7XG4gIGZvbnQtZmFtaWx5OiAke2ZvbnRzLnNhbnN9O1xuICBkaXNwbGF5OiBmbGV4O1xuICBwYWRkaW5nOiAke3NwYWNpbmcuc21hbGx9O1xuICBwb3NpdGlvbjogJHsocHJvcHMpID0+IFN0eWxlQnlUeXBlKHByb3BzLmJveFR5cGUpLnBvc2l0aW9ufTtcbiAgYm9yZGVyOiAkeyhwcm9wcykgPT4gU3R5bGVCeVR5cGUocHJvcHMuYm94VHlwZSkuYm9yZGVyfTtcbiAgYm9yZGVyLXJhZGl1czogJHsocHJvcHMpID0+IFN0eWxlQnlUeXBlKHByb3BzLmJveFR5cGUpLmJvcmRlclJhZGl1c307XG4gIHRyYW5zZm9ybTogJHsocHJvcHMpID0+IFN0eWxlQnlUeXBlKHByb3BzLmJveFR5cGUpLnRyYW5zZm9ybX07XG4gIGxlZnQ6ICR7KHByb3BzKSA9PiBTdHlsZUJ5VHlwZShwcm9wcy5ib3hUeXBlKS5sZWZ0fTtcbiAgei1pbmRleDogMTA7XG4gIHdpZHRoOiAkeyhwcm9wcykgPT4gU3R5bGVCeVR5cGUocHJvcHMuYm94VHlwZSkud2lkdGh9O1xuYDtcblxuY29uc3QgSW5mb1dyYXBwZXIgPSBzdHlsZWQuZGl2PFdyYXBwZXJQcm9wcz5gXG4gIG1hcmdpbjogJHsocHJvcHMpID0+IFN0eWxlQnlUeXBlKHByb3BzLmJveFR5cGUpLm1hcmdpbn07XG4gIHBhZGRpbmc6ICR7KHByb3BzKSA9PiBTdHlsZUJ5VHlwZShwcm9wcy5ib3hUeXBlKS5wYWRkaW5nfTtcbiAgZGlzcGxheTogZmxleDtcbiAgJHttcS5yYW5nZSh7IHVudGlsOiBicmVha3BvaW50cy50YWJsZXRXaWRlIH0pfSB7XG4gICAgcGFkZGluZzogMCA5MHB4IDAgMDtcbiAgfVxuICAke21xLnJhbmdlKHsgdW50aWw6IGJyZWFrcG9pbnRzLm1vYmlsZVdpZGUgfSl9IHtcbiAgICBwYWRkaW5nOiAwIDVweCAwIDA7XG4gICAgZm9udC1zaXplOiAxNnB4O1xuICB9XG5gO1xuY29uc3QgVGV4dFdyYXBwZXIgPSBzdHlsZWQuZGl2PFdyYXBwZXJQcm9wcz5gXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGZsZXgtd3JhcDogd3JhcDtcbiAgJHttcS5yYW5nZSh7IHVudGlsOiBicmVha3BvaW50cy50YWJsZXRXaWRlIH0pfSB7XG4gICAgbGluZS1oZWlnaHQ6IDI0cHg7XG4gICAgZm9udC1zaXplOiAxNnB4O1xuICB9XG5gO1xuXG5jb25zdCBJY29uV3JhcHBlciA9IHN0eWxlZC5kaXY8V3JhcHBlclByb3BzPmBcbiAgcGFkZGluZy1yaWdodDogJHtzcGFjaW5nLnNtYWxsfTtcbiAgZGlzcGxheTogJHsocHJvcHMpID0+IFN0eWxlQnlUeXBlKHByb3BzLmJveFR5cGUpLmRpc3BsYXl9O1xuICBhbGlnbi1pdGVtczogZmxleC1zdGFydDtcbiAgJHttcS5yYW5nZSh7IGZyb206IGJyZWFrcG9pbnRzLnRhYmxldFdpZGUgfSl9IHtcbiAgICBwYWRkaW5nLXRvcDogNHB4O1xuICB9XG5gO1xuXG5jb25zdCBMaW5rV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIGRpc3BsYXk6IGJsb2NrO1xuICB3aWR0aDogMTAwJTtcbiAgYmFja2dyb3VuZC1jb2xvcjogI2Y5ZjRjODtcbiAgcGFkZGluZy1ib3R0b206IDIwcHg7XG4gIG1hcmdpbi10b3A6IC0ycHg7XG4gIHBhZGRpbmctbGVmdDogNThweDtcbiAgYm9yZGVyLXJhZGl1czogMHB4IDBweCA1cHggNXB4O1xuICAke21xLnJhbmdlKHsgdW50aWw6IGJyZWFrcG9pbnRzLm1vYmlsZVdpZGUgfSl9IHtcbiAgICBwYWRkaW5nLWxlZnQ6IDQ1cHg7XG4gIH1cbmA7XG5jb25zdCBMaW5rID0gc3R5bGVkLmFgXG4gIGNvbG9yOiAjMjA1ODhmO1xuICBmb250LXNpemU6IDE2cHg7XG4gIHBhZGRpbmctYm90dG9tOiAxcHg7XG4gIG1hcmdpbjogMHB4IDQwcHggMXB4IDJweDtcbiAgZm9udC1mYW1pbHk6ICR7Zm9udHMuc2Fuc307XG4gICR7bXEucmFuZ2UoeyB1bnRpbDogYnJlYWtwb2ludHMubW9iaWxlV2lkZSB9KX0ge1xuICAgIG1hcmdpbjogMHB4IDE1cHggMXB4IDVweDtcbiAgICBib3gtc2hhZG93OiBub25lO1xuICB9XG5gO1xuY29uc3QgQ2xvc2VCdXR0b25XcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgcG9zaXRpb246IGFic29sdXRlO1xuICB0b3A6IDEwcHg7XG4gIHJpZ2h0OiAxcHg7XG5gO1xuXG50eXBlIExpbmtQcm9wcyA9IHtcbiAgaHJlZj86IHN0cmluZztcbiAgdGV4dD86IHN0cmluZztcbn07XG50eXBlIFByb3BzID0ge1xuICB0eXBlPzogV3JhcHBlclByb3BzWydib3hUeXBlJ107XG4gIHN0aWNreT86IGJvb2xlYW47XG4gIGNoaWxkcmVuPzogc3RyaW5nO1xuICBsaW5rcz86IExpbmtQcm9wc1tdO1xuICBzaG93Q2xvc2VCdXR0b24/OiBib29sZWFuO1xufTtcblxuZXhwb3J0IGNvbnN0IE1lc3NhZ2VCb3ggPSAoeyB0eXBlLCBzdGlja3kgPSBmYWxzZSwgY2hpbGRyZW4sIGxpbmtzLCB0LCBzaG93Q2xvc2VCdXR0b24gfTogUHJvcHMgJiBXaXRoVHJhbnNsYXRpb24pID0+IHtcbiAgY29uc3QgW2hpZGVNZXNzYWdlQm94LCBzZXRIaWRlTWVzc2FnZUJveF0gPSB1c2VTdGF0ZShmYWxzZSk7XG4gIGNvbnN0IG9uQ2xvc2VNZXNzYWdlQm94ID0gKCkgPT4ge1xuICAgIHNldEhpZGVNZXNzYWdlQm94KHRydWUpO1xuICB9O1xuICBjb25zdCBJY29uID0gdHlwZSA9PT0gJ2dob3N0JyA/IEh1bWFuTWFsZUJvYXJkIDogSW5mb3JtYXRpb25PdXRsaW5lO1xuICByZXR1cm4gKFxuICAgIC8vU3RpY2t5U3R5bGUgdG9wOjg0IG1ha2VzIHN1cmUgdGhhdCB0aGUgbWVzc2FnZWJveCBzaXRzIGJlbmVhdGggdGhlIG1hc3RoZWFkIChoZWFkZXIgKSBhbmQgdGhlIHRvcE9mZnNldHQgc2V0cyBpdCBzbyB0aGF0IGl0IGFwcGxpZXMgd2hlbiByZWFjaGluZyB0aGUgdG9wIG9mIHRoZSBtZXNzYWdlYm94XG4gICAgPFN0aWNreSBkaXNhYmxlZD17IXN0aWNreX0gc3RpY2t5U3R5bGU9e3sgekluZGV4OiA5OTk4LCB0b3A6IDg0IH19IHRvcE9mZnNldD17LTg0fT5cbiAgICAgIDxXcmFwcGVyIGJveFR5cGU9e3R5cGV9IHN0eWxlPXt7IGRpc3BsYXk6IGhpZGVNZXNzYWdlQm94ID8gJ25vbmUnIDogJ2ZsZXgnIH19PlxuICAgICAgICA8SW5mb1dyYXBwZXIgYm94VHlwZT17dHlwZX0+XG4gICAgICAgICAgPEljb25XcmFwcGVyIGJveFR5cGU9e3R5cGV9PlxuICAgICAgICAgICAgPEljb24gc3R5bGU9e3sgd2lkdGg6ICcyNHB4JywgaGVpZ2h0OiAnMjRweCcgfX0gLz5cbiAgICAgICAgICA8L0ljb25XcmFwcGVyPlxuICAgICAgICAgIDxUZXh0V3JhcHBlcj57Y2hpbGRyZW59PC9UZXh0V3JhcHBlcj5cbiAgICAgICAgPC9JbmZvV3JhcHBlcj5cbiAgICAgICAge3Nob3dDbG9zZUJ1dHRvbiAmJiAoXG4gICAgICAgICAgPENsb3NlQnV0dG9uV3JhcHBlcj5cbiAgICAgICAgICAgIDxDbG9zZUJ1dHRvbiBvbkNsaWNrPXtvbkNsb3NlTWVzc2FnZUJveH0gLz5cbiAgICAgICAgICA8L0Nsb3NlQnV0dG9uV3JhcHBlcj5cbiAgICAgICAgKX1cbiAgICAgIDwvV3JhcHBlcj5cblxuICAgICAge2xpbmtzICYmIChcbiAgICAgICAgLy9sb29wcyB0aHJvdWdoIHRoZSBsaW5rcyBwYXNzZWQgaW4gYXMgcHJvcGVydGllcyBpZiB0aGVyZSBhcmUgYW55IGFuZCBjcmVhdGVzIGEgd29ya2luZyBsaW5rIGZvciBlYWNoIG9mIHRoZW1cbiAgICAgICAgPExpbmtXcmFwcGVyIHN0eWxlPXt7IGRpc3BsYXk6IGhpZGVNZXNzYWdlQm94ID8gJ25vbmUnIDogJ2ZsZXgnIH19PlxuICAgICAgICAgIHtsaW5rcy5tYXAoKHgpID0+IChcbiAgICAgICAgICAgIDxMaW5rIGhyZWY9e3guaHJlZn0+e3gudGV4dH08L0xpbms+XG4gICAgICAgICAgKSl9XG4gICAgICAgIDwvTGlua1dyYXBwZXI+XG4gICAgICApfVxuICAgIDwvU3RpY2t5PlxuICApO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgd2l0aFRyYW5zbGF0aW9uKCkoTWVzc2FnZUJveCk7XG4iXX0= */"));
151
+ }), "{margin:0px 15px 1px 5px;box-shadow:none;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["MessageBox.tsx"],"names":[],"mappings":"AAsIqB","file":"MessageBox.tsx","sourcesContent":["/**\n * Copyright (c) 2022-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, { HTMLAttributes, useState } from 'react';\nimport styled from '@emotion/styled';\nimport Sticky from 'react-sticky-el';\nimport { breakpoints, fonts, mq, spacing } from '@ndla/core';\nimport { InformationOutline, HumanMaleBoard } from '@ndla/icons/common';\nimport { WithTranslation, withTranslation } from 'react-i18next';\n\n// @ts-ignore\nimport { Remarkable } from 'remarkable';\nimport { CloseButton } from '../CloseButton';\n\nexport enum MessageBoxType {\n  ghost = 'ghost',\n  fullpage = 'fullpage',\n  medium = 'medium',\n  masthead = 'masthead',\n}\ntype WrapperProps = {\n  boxType?: MessageBoxType;\n};\n\nconst StyleByType = (type: WrapperProps['boxType']) => {\n  const styles: HTMLAttributes<HTMLElement>['style'] = {\n    margin: '1px',\n    color: '#444444',\n    backgroundColor: '#f9f4c8',\n    border: 'none',\n    display: 'flex',\n    padding: '10px',\n    width: 'auto',\n    borderRadius: '5px',\n    position: 'relative',\n    transform: 'auto',\n    left: 'auto',\n  }; //Different CSS properties for different types of message-boxes\n  switch (type) {\n    case 'fullpage':\n      styles.margin = '0 auto';\n      styles.display = 'none';\n      styles.width = '100vw';\n      styles.position = 'relative';\n      styles.left = '50%';\n      styles.padding = '0';\n      styles.transform = 'translateX(-50%)';\n      break;\n    case 'medium':\n      styles.margin = '0px';\n      break;\n    case 'ghost':\n      styles.backgroundColor = 'transparent';\n      styles.border = '1px solid #D1D6DB';\n      styles.color = '#444444';\n      break;\n    case 'masthead':\n      styles.margin = '0 auto';\n      styles.display = 'none';\n      styles.padding = '0';\n      styles.borderRadius = '0';\n      break;\n  }\n  return styles;\n};\n\nconst Wrapper = styled.div<WrapperProps>`\n  background: ${(props) => StyleByType(props.boxType).backgroundColor};\n  color: ${(props) => StyleByType(props.boxType).color};\n  font-size: 18px;\n  line-height: 32px;\n  font-family: ${fonts.sans};\n  display: flex;\n  padding: ${spacing.small};\n  position: ${(props) => StyleByType(props.boxType).position};\n  border: ${(props) => StyleByType(props.boxType).border};\n  border-radius: ${(props) => StyleByType(props.boxType).borderRadius};\n  transform: ${(props) => StyleByType(props.boxType).transform};\n  left: ${(props) => StyleByType(props.boxType).left};\n  z-index: 10;\n  width: ${(props) => StyleByType(props.boxType).width};\n`;\n\nconst InfoWrapper = styled.div<WrapperProps>`\n  margin: ${(props) => StyleByType(props.boxType).margin};\n  padding: ${(props) => StyleByType(props.boxType).padding};\n  display: flex;\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    padding: 0 90px 0 0;\n  }\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    padding: 0 5px 0 0;\n    font-size: 16px;\n  }\n`;\nconst TextWrapper = styled.div<WrapperProps>`\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    line-height: 24px;\n    font-size: 16px;\n  }\n  & p {\n    margin: 0;\n  }\n`;\n\nconst IconWrapper = styled.div<WrapperProps>`\n  padding-right: ${spacing.small};\n  display: ${(props) => StyleByType(props.boxType).display};\n  align-items: flex-start;\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding-top: 4px;\n  }\n`;\n\nconst LinkWrapper = styled.div`\n  display: block;\n  width: 100%;\n  background-color: #f9f4c8;\n  padding-bottom: 20px;\n  margin-top: -2px;\n  padding-left: 58px;\n  border-radius: 0px 0px 5px 5px;\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    padding-left: 45px;\n  }\n`;\nconst Link = styled.a`\n  color: #20588f;\n  font-size: 16px;\n  padding-bottom: 1px;\n  margin: 0px 40px 1px 2px;\n  font-family: ${fonts.sans};\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    margin: 0px 15px 1px 5px;\n    box-shadow: none;\n  }\n`;\nconst CloseButtonWrapper = styled.div`\n  position: absolute;\n  top: 10px;\n  right: 1px;\n`;\n\ntype LinkProps = {\n  href?: string;\n  text?: string;\n};\ntype Props = {\n  type?: WrapperProps['boxType'];\n  sticky?: boolean;\n  children?: string;\n  links?: LinkProps[];\n  showCloseButton?: boolean;\n  onClose?: () => void;\n};\n\nconst markdown = new Remarkable({ breaks: true });\nmarkdown.inline.ruler.enable(['sub', 'sup']);\nmarkdown.block.ruler.disable(['list', 'table']);\n\nexport const MessageBox = ({\n  type,\n  sticky = false,\n  children = '',\n  links,\n  showCloseButton,\n  onClose,\n}: Props & WithTranslation) => {\n  const [hideMessageBox, setHideMessageBox] = useState(false);\n  const onCloseMessageBox = () => {\n    setHideMessageBox(true);\n    onClose?.();\n  };\n  const Icon = type === 'ghost' ? HumanMaleBoard : InformationOutline;\n  return (\n    //StickyStyle top:84 makes sure that the messagebox sits beneath the masthead (header ) and the topOffsett sets it so that it applies when reaching the top of the messagebox\n    <Sticky disabled={!sticky} stickyStyle={{ zIndex: 9998, top: 84 }} topOffset={-84}>\n      <Wrapper boxType={type} style={{ display: hideMessageBox ? 'none' : 'flex' }}>\n        <InfoWrapper boxType={type}>\n          <IconWrapper boxType={type}>\n            <Icon style={{ width: '24px', height: '24px' }} />\n          </IconWrapper>\n          <TextWrapper dangerouslySetInnerHTML={{ __html: markdown.render(children) }}></TextWrapper>\n        </InfoWrapper>\n        {showCloseButton && (\n          <CloseButtonWrapper>\n            <CloseButton onClick={onCloseMessageBox} />\n          </CloseButtonWrapper>\n        )}\n      </Wrapper>\n\n      {links && (\n        //loops through the links passed in as properties if there are any and creates a working link for each of them\n        <LinkWrapper style={{ display: hideMessageBox ? 'none' : 'flex' }}>\n          {links.map((x) => (\n            <Link href={x.href}>{x.text}</Link>\n          ))}\n        </LinkWrapper>\n      )}\n    </Sticky>\n  );\n};\n\nexport default withTranslation()(MessageBox);\n"]} */"));
149
152
 
150
153
  var CloseButtonWrapper = _styled("div", {
151
154
  target: "e1ckcvyi6",
@@ -156,18 +159,24 @@ var CloseButtonWrapper = _styled("div", {
156
159
  } : {
157
160
  name: "16ubfqw",
158
161
  styles: "position:absolute;top:10px;right:1px;",
159
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIk1lc3NhZ2VCb3gudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTBJcUMiLCJmaWxlIjoiTWVzc2FnZUJveC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAyMi1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCBSZWFjdCwgeyBIVE1MQXR0cmlidXRlcywgdXNlU3RhdGUgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgU3RpY2t5IGZyb20gJ3JlYWN0LXN0aWNreS1lbCc7XG5pbXBvcnQgeyBicmVha3BvaW50cywgZm9udHMsIG1xLCBzcGFjaW5nIH0gZnJvbSAnQG5kbGEvY29yZSc7XG5pbXBvcnQgeyBJbmZvcm1hdGlvbk91dGxpbmUsIEh1bWFuTWFsZUJvYXJkIH0gZnJvbSAnQG5kbGEvaWNvbnMvY29tbW9uJztcbmltcG9ydCB7IFdpdGhUcmFuc2xhdGlvbiwgd2l0aFRyYW5zbGF0aW9uIH0gZnJvbSAncmVhY3QtaTE4bmV4dCc7XG5pbXBvcnQgeyBDbG9zZUJ1dHRvbiB9IGZyb20gJy4uL0Nsb3NlQnV0dG9uJztcblxuZXhwb3J0IGVudW0gTWVzc2FnZUJveFR5cGUge1xuICBnaG9zdCA9ICdnaG9zdCcsXG4gIGZ1bGxwYWdlID0gJ2Z1bGxwYWdlJyxcbiAgbWVkaXVtID0gJ21lZGl1bScsXG4gIG1hc3RoZWFkID0gJ21hc3RoZWFkJyxcbn1cbnR5cGUgV3JhcHBlclByb3BzID0ge1xuICBib3hUeXBlPzogTWVzc2FnZUJveFR5cGU7XG59O1xuXG5jb25zdCBTdHlsZUJ5VHlwZSA9ICh0eXBlOiBXcmFwcGVyUHJvcHNbJ2JveFR5cGUnXSkgPT4ge1xuICBjb25zdCBzdHlsZXM6IEhUTUxBdHRyaWJ1dGVzPEhUTUxFbGVtZW50Plsnc3R5bGUnXSA9IHtcbiAgICBtYXJnaW46ICcxcHgnLFxuICAgIGNvbG9yOiAnIzQ0NDQ0NCcsXG4gICAgYmFja2dyb3VuZENvbG9yOiAnI2Y5ZjRjOCcsXG4gICAgYm9yZGVyOiAnbm9uZScsXG4gICAgZGlzcGxheTogJ2ZsZXgnLFxuICAgIHBhZGRpbmc6ICcxMHB4JyxcbiAgICB3aWR0aDogJ2F1dG8nLFxuICAgIGJvcmRlclJhZGl1czogJzVweCcsXG4gICAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gICAgdHJhbnNmb3JtOiAnYXV0bycsXG4gICAgbGVmdDogJ2F1dG8nLFxuICB9OyAvL0RpZmZlcmVudCBDU1MgcHJvcGVydGllcyBmb3IgZGlmZmVyZW50IHR5cGVzIG9mIG1lc3NhZ2UtYm94ZXNcbiAgc3dpdGNoICh0eXBlKSB7XG4gICAgY2FzZSAnZnVsbHBhZ2UnOlxuICAgICAgc3R5bGVzLm1hcmdpbiA9ICcwIGF1dG8nO1xuICAgICAgc3R5bGVzLmRpc3BsYXkgPSAnbm9uZSc7XG4gICAgICBzdHlsZXMud2lkdGggPSAnMTAwdncnO1xuICAgICAgc3R5bGVzLnBvc2l0aW9uID0gJ3JlbGF0aXZlJztcbiAgICAgIHN0eWxlcy5sZWZ0ID0gJzUwJSc7XG4gICAgICBzdHlsZXMudHJhbnNmb3JtID0gJ3RyYW5zbGF0ZVgoLTUwJSknO1xuICAgICAgYnJlYWs7XG4gICAgY2FzZSAnbWVkaXVtJzpcbiAgICAgIHN0eWxlcy5tYXJnaW4gPSAnMHB4JztcbiAgICAgIGJyZWFrO1xuICAgIGNhc2UgJ2dob3N0JzpcbiAgICAgIHN0eWxlcy5iYWNrZ3JvdW5kQ29sb3IgPSAndHJhbnNwYXJlbnQnO1xuICAgICAgc3R5bGVzLmJvcmRlciA9ICcxcHggc29saWQgI0QxRDZEQic7XG4gICAgICBzdHlsZXMuY29sb3IgPSAnIzQ0NDQ0NCc7XG4gICAgICBicmVhaztcbiAgICBjYXNlICdtYXN0aGVhZCc6XG4gICAgICBzdHlsZXMubWFyZ2luID0gJzAgYXV0byc7XG4gICAgICBzdHlsZXMuZGlzcGxheSA9ICdub25lJztcbiAgICAgIHN0eWxlcy5wYWRkaW5nID0gJzAnO1xuICAgICAgc3R5bGVzLmJvcmRlclJhZGl1cyA9ICcwJztcbiAgICAgIGJyZWFrO1xuICB9XG4gIHJldHVybiBzdHlsZXM7XG59O1xuXG5jb25zdCBXcmFwcGVyID0gc3R5bGVkLmRpdjxXcmFwcGVyUHJvcHM+YFxuICBiYWNrZ3JvdW5kOiAkeyhwcm9wcykgPT4gU3R5bGVCeVR5cGUocHJvcHMuYm94VHlwZSkuYmFja2dyb3VuZENvbG9yfTtcbiAgY29sb3I6ICR7KHByb3BzKSA9PiBTdHlsZUJ5VHlwZShwcm9wcy5ib3hUeXBlKS5jb2xvcn07XG4gIGZvbnQtc2l6ZTogMThweDtcbiAgbGluZS1oZWlnaHQ6IDMycHg7XG4gIGZvbnQtZmFtaWx5OiAke2ZvbnRzLnNhbnN9O1xuICBkaXNwbGF5OiBmbGV4O1xuICBwYWRkaW5nOiAke3NwYWNpbmcuc21hbGx9O1xuICBwb3NpdGlvbjogJHsocHJvcHMpID0+IFN0eWxlQnlUeXBlKHByb3BzLmJveFR5cGUpLnBvc2l0aW9ufTtcbiAgYm9yZGVyOiAkeyhwcm9wcykgPT4gU3R5bGVCeVR5cGUocHJvcHMuYm94VHlwZSkuYm9yZGVyfTtcbiAgYm9yZGVyLXJhZGl1czogJHsocHJvcHMpID0+IFN0eWxlQnlUeXBlKHByb3BzLmJveFR5cGUpLmJvcmRlclJhZGl1c307XG4gIHRyYW5zZm9ybTogJHsocHJvcHMpID0+IFN0eWxlQnlUeXBlKHByb3BzLmJveFR5cGUpLnRyYW5zZm9ybX07XG4gIGxlZnQ6ICR7KHByb3BzKSA9PiBTdHlsZUJ5VHlwZShwcm9wcy5ib3hUeXBlKS5sZWZ0fTtcbiAgei1pbmRleDogMTA7XG4gIHdpZHRoOiAkeyhwcm9wcykgPT4gU3R5bGVCeVR5cGUocHJvcHMuYm94VHlwZSkud2lkdGh9O1xuYDtcblxuY29uc3QgSW5mb1dyYXBwZXIgPSBzdHlsZWQuZGl2PFdyYXBwZXJQcm9wcz5gXG4gIG1hcmdpbjogJHsocHJvcHMpID0+IFN0eWxlQnlUeXBlKHByb3BzLmJveFR5cGUpLm1hcmdpbn07XG4gIHBhZGRpbmc6ICR7KHByb3BzKSA9PiBTdHlsZUJ5VHlwZShwcm9wcy5ib3hUeXBlKS5wYWRkaW5nfTtcbiAgZGlzcGxheTogZmxleDtcbiAgJHttcS5yYW5nZSh7IHVudGlsOiBicmVha3BvaW50cy50YWJsZXRXaWRlIH0pfSB7XG4gICAgcGFkZGluZzogMCA5MHB4IDAgMDtcbiAgfVxuICAke21xLnJhbmdlKHsgdW50aWw6IGJyZWFrcG9pbnRzLm1vYmlsZVdpZGUgfSl9IHtcbiAgICBwYWRkaW5nOiAwIDVweCAwIDA7XG4gICAgZm9udC1zaXplOiAxNnB4O1xuICB9XG5gO1xuY29uc3QgVGV4dFdyYXBwZXIgPSBzdHlsZWQuZGl2PFdyYXBwZXJQcm9wcz5gXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGZsZXgtd3JhcDogd3JhcDtcbiAgJHttcS5yYW5nZSh7IHVudGlsOiBicmVha3BvaW50cy50YWJsZXRXaWRlIH0pfSB7XG4gICAgbGluZS1oZWlnaHQ6IDI0cHg7XG4gICAgZm9udC1zaXplOiAxNnB4O1xuICB9XG5gO1xuXG5jb25zdCBJY29uV3JhcHBlciA9IHN0eWxlZC5kaXY8V3JhcHBlclByb3BzPmBcbiAgcGFkZGluZy1yaWdodDogJHtzcGFjaW5nLnNtYWxsfTtcbiAgZGlzcGxheTogJHsocHJvcHMpID0+IFN0eWxlQnlUeXBlKHByb3BzLmJveFR5cGUpLmRpc3BsYXl9O1xuICBhbGlnbi1pdGVtczogZmxleC1zdGFydDtcbiAgJHttcS5yYW5nZSh7IGZyb206IGJyZWFrcG9pbnRzLnRhYmxldFdpZGUgfSl9IHtcbiAgICBwYWRkaW5nLXRvcDogNHB4O1xuICB9XG5gO1xuXG5jb25zdCBMaW5rV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIGRpc3BsYXk6IGJsb2NrO1xuICB3aWR0aDogMTAwJTtcbiAgYmFja2dyb3VuZC1jb2xvcjogI2Y5ZjRjODtcbiAgcGFkZGluZy1ib3R0b206IDIwcHg7XG4gIG1hcmdpbi10b3A6IC0ycHg7XG4gIHBhZGRpbmctbGVmdDogNThweDtcbiAgYm9yZGVyLXJhZGl1czogMHB4IDBweCA1cHggNXB4O1xuICAke21xLnJhbmdlKHsgdW50aWw6IGJyZWFrcG9pbnRzLm1vYmlsZVdpZGUgfSl9IHtcbiAgICBwYWRkaW5nLWxlZnQ6IDQ1cHg7XG4gIH1cbmA7XG5jb25zdCBMaW5rID0gc3R5bGVkLmFgXG4gIGNvbG9yOiAjMjA1ODhmO1xuICBmb250LXNpemU6IDE2cHg7XG4gIHBhZGRpbmctYm90dG9tOiAxcHg7XG4gIG1hcmdpbjogMHB4IDQwcHggMXB4IDJweDtcbiAgZm9udC1mYW1pbHk6ICR7Zm9udHMuc2Fuc307XG4gICR7bXEucmFuZ2UoeyB1bnRpbDogYnJlYWtwb2ludHMubW9iaWxlV2lkZSB9KX0ge1xuICAgIG1hcmdpbjogMHB4IDE1cHggMXB4IDVweDtcbiAgICBib3gtc2hhZG93OiBub25lO1xuICB9XG5gO1xuY29uc3QgQ2xvc2VCdXR0b25XcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgcG9zaXRpb246IGFic29sdXRlO1xuICB0b3A6IDEwcHg7XG4gIHJpZ2h0OiAxcHg7XG5gO1xuXG50eXBlIExpbmtQcm9wcyA9IHtcbiAgaHJlZj86IHN0cmluZztcbiAgdGV4dD86IHN0cmluZztcbn07XG50eXBlIFByb3BzID0ge1xuICB0eXBlPzogV3JhcHBlclByb3BzWydib3hUeXBlJ107XG4gIHN0aWNreT86IGJvb2xlYW47XG4gIGNoaWxkcmVuPzogc3RyaW5nO1xuICBsaW5rcz86IExpbmtQcm9wc1tdO1xuICBzaG93Q2xvc2VCdXR0b24/OiBib29sZWFuO1xufTtcblxuZXhwb3J0IGNvbnN0IE1lc3NhZ2VCb3ggPSAoeyB0eXBlLCBzdGlja3kgPSBmYWxzZSwgY2hpbGRyZW4sIGxpbmtzLCB0LCBzaG93Q2xvc2VCdXR0b24gfTogUHJvcHMgJiBXaXRoVHJhbnNsYXRpb24pID0+IHtcbiAgY29uc3QgW2hpZGVNZXNzYWdlQm94LCBzZXRIaWRlTWVzc2FnZUJveF0gPSB1c2VTdGF0ZShmYWxzZSk7XG4gIGNvbnN0IG9uQ2xvc2VNZXNzYWdlQm94ID0gKCkgPT4ge1xuICAgIHNldEhpZGVNZXNzYWdlQm94KHRydWUpO1xuICB9O1xuICBjb25zdCBJY29uID0gdHlwZSA9PT0gJ2dob3N0JyA/IEh1bWFuTWFsZUJvYXJkIDogSW5mb3JtYXRpb25PdXRsaW5lO1xuICByZXR1cm4gKFxuICAgIC8vU3RpY2t5U3R5bGUgdG9wOjg0IG1ha2VzIHN1cmUgdGhhdCB0aGUgbWVzc2FnZWJveCBzaXRzIGJlbmVhdGggdGhlIG1hc3RoZWFkIChoZWFkZXIgKSBhbmQgdGhlIHRvcE9mZnNldHQgc2V0cyBpdCBzbyB0aGF0IGl0IGFwcGxpZXMgd2hlbiByZWFjaGluZyB0aGUgdG9wIG9mIHRoZSBtZXNzYWdlYm94XG4gICAgPFN0aWNreSBkaXNhYmxlZD17IXN0aWNreX0gc3RpY2t5U3R5bGU9e3sgekluZGV4OiA5OTk4LCB0b3A6IDg0IH19IHRvcE9mZnNldD17LTg0fT5cbiAgICAgIDxXcmFwcGVyIGJveFR5cGU9e3R5cGV9IHN0eWxlPXt7IGRpc3BsYXk6IGhpZGVNZXNzYWdlQm94ID8gJ25vbmUnIDogJ2ZsZXgnIH19PlxuICAgICAgICA8SW5mb1dyYXBwZXIgYm94VHlwZT17dHlwZX0+XG4gICAgICAgICAgPEljb25XcmFwcGVyIGJveFR5cGU9e3R5cGV9PlxuICAgICAgICAgICAgPEljb24gc3R5bGU9e3sgd2lkdGg6ICcyNHB4JywgaGVpZ2h0OiAnMjRweCcgfX0gLz5cbiAgICAgICAgICA8L0ljb25XcmFwcGVyPlxuICAgICAgICAgIDxUZXh0V3JhcHBlcj57Y2hpbGRyZW59PC9UZXh0V3JhcHBlcj5cbiAgICAgICAgPC9JbmZvV3JhcHBlcj5cbiAgICAgICAge3Nob3dDbG9zZUJ1dHRvbiAmJiAoXG4gICAgICAgICAgPENsb3NlQnV0dG9uV3JhcHBlcj5cbiAgICAgICAgICAgIDxDbG9zZUJ1dHRvbiBvbkNsaWNrPXtvbkNsb3NlTWVzc2FnZUJveH0gLz5cbiAgICAgICAgICA8L0Nsb3NlQnV0dG9uV3JhcHBlcj5cbiAgICAgICAgKX1cbiAgICAgIDwvV3JhcHBlcj5cblxuICAgICAge2xpbmtzICYmIChcbiAgICAgICAgLy9sb29wcyB0aHJvdWdoIHRoZSBsaW5rcyBwYXNzZWQgaW4gYXMgcHJvcGVydGllcyBpZiB0aGVyZSBhcmUgYW55IGFuZCBjcmVhdGVzIGEgd29ya2luZyBsaW5rIGZvciBlYWNoIG9mIHRoZW1cbiAgICAgICAgPExpbmtXcmFwcGVyIHN0eWxlPXt7IGRpc3BsYXk6IGhpZGVNZXNzYWdlQm94ID8gJ25vbmUnIDogJ2ZsZXgnIH19PlxuICAgICAgICAgIHtsaW5rcy5tYXAoKHgpID0+IChcbiAgICAgICAgICAgIDxMaW5rIGhyZWY9e3guaHJlZn0+e3gudGV4dH08L0xpbms+XG4gICAgICAgICAgKSl9XG4gICAgICAgIDwvTGlua1dyYXBwZXI+XG4gICAgICApfVxuICAgIDwvU3RpY2t5PlxuICApO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgd2l0aFRyYW5zbGF0aW9uKCkoTWVzc2FnZUJveCk7XG4iXX0= */",
162
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["MessageBox.tsx"],"names":[],"mappings":"AAiJqC","file":"MessageBox.tsx","sourcesContent":["/**\n * Copyright (c) 2022-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, { HTMLAttributes, useState } from 'react';\nimport styled from '@emotion/styled';\nimport Sticky from 'react-sticky-el';\nimport { breakpoints, fonts, mq, spacing } from '@ndla/core';\nimport { InformationOutline, HumanMaleBoard } from '@ndla/icons/common';\nimport { WithTranslation, withTranslation } from 'react-i18next';\n\n// @ts-ignore\nimport { Remarkable } from 'remarkable';\nimport { CloseButton } from '../CloseButton';\n\nexport enum MessageBoxType {\n  ghost = 'ghost',\n  fullpage = 'fullpage',\n  medium = 'medium',\n  masthead = 'masthead',\n}\ntype WrapperProps = {\n  boxType?: MessageBoxType;\n};\n\nconst StyleByType = (type: WrapperProps['boxType']) => {\n  const styles: HTMLAttributes<HTMLElement>['style'] = {\n    margin: '1px',\n    color: '#444444',\n    backgroundColor: '#f9f4c8',\n    border: 'none',\n    display: 'flex',\n    padding: '10px',\n    width: 'auto',\n    borderRadius: '5px',\n    position: 'relative',\n    transform: 'auto',\n    left: 'auto',\n  }; //Different CSS properties for different types of message-boxes\n  switch (type) {\n    case 'fullpage':\n      styles.margin = '0 auto';\n      styles.display = 'none';\n      styles.width = '100vw';\n      styles.position = 'relative';\n      styles.left = '50%';\n      styles.padding = '0';\n      styles.transform = 'translateX(-50%)';\n      break;\n    case 'medium':\n      styles.margin = '0px';\n      break;\n    case 'ghost':\n      styles.backgroundColor = 'transparent';\n      styles.border = '1px solid #D1D6DB';\n      styles.color = '#444444';\n      break;\n    case 'masthead':\n      styles.margin = '0 auto';\n      styles.display = 'none';\n      styles.padding = '0';\n      styles.borderRadius = '0';\n      break;\n  }\n  return styles;\n};\n\nconst Wrapper = styled.div<WrapperProps>`\n  background: ${(props) => StyleByType(props.boxType).backgroundColor};\n  color: ${(props) => StyleByType(props.boxType).color};\n  font-size: 18px;\n  line-height: 32px;\n  font-family: ${fonts.sans};\n  display: flex;\n  padding: ${spacing.small};\n  position: ${(props) => StyleByType(props.boxType).position};\n  border: ${(props) => StyleByType(props.boxType).border};\n  border-radius: ${(props) => StyleByType(props.boxType).borderRadius};\n  transform: ${(props) => StyleByType(props.boxType).transform};\n  left: ${(props) => StyleByType(props.boxType).left};\n  z-index: 10;\n  width: ${(props) => StyleByType(props.boxType).width};\n`;\n\nconst InfoWrapper = styled.div<WrapperProps>`\n  margin: ${(props) => StyleByType(props.boxType).margin};\n  padding: ${(props) => StyleByType(props.boxType).padding};\n  display: flex;\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    padding: 0 90px 0 0;\n  }\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    padding: 0 5px 0 0;\n    font-size: 16px;\n  }\n`;\nconst TextWrapper = styled.div<WrapperProps>`\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    line-height: 24px;\n    font-size: 16px;\n  }\n  & p {\n    margin: 0;\n  }\n`;\n\nconst IconWrapper = styled.div<WrapperProps>`\n  padding-right: ${spacing.small};\n  display: ${(props) => StyleByType(props.boxType).display};\n  align-items: flex-start;\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding-top: 4px;\n  }\n`;\n\nconst LinkWrapper = styled.div`\n  display: block;\n  width: 100%;\n  background-color: #f9f4c8;\n  padding-bottom: 20px;\n  margin-top: -2px;\n  padding-left: 58px;\n  border-radius: 0px 0px 5px 5px;\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    padding-left: 45px;\n  }\n`;\nconst Link = styled.a`\n  color: #20588f;\n  font-size: 16px;\n  padding-bottom: 1px;\n  margin: 0px 40px 1px 2px;\n  font-family: ${fonts.sans};\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    margin: 0px 15px 1px 5px;\n    box-shadow: none;\n  }\n`;\nconst CloseButtonWrapper = styled.div`\n  position: absolute;\n  top: 10px;\n  right: 1px;\n`;\n\ntype LinkProps = {\n  href?: string;\n  text?: string;\n};\ntype Props = {\n  type?: WrapperProps['boxType'];\n  sticky?: boolean;\n  children?: string;\n  links?: LinkProps[];\n  showCloseButton?: boolean;\n  onClose?: () => void;\n};\n\nconst markdown = new Remarkable({ breaks: true });\nmarkdown.inline.ruler.enable(['sub', 'sup']);\nmarkdown.block.ruler.disable(['list', 'table']);\n\nexport const MessageBox = ({\n  type,\n  sticky = false,\n  children = '',\n  links,\n  showCloseButton,\n  onClose,\n}: Props & WithTranslation) => {\n  const [hideMessageBox, setHideMessageBox] = useState(false);\n  const onCloseMessageBox = () => {\n    setHideMessageBox(true);\n    onClose?.();\n  };\n  const Icon = type === 'ghost' ? HumanMaleBoard : InformationOutline;\n  return (\n    //StickyStyle top:84 makes sure that the messagebox sits beneath the masthead (header ) and the topOffsett sets it so that it applies when reaching the top of the messagebox\n    <Sticky disabled={!sticky} stickyStyle={{ zIndex: 9998, top: 84 }} topOffset={-84}>\n      <Wrapper boxType={type} style={{ display: hideMessageBox ? 'none' : 'flex' }}>\n        <InfoWrapper boxType={type}>\n          <IconWrapper boxType={type}>\n            <Icon style={{ width: '24px', height: '24px' }} />\n          </IconWrapper>\n          <TextWrapper dangerouslySetInnerHTML={{ __html: markdown.render(children) }}></TextWrapper>\n        </InfoWrapper>\n        {showCloseButton && (\n          <CloseButtonWrapper>\n            <CloseButton onClick={onCloseMessageBox} />\n          </CloseButtonWrapper>\n        )}\n      </Wrapper>\n\n      {links && (\n        //loops through the links passed in as properties if there are any and creates a working link for each of them\n        <LinkWrapper style={{ display: hideMessageBox ? 'none' : 'flex' }}>\n          {links.map((x) => (\n            <Link href={x.href}>{x.text}</Link>\n          ))}\n        </LinkWrapper>\n      )}\n    </Sticky>\n  );\n};\n\nexport default withTranslation()(MessageBox);\n"]} */",
160
163
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
161
164
  });
162
165
 
166
+ var markdown = new Remarkable({
167
+ breaks: true
168
+ });
169
+ markdown.inline.ruler.enable(['sub', 'sup']);
170
+ markdown.block.ruler.disable(['list', 'table']);
163
171
  export var MessageBox = function MessageBox(_ref) {
164
172
  var type = _ref.type,
165
173
  _ref$sticky = _ref.sticky,
166
174
  sticky = _ref$sticky === void 0 ? false : _ref$sticky,
167
- children = _ref.children,
175
+ _ref$children = _ref.children,
176
+ children = _ref$children === void 0 ? '' : _ref$children,
168
177
  links = _ref.links,
169
- t = _ref.t,
170
- showCloseButton = _ref.showCloseButton;
178
+ showCloseButton = _ref.showCloseButton,
179
+ onClose = _ref.onClose;
171
180
 
172
181
  var _useState = useState(false),
173
182
  _useState2 = _slicedToArray(_useState, 2),
@@ -176,6 +185,7 @@ export var MessageBox = function MessageBox(_ref) {
176
185
 
177
186
  var onCloseMessageBox = function onCloseMessageBox() {
178
187
  setHideMessageBox(true);
188
+ onClose === null || onClose === void 0 ? void 0 : onClose();
179
189
  };
180
190
 
181
191
  var Icon = type === 'ghost' ? HumanMaleBoard : InformationOutline;
@@ -201,7 +211,11 @@ export var MessageBox = function MessageBox(_ref) {
201
211
  width: '24px',
202
212
  height: '24px'
203
213
  }
204
- })), ___EmotionJSX(TextWrapper, null, children)), showCloseButton && ___EmotionJSX(CloseButtonWrapper, null, ___EmotionJSX(CloseButton, {
214
+ })), ___EmotionJSX(TextWrapper, {
215
+ dangerouslySetInnerHTML: {
216
+ __html: markdown.render(children)
217
+ }
218
+ })), showCloseButton && ___EmotionJSX(CloseButtonWrapper, null, ___EmotionJSX(CloseButton, {
205
219
  onClick: onCloseMessageBox
206
220
  }))), links && //loops through the links passed in as properties if there are any and creates a working link for each of them
207
221
  ___EmotionJSX(LinkWrapper, {
@@ -14,14 +14,20 @@ interface MastheadItemProps {
14
14
  left?: boolean;
15
15
  }
16
16
  export declare const MastheadItem: ({ children, className, left, right }: MastheadItemProps) => JSX.Element;
17
+ interface Alert {
18
+ content: string;
19
+ closable?: boolean;
20
+ number: number;
21
+ }
17
22
  interface Props {
18
23
  children?: ReactNode;
19
24
  fixed?: boolean;
20
25
  infoContent?: ReactNode;
21
26
  ndlaFilm?: boolean;
22
27
  skipToMainContentId?: string;
23
- messages?: string[];
28
+ messages?: Alert[];
29
+ onCloseAlert?: (id: number) => void;
24
30
  }
25
- export declare const Masthead: ({ children, fixed, infoContent, ndlaFilm, skipToMainContentId, messages, t, }: Props & WithTranslation) => JSX.Element;
26
- declare const _default: React.ComponentType<Pick<Pick<Props & WithTranslation<"translation">, "fixed" | "children" | "t" | "tReady" | "messages" | "ndlaFilm" | "infoContent" | "skipToMainContentId">, "fixed" | "children" | "messages" | "ndlaFilm" | "infoContent" | "skipToMainContentId"> & import("react-i18next").WithTranslationProps>;
31
+ export declare const Masthead: ({ children, fixed, infoContent, ndlaFilm, skipToMainContentId, messages, onCloseAlert, t, }: Props & WithTranslation) => JSX.Element;
32
+ declare const _default: React.ComponentType<Pick<Pick<Props & WithTranslation<"translation">, "fixed" | "children" | "t" | "tReady" | "messages" | "ndlaFilm" | "infoContent" | "skipToMainContentId" | "onCloseAlert">, "fixed" | "children" | "messages" | "ndlaFilm" | "infoContent" | "skipToMainContentId" | "onCloseAlert"> & import("react-i18next").WithTranslationProps>;
27
33
  export default _default;
@@ -60,6 +60,7 @@ var Masthead = function Masthead(_ref3) {
60
60
  ndlaFilm = _ref3.ndlaFilm,
61
61
  skipToMainContentId = _ref3.skipToMainContentId,
62
62
  messages = _ref3.messages,
63
+ onCloseAlert = _ref3.onCloseAlert,
63
64
  t = _ref3.t;
64
65
  var mastheadRef = (0, _react.useRef)(null);
65
66
 
@@ -92,8 +93,12 @@ var Masthead = function Masthead(_ref3) {
92
93
  ndlaFilm: !!ndlaFilm
93
94
  })), messages === null || messages === void 0 ? void 0 : messages.map(function (message) {
94
95
  return (0, _core.jsx)(_MessageBox.MessageBox, {
95
- type: _MessageBox.MessageBoxType.masthead
96
- }, message);
96
+ type: _MessageBox.MessageBoxType.masthead,
97
+ showCloseButton: message.closable,
98
+ onClose: function onClose() {
99
+ return onCloseAlert === null || onCloseAlert === void 0 ? void 0 : onCloseAlert(message.number);
100
+ }
101
+ }, message.content);
97
102
  }), infoContent && (0, _core.jsx)(_Animation.DisplayOnPageYOffset, {
98
103
  yOffsetMin: 0,
99
104
  yOffsetMax: 90
@@ -26,7 +26,8 @@ declare type Props = {
26
26
  children?: string;
27
27
  links?: LinkProps[];
28
28
  showCloseButton?: boolean;
29
+ onClose?: () => void;
29
30
  };
30
- export declare const MessageBox: ({ type, sticky, children, links, t, showCloseButton }: Props & WithTranslation) => JSX.Element;
31
- declare const _default: React.ComponentType<Pick<Pick<Props & WithTranslation<"translation">, "sticky" | "children" | "type" | "t" | "tReady" | "links" | "showCloseButton">, "sticky" | "children" | "type" | "links" | "showCloseButton"> & import("react-i18next").WithTranslationProps>;
31
+ export declare const MessageBox: ({ type, sticky, children, links, showCloseButton, onClose, }: Props & WithTranslation) => JSX.Element;
32
+ declare const _default: React.ComponentType<Pick<Pick<Props & WithTranslation<"translation">, "sticky" | "children" | "type" | "t" | "tReady" | "onClose" | "links" | "showCloseButton">, "sticky" | "children" | "type" | "onClose" | "links" | "showCloseButton"> & import("react-i18next").WithTranslationProps>;
32
33
  export default _default;
@@ -19,6 +19,8 @@ var _common = require("@ndla/icons/common");
19
19
 
20
20
  var _reactI18next = require("react-i18next");
21
21
 
22
+ var _remarkable = require("remarkable");
23
+
22
24
  var _CloseButton = require("../CloseButton");
23
25
 
24
26
  var _core2 = require("@emotion/core");
@@ -75,6 +77,7 @@ var StyleByType = function StyleByType(type) {
75
77
  styles.width = '100vw';
76
78
  styles.position = 'relative';
77
79
  styles.left = '50%';
80
+ styles.padding = '0';
78
81
  styles.transform = 'translateX(-50%)';
79
82
  break;
80
83
 
@@ -118,7 +121,7 @@ var Wrapper = (0, _styledBase["default"])("div", {
118
121
  return StyleByType(props.boxType).left;
119
122
  }, ";z-index:10;width:", function (props) {
120
123
  return StyleByType(props.boxType).width;
121
- }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIk1lc3NhZ2VCb3gudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQW1Fd0MiLCJmaWxlIjoiTWVzc2FnZUJveC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAyMi1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCBSZWFjdCwgeyBIVE1MQXR0cmlidXRlcywgdXNlU3RhdGUgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgU3RpY2t5IGZyb20gJ3JlYWN0LXN0aWNreS1lbCc7XG5pbXBvcnQgeyBicmVha3BvaW50cywgZm9udHMsIG1xLCBzcGFjaW5nIH0gZnJvbSAnQG5kbGEvY29yZSc7XG5pbXBvcnQgeyBJbmZvcm1hdGlvbk91dGxpbmUsIEh1bWFuTWFsZUJvYXJkIH0gZnJvbSAnQG5kbGEvaWNvbnMvY29tbW9uJztcbmltcG9ydCB7IFdpdGhUcmFuc2xhdGlvbiwgd2l0aFRyYW5zbGF0aW9uIH0gZnJvbSAncmVhY3QtaTE4bmV4dCc7XG5pbXBvcnQgeyBDbG9zZUJ1dHRvbiB9IGZyb20gJy4uL0Nsb3NlQnV0dG9uJztcblxuZXhwb3J0IGVudW0gTWVzc2FnZUJveFR5cGUge1xuICBnaG9zdCA9ICdnaG9zdCcsXG4gIGZ1bGxwYWdlID0gJ2Z1bGxwYWdlJyxcbiAgbWVkaXVtID0gJ21lZGl1bScsXG4gIG1hc3RoZWFkID0gJ21hc3RoZWFkJyxcbn1cbnR5cGUgV3JhcHBlclByb3BzID0ge1xuICBib3hUeXBlPzogTWVzc2FnZUJveFR5cGU7XG59O1xuXG5jb25zdCBTdHlsZUJ5VHlwZSA9ICh0eXBlOiBXcmFwcGVyUHJvcHNbJ2JveFR5cGUnXSkgPT4ge1xuICBjb25zdCBzdHlsZXM6IEhUTUxBdHRyaWJ1dGVzPEhUTUxFbGVtZW50Plsnc3R5bGUnXSA9IHtcbiAgICBtYXJnaW46ICcxcHgnLFxuICAgIGNvbG9yOiAnIzQ0NDQ0NCcsXG4gICAgYmFja2dyb3VuZENvbG9yOiAnI2Y5ZjRjOCcsXG4gICAgYm9yZGVyOiAnbm9uZScsXG4gICAgZGlzcGxheTogJ2ZsZXgnLFxuICAgIHBhZGRpbmc6ICcxMHB4JyxcbiAgICB3aWR0aDogJ2F1dG8nLFxuICAgIGJvcmRlclJhZGl1czogJzVweCcsXG4gICAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gICAgdHJhbnNmb3JtOiAnYXV0bycsXG4gICAgbGVmdDogJ2F1dG8nLFxuICB9OyAvL0RpZmZlcmVudCBDU1MgcHJvcGVydGllcyBmb3IgZGlmZmVyZW50IHR5cGVzIG9mIG1lc3NhZ2UtYm94ZXNcbiAgc3dpdGNoICh0eXBlKSB7XG4gICAgY2FzZSAnZnVsbHBhZ2UnOlxuICAgICAgc3R5bGVzLm1hcmdpbiA9ICcwIGF1dG8nO1xuICAgICAgc3R5bGVzLmRpc3BsYXkgPSAnbm9uZSc7XG4gICAgICBzdHlsZXMud2lkdGggPSAnMTAwdncnO1xuICAgICAgc3R5bGVzLnBvc2l0aW9uID0gJ3JlbGF0aXZlJztcbiAgICAgIHN0eWxlcy5sZWZ0ID0gJzUwJSc7XG4gICAgICBzdHlsZXMudHJhbnNmb3JtID0gJ3RyYW5zbGF0ZVgoLTUwJSknO1xuICAgICAgYnJlYWs7XG4gICAgY2FzZSAnbWVkaXVtJzpcbiAgICAgIHN0eWxlcy5tYXJnaW4gPSAnMHB4JztcbiAgICAgIGJyZWFrO1xuICAgIGNhc2UgJ2dob3N0JzpcbiAgICAgIHN0eWxlcy5iYWNrZ3JvdW5kQ29sb3IgPSAndHJhbnNwYXJlbnQnO1xuICAgICAgc3R5bGVzLmJvcmRlciA9ICcxcHggc29saWQgI0QxRDZEQic7XG4gICAgICBzdHlsZXMuY29sb3IgPSAnIzQ0NDQ0NCc7XG4gICAgICBicmVhaztcbiAgICBjYXNlICdtYXN0aGVhZCc6XG4gICAgICBzdHlsZXMubWFyZ2luID0gJzAgYXV0byc7XG4gICAgICBzdHlsZXMuZGlzcGxheSA9ICdub25lJztcbiAgICAgIHN0eWxlcy5wYWRkaW5nID0gJzAnO1xuICAgICAgc3R5bGVzLmJvcmRlclJhZGl1cyA9ICcwJztcbiAgICAgIGJyZWFrO1xuICB9XG4gIHJldHVybiBzdHlsZXM7XG59O1xuXG5jb25zdCBXcmFwcGVyID0gc3R5bGVkLmRpdjxXcmFwcGVyUHJvcHM+YFxuICBiYWNrZ3JvdW5kOiAkeyhwcm9wcykgPT4gU3R5bGVCeVR5cGUocHJvcHMuYm94VHlwZSkuYmFja2dyb3VuZENvbG9yfTtcbiAgY29sb3I6ICR7KHByb3BzKSA9PiBTdHlsZUJ5VHlwZShwcm9wcy5ib3hUeXBlKS5jb2xvcn07XG4gIGZvbnQtc2l6ZTogMThweDtcbiAgbGluZS1oZWlnaHQ6IDMycHg7XG4gIGZvbnQtZmFtaWx5OiAke2ZvbnRzLnNhbnN9O1xuICBkaXNwbGF5OiBmbGV4O1xuICBwYWRkaW5nOiAke3NwYWNpbmcuc21hbGx9O1xuICBwb3NpdGlvbjogJHsocHJvcHMpID0+IFN0eWxlQnlUeXBlKHByb3BzLmJveFR5cGUpLnBvc2l0aW9ufTtcbiAgYm9yZGVyOiAkeyhwcm9wcykgPT4gU3R5bGVCeVR5cGUocHJvcHMuYm94VHlwZSkuYm9yZGVyfTtcbiAgYm9yZGVyLXJhZGl1czogJHsocHJvcHMpID0+IFN0eWxlQnlUeXBlKHByb3BzLmJveFR5cGUpLmJvcmRlclJhZGl1c307XG4gIHRyYW5zZm9ybTogJHsocHJvcHMpID0+IFN0eWxlQnlUeXBlKHByb3BzLmJveFR5cGUpLnRyYW5zZm9ybX07XG4gIGxlZnQ6ICR7KHByb3BzKSA9PiBTdHlsZUJ5VHlwZShwcm9wcy5ib3hUeXBlKS5sZWZ0fTtcbiAgei1pbmRleDogMTA7XG4gIHdpZHRoOiAkeyhwcm9wcykgPT4gU3R5bGVCeVR5cGUocHJvcHMuYm94VHlwZSkud2lkdGh9O1xuYDtcblxuY29uc3QgSW5mb1dyYXBwZXIgPSBzdHlsZWQuZGl2PFdyYXBwZXJQcm9wcz5gXG4gIG1hcmdpbjogJHsocHJvcHMpID0+IFN0eWxlQnlUeXBlKHByb3BzLmJveFR5cGUpLm1hcmdpbn07XG4gIHBhZGRpbmc6ICR7KHByb3BzKSA9PiBTdHlsZUJ5VHlwZShwcm9wcy5ib3hUeXBlKS5wYWRkaW5nfTtcbiAgZGlzcGxheTogZmxleDtcbiAgJHttcS5yYW5nZSh7IHVudGlsOiBicmVha3BvaW50cy50YWJsZXRXaWRlIH0pfSB7XG4gICAgcGFkZGluZzogMCA5MHB4IDAgMDtcbiAgfVxuICAke21xLnJhbmdlKHsgdW50aWw6IGJyZWFrcG9pbnRzLm1vYmlsZVdpZGUgfSl9IHtcbiAgICBwYWRkaW5nOiAwIDVweCAwIDA7XG4gICAgZm9udC1zaXplOiAxNnB4O1xuICB9XG5gO1xuY29uc3QgVGV4dFdyYXBwZXIgPSBzdHlsZWQuZGl2PFdyYXBwZXJQcm9wcz5gXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGZsZXgtd3JhcDogd3JhcDtcbiAgJHttcS5yYW5nZSh7IHVudGlsOiBicmVha3BvaW50cy50YWJsZXRXaWRlIH0pfSB7XG4gICAgbGluZS1oZWlnaHQ6IDI0cHg7XG4gICAgZm9udC1zaXplOiAxNnB4O1xuICB9XG5gO1xuXG5jb25zdCBJY29uV3JhcHBlciA9IHN0eWxlZC5kaXY8V3JhcHBlclByb3BzPmBcbiAgcGFkZGluZy1yaWdodDogJHtzcGFjaW5nLnNtYWxsfTtcbiAgZGlzcGxheTogJHsocHJvcHMpID0+IFN0eWxlQnlUeXBlKHByb3BzLmJveFR5cGUpLmRpc3BsYXl9O1xuICBhbGlnbi1pdGVtczogZmxleC1zdGFydDtcbiAgJHttcS5yYW5nZSh7IGZyb206IGJyZWFrcG9pbnRzLnRhYmxldFdpZGUgfSl9IHtcbiAgICBwYWRkaW5nLXRvcDogNHB4O1xuICB9XG5gO1xuXG5jb25zdCBMaW5rV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIGRpc3BsYXk6IGJsb2NrO1xuICB3aWR0aDogMTAwJTtcbiAgYmFja2dyb3VuZC1jb2xvcjogI2Y5ZjRjODtcbiAgcGFkZGluZy1ib3R0b206IDIwcHg7XG4gIG1hcmdpbi10b3A6IC0ycHg7XG4gIHBhZGRpbmctbGVmdDogNThweDtcbiAgYm9yZGVyLXJhZGl1czogMHB4IDBweCA1cHggNXB4O1xuICAke21xLnJhbmdlKHsgdW50aWw6IGJyZWFrcG9pbnRzLm1vYmlsZVdpZGUgfSl9IHtcbiAgICBwYWRkaW5nLWxlZnQ6IDQ1cHg7XG4gIH1cbmA7XG5jb25zdCBMaW5rID0gc3R5bGVkLmFgXG4gIGNvbG9yOiAjMjA1ODhmO1xuICBmb250LXNpemU6IDE2cHg7XG4gIHBhZGRpbmctYm90dG9tOiAxcHg7XG4gIG1hcmdpbjogMHB4IDQwcHggMXB4IDJweDtcbiAgZm9udC1mYW1pbHk6ICR7Zm9udHMuc2Fuc307XG4gICR7bXEucmFuZ2UoeyB1bnRpbDogYnJlYWtwb2ludHMubW9iaWxlV2lkZSB9KX0ge1xuICAgIG1hcmdpbjogMHB4IDE1cHggMXB4IDVweDtcbiAgICBib3gtc2hhZG93OiBub25lO1xuICB9XG5gO1xuY29uc3QgQ2xvc2VCdXR0b25XcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgcG9zaXRpb246IGFic29sdXRlO1xuICB0b3A6IDEwcHg7XG4gIHJpZ2h0OiAxcHg7XG5gO1xuXG50eXBlIExpbmtQcm9wcyA9IHtcbiAgaHJlZj86IHN0cmluZztcbiAgdGV4dD86IHN0cmluZztcbn07XG50eXBlIFByb3BzID0ge1xuICB0eXBlPzogV3JhcHBlclByb3BzWydib3hUeXBlJ107XG4gIHN0aWNreT86IGJvb2xlYW47XG4gIGNoaWxkcmVuPzogc3RyaW5nO1xuICBsaW5rcz86IExpbmtQcm9wc1tdO1xuICBzaG93Q2xvc2VCdXR0b24/OiBib29sZWFuO1xufTtcblxuZXhwb3J0IGNvbnN0IE1lc3NhZ2VCb3ggPSAoeyB0eXBlLCBzdGlja3kgPSBmYWxzZSwgY2hpbGRyZW4sIGxpbmtzLCB0LCBzaG93Q2xvc2VCdXR0b24gfTogUHJvcHMgJiBXaXRoVHJhbnNsYXRpb24pID0+IHtcbiAgY29uc3QgW2hpZGVNZXNzYWdlQm94LCBzZXRIaWRlTWVzc2FnZUJveF0gPSB1c2VTdGF0ZShmYWxzZSk7XG4gIGNvbnN0IG9uQ2xvc2VNZXNzYWdlQm94ID0gKCkgPT4ge1xuICAgIHNldEhpZGVNZXNzYWdlQm94KHRydWUpO1xuICB9O1xuICBjb25zdCBJY29uID0gdHlwZSA9PT0gJ2dob3N0JyA/IEh1bWFuTWFsZUJvYXJkIDogSW5mb3JtYXRpb25PdXRsaW5lO1xuICByZXR1cm4gKFxuICAgIC8vU3RpY2t5U3R5bGUgdG9wOjg0IG1ha2VzIHN1cmUgdGhhdCB0aGUgbWVzc2FnZWJveCBzaXRzIGJlbmVhdGggdGhlIG1hc3RoZWFkIChoZWFkZXIgKSBhbmQgdGhlIHRvcE9mZnNldHQgc2V0cyBpdCBzbyB0aGF0IGl0IGFwcGxpZXMgd2hlbiByZWFjaGluZyB0aGUgdG9wIG9mIHRoZSBtZXNzYWdlYm94XG4gICAgPFN0aWNreSBkaXNhYmxlZD17IXN0aWNreX0gc3RpY2t5U3R5bGU9e3sgekluZGV4OiA5OTk4LCB0b3A6IDg0IH19IHRvcE9mZnNldD17LTg0fT5cbiAgICAgIDxXcmFwcGVyIGJveFR5cGU9e3R5cGV9IHN0eWxlPXt7IGRpc3BsYXk6IGhpZGVNZXNzYWdlQm94ID8gJ25vbmUnIDogJ2ZsZXgnIH19PlxuICAgICAgICA8SW5mb1dyYXBwZXIgYm94VHlwZT17dHlwZX0+XG4gICAgICAgICAgPEljb25XcmFwcGVyIGJveFR5cGU9e3R5cGV9PlxuICAgICAgICAgICAgPEljb24gc3R5bGU9e3sgd2lkdGg6ICcyNHB4JywgaGVpZ2h0OiAnMjRweCcgfX0gLz5cbiAgICAgICAgICA8L0ljb25XcmFwcGVyPlxuICAgICAgICAgIDxUZXh0V3JhcHBlcj57Y2hpbGRyZW59PC9UZXh0V3JhcHBlcj5cbiAgICAgICAgPC9JbmZvV3JhcHBlcj5cbiAgICAgICAge3Nob3dDbG9zZUJ1dHRvbiAmJiAoXG4gICAgICAgICAgPENsb3NlQnV0dG9uV3JhcHBlcj5cbiAgICAgICAgICAgIDxDbG9zZUJ1dHRvbiBvbkNsaWNrPXtvbkNsb3NlTWVzc2FnZUJveH0gLz5cbiAgICAgICAgICA8L0Nsb3NlQnV0dG9uV3JhcHBlcj5cbiAgICAgICAgKX1cbiAgICAgIDwvV3JhcHBlcj5cblxuICAgICAge2xpbmtzICYmIChcbiAgICAgICAgLy9sb29wcyB0aHJvdWdoIHRoZSBsaW5rcyBwYXNzZWQgaW4gYXMgcHJvcGVydGllcyBpZiB0aGVyZSBhcmUgYW55IGFuZCBjcmVhdGVzIGEgd29ya2luZyBsaW5rIGZvciBlYWNoIG9mIHRoZW1cbiAgICAgICAgPExpbmtXcmFwcGVyIHN0eWxlPXt7IGRpc3BsYXk6IGhpZGVNZXNzYWdlQm94ID8gJ25vbmUnIDogJ2ZsZXgnIH19PlxuICAgICAgICAgIHtsaW5rcy5tYXAoKHgpID0+IChcbiAgICAgICAgICAgIDxMaW5rIGhyZWY9e3guaHJlZn0+e3gudGV4dH08L0xpbms+XG4gICAgICAgICAgKSl9XG4gICAgICAgIDwvTGlua1dyYXBwZXI+XG4gICAgICApfVxuICAgIDwvU3RpY2t5PlxuICApO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgd2l0aFRyYW5zbGF0aW9uKCkoTWVzc2FnZUJveCk7XG4iXX0= */"));
124
+ }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["MessageBox.tsx"],"names":[],"mappings":"AAuEwC","file":"MessageBox.tsx","sourcesContent":["/**\n * Copyright (c) 2022-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, { HTMLAttributes, useState } from 'react';\nimport styled from '@emotion/styled';\nimport Sticky from 'react-sticky-el';\nimport { breakpoints, fonts, mq, spacing } from '@ndla/core';\nimport { InformationOutline, HumanMaleBoard } from '@ndla/icons/common';\nimport { WithTranslation, withTranslation } from 'react-i18next';\n\n// @ts-ignore\nimport { Remarkable } from 'remarkable';\nimport { CloseButton } from '../CloseButton';\n\nexport enum MessageBoxType {\n  ghost = 'ghost',\n  fullpage = 'fullpage',\n  medium = 'medium',\n  masthead = 'masthead',\n}\ntype WrapperProps = {\n  boxType?: MessageBoxType;\n};\n\nconst StyleByType = (type: WrapperProps['boxType']) => {\n  const styles: HTMLAttributes<HTMLElement>['style'] = {\n    margin: '1px',\n    color: '#444444',\n    backgroundColor: '#f9f4c8',\n    border: 'none',\n    display: 'flex',\n    padding: '10px',\n    width: 'auto',\n    borderRadius: '5px',\n    position: 'relative',\n    transform: 'auto',\n    left: 'auto',\n  }; //Different CSS properties for different types of message-boxes\n  switch (type) {\n    case 'fullpage':\n      styles.margin = '0 auto';\n      styles.display = 'none';\n      styles.width = '100vw';\n      styles.position = 'relative';\n      styles.left = '50%';\n      styles.padding = '0';\n      styles.transform = 'translateX(-50%)';\n      break;\n    case 'medium':\n      styles.margin = '0px';\n      break;\n    case 'ghost':\n      styles.backgroundColor = 'transparent';\n      styles.border = '1px solid #D1D6DB';\n      styles.color = '#444444';\n      break;\n    case 'masthead':\n      styles.margin = '0 auto';\n      styles.display = 'none';\n      styles.padding = '0';\n      styles.borderRadius = '0';\n      break;\n  }\n  return styles;\n};\n\nconst Wrapper = styled.div<WrapperProps>`\n  background: ${(props) => StyleByType(props.boxType).backgroundColor};\n  color: ${(props) => StyleByType(props.boxType).color};\n  font-size: 18px;\n  line-height: 32px;\n  font-family: ${fonts.sans};\n  display: flex;\n  padding: ${spacing.small};\n  position: ${(props) => StyleByType(props.boxType).position};\n  border: ${(props) => StyleByType(props.boxType).border};\n  border-radius: ${(props) => StyleByType(props.boxType).borderRadius};\n  transform: ${(props) => StyleByType(props.boxType).transform};\n  left: ${(props) => StyleByType(props.boxType).left};\n  z-index: 10;\n  width: ${(props) => StyleByType(props.boxType).width};\n`;\n\nconst InfoWrapper = styled.div<WrapperProps>`\n  margin: ${(props) => StyleByType(props.boxType).margin};\n  padding: ${(props) => StyleByType(props.boxType).padding};\n  display: flex;\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    padding: 0 90px 0 0;\n  }\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    padding: 0 5px 0 0;\n    font-size: 16px;\n  }\n`;\nconst TextWrapper = styled.div<WrapperProps>`\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    line-height: 24px;\n    font-size: 16px;\n  }\n  & p {\n    margin: 0;\n  }\n`;\n\nconst IconWrapper = styled.div<WrapperProps>`\n  padding-right: ${spacing.small};\n  display: ${(props) => StyleByType(props.boxType).display};\n  align-items: flex-start;\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding-top: 4px;\n  }\n`;\n\nconst LinkWrapper = styled.div`\n  display: block;\n  width: 100%;\n  background-color: #f9f4c8;\n  padding-bottom: 20px;\n  margin-top: -2px;\n  padding-left: 58px;\n  border-radius: 0px 0px 5px 5px;\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    padding-left: 45px;\n  }\n`;\nconst Link = styled.a`\n  color: #20588f;\n  font-size: 16px;\n  padding-bottom: 1px;\n  margin: 0px 40px 1px 2px;\n  font-family: ${fonts.sans};\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    margin: 0px 15px 1px 5px;\n    box-shadow: none;\n  }\n`;\nconst CloseButtonWrapper = styled.div`\n  position: absolute;\n  top: 10px;\n  right: 1px;\n`;\n\ntype LinkProps = {\n  href?: string;\n  text?: string;\n};\ntype Props = {\n  type?: WrapperProps['boxType'];\n  sticky?: boolean;\n  children?: string;\n  links?: LinkProps[];\n  showCloseButton?: boolean;\n  onClose?: () => void;\n};\n\nconst markdown = new Remarkable({ breaks: true });\nmarkdown.inline.ruler.enable(['sub', 'sup']);\nmarkdown.block.ruler.disable(['list', 'table']);\n\nexport const MessageBox = ({\n  type,\n  sticky = false,\n  children = '',\n  links,\n  showCloseButton,\n  onClose,\n}: Props & WithTranslation) => {\n  const [hideMessageBox, setHideMessageBox] = useState(false);\n  const onCloseMessageBox = () => {\n    setHideMessageBox(true);\n    onClose?.();\n  };\n  const Icon = type === 'ghost' ? HumanMaleBoard : InformationOutline;\n  return (\n    //StickyStyle top:84 makes sure that the messagebox sits beneath the masthead (header ) and the topOffsett sets it so that it applies when reaching the top of the messagebox\n    <Sticky disabled={!sticky} stickyStyle={{ zIndex: 9998, top: 84 }} topOffset={-84}>\n      <Wrapper boxType={type} style={{ display: hideMessageBox ? 'none' : 'flex' }}>\n        <InfoWrapper boxType={type}>\n          <IconWrapper boxType={type}>\n            <Icon style={{ width: '24px', height: '24px' }} />\n          </IconWrapper>\n          <TextWrapper dangerouslySetInnerHTML={{ __html: markdown.render(children) }}></TextWrapper>\n        </InfoWrapper>\n        {showCloseButton && (\n          <CloseButtonWrapper>\n            <CloseButton onClick={onCloseMessageBox} />\n          </CloseButtonWrapper>\n        )}\n      </Wrapper>\n\n      {links && (\n        //loops through the links passed in as properties if there are any and creates a working link for each of them\n        <LinkWrapper style={{ display: hideMessageBox ? 'none' : 'flex' }}>\n          {links.map((x) => (\n            <Link href={x.href}>{x.text}</Link>\n          ))}\n        </LinkWrapper>\n      )}\n    </Sticky>\n  );\n};\n\nexport default withTranslation()(MessageBox);\n"]} */"));
122
125
  var InfoWrapper = (0, _styledBase["default"])("div", {
123
126
  target: "e1ckcvyi1",
124
127
  label: "InfoWrapper"
@@ -130,13 +133,13 @@ var InfoWrapper = (0, _styledBase["default"])("div", {
130
133
  until: _core.breakpoints.tabletWide
131
134
  }), "{padding:0 90px 0 0;}", _core.mq.range({
132
135
  until: _core.breakpoints.mobileWide
133
- }), "{padding:0 5px 0 0;font-size:16px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIk1lc3NhZ2VCb3gudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQW9GNEMiLCJmaWxlIjoiTWVzc2FnZUJveC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAyMi1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCBSZWFjdCwgeyBIVE1MQXR0cmlidXRlcywgdXNlU3RhdGUgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgU3RpY2t5IGZyb20gJ3JlYWN0LXN0aWNreS1lbCc7XG5pbXBvcnQgeyBicmVha3BvaW50cywgZm9udHMsIG1xLCBzcGFjaW5nIH0gZnJvbSAnQG5kbGEvY29yZSc7XG5pbXBvcnQgeyBJbmZvcm1hdGlvbk91dGxpbmUsIEh1bWFuTWFsZUJvYXJkIH0gZnJvbSAnQG5kbGEvaWNvbnMvY29tbW9uJztcbmltcG9ydCB7IFdpdGhUcmFuc2xhdGlvbiwgd2l0aFRyYW5zbGF0aW9uIH0gZnJvbSAncmVhY3QtaTE4bmV4dCc7XG5pbXBvcnQgeyBDbG9zZUJ1dHRvbiB9IGZyb20gJy4uL0Nsb3NlQnV0dG9uJztcblxuZXhwb3J0IGVudW0gTWVzc2FnZUJveFR5cGUge1xuICBnaG9zdCA9ICdnaG9zdCcsXG4gIGZ1bGxwYWdlID0gJ2Z1bGxwYWdlJyxcbiAgbWVkaXVtID0gJ21lZGl1bScsXG4gIG1hc3RoZWFkID0gJ21hc3RoZWFkJyxcbn1cbnR5cGUgV3JhcHBlclByb3BzID0ge1xuICBib3hUeXBlPzogTWVzc2FnZUJveFR5cGU7XG59O1xuXG5jb25zdCBTdHlsZUJ5VHlwZSA9ICh0eXBlOiBXcmFwcGVyUHJvcHNbJ2JveFR5cGUnXSkgPT4ge1xuICBjb25zdCBzdHlsZXM6IEhUTUxBdHRyaWJ1dGVzPEhUTUxFbGVtZW50Plsnc3R5bGUnXSA9IHtcbiAgICBtYXJnaW46ICcxcHgnLFxuICAgIGNvbG9yOiAnIzQ0NDQ0NCcsXG4gICAgYmFja2dyb3VuZENvbG9yOiAnI2Y5ZjRjOCcsXG4gICAgYm9yZGVyOiAnbm9uZScsXG4gICAgZGlzcGxheTogJ2ZsZXgnLFxuICAgIHBhZGRpbmc6ICcxMHB4JyxcbiAgICB3aWR0aDogJ2F1dG8nLFxuICAgIGJvcmRlclJhZGl1czogJzVweCcsXG4gICAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gICAgdHJhbnNmb3JtOiAnYXV0bycsXG4gICAgbGVmdDogJ2F1dG8nLFxuICB9OyAvL0RpZmZlcmVudCBDU1MgcHJvcGVydGllcyBmb3IgZGlmZmVyZW50IHR5cGVzIG9mIG1lc3NhZ2UtYm94ZXNcbiAgc3dpdGNoICh0eXBlKSB7XG4gICAgY2FzZSAnZnVsbHBhZ2UnOlxuICAgICAgc3R5bGVzLm1hcmdpbiA9ICcwIGF1dG8nO1xuICAgICAgc3R5bGVzLmRpc3BsYXkgPSAnbm9uZSc7XG4gICAgICBzdHlsZXMud2lkdGggPSAnMTAwdncnO1xuICAgICAgc3R5bGVzLnBvc2l0aW9uID0gJ3JlbGF0aXZlJztcbiAgICAgIHN0eWxlcy5sZWZ0ID0gJzUwJSc7XG4gICAgICBzdHlsZXMudHJhbnNmb3JtID0gJ3RyYW5zbGF0ZVgoLTUwJSknO1xuICAgICAgYnJlYWs7XG4gICAgY2FzZSAnbWVkaXVtJzpcbiAgICAgIHN0eWxlcy5tYXJnaW4gPSAnMHB4JztcbiAgICAgIGJyZWFrO1xuICAgIGNhc2UgJ2dob3N0JzpcbiAgICAgIHN0eWxlcy5iYWNrZ3JvdW5kQ29sb3IgPSAndHJhbnNwYXJlbnQnO1xuICAgICAgc3R5bGVzLmJvcmRlciA9ICcxcHggc29saWQgI0QxRDZEQic7XG4gICAgICBzdHlsZXMuY29sb3IgPSAnIzQ0NDQ0NCc7XG4gICAgICBicmVhaztcbiAgICBjYXNlICdtYXN0aGVhZCc6XG4gICAgICBzdHlsZXMubWFyZ2luID0gJzAgYXV0byc7XG4gICAgICBzdHlsZXMuZGlzcGxheSA9ICdub25lJztcbiAgICAgIHN0eWxlcy5wYWRkaW5nID0gJzAnO1xuICAgICAgc3R5bGVzLmJvcmRlclJhZGl1cyA9ICcwJztcbiAgICAgIGJyZWFrO1xuICB9XG4gIHJldHVybiBzdHlsZXM7XG59O1xuXG5jb25zdCBXcmFwcGVyID0gc3R5bGVkLmRpdjxXcmFwcGVyUHJvcHM+YFxuICBiYWNrZ3JvdW5kOiAkeyhwcm9wcykgPT4gU3R5bGVCeVR5cGUocHJvcHMuYm94VHlwZSkuYmFja2dyb3VuZENvbG9yfTtcbiAgY29sb3I6ICR7KHByb3BzKSA9PiBTdHlsZUJ5VHlwZShwcm9wcy5ib3hUeXBlKS5jb2xvcn07XG4gIGZvbnQtc2l6ZTogMThweDtcbiAgbGluZS1oZWlnaHQ6IDMycHg7XG4gIGZvbnQtZmFtaWx5OiAke2ZvbnRzLnNhbnN9O1xuICBkaXNwbGF5OiBmbGV4O1xuICBwYWRkaW5nOiAke3NwYWNpbmcuc21hbGx9O1xuICBwb3NpdGlvbjogJHsocHJvcHMpID0+IFN0eWxlQnlUeXBlKHByb3BzLmJveFR5cGUpLnBvc2l0aW9ufTtcbiAgYm9yZGVyOiAkeyhwcm9wcykgPT4gU3R5bGVCeVR5cGUocHJvcHMuYm94VHlwZSkuYm9yZGVyfTtcbiAgYm9yZGVyLXJhZGl1czogJHsocHJvcHMpID0+IFN0eWxlQnlUeXBlKHByb3BzLmJveFR5cGUpLmJvcmRlclJhZGl1c307XG4gIHRyYW5zZm9ybTogJHsocHJvcHMpID0+IFN0eWxlQnlUeXBlKHByb3BzLmJveFR5cGUpLnRyYW5zZm9ybX07XG4gIGxlZnQ6ICR7KHByb3BzKSA9PiBTdHlsZUJ5VHlwZShwcm9wcy5ib3hUeXBlKS5sZWZ0fTtcbiAgei1pbmRleDogMTA7XG4gIHdpZHRoOiAkeyhwcm9wcykgPT4gU3R5bGVCeVR5cGUocHJvcHMuYm94VHlwZSkud2lkdGh9O1xuYDtcblxuY29uc3QgSW5mb1dyYXBwZXIgPSBzdHlsZWQuZGl2PFdyYXBwZXJQcm9wcz5gXG4gIG1hcmdpbjogJHsocHJvcHMpID0+IFN0eWxlQnlUeXBlKHByb3BzLmJveFR5cGUpLm1hcmdpbn07XG4gIHBhZGRpbmc6ICR7KHByb3BzKSA9PiBTdHlsZUJ5VHlwZShwcm9wcy5ib3hUeXBlKS5wYWRkaW5nfTtcbiAgZGlzcGxheTogZmxleDtcbiAgJHttcS5yYW5nZSh7IHVudGlsOiBicmVha3BvaW50cy50YWJsZXRXaWRlIH0pfSB7XG4gICAgcGFkZGluZzogMCA5MHB4IDAgMDtcbiAgfVxuICAke21xLnJhbmdlKHsgdW50aWw6IGJyZWFrcG9pbnRzLm1vYmlsZVdpZGUgfSl9IHtcbiAgICBwYWRkaW5nOiAwIDVweCAwIDA7XG4gICAgZm9udC1zaXplOiAxNnB4O1xuICB9XG5gO1xuY29uc3QgVGV4dFdyYXBwZXIgPSBzdHlsZWQuZGl2PFdyYXBwZXJQcm9wcz5gXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGZsZXgtd3JhcDogd3JhcDtcbiAgJHttcS5yYW5nZSh7IHVudGlsOiBicmVha3BvaW50cy50YWJsZXRXaWRlIH0pfSB7XG4gICAgbGluZS1oZWlnaHQ6IDI0cHg7XG4gICAgZm9udC1zaXplOiAxNnB4O1xuICB9XG5gO1xuXG5jb25zdCBJY29uV3JhcHBlciA9IHN0eWxlZC5kaXY8V3JhcHBlclByb3BzPmBcbiAgcGFkZGluZy1yaWdodDogJHtzcGFjaW5nLnNtYWxsfTtcbiAgZGlzcGxheTogJHsocHJvcHMpID0+IFN0eWxlQnlUeXBlKHByb3BzLmJveFR5cGUpLmRpc3BsYXl9O1xuICBhbGlnbi1pdGVtczogZmxleC1zdGFydDtcbiAgJHttcS5yYW5nZSh7IGZyb206IGJyZWFrcG9pbnRzLnRhYmxldFdpZGUgfSl9IHtcbiAgICBwYWRkaW5nLXRvcDogNHB4O1xuICB9XG5gO1xuXG5jb25zdCBMaW5rV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIGRpc3BsYXk6IGJsb2NrO1xuICB3aWR0aDogMTAwJTtcbiAgYmFja2dyb3VuZC1jb2xvcjogI2Y5ZjRjODtcbiAgcGFkZGluZy1ib3R0b206IDIwcHg7XG4gIG1hcmdpbi10b3A6IC0ycHg7XG4gIHBhZGRpbmctbGVmdDogNThweDtcbiAgYm9yZGVyLXJhZGl1czogMHB4IDBweCA1cHggNXB4O1xuICAke21xLnJhbmdlKHsgdW50aWw6IGJyZWFrcG9pbnRzLm1vYmlsZVdpZGUgfSl9IHtcbiAgICBwYWRkaW5nLWxlZnQ6IDQ1cHg7XG4gIH1cbmA7XG5jb25zdCBMaW5rID0gc3R5bGVkLmFgXG4gIGNvbG9yOiAjMjA1ODhmO1xuICBmb250LXNpemU6IDE2cHg7XG4gIHBhZGRpbmctYm90dG9tOiAxcHg7XG4gIG1hcmdpbjogMHB4IDQwcHggMXB4IDJweDtcbiAgZm9udC1mYW1pbHk6ICR7Zm9udHMuc2Fuc307XG4gICR7bXEucmFuZ2UoeyB1bnRpbDogYnJlYWtwb2ludHMubW9iaWxlV2lkZSB9KX0ge1xuICAgIG1hcmdpbjogMHB4IDE1cHggMXB4IDVweDtcbiAgICBib3gtc2hhZG93OiBub25lO1xuICB9XG5gO1xuY29uc3QgQ2xvc2VCdXR0b25XcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgcG9zaXRpb246IGFic29sdXRlO1xuICB0b3A6IDEwcHg7XG4gIHJpZ2h0OiAxcHg7XG5gO1xuXG50eXBlIExpbmtQcm9wcyA9IHtcbiAgaHJlZj86IHN0cmluZztcbiAgdGV4dD86IHN0cmluZztcbn07XG50eXBlIFByb3BzID0ge1xuICB0eXBlPzogV3JhcHBlclByb3BzWydib3hUeXBlJ107XG4gIHN0aWNreT86IGJvb2xlYW47XG4gIGNoaWxkcmVuPzogc3RyaW5nO1xuICBsaW5rcz86IExpbmtQcm9wc1tdO1xuICBzaG93Q2xvc2VCdXR0b24/OiBib29sZWFuO1xufTtcblxuZXhwb3J0IGNvbnN0IE1lc3NhZ2VCb3ggPSAoeyB0eXBlLCBzdGlja3kgPSBmYWxzZSwgY2hpbGRyZW4sIGxpbmtzLCB0LCBzaG93Q2xvc2VCdXR0b24gfTogUHJvcHMgJiBXaXRoVHJhbnNsYXRpb24pID0+IHtcbiAgY29uc3QgW2hpZGVNZXNzYWdlQm94LCBzZXRIaWRlTWVzc2FnZUJveF0gPSB1c2VTdGF0ZShmYWxzZSk7XG4gIGNvbnN0IG9uQ2xvc2VNZXNzYWdlQm94ID0gKCkgPT4ge1xuICAgIHNldEhpZGVNZXNzYWdlQm94KHRydWUpO1xuICB9O1xuICBjb25zdCBJY29uID0gdHlwZSA9PT0gJ2dob3N0JyA/IEh1bWFuTWFsZUJvYXJkIDogSW5mb3JtYXRpb25PdXRsaW5lO1xuICByZXR1cm4gKFxuICAgIC8vU3RpY2t5U3R5bGUgdG9wOjg0IG1ha2VzIHN1cmUgdGhhdCB0aGUgbWVzc2FnZWJveCBzaXRzIGJlbmVhdGggdGhlIG1hc3RoZWFkIChoZWFkZXIgKSBhbmQgdGhlIHRvcE9mZnNldHQgc2V0cyBpdCBzbyB0aGF0IGl0IGFwcGxpZXMgd2hlbiByZWFjaGluZyB0aGUgdG9wIG9mIHRoZSBtZXNzYWdlYm94XG4gICAgPFN0aWNreSBkaXNhYmxlZD17IXN0aWNreX0gc3RpY2t5U3R5bGU9e3sgekluZGV4OiA5OTk4LCB0b3A6IDg0IH19IHRvcE9mZnNldD17LTg0fT5cbiAgICAgIDxXcmFwcGVyIGJveFR5cGU9e3R5cGV9IHN0eWxlPXt7IGRpc3BsYXk6IGhpZGVNZXNzYWdlQm94ID8gJ25vbmUnIDogJ2ZsZXgnIH19PlxuICAgICAgICA8SW5mb1dyYXBwZXIgYm94VHlwZT17dHlwZX0+XG4gICAgICAgICAgPEljb25XcmFwcGVyIGJveFR5cGU9e3R5cGV9PlxuICAgICAgICAgICAgPEljb24gc3R5bGU9e3sgd2lkdGg6ICcyNHB4JywgaGVpZ2h0OiAnMjRweCcgfX0gLz5cbiAgICAgICAgICA8L0ljb25XcmFwcGVyPlxuICAgICAgICAgIDxUZXh0V3JhcHBlcj57Y2hpbGRyZW59PC9UZXh0V3JhcHBlcj5cbiAgICAgICAgPC9JbmZvV3JhcHBlcj5cbiAgICAgICAge3Nob3dDbG9zZUJ1dHRvbiAmJiAoXG4gICAgICAgICAgPENsb3NlQnV0dG9uV3JhcHBlcj5cbiAgICAgICAgICAgIDxDbG9zZUJ1dHRvbiBvbkNsaWNrPXtvbkNsb3NlTWVzc2FnZUJveH0gLz5cbiAgICAgICAgICA8L0Nsb3NlQnV0dG9uV3JhcHBlcj5cbiAgICAgICAgKX1cbiAgICAgIDwvV3JhcHBlcj5cblxuICAgICAge2xpbmtzICYmIChcbiAgICAgICAgLy9sb29wcyB0aHJvdWdoIHRoZSBsaW5rcyBwYXNzZWQgaW4gYXMgcHJvcGVydGllcyBpZiB0aGVyZSBhcmUgYW55IGFuZCBjcmVhdGVzIGEgd29ya2luZyBsaW5rIGZvciBlYWNoIG9mIHRoZW1cbiAgICAgICAgPExpbmtXcmFwcGVyIHN0eWxlPXt7IGRpc3BsYXk6IGhpZGVNZXNzYWdlQm94ID8gJ25vbmUnIDogJ2ZsZXgnIH19PlxuICAgICAgICAgIHtsaW5rcy5tYXAoKHgpID0+IChcbiAgICAgICAgICAgIDxMaW5rIGhyZWY9e3guaHJlZn0+e3gudGV4dH08L0xpbms+XG4gICAgICAgICAgKSl9XG4gICAgICAgIDwvTGlua1dyYXBwZXI+XG4gICAgICApfVxuICAgIDwvU3RpY2t5PlxuICApO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgd2l0aFRyYW5zbGF0aW9uKCkoTWVzc2FnZUJveCk7XG4iXX0= */"));
136
+ }), "{padding:0 5px 0 0;font-size:16px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["MessageBox.tsx"],"names":[],"mappings":"AAwF4C","file":"MessageBox.tsx","sourcesContent":["/**\n * Copyright (c) 2022-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, { HTMLAttributes, useState } from 'react';\nimport styled from '@emotion/styled';\nimport Sticky from 'react-sticky-el';\nimport { breakpoints, fonts, mq, spacing } from '@ndla/core';\nimport { InformationOutline, HumanMaleBoard } from '@ndla/icons/common';\nimport { WithTranslation, withTranslation } from 'react-i18next';\n\n// @ts-ignore\nimport { Remarkable } from 'remarkable';\nimport { CloseButton } from '../CloseButton';\n\nexport enum MessageBoxType {\n  ghost = 'ghost',\n  fullpage = 'fullpage',\n  medium = 'medium',\n  masthead = 'masthead',\n}\ntype WrapperProps = {\n  boxType?: MessageBoxType;\n};\n\nconst StyleByType = (type: WrapperProps['boxType']) => {\n  const styles: HTMLAttributes<HTMLElement>['style'] = {\n    margin: '1px',\n    color: '#444444',\n    backgroundColor: '#f9f4c8',\n    border: 'none',\n    display: 'flex',\n    padding: '10px',\n    width: 'auto',\n    borderRadius: '5px',\n    position: 'relative',\n    transform: 'auto',\n    left: 'auto',\n  }; //Different CSS properties for different types of message-boxes\n  switch (type) {\n    case 'fullpage':\n      styles.margin = '0 auto';\n      styles.display = 'none';\n      styles.width = '100vw';\n      styles.position = 'relative';\n      styles.left = '50%';\n      styles.padding = '0';\n      styles.transform = 'translateX(-50%)';\n      break;\n    case 'medium':\n      styles.margin = '0px';\n      break;\n    case 'ghost':\n      styles.backgroundColor = 'transparent';\n      styles.border = '1px solid #D1D6DB';\n      styles.color = '#444444';\n      break;\n    case 'masthead':\n      styles.margin = '0 auto';\n      styles.display = 'none';\n      styles.padding = '0';\n      styles.borderRadius = '0';\n      break;\n  }\n  return styles;\n};\n\nconst Wrapper = styled.div<WrapperProps>`\n  background: ${(props) => StyleByType(props.boxType).backgroundColor};\n  color: ${(props) => StyleByType(props.boxType).color};\n  font-size: 18px;\n  line-height: 32px;\n  font-family: ${fonts.sans};\n  display: flex;\n  padding: ${spacing.small};\n  position: ${(props) => StyleByType(props.boxType).position};\n  border: ${(props) => StyleByType(props.boxType).border};\n  border-radius: ${(props) => StyleByType(props.boxType).borderRadius};\n  transform: ${(props) => StyleByType(props.boxType).transform};\n  left: ${(props) => StyleByType(props.boxType).left};\n  z-index: 10;\n  width: ${(props) => StyleByType(props.boxType).width};\n`;\n\nconst InfoWrapper = styled.div<WrapperProps>`\n  margin: ${(props) => StyleByType(props.boxType).margin};\n  padding: ${(props) => StyleByType(props.boxType).padding};\n  display: flex;\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    padding: 0 90px 0 0;\n  }\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    padding: 0 5px 0 0;\n    font-size: 16px;\n  }\n`;\nconst TextWrapper = styled.div<WrapperProps>`\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    line-height: 24px;\n    font-size: 16px;\n  }\n  & p {\n    margin: 0;\n  }\n`;\n\nconst IconWrapper = styled.div<WrapperProps>`\n  padding-right: ${spacing.small};\n  display: ${(props) => StyleByType(props.boxType).display};\n  align-items: flex-start;\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding-top: 4px;\n  }\n`;\n\nconst LinkWrapper = styled.div`\n  display: block;\n  width: 100%;\n  background-color: #f9f4c8;\n  padding-bottom: 20px;\n  margin-top: -2px;\n  padding-left: 58px;\n  border-radius: 0px 0px 5px 5px;\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    padding-left: 45px;\n  }\n`;\nconst Link = styled.a`\n  color: #20588f;\n  font-size: 16px;\n  padding-bottom: 1px;\n  margin: 0px 40px 1px 2px;\n  font-family: ${fonts.sans};\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    margin: 0px 15px 1px 5px;\n    box-shadow: none;\n  }\n`;\nconst CloseButtonWrapper = styled.div`\n  position: absolute;\n  top: 10px;\n  right: 1px;\n`;\n\ntype LinkProps = {\n  href?: string;\n  text?: string;\n};\ntype Props = {\n  type?: WrapperProps['boxType'];\n  sticky?: boolean;\n  children?: string;\n  links?: LinkProps[];\n  showCloseButton?: boolean;\n  onClose?: () => void;\n};\n\nconst markdown = new Remarkable({ breaks: true });\nmarkdown.inline.ruler.enable(['sub', 'sup']);\nmarkdown.block.ruler.disable(['list', 'table']);\n\nexport const MessageBox = ({\n  type,\n  sticky = false,\n  children = '',\n  links,\n  showCloseButton,\n  onClose,\n}: Props & WithTranslation) => {\n  const [hideMessageBox, setHideMessageBox] = useState(false);\n  const onCloseMessageBox = () => {\n    setHideMessageBox(true);\n    onClose?.();\n  };\n  const Icon = type === 'ghost' ? HumanMaleBoard : InformationOutline;\n  return (\n    //StickyStyle top:84 makes sure that the messagebox sits beneath the masthead (header ) and the topOffsett sets it so that it applies when reaching the top of the messagebox\n    <Sticky disabled={!sticky} stickyStyle={{ zIndex: 9998, top: 84 }} topOffset={-84}>\n      <Wrapper boxType={type} style={{ display: hideMessageBox ? 'none' : 'flex' }}>\n        <InfoWrapper boxType={type}>\n          <IconWrapper boxType={type}>\n            <Icon style={{ width: '24px', height: '24px' }} />\n          </IconWrapper>\n          <TextWrapper dangerouslySetInnerHTML={{ __html: markdown.render(children) }}></TextWrapper>\n        </InfoWrapper>\n        {showCloseButton && (\n          <CloseButtonWrapper>\n            <CloseButton onClick={onCloseMessageBox} />\n          </CloseButtonWrapper>\n        )}\n      </Wrapper>\n\n      {links && (\n        //loops through the links passed in as properties if there are any and creates a working link for each of them\n        <LinkWrapper style={{ display: hideMessageBox ? 'none' : 'flex' }}>\n          {links.map((x) => (\n            <Link href={x.href}>{x.text}</Link>\n          ))}\n        </LinkWrapper>\n      )}\n    </Sticky>\n  );\n};\n\nexport default withTranslation()(MessageBox);\n"]} */"));
134
137
  var TextWrapper = (0, _styledBase["default"])("div", {
135
138
  target: "e1ckcvyi2",
136
139
  label: "TextWrapper"
137
140
  })("display:flex;align-items:center;flex-wrap:wrap;", _core.mq.range({
138
141
  until: _core.breakpoints.tabletWide
139
- }), "{line-height:24px;font-size:16px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIk1lc3NhZ2VCb3gudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWdHNEMiLCJmaWxlIjoiTWVzc2FnZUJveC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAyMi1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCBSZWFjdCwgeyBIVE1MQXR0cmlidXRlcywgdXNlU3RhdGUgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgU3RpY2t5IGZyb20gJ3JlYWN0LXN0aWNreS1lbCc7XG5pbXBvcnQgeyBicmVha3BvaW50cywgZm9udHMsIG1xLCBzcGFjaW5nIH0gZnJvbSAnQG5kbGEvY29yZSc7XG5pbXBvcnQgeyBJbmZvcm1hdGlvbk91dGxpbmUsIEh1bWFuTWFsZUJvYXJkIH0gZnJvbSAnQG5kbGEvaWNvbnMvY29tbW9uJztcbmltcG9ydCB7IFdpdGhUcmFuc2xhdGlvbiwgd2l0aFRyYW5zbGF0aW9uIH0gZnJvbSAncmVhY3QtaTE4bmV4dCc7XG5pbXBvcnQgeyBDbG9zZUJ1dHRvbiB9IGZyb20gJy4uL0Nsb3NlQnV0dG9uJztcblxuZXhwb3J0IGVudW0gTWVzc2FnZUJveFR5cGUge1xuICBnaG9zdCA9ICdnaG9zdCcsXG4gIGZ1bGxwYWdlID0gJ2Z1bGxwYWdlJyxcbiAgbWVkaXVtID0gJ21lZGl1bScsXG4gIG1hc3RoZWFkID0gJ21hc3RoZWFkJyxcbn1cbnR5cGUgV3JhcHBlclByb3BzID0ge1xuICBib3hUeXBlPzogTWVzc2FnZUJveFR5cGU7XG59O1xuXG5jb25zdCBTdHlsZUJ5VHlwZSA9ICh0eXBlOiBXcmFwcGVyUHJvcHNbJ2JveFR5cGUnXSkgPT4ge1xuICBjb25zdCBzdHlsZXM6IEhUTUxBdHRyaWJ1dGVzPEhUTUxFbGVtZW50Plsnc3R5bGUnXSA9IHtcbiAgICBtYXJnaW46ICcxcHgnLFxuICAgIGNvbG9yOiAnIzQ0NDQ0NCcsXG4gICAgYmFja2dyb3VuZENvbG9yOiAnI2Y5ZjRjOCcsXG4gICAgYm9yZGVyOiAnbm9uZScsXG4gICAgZGlzcGxheTogJ2ZsZXgnLFxuICAgIHBhZGRpbmc6ICcxMHB4JyxcbiAgICB3aWR0aDogJ2F1dG8nLFxuICAgIGJvcmRlclJhZGl1czogJzVweCcsXG4gICAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gICAgdHJhbnNmb3JtOiAnYXV0bycsXG4gICAgbGVmdDogJ2F1dG8nLFxuICB9OyAvL0RpZmZlcmVudCBDU1MgcHJvcGVydGllcyBmb3IgZGlmZmVyZW50IHR5cGVzIG9mIG1lc3NhZ2UtYm94ZXNcbiAgc3dpdGNoICh0eXBlKSB7XG4gICAgY2FzZSAnZnVsbHBhZ2UnOlxuICAgICAgc3R5bGVzLm1hcmdpbiA9ICcwIGF1dG8nO1xuICAgICAgc3R5bGVzLmRpc3BsYXkgPSAnbm9uZSc7XG4gICAgICBzdHlsZXMud2lkdGggPSAnMTAwdncnO1xuICAgICAgc3R5bGVzLnBvc2l0aW9uID0gJ3JlbGF0aXZlJztcbiAgICAgIHN0eWxlcy5sZWZ0ID0gJzUwJSc7XG4gICAgICBzdHlsZXMudHJhbnNmb3JtID0gJ3RyYW5zbGF0ZVgoLTUwJSknO1xuICAgICAgYnJlYWs7XG4gICAgY2FzZSAnbWVkaXVtJzpcbiAgICAgIHN0eWxlcy5tYXJnaW4gPSAnMHB4JztcbiAgICAgIGJyZWFrO1xuICAgIGNhc2UgJ2dob3N0JzpcbiAgICAgIHN0eWxlcy5iYWNrZ3JvdW5kQ29sb3IgPSAndHJhbnNwYXJlbnQnO1xuICAgICAgc3R5bGVzLmJvcmRlciA9ICcxcHggc29saWQgI0QxRDZEQic7XG4gICAgICBzdHlsZXMuY29sb3IgPSAnIzQ0NDQ0NCc7XG4gICAgICBicmVhaztcbiAgICBjYXNlICdtYXN0aGVhZCc6XG4gICAgICBzdHlsZXMubWFyZ2luID0gJzAgYXV0byc7XG4gICAgICBzdHlsZXMuZGlzcGxheSA9ICdub25lJztcbiAgICAgIHN0eWxlcy5wYWRkaW5nID0gJzAnO1xuICAgICAgc3R5bGVzLmJvcmRlclJhZGl1cyA9ICcwJztcbiAgICAgIGJyZWFrO1xuICB9XG4gIHJldHVybiBzdHlsZXM7XG59O1xuXG5jb25zdCBXcmFwcGVyID0gc3R5bGVkLmRpdjxXcmFwcGVyUHJvcHM+YFxuICBiYWNrZ3JvdW5kOiAkeyhwcm9wcykgPT4gU3R5bGVCeVR5cGUocHJvcHMuYm94VHlwZSkuYmFja2dyb3VuZENvbG9yfTtcbiAgY29sb3I6ICR7KHByb3BzKSA9PiBTdHlsZUJ5VHlwZShwcm9wcy5ib3hUeXBlKS5jb2xvcn07XG4gIGZvbnQtc2l6ZTogMThweDtcbiAgbGluZS1oZWlnaHQ6IDMycHg7XG4gIGZvbnQtZmFtaWx5OiAke2ZvbnRzLnNhbnN9O1xuICBkaXNwbGF5OiBmbGV4O1xuICBwYWRkaW5nOiAke3NwYWNpbmcuc21hbGx9O1xuICBwb3NpdGlvbjogJHsocHJvcHMpID0+IFN0eWxlQnlUeXBlKHByb3BzLmJveFR5cGUpLnBvc2l0aW9ufTtcbiAgYm9yZGVyOiAkeyhwcm9wcykgPT4gU3R5bGVCeVR5cGUocHJvcHMuYm94VHlwZSkuYm9yZGVyfTtcbiAgYm9yZGVyLXJhZGl1czogJHsocHJvcHMpID0+IFN0eWxlQnlUeXBlKHByb3BzLmJveFR5cGUpLmJvcmRlclJhZGl1c307XG4gIHRyYW5zZm9ybTogJHsocHJvcHMpID0+IFN0eWxlQnlUeXBlKHByb3BzLmJveFR5cGUpLnRyYW5zZm9ybX07XG4gIGxlZnQ6ICR7KHByb3BzKSA9PiBTdHlsZUJ5VHlwZShwcm9wcy5ib3hUeXBlKS5sZWZ0fTtcbiAgei1pbmRleDogMTA7XG4gIHdpZHRoOiAkeyhwcm9wcykgPT4gU3R5bGVCeVR5cGUocHJvcHMuYm94VHlwZSkud2lkdGh9O1xuYDtcblxuY29uc3QgSW5mb1dyYXBwZXIgPSBzdHlsZWQuZGl2PFdyYXBwZXJQcm9wcz5gXG4gIG1hcmdpbjogJHsocHJvcHMpID0+IFN0eWxlQnlUeXBlKHByb3BzLmJveFR5cGUpLm1hcmdpbn07XG4gIHBhZGRpbmc6ICR7KHByb3BzKSA9PiBTdHlsZUJ5VHlwZShwcm9wcy5ib3hUeXBlKS5wYWRkaW5nfTtcbiAgZGlzcGxheTogZmxleDtcbiAgJHttcS5yYW5nZSh7IHVudGlsOiBicmVha3BvaW50cy50YWJsZXRXaWRlIH0pfSB7XG4gICAgcGFkZGluZzogMCA5MHB4IDAgMDtcbiAgfVxuICAke21xLnJhbmdlKHsgdW50aWw6IGJyZWFrcG9pbnRzLm1vYmlsZVdpZGUgfSl9IHtcbiAgICBwYWRkaW5nOiAwIDVweCAwIDA7XG4gICAgZm9udC1zaXplOiAxNnB4O1xuICB9XG5gO1xuY29uc3QgVGV4dFdyYXBwZXIgPSBzdHlsZWQuZGl2PFdyYXBwZXJQcm9wcz5gXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGZsZXgtd3JhcDogd3JhcDtcbiAgJHttcS5yYW5nZSh7IHVudGlsOiBicmVha3BvaW50cy50YWJsZXRXaWRlIH0pfSB7XG4gICAgbGluZS1oZWlnaHQ6IDI0cHg7XG4gICAgZm9udC1zaXplOiAxNnB4O1xuICB9XG5gO1xuXG5jb25zdCBJY29uV3JhcHBlciA9IHN0eWxlZC5kaXY8V3JhcHBlclByb3BzPmBcbiAgcGFkZGluZy1yaWdodDogJHtzcGFjaW5nLnNtYWxsfTtcbiAgZGlzcGxheTogJHsocHJvcHMpID0+IFN0eWxlQnlUeXBlKHByb3BzLmJveFR5cGUpLmRpc3BsYXl9O1xuICBhbGlnbi1pdGVtczogZmxleC1zdGFydDtcbiAgJHttcS5yYW5nZSh7IGZyb206IGJyZWFrcG9pbnRzLnRhYmxldFdpZGUgfSl9IHtcbiAgICBwYWRkaW5nLXRvcDogNHB4O1xuICB9XG5gO1xuXG5jb25zdCBMaW5rV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIGRpc3BsYXk6IGJsb2NrO1xuICB3aWR0aDogMTAwJTtcbiAgYmFja2dyb3VuZC1jb2xvcjogI2Y5ZjRjODtcbiAgcGFkZGluZy1ib3R0b206IDIwcHg7XG4gIG1hcmdpbi10b3A6IC0ycHg7XG4gIHBhZGRpbmctbGVmdDogNThweDtcbiAgYm9yZGVyLXJhZGl1czogMHB4IDBweCA1cHggNXB4O1xuICAke21xLnJhbmdlKHsgdW50aWw6IGJyZWFrcG9pbnRzLm1vYmlsZVdpZGUgfSl9IHtcbiAgICBwYWRkaW5nLWxlZnQ6IDQ1cHg7XG4gIH1cbmA7XG5jb25zdCBMaW5rID0gc3R5bGVkLmFgXG4gIGNvbG9yOiAjMjA1ODhmO1xuICBmb250LXNpemU6IDE2cHg7XG4gIHBhZGRpbmctYm90dG9tOiAxcHg7XG4gIG1hcmdpbjogMHB4IDQwcHggMXB4IDJweDtcbiAgZm9udC1mYW1pbHk6ICR7Zm9udHMuc2Fuc307XG4gICR7bXEucmFuZ2UoeyB1bnRpbDogYnJlYWtwb2ludHMubW9iaWxlV2lkZSB9KX0ge1xuICAgIG1hcmdpbjogMHB4IDE1cHggMXB4IDVweDtcbiAgICBib3gtc2hhZG93OiBub25lO1xuICB9XG5gO1xuY29uc3QgQ2xvc2VCdXR0b25XcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgcG9zaXRpb246IGFic29sdXRlO1xuICB0b3A6IDEwcHg7XG4gIHJpZ2h0OiAxcHg7XG5gO1xuXG50eXBlIExpbmtQcm9wcyA9IHtcbiAgaHJlZj86IHN0cmluZztcbiAgdGV4dD86IHN0cmluZztcbn07XG50eXBlIFByb3BzID0ge1xuICB0eXBlPzogV3JhcHBlclByb3BzWydib3hUeXBlJ107XG4gIHN0aWNreT86IGJvb2xlYW47XG4gIGNoaWxkcmVuPzogc3RyaW5nO1xuICBsaW5rcz86IExpbmtQcm9wc1tdO1xuICBzaG93Q2xvc2VCdXR0b24/OiBib29sZWFuO1xufTtcblxuZXhwb3J0IGNvbnN0IE1lc3NhZ2VCb3ggPSAoeyB0eXBlLCBzdGlja3kgPSBmYWxzZSwgY2hpbGRyZW4sIGxpbmtzLCB0LCBzaG93Q2xvc2VCdXR0b24gfTogUHJvcHMgJiBXaXRoVHJhbnNsYXRpb24pID0+IHtcbiAgY29uc3QgW2hpZGVNZXNzYWdlQm94LCBzZXRIaWRlTWVzc2FnZUJveF0gPSB1c2VTdGF0ZShmYWxzZSk7XG4gIGNvbnN0IG9uQ2xvc2VNZXNzYWdlQm94ID0gKCkgPT4ge1xuICAgIHNldEhpZGVNZXNzYWdlQm94KHRydWUpO1xuICB9O1xuICBjb25zdCBJY29uID0gdHlwZSA9PT0gJ2dob3N0JyA/IEh1bWFuTWFsZUJvYXJkIDogSW5mb3JtYXRpb25PdXRsaW5lO1xuICByZXR1cm4gKFxuICAgIC8vU3RpY2t5U3R5bGUgdG9wOjg0IG1ha2VzIHN1cmUgdGhhdCB0aGUgbWVzc2FnZWJveCBzaXRzIGJlbmVhdGggdGhlIG1hc3RoZWFkIChoZWFkZXIgKSBhbmQgdGhlIHRvcE9mZnNldHQgc2V0cyBpdCBzbyB0aGF0IGl0IGFwcGxpZXMgd2hlbiByZWFjaGluZyB0aGUgdG9wIG9mIHRoZSBtZXNzYWdlYm94XG4gICAgPFN0aWNreSBkaXNhYmxlZD17IXN0aWNreX0gc3RpY2t5U3R5bGU9e3sgekluZGV4OiA5OTk4LCB0b3A6IDg0IH19IHRvcE9mZnNldD17LTg0fT5cbiAgICAgIDxXcmFwcGVyIGJveFR5cGU9e3R5cGV9IHN0eWxlPXt7IGRpc3BsYXk6IGhpZGVNZXNzYWdlQm94ID8gJ25vbmUnIDogJ2ZsZXgnIH19PlxuICAgICAgICA8SW5mb1dyYXBwZXIgYm94VHlwZT17dHlwZX0+XG4gICAgICAgICAgPEljb25XcmFwcGVyIGJveFR5cGU9e3R5cGV9PlxuICAgICAgICAgICAgPEljb24gc3R5bGU9e3sgd2lkdGg6ICcyNHB4JywgaGVpZ2h0OiAnMjRweCcgfX0gLz5cbiAgICAgICAgICA8L0ljb25XcmFwcGVyPlxuICAgICAgICAgIDxUZXh0V3JhcHBlcj57Y2hpbGRyZW59PC9UZXh0V3JhcHBlcj5cbiAgICAgICAgPC9JbmZvV3JhcHBlcj5cbiAgICAgICAge3Nob3dDbG9zZUJ1dHRvbiAmJiAoXG4gICAgICAgICAgPENsb3NlQnV0dG9uV3JhcHBlcj5cbiAgICAgICAgICAgIDxDbG9zZUJ1dHRvbiBvbkNsaWNrPXtvbkNsb3NlTWVzc2FnZUJveH0gLz5cbiAgICAgICAgICA8L0Nsb3NlQnV0dG9uV3JhcHBlcj5cbiAgICAgICAgKX1cbiAgICAgIDwvV3JhcHBlcj5cblxuICAgICAge2xpbmtzICYmIChcbiAgICAgICAgLy9sb29wcyB0aHJvdWdoIHRoZSBsaW5rcyBwYXNzZWQgaW4gYXMgcHJvcGVydGllcyBpZiB0aGVyZSBhcmUgYW55IGFuZCBjcmVhdGVzIGEgd29ya2luZyBsaW5rIGZvciBlYWNoIG9mIHRoZW1cbiAgICAgICAgPExpbmtXcmFwcGVyIHN0eWxlPXt7IGRpc3BsYXk6IGhpZGVNZXNzYWdlQm94ID8gJ25vbmUnIDogJ2ZsZXgnIH19PlxuICAgICAgICAgIHtsaW5rcy5tYXAoKHgpID0+IChcbiAgICAgICAgICAgIDxMaW5rIGhyZWY9e3guaHJlZn0+e3gudGV4dH08L0xpbms+XG4gICAgICAgICAgKSl9XG4gICAgICAgIDwvTGlua1dyYXBwZXI+XG4gICAgICApfVxuICAgIDwvU3RpY2t5PlxuICApO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgd2l0aFRyYW5zbGF0aW9uKCkoTWVzc2FnZUJveCk7XG4iXX0= */"));
142
+ }), "{line-height:24px;font-size:16px;}& p{margin:0;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["MessageBox.tsx"],"names":[],"mappings":"AAoG4C","file":"MessageBox.tsx","sourcesContent":["/**\n * Copyright (c) 2022-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, { HTMLAttributes, useState } from 'react';\nimport styled from '@emotion/styled';\nimport Sticky from 'react-sticky-el';\nimport { breakpoints, fonts, mq, spacing } from '@ndla/core';\nimport { InformationOutline, HumanMaleBoard } from '@ndla/icons/common';\nimport { WithTranslation, withTranslation } from 'react-i18next';\n\n// @ts-ignore\nimport { Remarkable } from 'remarkable';\nimport { CloseButton } from '../CloseButton';\n\nexport enum MessageBoxType {\n  ghost = 'ghost',\n  fullpage = 'fullpage',\n  medium = 'medium',\n  masthead = 'masthead',\n}\ntype WrapperProps = {\n  boxType?: MessageBoxType;\n};\n\nconst StyleByType = (type: WrapperProps['boxType']) => {\n  const styles: HTMLAttributes<HTMLElement>['style'] = {\n    margin: '1px',\n    color: '#444444',\n    backgroundColor: '#f9f4c8',\n    border: 'none',\n    display: 'flex',\n    padding: '10px',\n    width: 'auto',\n    borderRadius: '5px',\n    position: 'relative',\n    transform: 'auto',\n    left: 'auto',\n  }; //Different CSS properties for different types of message-boxes\n  switch (type) {\n    case 'fullpage':\n      styles.margin = '0 auto';\n      styles.display = 'none';\n      styles.width = '100vw';\n      styles.position = 'relative';\n      styles.left = '50%';\n      styles.padding = '0';\n      styles.transform = 'translateX(-50%)';\n      break;\n    case 'medium':\n      styles.margin = '0px';\n      break;\n    case 'ghost':\n      styles.backgroundColor = 'transparent';\n      styles.border = '1px solid #D1D6DB';\n      styles.color = '#444444';\n      break;\n    case 'masthead':\n      styles.margin = '0 auto';\n      styles.display = 'none';\n      styles.padding = '0';\n      styles.borderRadius = '0';\n      break;\n  }\n  return styles;\n};\n\nconst Wrapper = styled.div<WrapperProps>`\n  background: ${(props) => StyleByType(props.boxType).backgroundColor};\n  color: ${(props) => StyleByType(props.boxType).color};\n  font-size: 18px;\n  line-height: 32px;\n  font-family: ${fonts.sans};\n  display: flex;\n  padding: ${spacing.small};\n  position: ${(props) => StyleByType(props.boxType).position};\n  border: ${(props) => StyleByType(props.boxType).border};\n  border-radius: ${(props) => StyleByType(props.boxType).borderRadius};\n  transform: ${(props) => StyleByType(props.boxType).transform};\n  left: ${(props) => StyleByType(props.boxType).left};\n  z-index: 10;\n  width: ${(props) => StyleByType(props.boxType).width};\n`;\n\nconst InfoWrapper = styled.div<WrapperProps>`\n  margin: ${(props) => StyleByType(props.boxType).margin};\n  padding: ${(props) => StyleByType(props.boxType).padding};\n  display: flex;\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    padding: 0 90px 0 0;\n  }\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    padding: 0 5px 0 0;\n    font-size: 16px;\n  }\n`;\nconst TextWrapper = styled.div<WrapperProps>`\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    line-height: 24px;\n    font-size: 16px;\n  }\n  & p {\n    margin: 0;\n  }\n`;\n\nconst IconWrapper = styled.div<WrapperProps>`\n  padding-right: ${spacing.small};\n  display: ${(props) => StyleByType(props.boxType).display};\n  align-items: flex-start;\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding-top: 4px;\n  }\n`;\n\nconst LinkWrapper = styled.div`\n  display: block;\n  width: 100%;\n  background-color: #f9f4c8;\n  padding-bottom: 20px;\n  margin-top: -2px;\n  padding-left: 58px;\n  border-radius: 0px 0px 5px 5px;\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    padding-left: 45px;\n  }\n`;\nconst Link = styled.a`\n  color: #20588f;\n  font-size: 16px;\n  padding-bottom: 1px;\n  margin: 0px 40px 1px 2px;\n  font-family: ${fonts.sans};\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    margin: 0px 15px 1px 5px;\n    box-shadow: none;\n  }\n`;\nconst CloseButtonWrapper = styled.div`\n  position: absolute;\n  top: 10px;\n  right: 1px;\n`;\n\ntype LinkProps = {\n  href?: string;\n  text?: string;\n};\ntype Props = {\n  type?: WrapperProps['boxType'];\n  sticky?: boolean;\n  children?: string;\n  links?: LinkProps[];\n  showCloseButton?: boolean;\n  onClose?: () => void;\n};\n\nconst markdown = new Remarkable({ breaks: true });\nmarkdown.inline.ruler.enable(['sub', 'sup']);\nmarkdown.block.ruler.disable(['list', 'table']);\n\nexport const MessageBox = ({\n  type,\n  sticky = false,\n  children = '',\n  links,\n  showCloseButton,\n  onClose,\n}: Props & WithTranslation) => {\n  const [hideMessageBox, setHideMessageBox] = useState(false);\n  const onCloseMessageBox = () => {\n    setHideMessageBox(true);\n    onClose?.();\n  };\n  const Icon = type === 'ghost' ? HumanMaleBoard : InformationOutline;\n  return (\n    //StickyStyle top:84 makes sure that the messagebox sits beneath the masthead (header ) and the topOffsett sets it so that it applies when reaching the top of the messagebox\n    <Sticky disabled={!sticky} stickyStyle={{ zIndex: 9998, top: 84 }} topOffset={-84}>\n      <Wrapper boxType={type} style={{ display: hideMessageBox ? 'none' : 'flex' }}>\n        <InfoWrapper boxType={type}>\n          <IconWrapper boxType={type}>\n            <Icon style={{ width: '24px', height: '24px' }} />\n          </IconWrapper>\n          <TextWrapper dangerouslySetInnerHTML={{ __html: markdown.render(children) }}></TextWrapper>\n        </InfoWrapper>\n        {showCloseButton && (\n          <CloseButtonWrapper>\n            <CloseButton onClick={onCloseMessageBox} />\n          </CloseButtonWrapper>\n        )}\n      </Wrapper>\n\n      {links && (\n        //loops through the links passed in as properties if there are any and creates a working link for each of them\n        <LinkWrapper style={{ display: hideMessageBox ? 'none' : 'flex' }}>\n          {links.map((x) => (\n            <Link href={x.href}>{x.text}</Link>\n          ))}\n        </LinkWrapper>\n      )}\n    </Sticky>\n  );\n};\n\nexport default withTranslation()(MessageBox);\n"]} */"));
140
143
  var IconWrapper = (0, _styledBase["default"])("div", {
141
144
  target: "e1ckcvyi3",
142
145
  label: "IconWrapper"
@@ -144,19 +147,19 @@ var IconWrapper = (0, _styledBase["default"])("div", {
144
147
  return StyleByType(props.boxType).display;
145
148
  }, ";align-items:flex-start;", _core.mq.range({
146
149
  from: _core.breakpoints.tabletWide
147
- }), "{padding-top:4px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIk1lc3NhZ2VCb3gudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTBHNEMiLCJmaWxlIjoiTWVzc2FnZUJveC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAyMi1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCBSZWFjdCwgeyBIVE1MQXR0cmlidXRlcywgdXNlU3RhdGUgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgU3RpY2t5IGZyb20gJ3JlYWN0LXN0aWNreS1lbCc7XG5pbXBvcnQgeyBicmVha3BvaW50cywgZm9udHMsIG1xLCBzcGFjaW5nIH0gZnJvbSAnQG5kbGEvY29yZSc7XG5pbXBvcnQgeyBJbmZvcm1hdGlvbk91dGxpbmUsIEh1bWFuTWFsZUJvYXJkIH0gZnJvbSAnQG5kbGEvaWNvbnMvY29tbW9uJztcbmltcG9ydCB7IFdpdGhUcmFuc2xhdGlvbiwgd2l0aFRyYW5zbGF0aW9uIH0gZnJvbSAncmVhY3QtaTE4bmV4dCc7XG5pbXBvcnQgeyBDbG9zZUJ1dHRvbiB9IGZyb20gJy4uL0Nsb3NlQnV0dG9uJztcblxuZXhwb3J0IGVudW0gTWVzc2FnZUJveFR5cGUge1xuICBnaG9zdCA9ICdnaG9zdCcsXG4gIGZ1bGxwYWdlID0gJ2Z1bGxwYWdlJyxcbiAgbWVkaXVtID0gJ21lZGl1bScsXG4gIG1hc3RoZWFkID0gJ21hc3RoZWFkJyxcbn1cbnR5cGUgV3JhcHBlclByb3BzID0ge1xuICBib3hUeXBlPzogTWVzc2FnZUJveFR5cGU7XG59O1xuXG5jb25zdCBTdHlsZUJ5VHlwZSA9ICh0eXBlOiBXcmFwcGVyUHJvcHNbJ2JveFR5cGUnXSkgPT4ge1xuICBjb25zdCBzdHlsZXM6IEhUTUxBdHRyaWJ1dGVzPEhUTUxFbGVtZW50Plsnc3R5bGUnXSA9IHtcbiAgICBtYXJnaW46ICcxcHgnLFxuICAgIGNvbG9yOiAnIzQ0NDQ0NCcsXG4gICAgYmFja2dyb3VuZENvbG9yOiAnI2Y5ZjRjOCcsXG4gICAgYm9yZGVyOiAnbm9uZScsXG4gICAgZGlzcGxheTogJ2ZsZXgnLFxuICAgIHBhZGRpbmc6ICcxMHB4JyxcbiAgICB3aWR0aDogJ2F1dG8nLFxuICAgIGJvcmRlclJhZGl1czogJzVweCcsXG4gICAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gICAgdHJhbnNmb3JtOiAnYXV0bycsXG4gICAgbGVmdDogJ2F1dG8nLFxuICB9OyAvL0RpZmZlcmVudCBDU1MgcHJvcGVydGllcyBmb3IgZGlmZmVyZW50IHR5cGVzIG9mIG1lc3NhZ2UtYm94ZXNcbiAgc3dpdGNoICh0eXBlKSB7XG4gICAgY2FzZSAnZnVsbHBhZ2UnOlxuICAgICAgc3R5bGVzLm1hcmdpbiA9ICcwIGF1dG8nO1xuICAgICAgc3R5bGVzLmRpc3BsYXkgPSAnbm9uZSc7XG4gICAgICBzdHlsZXMud2lkdGggPSAnMTAwdncnO1xuICAgICAgc3R5bGVzLnBvc2l0aW9uID0gJ3JlbGF0aXZlJztcbiAgICAgIHN0eWxlcy5sZWZ0ID0gJzUwJSc7XG4gICAgICBzdHlsZXMudHJhbnNmb3JtID0gJ3RyYW5zbGF0ZVgoLTUwJSknO1xuICAgICAgYnJlYWs7XG4gICAgY2FzZSAnbWVkaXVtJzpcbiAgICAgIHN0eWxlcy5tYXJnaW4gPSAnMHB4JztcbiAgICAgIGJyZWFrO1xuICAgIGNhc2UgJ2dob3N0JzpcbiAgICAgIHN0eWxlcy5iYWNrZ3JvdW5kQ29sb3IgPSAndHJhbnNwYXJlbnQnO1xuICAgICAgc3R5bGVzLmJvcmRlciA9ICcxcHggc29saWQgI0QxRDZEQic7XG4gICAgICBzdHlsZXMuY29sb3IgPSAnIzQ0NDQ0NCc7XG4gICAgICBicmVhaztcbiAgICBjYXNlICdtYXN0aGVhZCc6XG4gICAgICBzdHlsZXMubWFyZ2luID0gJzAgYXV0byc7XG4gICAgICBzdHlsZXMuZGlzcGxheSA9ICdub25lJztcbiAgICAgIHN0eWxlcy5wYWRkaW5nID0gJzAnO1xuICAgICAgc3R5bGVzLmJvcmRlclJhZGl1cyA9ICcwJztcbiAgICAgIGJyZWFrO1xuICB9XG4gIHJldHVybiBzdHlsZXM7XG59O1xuXG5jb25zdCBXcmFwcGVyID0gc3R5bGVkLmRpdjxXcmFwcGVyUHJvcHM+YFxuICBiYWNrZ3JvdW5kOiAkeyhwcm9wcykgPT4gU3R5bGVCeVR5cGUocHJvcHMuYm94VHlwZSkuYmFja2dyb3VuZENvbG9yfTtcbiAgY29sb3I6ICR7KHByb3BzKSA9PiBTdHlsZUJ5VHlwZShwcm9wcy5ib3hUeXBlKS5jb2xvcn07XG4gIGZvbnQtc2l6ZTogMThweDtcbiAgbGluZS1oZWlnaHQ6IDMycHg7XG4gIGZvbnQtZmFtaWx5OiAke2ZvbnRzLnNhbnN9O1xuICBkaXNwbGF5OiBmbGV4O1xuICBwYWRkaW5nOiAke3NwYWNpbmcuc21hbGx9O1xuICBwb3NpdGlvbjogJHsocHJvcHMpID0+IFN0eWxlQnlUeXBlKHByb3BzLmJveFR5cGUpLnBvc2l0aW9ufTtcbiAgYm9yZGVyOiAkeyhwcm9wcykgPT4gU3R5bGVCeVR5cGUocHJvcHMuYm94VHlwZSkuYm9yZGVyfTtcbiAgYm9yZGVyLXJhZGl1czogJHsocHJvcHMpID0+IFN0eWxlQnlUeXBlKHByb3BzLmJveFR5cGUpLmJvcmRlclJhZGl1c307XG4gIHRyYW5zZm9ybTogJHsocHJvcHMpID0+IFN0eWxlQnlUeXBlKHByb3BzLmJveFR5cGUpLnRyYW5zZm9ybX07XG4gIGxlZnQ6ICR7KHByb3BzKSA9PiBTdHlsZUJ5VHlwZShwcm9wcy5ib3hUeXBlKS5sZWZ0fTtcbiAgei1pbmRleDogMTA7XG4gIHdpZHRoOiAkeyhwcm9wcykgPT4gU3R5bGVCeVR5cGUocHJvcHMuYm94VHlwZSkud2lkdGh9O1xuYDtcblxuY29uc3QgSW5mb1dyYXBwZXIgPSBzdHlsZWQuZGl2PFdyYXBwZXJQcm9wcz5gXG4gIG1hcmdpbjogJHsocHJvcHMpID0+IFN0eWxlQnlUeXBlKHByb3BzLmJveFR5cGUpLm1hcmdpbn07XG4gIHBhZGRpbmc6ICR7KHByb3BzKSA9PiBTdHlsZUJ5VHlwZShwcm9wcy5ib3hUeXBlKS5wYWRkaW5nfTtcbiAgZGlzcGxheTogZmxleDtcbiAgJHttcS5yYW5nZSh7IHVudGlsOiBicmVha3BvaW50cy50YWJsZXRXaWRlIH0pfSB7XG4gICAgcGFkZGluZzogMCA5MHB4IDAgMDtcbiAgfVxuICAke21xLnJhbmdlKHsgdW50aWw6IGJyZWFrcG9pbnRzLm1vYmlsZVdpZGUgfSl9IHtcbiAgICBwYWRkaW5nOiAwIDVweCAwIDA7XG4gICAgZm9udC1zaXplOiAxNnB4O1xuICB9XG5gO1xuY29uc3QgVGV4dFdyYXBwZXIgPSBzdHlsZWQuZGl2PFdyYXBwZXJQcm9wcz5gXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGZsZXgtd3JhcDogd3JhcDtcbiAgJHttcS5yYW5nZSh7IHVudGlsOiBicmVha3BvaW50cy50YWJsZXRXaWRlIH0pfSB7XG4gICAgbGluZS1oZWlnaHQ6IDI0cHg7XG4gICAgZm9udC1zaXplOiAxNnB4O1xuICB9XG5gO1xuXG5jb25zdCBJY29uV3JhcHBlciA9IHN0eWxlZC5kaXY8V3JhcHBlclByb3BzPmBcbiAgcGFkZGluZy1yaWdodDogJHtzcGFjaW5nLnNtYWxsfTtcbiAgZGlzcGxheTogJHsocHJvcHMpID0+IFN0eWxlQnlUeXBlKHByb3BzLmJveFR5cGUpLmRpc3BsYXl9O1xuICBhbGlnbi1pdGVtczogZmxleC1zdGFydDtcbiAgJHttcS5yYW5nZSh7IGZyb206IGJyZWFrcG9pbnRzLnRhYmxldFdpZGUgfSl9IHtcbiAgICBwYWRkaW5nLXRvcDogNHB4O1xuICB9XG5gO1xuXG5jb25zdCBMaW5rV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIGRpc3BsYXk6IGJsb2NrO1xuICB3aWR0aDogMTAwJTtcbiAgYmFja2dyb3VuZC1jb2xvcjogI2Y5ZjRjODtcbiAgcGFkZGluZy1ib3R0b206IDIwcHg7XG4gIG1hcmdpbi10b3A6IC0ycHg7XG4gIHBhZGRpbmctbGVmdDogNThweDtcbiAgYm9yZGVyLXJhZGl1czogMHB4IDBweCA1cHggNXB4O1xuICAke21xLnJhbmdlKHsgdW50aWw6IGJyZWFrcG9pbnRzLm1vYmlsZVdpZGUgfSl9IHtcbiAgICBwYWRkaW5nLWxlZnQ6IDQ1cHg7XG4gIH1cbmA7XG5jb25zdCBMaW5rID0gc3R5bGVkLmFgXG4gIGNvbG9yOiAjMjA1ODhmO1xuICBmb250LXNpemU6IDE2cHg7XG4gIHBhZGRpbmctYm90dG9tOiAxcHg7XG4gIG1hcmdpbjogMHB4IDQwcHggMXB4IDJweDtcbiAgZm9udC1mYW1pbHk6ICR7Zm9udHMuc2Fuc307XG4gICR7bXEucmFuZ2UoeyB1bnRpbDogYnJlYWtwb2ludHMubW9iaWxlV2lkZSB9KX0ge1xuICAgIG1hcmdpbjogMHB4IDE1cHggMXB4IDVweDtcbiAgICBib3gtc2hhZG93OiBub25lO1xuICB9XG5gO1xuY29uc3QgQ2xvc2VCdXR0b25XcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgcG9zaXRpb246IGFic29sdXRlO1xuICB0b3A6IDEwcHg7XG4gIHJpZ2h0OiAxcHg7XG5gO1xuXG50eXBlIExpbmtQcm9wcyA9IHtcbiAgaHJlZj86IHN0cmluZztcbiAgdGV4dD86IHN0cmluZztcbn07XG50eXBlIFByb3BzID0ge1xuICB0eXBlPzogV3JhcHBlclByb3BzWydib3hUeXBlJ107XG4gIHN0aWNreT86IGJvb2xlYW47XG4gIGNoaWxkcmVuPzogc3RyaW5nO1xuICBsaW5rcz86IExpbmtQcm9wc1tdO1xuICBzaG93Q2xvc2VCdXR0b24/OiBib29sZWFuO1xufTtcblxuZXhwb3J0IGNvbnN0IE1lc3NhZ2VCb3ggPSAoeyB0eXBlLCBzdGlja3kgPSBmYWxzZSwgY2hpbGRyZW4sIGxpbmtzLCB0LCBzaG93Q2xvc2VCdXR0b24gfTogUHJvcHMgJiBXaXRoVHJhbnNsYXRpb24pID0+IHtcbiAgY29uc3QgW2hpZGVNZXNzYWdlQm94LCBzZXRIaWRlTWVzc2FnZUJveF0gPSB1c2VTdGF0ZShmYWxzZSk7XG4gIGNvbnN0IG9uQ2xvc2VNZXNzYWdlQm94ID0gKCkgPT4ge1xuICAgIHNldEhpZGVNZXNzYWdlQm94KHRydWUpO1xuICB9O1xuICBjb25zdCBJY29uID0gdHlwZSA9PT0gJ2dob3N0JyA/IEh1bWFuTWFsZUJvYXJkIDogSW5mb3JtYXRpb25PdXRsaW5lO1xuICByZXR1cm4gKFxuICAgIC8vU3RpY2t5U3R5bGUgdG9wOjg0IG1ha2VzIHN1cmUgdGhhdCB0aGUgbWVzc2FnZWJveCBzaXRzIGJlbmVhdGggdGhlIG1hc3RoZWFkIChoZWFkZXIgKSBhbmQgdGhlIHRvcE9mZnNldHQgc2V0cyBpdCBzbyB0aGF0IGl0IGFwcGxpZXMgd2hlbiByZWFjaGluZyB0aGUgdG9wIG9mIHRoZSBtZXNzYWdlYm94XG4gICAgPFN0aWNreSBkaXNhYmxlZD17IXN0aWNreX0gc3RpY2t5U3R5bGU9e3sgekluZGV4OiA5OTk4LCB0b3A6IDg0IH19IHRvcE9mZnNldD17LTg0fT5cbiAgICAgIDxXcmFwcGVyIGJveFR5cGU9e3R5cGV9IHN0eWxlPXt7IGRpc3BsYXk6IGhpZGVNZXNzYWdlQm94ID8gJ25vbmUnIDogJ2ZsZXgnIH19PlxuICAgICAgICA8SW5mb1dyYXBwZXIgYm94VHlwZT17dHlwZX0+XG4gICAgICAgICAgPEljb25XcmFwcGVyIGJveFR5cGU9e3R5cGV9PlxuICAgICAgICAgICAgPEljb24gc3R5bGU9e3sgd2lkdGg6ICcyNHB4JywgaGVpZ2h0OiAnMjRweCcgfX0gLz5cbiAgICAgICAgICA8L0ljb25XcmFwcGVyPlxuICAgICAgICAgIDxUZXh0V3JhcHBlcj57Y2hpbGRyZW59PC9UZXh0V3JhcHBlcj5cbiAgICAgICAgPC9JbmZvV3JhcHBlcj5cbiAgICAgICAge3Nob3dDbG9zZUJ1dHRvbiAmJiAoXG4gICAgICAgICAgPENsb3NlQnV0dG9uV3JhcHBlcj5cbiAgICAgICAgICAgIDxDbG9zZUJ1dHRvbiBvbkNsaWNrPXtvbkNsb3NlTWVzc2FnZUJveH0gLz5cbiAgICAgICAgICA8L0Nsb3NlQnV0dG9uV3JhcHBlcj5cbiAgICAgICAgKX1cbiAgICAgIDwvV3JhcHBlcj5cblxuICAgICAge2xpbmtzICYmIChcbiAgICAgICAgLy9sb29wcyB0aHJvdWdoIHRoZSBsaW5rcyBwYXNzZWQgaW4gYXMgcHJvcGVydGllcyBpZiB0aGVyZSBhcmUgYW55IGFuZCBjcmVhdGVzIGEgd29ya2luZyBsaW5rIGZvciBlYWNoIG9mIHRoZW1cbiAgICAgICAgPExpbmtXcmFwcGVyIHN0eWxlPXt7IGRpc3BsYXk6IGhpZGVNZXNzYWdlQm94ID8gJ25vbmUnIDogJ2ZsZXgnIH19PlxuICAgICAgICAgIHtsaW5rcy5tYXAoKHgpID0+IChcbiAgICAgICAgICAgIDxMaW5rIGhyZWY9e3guaHJlZn0+e3gudGV4dH08L0xpbms+XG4gICAgICAgICAgKSl9XG4gICAgICAgIDwvTGlua1dyYXBwZXI+XG4gICAgICApfVxuICAgIDwvU3RpY2t5PlxuICApO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgd2l0aFRyYW5zbGF0aW9uKCkoTWVzc2FnZUJveCk7XG4iXX0= */"));
150
+ }), "{padding-top:4px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["MessageBox.tsx"],"names":[],"mappings":"AAiH4C","file":"MessageBox.tsx","sourcesContent":["/**\n * Copyright (c) 2022-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, { HTMLAttributes, useState } from 'react';\nimport styled from '@emotion/styled';\nimport Sticky from 'react-sticky-el';\nimport { breakpoints, fonts, mq, spacing } from '@ndla/core';\nimport { InformationOutline, HumanMaleBoard } from '@ndla/icons/common';\nimport { WithTranslation, withTranslation } from 'react-i18next';\n\n// @ts-ignore\nimport { Remarkable } from 'remarkable';\nimport { CloseButton } from '../CloseButton';\n\nexport enum MessageBoxType {\n  ghost = 'ghost',\n  fullpage = 'fullpage',\n  medium = 'medium',\n  masthead = 'masthead',\n}\ntype WrapperProps = {\n  boxType?: MessageBoxType;\n};\n\nconst StyleByType = (type: WrapperProps['boxType']) => {\n  const styles: HTMLAttributes<HTMLElement>['style'] = {\n    margin: '1px',\n    color: '#444444',\n    backgroundColor: '#f9f4c8',\n    border: 'none',\n    display: 'flex',\n    padding: '10px',\n    width: 'auto',\n    borderRadius: '5px',\n    position: 'relative',\n    transform: 'auto',\n    left: 'auto',\n  }; //Different CSS properties for different types of message-boxes\n  switch (type) {\n    case 'fullpage':\n      styles.margin = '0 auto';\n      styles.display = 'none';\n      styles.width = '100vw';\n      styles.position = 'relative';\n      styles.left = '50%';\n      styles.padding = '0';\n      styles.transform = 'translateX(-50%)';\n      break;\n    case 'medium':\n      styles.margin = '0px';\n      break;\n    case 'ghost':\n      styles.backgroundColor = 'transparent';\n      styles.border = '1px solid #D1D6DB';\n      styles.color = '#444444';\n      break;\n    case 'masthead':\n      styles.margin = '0 auto';\n      styles.display = 'none';\n      styles.padding = '0';\n      styles.borderRadius = '0';\n      break;\n  }\n  return styles;\n};\n\nconst Wrapper = styled.div<WrapperProps>`\n  background: ${(props) => StyleByType(props.boxType).backgroundColor};\n  color: ${(props) => StyleByType(props.boxType).color};\n  font-size: 18px;\n  line-height: 32px;\n  font-family: ${fonts.sans};\n  display: flex;\n  padding: ${spacing.small};\n  position: ${(props) => StyleByType(props.boxType).position};\n  border: ${(props) => StyleByType(props.boxType).border};\n  border-radius: ${(props) => StyleByType(props.boxType).borderRadius};\n  transform: ${(props) => StyleByType(props.boxType).transform};\n  left: ${(props) => StyleByType(props.boxType).left};\n  z-index: 10;\n  width: ${(props) => StyleByType(props.boxType).width};\n`;\n\nconst InfoWrapper = styled.div<WrapperProps>`\n  margin: ${(props) => StyleByType(props.boxType).margin};\n  padding: ${(props) => StyleByType(props.boxType).padding};\n  display: flex;\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    padding: 0 90px 0 0;\n  }\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    padding: 0 5px 0 0;\n    font-size: 16px;\n  }\n`;\nconst TextWrapper = styled.div<WrapperProps>`\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    line-height: 24px;\n    font-size: 16px;\n  }\n  & p {\n    margin: 0;\n  }\n`;\n\nconst IconWrapper = styled.div<WrapperProps>`\n  padding-right: ${spacing.small};\n  display: ${(props) => StyleByType(props.boxType).display};\n  align-items: flex-start;\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding-top: 4px;\n  }\n`;\n\nconst LinkWrapper = styled.div`\n  display: block;\n  width: 100%;\n  background-color: #f9f4c8;\n  padding-bottom: 20px;\n  margin-top: -2px;\n  padding-left: 58px;\n  border-radius: 0px 0px 5px 5px;\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    padding-left: 45px;\n  }\n`;\nconst Link = styled.a`\n  color: #20588f;\n  font-size: 16px;\n  padding-bottom: 1px;\n  margin: 0px 40px 1px 2px;\n  font-family: ${fonts.sans};\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    margin: 0px 15px 1px 5px;\n    box-shadow: none;\n  }\n`;\nconst CloseButtonWrapper = styled.div`\n  position: absolute;\n  top: 10px;\n  right: 1px;\n`;\n\ntype LinkProps = {\n  href?: string;\n  text?: string;\n};\ntype Props = {\n  type?: WrapperProps['boxType'];\n  sticky?: boolean;\n  children?: string;\n  links?: LinkProps[];\n  showCloseButton?: boolean;\n  onClose?: () => void;\n};\n\nconst markdown = new Remarkable({ breaks: true });\nmarkdown.inline.ruler.enable(['sub', 'sup']);\nmarkdown.block.ruler.disable(['list', 'table']);\n\nexport const MessageBox = ({\n  type,\n  sticky = false,\n  children = '',\n  links,\n  showCloseButton,\n  onClose,\n}: Props & WithTranslation) => {\n  const [hideMessageBox, setHideMessageBox] = useState(false);\n  const onCloseMessageBox = () => {\n    setHideMessageBox(true);\n    onClose?.();\n  };\n  const Icon = type === 'ghost' ? HumanMaleBoard : InformationOutline;\n  return (\n    //StickyStyle top:84 makes sure that the messagebox sits beneath the masthead (header ) and the topOffsett sets it so that it applies when reaching the top of the messagebox\n    <Sticky disabled={!sticky} stickyStyle={{ zIndex: 9998, top: 84 }} topOffset={-84}>\n      <Wrapper boxType={type} style={{ display: hideMessageBox ? 'none' : 'flex' }}>\n        <InfoWrapper boxType={type}>\n          <IconWrapper boxType={type}>\n            <Icon style={{ width: '24px', height: '24px' }} />\n          </IconWrapper>\n          <TextWrapper dangerouslySetInnerHTML={{ __html: markdown.render(children) }}></TextWrapper>\n        </InfoWrapper>\n        {showCloseButton && (\n          <CloseButtonWrapper>\n            <CloseButton onClick={onCloseMessageBox} />\n          </CloseButtonWrapper>\n        )}\n      </Wrapper>\n\n      {links && (\n        //loops through the links passed in as properties if there are any and creates a working link for each of them\n        <LinkWrapper style={{ display: hideMessageBox ? 'none' : 'flex' }}>\n          {links.map((x) => (\n            <Link href={x.href}>{x.text}</Link>\n          ))}\n        </LinkWrapper>\n      )}\n    </Sticky>\n  );\n};\n\nexport default withTranslation()(MessageBox);\n"]} */"));
148
151
  var LinkWrapper = (0, _styledBase["default"])("div", {
149
152
  target: "e1ckcvyi4",
150
153
  label: "LinkWrapper"
151
154
  })("display:block;width:100%;background-color:#f9f4c8;padding-bottom:20px;margin-top:-2px;padding-left:58px;border-radius:0px 0px 5px 5px;", _core.mq.range({
152
155
  until: _core.breakpoints.mobileWide
153
- }), "{padding-left:45px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIk1lc3NhZ2VCb3gudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQW1IOEIiLCJmaWxlIjoiTWVzc2FnZUJveC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAyMi1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCBSZWFjdCwgeyBIVE1MQXR0cmlidXRlcywgdXNlU3RhdGUgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgU3RpY2t5IGZyb20gJ3JlYWN0LXN0aWNreS1lbCc7XG5pbXBvcnQgeyBicmVha3BvaW50cywgZm9udHMsIG1xLCBzcGFjaW5nIH0gZnJvbSAnQG5kbGEvY29yZSc7XG5pbXBvcnQgeyBJbmZvcm1hdGlvbk91dGxpbmUsIEh1bWFuTWFsZUJvYXJkIH0gZnJvbSAnQG5kbGEvaWNvbnMvY29tbW9uJztcbmltcG9ydCB7IFdpdGhUcmFuc2xhdGlvbiwgd2l0aFRyYW5zbGF0aW9uIH0gZnJvbSAncmVhY3QtaTE4bmV4dCc7XG5pbXBvcnQgeyBDbG9zZUJ1dHRvbiB9IGZyb20gJy4uL0Nsb3NlQnV0dG9uJztcblxuZXhwb3J0IGVudW0gTWVzc2FnZUJveFR5cGUge1xuICBnaG9zdCA9ICdnaG9zdCcsXG4gIGZ1bGxwYWdlID0gJ2Z1bGxwYWdlJyxcbiAgbWVkaXVtID0gJ21lZGl1bScsXG4gIG1hc3RoZWFkID0gJ21hc3RoZWFkJyxcbn1cbnR5cGUgV3JhcHBlclByb3BzID0ge1xuICBib3hUeXBlPzogTWVzc2FnZUJveFR5cGU7XG59O1xuXG5jb25zdCBTdHlsZUJ5VHlwZSA9ICh0eXBlOiBXcmFwcGVyUHJvcHNbJ2JveFR5cGUnXSkgPT4ge1xuICBjb25zdCBzdHlsZXM6IEhUTUxBdHRyaWJ1dGVzPEhUTUxFbGVtZW50Plsnc3R5bGUnXSA9IHtcbiAgICBtYXJnaW46ICcxcHgnLFxuICAgIGNvbG9yOiAnIzQ0NDQ0NCcsXG4gICAgYmFja2dyb3VuZENvbG9yOiAnI2Y5ZjRjOCcsXG4gICAgYm9yZGVyOiAnbm9uZScsXG4gICAgZGlzcGxheTogJ2ZsZXgnLFxuICAgIHBhZGRpbmc6ICcxMHB4JyxcbiAgICB3aWR0aDogJ2F1dG8nLFxuICAgIGJvcmRlclJhZGl1czogJzVweCcsXG4gICAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gICAgdHJhbnNmb3JtOiAnYXV0bycsXG4gICAgbGVmdDogJ2F1dG8nLFxuICB9OyAvL0RpZmZlcmVudCBDU1MgcHJvcGVydGllcyBmb3IgZGlmZmVyZW50IHR5cGVzIG9mIG1lc3NhZ2UtYm94ZXNcbiAgc3dpdGNoICh0eXBlKSB7XG4gICAgY2FzZSAnZnVsbHBhZ2UnOlxuICAgICAgc3R5bGVzLm1hcmdpbiA9ICcwIGF1dG8nO1xuICAgICAgc3R5bGVzLmRpc3BsYXkgPSAnbm9uZSc7XG4gICAgICBzdHlsZXMud2lkdGggPSAnMTAwdncnO1xuICAgICAgc3R5bGVzLnBvc2l0aW9uID0gJ3JlbGF0aXZlJztcbiAgICAgIHN0eWxlcy5sZWZ0ID0gJzUwJSc7XG4gICAgICBzdHlsZXMudHJhbnNmb3JtID0gJ3RyYW5zbGF0ZVgoLTUwJSknO1xuICAgICAgYnJlYWs7XG4gICAgY2FzZSAnbWVkaXVtJzpcbiAgICAgIHN0eWxlcy5tYXJnaW4gPSAnMHB4JztcbiAgICAgIGJyZWFrO1xuICAgIGNhc2UgJ2dob3N0JzpcbiAgICAgIHN0eWxlcy5iYWNrZ3JvdW5kQ29sb3IgPSAndHJhbnNwYXJlbnQnO1xuICAgICAgc3R5bGVzLmJvcmRlciA9ICcxcHggc29saWQgI0QxRDZEQic7XG4gICAgICBzdHlsZXMuY29sb3IgPSAnIzQ0NDQ0NCc7XG4gICAgICBicmVhaztcbiAgICBjYXNlICdtYXN0aGVhZCc6XG4gICAgICBzdHlsZXMubWFyZ2luID0gJzAgYXV0byc7XG4gICAgICBzdHlsZXMuZGlzcGxheSA9ICdub25lJztcbiAgICAgIHN0eWxlcy5wYWRkaW5nID0gJzAnO1xuICAgICAgc3R5bGVzLmJvcmRlclJhZGl1cyA9ICcwJztcbiAgICAgIGJyZWFrO1xuICB9XG4gIHJldHVybiBzdHlsZXM7XG59O1xuXG5jb25zdCBXcmFwcGVyID0gc3R5bGVkLmRpdjxXcmFwcGVyUHJvcHM+YFxuICBiYWNrZ3JvdW5kOiAkeyhwcm9wcykgPT4gU3R5bGVCeVR5cGUocHJvcHMuYm94VHlwZSkuYmFja2dyb3VuZENvbG9yfTtcbiAgY29sb3I6ICR7KHByb3BzKSA9PiBTdHlsZUJ5VHlwZShwcm9wcy5ib3hUeXBlKS5jb2xvcn07XG4gIGZvbnQtc2l6ZTogMThweDtcbiAgbGluZS1oZWlnaHQ6IDMycHg7XG4gIGZvbnQtZmFtaWx5OiAke2ZvbnRzLnNhbnN9O1xuICBkaXNwbGF5OiBmbGV4O1xuICBwYWRkaW5nOiAke3NwYWNpbmcuc21hbGx9O1xuICBwb3NpdGlvbjogJHsocHJvcHMpID0+IFN0eWxlQnlUeXBlKHByb3BzLmJveFR5cGUpLnBvc2l0aW9ufTtcbiAgYm9yZGVyOiAkeyhwcm9wcykgPT4gU3R5bGVCeVR5cGUocHJvcHMuYm94VHlwZSkuYm9yZGVyfTtcbiAgYm9yZGVyLXJhZGl1czogJHsocHJvcHMpID0+IFN0eWxlQnlUeXBlKHByb3BzLmJveFR5cGUpLmJvcmRlclJhZGl1c307XG4gIHRyYW5zZm9ybTogJHsocHJvcHMpID0+IFN0eWxlQnlUeXBlKHByb3BzLmJveFR5cGUpLnRyYW5zZm9ybX07XG4gIGxlZnQ6ICR7KHByb3BzKSA9PiBTdHlsZUJ5VHlwZShwcm9wcy5ib3hUeXBlKS5sZWZ0fTtcbiAgei1pbmRleDogMTA7XG4gIHdpZHRoOiAkeyhwcm9wcykgPT4gU3R5bGVCeVR5cGUocHJvcHMuYm94VHlwZSkud2lkdGh9O1xuYDtcblxuY29uc3QgSW5mb1dyYXBwZXIgPSBzdHlsZWQuZGl2PFdyYXBwZXJQcm9wcz5gXG4gIG1hcmdpbjogJHsocHJvcHMpID0+IFN0eWxlQnlUeXBlKHByb3BzLmJveFR5cGUpLm1hcmdpbn07XG4gIHBhZGRpbmc6ICR7KHByb3BzKSA9PiBTdHlsZUJ5VHlwZShwcm9wcy5ib3hUeXBlKS5wYWRkaW5nfTtcbiAgZGlzcGxheTogZmxleDtcbiAgJHttcS5yYW5nZSh7IHVudGlsOiBicmVha3BvaW50cy50YWJsZXRXaWRlIH0pfSB7XG4gICAgcGFkZGluZzogMCA5MHB4IDAgMDtcbiAgfVxuICAke21xLnJhbmdlKHsgdW50aWw6IGJyZWFrcG9pbnRzLm1vYmlsZVdpZGUgfSl9IHtcbiAgICBwYWRkaW5nOiAwIDVweCAwIDA7XG4gICAgZm9udC1zaXplOiAxNnB4O1xuICB9XG5gO1xuY29uc3QgVGV4dFdyYXBwZXIgPSBzdHlsZWQuZGl2PFdyYXBwZXJQcm9wcz5gXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGZsZXgtd3JhcDogd3JhcDtcbiAgJHttcS5yYW5nZSh7IHVudGlsOiBicmVha3BvaW50cy50YWJsZXRXaWRlIH0pfSB7XG4gICAgbGluZS1oZWlnaHQ6IDI0cHg7XG4gICAgZm9udC1zaXplOiAxNnB4O1xuICB9XG5gO1xuXG5jb25zdCBJY29uV3JhcHBlciA9IHN0eWxlZC5kaXY8V3JhcHBlclByb3BzPmBcbiAgcGFkZGluZy1yaWdodDogJHtzcGFjaW5nLnNtYWxsfTtcbiAgZGlzcGxheTogJHsocHJvcHMpID0+IFN0eWxlQnlUeXBlKHByb3BzLmJveFR5cGUpLmRpc3BsYXl9O1xuICBhbGlnbi1pdGVtczogZmxleC1zdGFydDtcbiAgJHttcS5yYW5nZSh7IGZyb206IGJyZWFrcG9pbnRzLnRhYmxldFdpZGUgfSl9IHtcbiAgICBwYWRkaW5nLXRvcDogNHB4O1xuICB9XG5gO1xuXG5jb25zdCBMaW5rV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIGRpc3BsYXk6IGJsb2NrO1xuICB3aWR0aDogMTAwJTtcbiAgYmFja2dyb3VuZC1jb2xvcjogI2Y5ZjRjODtcbiAgcGFkZGluZy1ib3R0b206IDIwcHg7XG4gIG1hcmdpbi10b3A6IC0ycHg7XG4gIHBhZGRpbmctbGVmdDogNThweDtcbiAgYm9yZGVyLXJhZGl1czogMHB4IDBweCA1cHggNXB4O1xuICAke21xLnJhbmdlKHsgdW50aWw6IGJyZWFrcG9pbnRzLm1vYmlsZVdpZGUgfSl9IHtcbiAgICBwYWRkaW5nLWxlZnQ6IDQ1cHg7XG4gIH1cbmA7XG5jb25zdCBMaW5rID0gc3R5bGVkLmFgXG4gIGNvbG9yOiAjMjA1ODhmO1xuICBmb250LXNpemU6IDE2cHg7XG4gIHBhZGRpbmctYm90dG9tOiAxcHg7XG4gIG1hcmdpbjogMHB4IDQwcHggMXB4IDJweDtcbiAgZm9udC1mYW1pbHk6ICR7Zm9udHMuc2Fuc307XG4gICR7bXEucmFuZ2UoeyB1bnRpbDogYnJlYWtwb2ludHMubW9iaWxlV2lkZSB9KX0ge1xuICAgIG1hcmdpbjogMHB4IDE1cHggMXB4IDVweDtcbiAgICBib3gtc2hhZG93OiBub25lO1xuICB9XG5gO1xuY29uc3QgQ2xvc2VCdXR0b25XcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgcG9zaXRpb246IGFic29sdXRlO1xuICB0b3A6IDEwcHg7XG4gIHJpZ2h0OiAxcHg7XG5gO1xuXG50eXBlIExpbmtQcm9wcyA9IHtcbiAgaHJlZj86IHN0cmluZztcbiAgdGV4dD86IHN0cmluZztcbn07XG50eXBlIFByb3BzID0ge1xuICB0eXBlPzogV3JhcHBlclByb3BzWydib3hUeXBlJ107XG4gIHN0aWNreT86IGJvb2xlYW47XG4gIGNoaWxkcmVuPzogc3RyaW5nO1xuICBsaW5rcz86IExpbmtQcm9wc1tdO1xuICBzaG93Q2xvc2VCdXR0b24/OiBib29sZWFuO1xufTtcblxuZXhwb3J0IGNvbnN0IE1lc3NhZ2VCb3ggPSAoeyB0eXBlLCBzdGlja3kgPSBmYWxzZSwgY2hpbGRyZW4sIGxpbmtzLCB0LCBzaG93Q2xvc2VCdXR0b24gfTogUHJvcHMgJiBXaXRoVHJhbnNsYXRpb24pID0+IHtcbiAgY29uc3QgW2hpZGVNZXNzYWdlQm94LCBzZXRIaWRlTWVzc2FnZUJveF0gPSB1c2VTdGF0ZShmYWxzZSk7XG4gIGNvbnN0IG9uQ2xvc2VNZXNzYWdlQm94ID0gKCkgPT4ge1xuICAgIHNldEhpZGVNZXNzYWdlQm94KHRydWUpO1xuICB9O1xuICBjb25zdCBJY29uID0gdHlwZSA9PT0gJ2dob3N0JyA/IEh1bWFuTWFsZUJvYXJkIDogSW5mb3JtYXRpb25PdXRsaW5lO1xuICByZXR1cm4gKFxuICAgIC8vU3RpY2t5U3R5bGUgdG9wOjg0IG1ha2VzIHN1cmUgdGhhdCB0aGUgbWVzc2FnZWJveCBzaXRzIGJlbmVhdGggdGhlIG1hc3RoZWFkIChoZWFkZXIgKSBhbmQgdGhlIHRvcE9mZnNldHQgc2V0cyBpdCBzbyB0aGF0IGl0IGFwcGxpZXMgd2hlbiByZWFjaGluZyB0aGUgdG9wIG9mIHRoZSBtZXNzYWdlYm94XG4gICAgPFN0aWNreSBkaXNhYmxlZD17IXN0aWNreX0gc3RpY2t5U3R5bGU9e3sgekluZGV4OiA5OTk4LCB0b3A6IDg0IH19IHRvcE9mZnNldD17LTg0fT5cbiAgICAgIDxXcmFwcGVyIGJveFR5cGU9e3R5cGV9IHN0eWxlPXt7IGRpc3BsYXk6IGhpZGVNZXNzYWdlQm94ID8gJ25vbmUnIDogJ2ZsZXgnIH19PlxuICAgICAgICA8SW5mb1dyYXBwZXIgYm94VHlwZT17dHlwZX0+XG4gICAgICAgICAgPEljb25XcmFwcGVyIGJveFR5cGU9e3R5cGV9PlxuICAgICAgICAgICAgPEljb24gc3R5bGU9e3sgd2lkdGg6ICcyNHB4JywgaGVpZ2h0OiAnMjRweCcgfX0gLz5cbiAgICAgICAgICA8L0ljb25XcmFwcGVyPlxuICAgICAgICAgIDxUZXh0V3JhcHBlcj57Y2hpbGRyZW59PC9UZXh0V3JhcHBlcj5cbiAgICAgICAgPC9JbmZvV3JhcHBlcj5cbiAgICAgICAge3Nob3dDbG9zZUJ1dHRvbiAmJiAoXG4gICAgICAgICAgPENsb3NlQnV0dG9uV3JhcHBlcj5cbiAgICAgICAgICAgIDxDbG9zZUJ1dHRvbiBvbkNsaWNrPXtvbkNsb3NlTWVzc2FnZUJveH0gLz5cbiAgICAgICAgICA8L0Nsb3NlQnV0dG9uV3JhcHBlcj5cbiAgICAgICAgKX1cbiAgICAgIDwvV3JhcHBlcj5cblxuICAgICAge2xpbmtzICYmIChcbiAgICAgICAgLy9sb29wcyB0aHJvdWdoIHRoZSBsaW5rcyBwYXNzZWQgaW4gYXMgcHJvcGVydGllcyBpZiB0aGVyZSBhcmUgYW55IGFuZCBjcmVhdGVzIGEgd29ya2luZyBsaW5rIGZvciBlYWNoIG9mIHRoZW1cbiAgICAgICAgPExpbmtXcmFwcGVyIHN0eWxlPXt7IGRpc3BsYXk6IGhpZGVNZXNzYWdlQm94ID8gJ25vbmUnIDogJ2ZsZXgnIH19PlxuICAgICAgICAgIHtsaW5rcy5tYXAoKHgpID0+IChcbiAgICAgICAgICAgIDxMaW5rIGhyZWY9e3guaHJlZn0+e3gudGV4dH08L0xpbms+XG4gICAgICAgICAgKSl9XG4gICAgICAgIDwvTGlua1dyYXBwZXI+XG4gICAgICApfVxuICAgIDwvU3RpY2t5PlxuICApO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgd2l0aFRyYW5zbGF0aW9uKCkoTWVzc2FnZUJveCk7XG4iXX0= */"));
156
+ }), "{padding-left:45px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["MessageBox.tsx"],"names":[],"mappings":"AA0H8B","file":"MessageBox.tsx","sourcesContent":["/**\n * Copyright (c) 2022-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, { HTMLAttributes, useState } from 'react';\nimport styled from '@emotion/styled';\nimport Sticky from 'react-sticky-el';\nimport { breakpoints, fonts, mq, spacing } from '@ndla/core';\nimport { InformationOutline, HumanMaleBoard } from '@ndla/icons/common';\nimport { WithTranslation, withTranslation } from 'react-i18next';\n\n// @ts-ignore\nimport { Remarkable } from 'remarkable';\nimport { CloseButton } from '../CloseButton';\n\nexport enum MessageBoxType {\n  ghost = 'ghost',\n  fullpage = 'fullpage',\n  medium = 'medium',\n  masthead = 'masthead',\n}\ntype WrapperProps = {\n  boxType?: MessageBoxType;\n};\n\nconst StyleByType = (type: WrapperProps['boxType']) => {\n  const styles: HTMLAttributes<HTMLElement>['style'] = {\n    margin: '1px',\n    color: '#444444',\n    backgroundColor: '#f9f4c8',\n    border: 'none',\n    display: 'flex',\n    padding: '10px',\n    width: 'auto',\n    borderRadius: '5px',\n    position: 'relative',\n    transform: 'auto',\n    left: 'auto',\n  }; //Different CSS properties for different types of message-boxes\n  switch (type) {\n    case 'fullpage':\n      styles.margin = '0 auto';\n      styles.display = 'none';\n      styles.width = '100vw';\n      styles.position = 'relative';\n      styles.left = '50%';\n      styles.padding = '0';\n      styles.transform = 'translateX(-50%)';\n      break;\n    case 'medium':\n      styles.margin = '0px';\n      break;\n    case 'ghost':\n      styles.backgroundColor = 'transparent';\n      styles.border = '1px solid #D1D6DB';\n      styles.color = '#444444';\n      break;\n    case 'masthead':\n      styles.margin = '0 auto';\n      styles.display = 'none';\n      styles.padding = '0';\n      styles.borderRadius = '0';\n      break;\n  }\n  return styles;\n};\n\nconst Wrapper = styled.div<WrapperProps>`\n  background: ${(props) => StyleByType(props.boxType).backgroundColor};\n  color: ${(props) => StyleByType(props.boxType).color};\n  font-size: 18px;\n  line-height: 32px;\n  font-family: ${fonts.sans};\n  display: flex;\n  padding: ${spacing.small};\n  position: ${(props) => StyleByType(props.boxType).position};\n  border: ${(props) => StyleByType(props.boxType).border};\n  border-radius: ${(props) => StyleByType(props.boxType).borderRadius};\n  transform: ${(props) => StyleByType(props.boxType).transform};\n  left: ${(props) => StyleByType(props.boxType).left};\n  z-index: 10;\n  width: ${(props) => StyleByType(props.boxType).width};\n`;\n\nconst InfoWrapper = styled.div<WrapperProps>`\n  margin: ${(props) => StyleByType(props.boxType).margin};\n  padding: ${(props) => StyleByType(props.boxType).padding};\n  display: flex;\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    padding: 0 90px 0 0;\n  }\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    padding: 0 5px 0 0;\n    font-size: 16px;\n  }\n`;\nconst TextWrapper = styled.div<WrapperProps>`\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    line-height: 24px;\n    font-size: 16px;\n  }\n  & p {\n    margin: 0;\n  }\n`;\n\nconst IconWrapper = styled.div<WrapperProps>`\n  padding-right: ${spacing.small};\n  display: ${(props) => StyleByType(props.boxType).display};\n  align-items: flex-start;\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding-top: 4px;\n  }\n`;\n\nconst LinkWrapper = styled.div`\n  display: block;\n  width: 100%;\n  background-color: #f9f4c8;\n  padding-bottom: 20px;\n  margin-top: -2px;\n  padding-left: 58px;\n  border-radius: 0px 0px 5px 5px;\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    padding-left: 45px;\n  }\n`;\nconst Link = styled.a`\n  color: #20588f;\n  font-size: 16px;\n  padding-bottom: 1px;\n  margin: 0px 40px 1px 2px;\n  font-family: ${fonts.sans};\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    margin: 0px 15px 1px 5px;\n    box-shadow: none;\n  }\n`;\nconst CloseButtonWrapper = styled.div`\n  position: absolute;\n  top: 10px;\n  right: 1px;\n`;\n\ntype LinkProps = {\n  href?: string;\n  text?: string;\n};\ntype Props = {\n  type?: WrapperProps['boxType'];\n  sticky?: boolean;\n  children?: string;\n  links?: LinkProps[];\n  showCloseButton?: boolean;\n  onClose?: () => void;\n};\n\nconst markdown = new Remarkable({ breaks: true });\nmarkdown.inline.ruler.enable(['sub', 'sup']);\nmarkdown.block.ruler.disable(['list', 'table']);\n\nexport const MessageBox = ({\n  type,\n  sticky = false,\n  children = '',\n  links,\n  showCloseButton,\n  onClose,\n}: Props & WithTranslation) => {\n  const [hideMessageBox, setHideMessageBox] = useState(false);\n  const onCloseMessageBox = () => {\n    setHideMessageBox(true);\n    onClose?.();\n  };\n  const Icon = type === 'ghost' ? HumanMaleBoard : InformationOutline;\n  return (\n    //StickyStyle top:84 makes sure that the messagebox sits beneath the masthead (header ) and the topOffsett sets it so that it applies when reaching the top of the messagebox\n    <Sticky disabled={!sticky} stickyStyle={{ zIndex: 9998, top: 84 }} topOffset={-84}>\n      <Wrapper boxType={type} style={{ display: hideMessageBox ? 'none' : 'flex' }}>\n        <InfoWrapper boxType={type}>\n          <IconWrapper boxType={type}>\n            <Icon style={{ width: '24px', height: '24px' }} />\n          </IconWrapper>\n          <TextWrapper dangerouslySetInnerHTML={{ __html: markdown.render(children) }}></TextWrapper>\n        </InfoWrapper>\n        {showCloseButton && (\n          <CloseButtonWrapper>\n            <CloseButton onClick={onCloseMessageBox} />\n          </CloseButtonWrapper>\n        )}\n      </Wrapper>\n\n      {links && (\n        //loops through the links passed in as properties if there are any and creates a working link for each of them\n        <LinkWrapper style={{ display: hideMessageBox ? 'none' : 'flex' }}>\n          {links.map((x) => (\n            <Link href={x.href}>{x.text}</Link>\n          ))}\n        </LinkWrapper>\n      )}\n    </Sticky>\n  );\n};\n\nexport default withTranslation()(MessageBox);\n"]} */"));
154
157
  var Link = (0, _styledBase["default"])("a", {
155
158
  target: "e1ckcvyi5",
156
159
  label: "Link"
157
160
  })("color:#20588f;font-size:16px;padding-bottom:1px;margin:0px 40px 1px 2px;font-family:", _core.fonts.sans, ";", _core.mq.range({
158
161
  until: _core.breakpoints.mobileWide
159
- }), "{margin:0px 15px 1px 5px;box-shadow:none;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIk1lc3NhZ2VCb3gudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQStIcUIiLCJmaWxlIjoiTWVzc2FnZUJveC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAyMi1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCBSZWFjdCwgeyBIVE1MQXR0cmlidXRlcywgdXNlU3RhdGUgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgU3RpY2t5IGZyb20gJ3JlYWN0LXN0aWNreS1lbCc7XG5pbXBvcnQgeyBicmVha3BvaW50cywgZm9udHMsIG1xLCBzcGFjaW5nIH0gZnJvbSAnQG5kbGEvY29yZSc7XG5pbXBvcnQgeyBJbmZvcm1hdGlvbk91dGxpbmUsIEh1bWFuTWFsZUJvYXJkIH0gZnJvbSAnQG5kbGEvaWNvbnMvY29tbW9uJztcbmltcG9ydCB7IFdpdGhUcmFuc2xhdGlvbiwgd2l0aFRyYW5zbGF0aW9uIH0gZnJvbSAncmVhY3QtaTE4bmV4dCc7XG5pbXBvcnQgeyBDbG9zZUJ1dHRvbiB9IGZyb20gJy4uL0Nsb3NlQnV0dG9uJztcblxuZXhwb3J0IGVudW0gTWVzc2FnZUJveFR5cGUge1xuICBnaG9zdCA9ICdnaG9zdCcsXG4gIGZ1bGxwYWdlID0gJ2Z1bGxwYWdlJyxcbiAgbWVkaXVtID0gJ21lZGl1bScsXG4gIG1hc3RoZWFkID0gJ21hc3RoZWFkJyxcbn1cbnR5cGUgV3JhcHBlclByb3BzID0ge1xuICBib3hUeXBlPzogTWVzc2FnZUJveFR5cGU7XG59O1xuXG5jb25zdCBTdHlsZUJ5VHlwZSA9ICh0eXBlOiBXcmFwcGVyUHJvcHNbJ2JveFR5cGUnXSkgPT4ge1xuICBjb25zdCBzdHlsZXM6IEhUTUxBdHRyaWJ1dGVzPEhUTUxFbGVtZW50Plsnc3R5bGUnXSA9IHtcbiAgICBtYXJnaW46ICcxcHgnLFxuICAgIGNvbG9yOiAnIzQ0NDQ0NCcsXG4gICAgYmFja2dyb3VuZENvbG9yOiAnI2Y5ZjRjOCcsXG4gICAgYm9yZGVyOiAnbm9uZScsXG4gICAgZGlzcGxheTogJ2ZsZXgnLFxuICAgIHBhZGRpbmc6ICcxMHB4JyxcbiAgICB3aWR0aDogJ2F1dG8nLFxuICAgIGJvcmRlclJhZGl1czogJzVweCcsXG4gICAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gICAgdHJhbnNmb3JtOiAnYXV0bycsXG4gICAgbGVmdDogJ2F1dG8nLFxuICB9OyAvL0RpZmZlcmVudCBDU1MgcHJvcGVydGllcyBmb3IgZGlmZmVyZW50IHR5cGVzIG9mIG1lc3NhZ2UtYm94ZXNcbiAgc3dpdGNoICh0eXBlKSB7XG4gICAgY2FzZSAnZnVsbHBhZ2UnOlxuICAgICAgc3R5bGVzLm1hcmdpbiA9ICcwIGF1dG8nO1xuICAgICAgc3R5bGVzLmRpc3BsYXkgPSAnbm9uZSc7XG4gICAgICBzdHlsZXMud2lkdGggPSAnMTAwdncnO1xuICAgICAgc3R5bGVzLnBvc2l0aW9uID0gJ3JlbGF0aXZlJztcbiAgICAgIHN0eWxlcy5sZWZ0ID0gJzUwJSc7XG4gICAgICBzdHlsZXMudHJhbnNmb3JtID0gJ3RyYW5zbGF0ZVgoLTUwJSknO1xuICAgICAgYnJlYWs7XG4gICAgY2FzZSAnbWVkaXVtJzpcbiAgICAgIHN0eWxlcy5tYXJnaW4gPSAnMHB4JztcbiAgICAgIGJyZWFrO1xuICAgIGNhc2UgJ2dob3N0JzpcbiAgICAgIHN0eWxlcy5iYWNrZ3JvdW5kQ29sb3IgPSAndHJhbnNwYXJlbnQnO1xuICAgICAgc3R5bGVzLmJvcmRlciA9ICcxcHggc29saWQgI0QxRDZEQic7XG4gICAgICBzdHlsZXMuY29sb3IgPSAnIzQ0NDQ0NCc7XG4gICAgICBicmVhaztcbiAgICBjYXNlICdtYXN0aGVhZCc6XG4gICAgICBzdHlsZXMubWFyZ2luID0gJzAgYXV0byc7XG4gICAgICBzdHlsZXMuZGlzcGxheSA9ICdub25lJztcbiAgICAgIHN0eWxlcy5wYWRkaW5nID0gJzAnO1xuICAgICAgc3R5bGVzLmJvcmRlclJhZGl1cyA9ICcwJztcbiAgICAgIGJyZWFrO1xuICB9XG4gIHJldHVybiBzdHlsZXM7XG59O1xuXG5jb25zdCBXcmFwcGVyID0gc3R5bGVkLmRpdjxXcmFwcGVyUHJvcHM+YFxuICBiYWNrZ3JvdW5kOiAkeyhwcm9wcykgPT4gU3R5bGVCeVR5cGUocHJvcHMuYm94VHlwZSkuYmFja2dyb3VuZENvbG9yfTtcbiAgY29sb3I6ICR7KHByb3BzKSA9PiBTdHlsZUJ5VHlwZShwcm9wcy5ib3hUeXBlKS5jb2xvcn07XG4gIGZvbnQtc2l6ZTogMThweDtcbiAgbGluZS1oZWlnaHQ6IDMycHg7XG4gIGZvbnQtZmFtaWx5OiAke2ZvbnRzLnNhbnN9O1xuICBkaXNwbGF5OiBmbGV4O1xuICBwYWRkaW5nOiAke3NwYWNpbmcuc21hbGx9O1xuICBwb3NpdGlvbjogJHsocHJvcHMpID0+IFN0eWxlQnlUeXBlKHByb3BzLmJveFR5cGUpLnBvc2l0aW9ufTtcbiAgYm9yZGVyOiAkeyhwcm9wcykgPT4gU3R5bGVCeVR5cGUocHJvcHMuYm94VHlwZSkuYm9yZGVyfTtcbiAgYm9yZGVyLXJhZGl1czogJHsocHJvcHMpID0+IFN0eWxlQnlUeXBlKHByb3BzLmJveFR5cGUpLmJvcmRlclJhZGl1c307XG4gIHRyYW5zZm9ybTogJHsocHJvcHMpID0+IFN0eWxlQnlUeXBlKHByb3BzLmJveFR5cGUpLnRyYW5zZm9ybX07XG4gIGxlZnQ6ICR7KHByb3BzKSA9PiBTdHlsZUJ5VHlwZShwcm9wcy5ib3hUeXBlKS5sZWZ0fTtcbiAgei1pbmRleDogMTA7XG4gIHdpZHRoOiAkeyhwcm9wcykgPT4gU3R5bGVCeVR5cGUocHJvcHMuYm94VHlwZSkud2lkdGh9O1xuYDtcblxuY29uc3QgSW5mb1dyYXBwZXIgPSBzdHlsZWQuZGl2PFdyYXBwZXJQcm9wcz5gXG4gIG1hcmdpbjogJHsocHJvcHMpID0+IFN0eWxlQnlUeXBlKHByb3BzLmJveFR5cGUpLm1hcmdpbn07XG4gIHBhZGRpbmc6ICR7KHByb3BzKSA9PiBTdHlsZUJ5VHlwZShwcm9wcy5ib3hUeXBlKS5wYWRkaW5nfTtcbiAgZGlzcGxheTogZmxleDtcbiAgJHttcS5yYW5nZSh7IHVudGlsOiBicmVha3BvaW50cy50YWJsZXRXaWRlIH0pfSB7XG4gICAgcGFkZGluZzogMCA5MHB4IDAgMDtcbiAgfVxuICAke21xLnJhbmdlKHsgdW50aWw6IGJyZWFrcG9pbnRzLm1vYmlsZVdpZGUgfSl9IHtcbiAgICBwYWRkaW5nOiAwIDVweCAwIDA7XG4gICAgZm9udC1zaXplOiAxNnB4O1xuICB9XG5gO1xuY29uc3QgVGV4dFdyYXBwZXIgPSBzdHlsZWQuZGl2PFdyYXBwZXJQcm9wcz5gXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGZsZXgtd3JhcDogd3JhcDtcbiAgJHttcS5yYW5nZSh7IHVudGlsOiBicmVha3BvaW50cy50YWJsZXRXaWRlIH0pfSB7XG4gICAgbGluZS1oZWlnaHQ6IDI0cHg7XG4gICAgZm9udC1zaXplOiAxNnB4O1xuICB9XG5gO1xuXG5jb25zdCBJY29uV3JhcHBlciA9IHN0eWxlZC5kaXY8V3JhcHBlclByb3BzPmBcbiAgcGFkZGluZy1yaWdodDogJHtzcGFjaW5nLnNtYWxsfTtcbiAgZGlzcGxheTogJHsocHJvcHMpID0+IFN0eWxlQnlUeXBlKHByb3BzLmJveFR5cGUpLmRpc3BsYXl9O1xuICBhbGlnbi1pdGVtczogZmxleC1zdGFydDtcbiAgJHttcS5yYW5nZSh7IGZyb206IGJyZWFrcG9pbnRzLnRhYmxldFdpZGUgfSl9IHtcbiAgICBwYWRkaW5nLXRvcDogNHB4O1xuICB9XG5gO1xuXG5jb25zdCBMaW5rV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIGRpc3BsYXk6IGJsb2NrO1xuICB3aWR0aDogMTAwJTtcbiAgYmFja2dyb3VuZC1jb2xvcjogI2Y5ZjRjODtcbiAgcGFkZGluZy1ib3R0b206IDIwcHg7XG4gIG1hcmdpbi10b3A6IC0ycHg7XG4gIHBhZGRpbmctbGVmdDogNThweDtcbiAgYm9yZGVyLXJhZGl1czogMHB4IDBweCA1cHggNXB4O1xuICAke21xLnJhbmdlKHsgdW50aWw6IGJyZWFrcG9pbnRzLm1vYmlsZVdpZGUgfSl9IHtcbiAgICBwYWRkaW5nLWxlZnQ6IDQ1cHg7XG4gIH1cbmA7XG5jb25zdCBMaW5rID0gc3R5bGVkLmFgXG4gIGNvbG9yOiAjMjA1ODhmO1xuICBmb250LXNpemU6IDE2cHg7XG4gIHBhZGRpbmctYm90dG9tOiAxcHg7XG4gIG1hcmdpbjogMHB4IDQwcHggMXB4IDJweDtcbiAgZm9udC1mYW1pbHk6ICR7Zm9udHMuc2Fuc307XG4gICR7bXEucmFuZ2UoeyB1bnRpbDogYnJlYWtwb2ludHMubW9iaWxlV2lkZSB9KX0ge1xuICAgIG1hcmdpbjogMHB4IDE1cHggMXB4IDVweDtcbiAgICBib3gtc2hhZG93OiBub25lO1xuICB9XG5gO1xuY29uc3QgQ2xvc2VCdXR0b25XcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgcG9zaXRpb246IGFic29sdXRlO1xuICB0b3A6IDEwcHg7XG4gIHJpZ2h0OiAxcHg7XG5gO1xuXG50eXBlIExpbmtQcm9wcyA9IHtcbiAgaHJlZj86IHN0cmluZztcbiAgdGV4dD86IHN0cmluZztcbn07XG50eXBlIFByb3BzID0ge1xuICB0eXBlPzogV3JhcHBlclByb3BzWydib3hUeXBlJ107XG4gIHN0aWNreT86IGJvb2xlYW47XG4gIGNoaWxkcmVuPzogc3RyaW5nO1xuICBsaW5rcz86IExpbmtQcm9wc1tdO1xuICBzaG93Q2xvc2VCdXR0b24/OiBib29sZWFuO1xufTtcblxuZXhwb3J0IGNvbnN0IE1lc3NhZ2VCb3ggPSAoeyB0eXBlLCBzdGlja3kgPSBmYWxzZSwgY2hpbGRyZW4sIGxpbmtzLCB0LCBzaG93Q2xvc2VCdXR0b24gfTogUHJvcHMgJiBXaXRoVHJhbnNsYXRpb24pID0+IHtcbiAgY29uc3QgW2hpZGVNZXNzYWdlQm94LCBzZXRIaWRlTWVzc2FnZUJveF0gPSB1c2VTdGF0ZShmYWxzZSk7XG4gIGNvbnN0IG9uQ2xvc2VNZXNzYWdlQm94ID0gKCkgPT4ge1xuICAgIHNldEhpZGVNZXNzYWdlQm94KHRydWUpO1xuICB9O1xuICBjb25zdCBJY29uID0gdHlwZSA9PT0gJ2dob3N0JyA/IEh1bWFuTWFsZUJvYXJkIDogSW5mb3JtYXRpb25PdXRsaW5lO1xuICByZXR1cm4gKFxuICAgIC8vU3RpY2t5U3R5bGUgdG9wOjg0IG1ha2VzIHN1cmUgdGhhdCB0aGUgbWVzc2FnZWJveCBzaXRzIGJlbmVhdGggdGhlIG1hc3RoZWFkIChoZWFkZXIgKSBhbmQgdGhlIHRvcE9mZnNldHQgc2V0cyBpdCBzbyB0aGF0IGl0IGFwcGxpZXMgd2hlbiByZWFjaGluZyB0aGUgdG9wIG9mIHRoZSBtZXNzYWdlYm94XG4gICAgPFN0aWNreSBkaXNhYmxlZD17IXN0aWNreX0gc3RpY2t5U3R5bGU9e3sgekluZGV4OiA5OTk4LCB0b3A6IDg0IH19IHRvcE9mZnNldD17LTg0fT5cbiAgICAgIDxXcmFwcGVyIGJveFR5cGU9e3R5cGV9IHN0eWxlPXt7IGRpc3BsYXk6IGhpZGVNZXNzYWdlQm94ID8gJ25vbmUnIDogJ2ZsZXgnIH19PlxuICAgICAgICA8SW5mb1dyYXBwZXIgYm94VHlwZT17dHlwZX0+XG4gICAgICAgICAgPEljb25XcmFwcGVyIGJveFR5cGU9e3R5cGV9PlxuICAgICAgICAgICAgPEljb24gc3R5bGU9e3sgd2lkdGg6ICcyNHB4JywgaGVpZ2h0OiAnMjRweCcgfX0gLz5cbiAgICAgICAgICA8L0ljb25XcmFwcGVyPlxuICAgICAgICAgIDxUZXh0V3JhcHBlcj57Y2hpbGRyZW59PC9UZXh0V3JhcHBlcj5cbiAgICAgICAgPC9JbmZvV3JhcHBlcj5cbiAgICAgICAge3Nob3dDbG9zZUJ1dHRvbiAmJiAoXG4gICAgICAgICAgPENsb3NlQnV0dG9uV3JhcHBlcj5cbiAgICAgICAgICAgIDxDbG9zZUJ1dHRvbiBvbkNsaWNrPXtvbkNsb3NlTWVzc2FnZUJveH0gLz5cbiAgICAgICAgICA8L0Nsb3NlQnV0dG9uV3JhcHBlcj5cbiAgICAgICAgKX1cbiAgICAgIDwvV3JhcHBlcj5cblxuICAgICAge2xpbmtzICYmIChcbiAgICAgICAgLy9sb29wcyB0aHJvdWdoIHRoZSBsaW5rcyBwYXNzZWQgaW4gYXMgcHJvcGVydGllcyBpZiB0aGVyZSBhcmUgYW55IGFuZCBjcmVhdGVzIGEgd29ya2luZyBsaW5rIGZvciBlYWNoIG9mIHRoZW1cbiAgICAgICAgPExpbmtXcmFwcGVyIHN0eWxlPXt7IGRpc3BsYXk6IGhpZGVNZXNzYWdlQm94ID8gJ25vbmUnIDogJ2ZsZXgnIH19PlxuICAgICAgICAgIHtsaW5rcy5tYXAoKHgpID0+IChcbiAgICAgICAgICAgIDxMaW5rIGhyZWY9e3guaHJlZn0+e3gudGV4dH08L0xpbms+XG4gICAgICAgICAgKSl9XG4gICAgICAgIDwvTGlua1dyYXBwZXI+XG4gICAgICApfVxuICAgIDwvU3RpY2t5PlxuICApO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgd2l0aFRyYW5zbGF0aW9uKCkoTWVzc2FnZUJveCk7XG4iXX0= */"));
162
+ }), "{margin:0px 15px 1px 5px;box-shadow:none;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["MessageBox.tsx"],"names":[],"mappings":"AAsIqB","file":"MessageBox.tsx","sourcesContent":["/**\n * Copyright (c) 2022-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, { HTMLAttributes, useState } from 'react';\nimport styled from '@emotion/styled';\nimport Sticky from 'react-sticky-el';\nimport { breakpoints, fonts, mq, spacing } from '@ndla/core';\nimport { InformationOutline, HumanMaleBoard } from '@ndla/icons/common';\nimport { WithTranslation, withTranslation } from 'react-i18next';\n\n// @ts-ignore\nimport { Remarkable } from 'remarkable';\nimport { CloseButton } from '../CloseButton';\n\nexport enum MessageBoxType {\n  ghost = 'ghost',\n  fullpage = 'fullpage',\n  medium = 'medium',\n  masthead = 'masthead',\n}\ntype WrapperProps = {\n  boxType?: MessageBoxType;\n};\n\nconst StyleByType = (type: WrapperProps['boxType']) => {\n  const styles: HTMLAttributes<HTMLElement>['style'] = {\n    margin: '1px',\n    color: '#444444',\n    backgroundColor: '#f9f4c8',\n    border: 'none',\n    display: 'flex',\n    padding: '10px',\n    width: 'auto',\n    borderRadius: '5px',\n    position: 'relative',\n    transform: 'auto',\n    left: 'auto',\n  }; //Different CSS properties for different types of message-boxes\n  switch (type) {\n    case 'fullpage':\n      styles.margin = '0 auto';\n      styles.display = 'none';\n      styles.width = '100vw';\n      styles.position = 'relative';\n      styles.left = '50%';\n      styles.padding = '0';\n      styles.transform = 'translateX(-50%)';\n      break;\n    case 'medium':\n      styles.margin = '0px';\n      break;\n    case 'ghost':\n      styles.backgroundColor = 'transparent';\n      styles.border = '1px solid #D1D6DB';\n      styles.color = '#444444';\n      break;\n    case 'masthead':\n      styles.margin = '0 auto';\n      styles.display = 'none';\n      styles.padding = '0';\n      styles.borderRadius = '0';\n      break;\n  }\n  return styles;\n};\n\nconst Wrapper = styled.div<WrapperProps>`\n  background: ${(props) => StyleByType(props.boxType).backgroundColor};\n  color: ${(props) => StyleByType(props.boxType).color};\n  font-size: 18px;\n  line-height: 32px;\n  font-family: ${fonts.sans};\n  display: flex;\n  padding: ${spacing.small};\n  position: ${(props) => StyleByType(props.boxType).position};\n  border: ${(props) => StyleByType(props.boxType).border};\n  border-radius: ${(props) => StyleByType(props.boxType).borderRadius};\n  transform: ${(props) => StyleByType(props.boxType).transform};\n  left: ${(props) => StyleByType(props.boxType).left};\n  z-index: 10;\n  width: ${(props) => StyleByType(props.boxType).width};\n`;\n\nconst InfoWrapper = styled.div<WrapperProps>`\n  margin: ${(props) => StyleByType(props.boxType).margin};\n  padding: ${(props) => StyleByType(props.boxType).padding};\n  display: flex;\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    padding: 0 90px 0 0;\n  }\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    padding: 0 5px 0 0;\n    font-size: 16px;\n  }\n`;\nconst TextWrapper = styled.div<WrapperProps>`\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    line-height: 24px;\n    font-size: 16px;\n  }\n  & p {\n    margin: 0;\n  }\n`;\n\nconst IconWrapper = styled.div<WrapperProps>`\n  padding-right: ${spacing.small};\n  display: ${(props) => StyleByType(props.boxType).display};\n  align-items: flex-start;\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding-top: 4px;\n  }\n`;\n\nconst LinkWrapper = styled.div`\n  display: block;\n  width: 100%;\n  background-color: #f9f4c8;\n  padding-bottom: 20px;\n  margin-top: -2px;\n  padding-left: 58px;\n  border-radius: 0px 0px 5px 5px;\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    padding-left: 45px;\n  }\n`;\nconst Link = styled.a`\n  color: #20588f;\n  font-size: 16px;\n  padding-bottom: 1px;\n  margin: 0px 40px 1px 2px;\n  font-family: ${fonts.sans};\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    margin: 0px 15px 1px 5px;\n    box-shadow: none;\n  }\n`;\nconst CloseButtonWrapper = styled.div`\n  position: absolute;\n  top: 10px;\n  right: 1px;\n`;\n\ntype LinkProps = {\n  href?: string;\n  text?: string;\n};\ntype Props = {\n  type?: WrapperProps['boxType'];\n  sticky?: boolean;\n  children?: string;\n  links?: LinkProps[];\n  showCloseButton?: boolean;\n  onClose?: () => void;\n};\n\nconst markdown = new Remarkable({ breaks: true });\nmarkdown.inline.ruler.enable(['sub', 'sup']);\nmarkdown.block.ruler.disable(['list', 'table']);\n\nexport const MessageBox = ({\n  type,\n  sticky = false,\n  children = '',\n  links,\n  showCloseButton,\n  onClose,\n}: Props & WithTranslation) => {\n  const [hideMessageBox, setHideMessageBox] = useState(false);\n  const onCloseMessageBox = () => {\n    setHideMessageBox(true);\n    onClose?.();\n  };\n  const Icon = type === 'ghost' ? HumanMaleBoard : InformationOutline;\n  return (\n    //StickyStyle top:84 makes sure that the messagebox sits beneath the masthead (header ) and the topOffsett sets it so that it applies when reaching the top of the messagebox\n    <Sticky disabled={!sticky} stickyStyle={{ zIndex: 9998, top: 84 }} topOffset={-84}>\n      <Wrapper boxType={type} style={{ display: hideMessageBox ? 'none' : 'flex' }}>\n        <InfoWrapper boxType={type}>\n          <IconWrapper boxType={type}>\n            <Icon style={{ width: '24px', height: '24px' }} />\n          </IconWrapper>\n          <TextWrapper dangerouslySetInnerHTML={{ __html: markdown.render(children) }}></TextWrapper>\n        </InfoWrapper>\n        {showCloseButton && (\n          <CloseButtonWrapper>\n            <CloseButton onClick={onCloseMessageBox} />\n          </CloseButtonWrapper>\n        )}\n      </Wrapper>\n\n      {links && (\n        //loops through the links passed in as properties if there are any and creates a working link for each of them\n        <LinkWrapper style={{ display: hideMessageBox ? 'none' : 'flex' }}>\n          {links.map((x) => (\n            <Link href={x.href}>{x.text}</Link>\n          ))}\n        </LinkWrapper>\n      )}\n    </Sticky>\n  );\n};\n\nexport default withTranslation()(MessageBox);\n"]} */"));
160
163
  var CloseButtonWrapper = (0, _styledBase["default"])("div", {
161
164
  target: "e1ckcvyi6",
162
165
  label: "CloseButtonWrapper"
@@ -166,18 +169,24 @@ var CloseButtonWrapper = (0, _styledBase["default"])("div", {
166
169
  } : {
167
170
  name: "16ubfqw",
168
171
  styles: "position:absolute;top:10px;right:1px;",
169
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIk1lc3NhZ2VCb3gudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTBJcUMiLCJmaWxlIjoiTWVzc2FnZUJveC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAyMi1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCBSZWFjdCwgeyBIVE1MQXR0cmlidXRlcywgdXNlU3RhdGUgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgU3RpY2t5IGZyb20gJ3JlYWN0LXN0aWNreS1lbCc7XG5pbXBvcnQgeyBicmVha3BvaW50cywgZm9udHMsIG1xLCBzcGFjaW5nIH0gZnJvbSAnQG5kbGEvY29yZSc7XG5pbXBvcnQgeyBJbmZvcm1hdGlvbk91dGxpbmUsIEh1bWFuTWFsZUJvYXJkIH0gZnJvbSAnQG5kbGEvaWNvbnMvY29tbW9uJztcbmltcG9ydCB7IFdpdGhUcmFuc2xhdGlvbiwgd2l0aFRyYW5zbGF0aW9uIH0gZnJvbSAncmVhY3QtaTE4bmV4dCc7XG5pbXBvcnQgeyBDbG9zZUJ1dHRvbiB9IGZyb20gJy4uL0Nsb3NlQnV0dG9uJztcblxuZXhwb3J0IGVudW0gTWVzc2FnZUJveFR5cGUge1xuICBnaG9zdCA9ICdnaG9zdCcsXG4gIGZ1bGxwYWdlID0gJ2Z1bGxwYWdlJyxcbiAgbWVkaXVtID0gJ21lZGl1bScsXG4gIG1hc3RoZWFkID0gJ21hc3RoZWFkJyxcbn1cbnR5cGUgV3JhcHBlclByb3BzID0ge1xuICBib3hUeXBlPzogTWVzc2FnZUJveFR5cGU7XG59O1xuXG5jb25zdCBTdHlsZUJ5VHlwZSA9ICh0eXBlOiBXcmFwcGVyUHJvcHNbJ2JveFR5cGUnXSkgPT4ge1xuICBjb25zdCBzdHlsZXM6IEhUTUxBdHRyaWJ1dGVzPEhUTUxFbGVtZW50Plsnc3R5bGUnXSA9IHtcbiAgICBtYXJnaW46ICcxcHgnLFxuICAgIGNvbG9yOiAnIzQ0NDQ0NCcsXG4gICAgYmFja2dyb3VuZENvbG9yOiAnI2Y5ZjRjOCcsXG4gICAgYm9yZGVyOiAnbm9uZScsXG4gICAgZGlzcGxheTogJ2ZsZXgnLFxuICAgIHBhZGRpbmc6ICcxMHB4JyxcbiAgICB3aWR0aDogJ2F1dG8nLFxuICAgIGJvcmRlclJhZGl1czogJzVweCcsXG4gICAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gICAgdHJhbnNmb3JtOiAnYXV0bycsXG4gICAgbGVmdDogJ2F1dG8nLFxuICB9OyAvL0RpZmZlcmVudCBDU1MgcHJvcGVydGllcyBmb3IgZGlmZmVyZW50IHR5cGVzIG9mIG1lc3NhZ2UtYm94ZXNcbiAgc3dpdGNoICh0eXBlKSB7XG4gICAgY2FzZSAnZnVsbHBhZ2UnOlxuICAgICAgc3R5bGVzLm1hcmdpbiA9ICcwIGF1dG8nO1xuICAgICAgc3R5bGVzLmRpc3BsYXkgPSAnbm9uZSc7XG4gICAgICBzdHlsZXMud2lkdGggPSAnMTAwdncnO1xuICAgICAgc3R5bGVzLnBvc2l0aW9uID0gJ3JlbGF0aXZlJztcbiAgICAgIHN0eWxlcy5sZWZ0ID0gJzUwJSc7XG4gICAgICBzdHlsZXMudHJhbnNmb3JtID0gJ3RyYW5zbGF0ZVgoLTUwJSknO1xuICAgICAgYnJlYWs7XG4gICAgY2FzZSAnbWVkaXVtJzpcbiAgICAgIHN0eWxlcy5tYXJnaW4gPSAnMHB4JztcbiAgICAgIGJyZWFrO1xuICAgIGNhc2UgJ2dob3N0JzpcbiAgICAgIHN0eWxlcy5iYWNrZ3JvdW5kQ29sb3IgPSAndHJhbnNwYXJlbnQnO1xuICAgICAgc3R5bGVzLmJvcmRlciA9ICcxcHggc29saWQgI0QxRDZEQic7XG4gICAgICBzdHlsZXMuY29sb3IgPSAnIzQ0NDQ0NCc7XG4gICAgICBicmVhaztcbiAgICBjYXNlICdtYXN0aGVhZCc6XG4gICAgICBzdHlsZXMubWFyZ2luID0gJzAgYXV0byc7XG4gICAgICBzdHlsZXMuZGlzcGxheSA9ICdub25lJztcbiAgICAgIHN0eWxlcy5wYWRkaW5nID0gJzAnO1xuICAgICAgc3R5bGVzLmJvcmRlclJhZGl1cyA9ICcwJztcbiAgICAgIGJyZWFrO1xuICB9XG4gIHJldHVybiBzdHlsZXM7XG59O1xuXG5jb25zdCBXcmFwcGVyID0gc3R5bGVkLmRpdjxXcmFwcGVyUHJvcHM+YFxuICBiYWNrZ3JvdW5kOiAkeyhwcm9wcykgPT4gU3R5bGVCeVR5cGUocHJvcHMuYm94VHlwZSkuYmFja2dyb3VuZENvbG9yfTtcbiAgY29sb3I6ICR7KHByb3BzKSA9PiBTdHlsZUJ5VHlwZShwcm9wcy5ib3hUeXBlKS5jb2xvcn07XG4gIGZvbnQtc2l6ZTogMThweDtcbiAgbGluZS1oZWlnaHQ6IDMycHg7XG4gIGZvbnQtZmFtaWx5OiAke2ZvbnRzLnNhbnN9O1xuICBkaXNwbGF5OiBmbGV4O1xuICBwYWRkaW5nOiAke3NwYWNpbmcuc21hbGx9O1xuICBwb3NpdGlvbjogJHsocHJvcHMpID0+IFN0eWxlQnlUeXBlKHByb3BzLmJveFR5cGUpLnBvc2l0aW9ufTtcbiAgYm9yZGVyOiAkeyhwcm9wcykgPT4gU3R5bGVCeVR5cGUocHJvcHMuYm94VHlwZSkuYm9yZGVyfTtcbiAgYm9yZGVyLXJhZGl1czogJHsocHJvcHMpID0+IFN0eWxlQnlUeXBlKHByb3BzLmJveFR5cGUpLmJvcmRlclJhZGl1c307XG4gIHRyYW5zZm9ybTogJHsocHJvcHMpID0+IFN0eWxlQnlUeXBlKHByb3BzLmJveFR5cGUpLnRyYW5zZm9ybX07XG4gIGxlZnQ6ICR7KHByb3BzKSA9PiBTdHlsZUJ5VHlwZShwcm9wcy5ib3hUeXBlKS5sZWZ0fTtcbiAgei1pbmRleDogMTA7XG4gIHdpZHRoOiAkeyhwcm9wcykgPT4gU3R5bGVCeVR5cGUocHJvcHMuYm94VHlwZSkud2lkdGh9O1xuYDtcblxuY29uc3QgSW5mb1dyYXBwZXIgPSBzdHlsZWQuZGl2PFdyYXBwZXJQcm9wcz5gXG4gIG1hcmdpbjogJHsocHJvcHMpID0+IFN0eWxlQnlUeXBlKHByb3BzLmJveFR5cGUpLm1hcmdpbn07XG4gIHBhZGRpbmc6ICR7KHByb3BzKSA9PiBTdHlsZUJ5VHlwZShwcm9wcy5ib3hUeXBlKS5wYWRkaW5nfTtcbiAgZGlzcGxheTogZmxleDtcbiAgJHttcS5yYW5nZSh7IHVudGlsOiBicmVha3BvaW50cy50YWJsZXRXaWRlIH0pfSB7XG4gICAgcGFkZGluZzogMCA5MHB4IDAgMDtcbiAgfVxuICAke21xLnJhbmdlKHsgdW50aWw6IGJyZWFrcG9pbnRzLm1vYmlsZVdpZGUgfSl9IHtcbiAgICBwYWRkaW5nOiAwIDVweCAwIDA7XG4gICAgZm9udC1zaXplOiAxNnB4O1xuICB9XG5gO1xuY29uc3QgVGV4dFdyYXBwZXIgPSBzdHlsZWQuZGl2PFdyYXBwZXJQcm9wcz5gXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGZsZXgtd3JhcDogd3JhcDtcbiAgJHttcS5yYW5nZSh7IHVudGlsOiBicmVha3BvaW50cy50YWJsZXRXaWRlIH0pfSB7XG4gICAgbGluZS1oZWlnaHQ6IDI0cHg7XG4gICAgZm9udC1zaXplOiAxNnB4O1xuICB9XG5gO1xuXG5jb25zdCBJY29uV3JhcHBlciA9IHN0eWxlZC5kaXY8V3JhcHBlclByb3BzPmBcbiAgcGFkZGluZy1yaWdodDogJHtzcGFjaW5nLnNtYWxsfTtcbiAgZGlzcGxheTogJHsocHJvcHMpID0+IFN0eWxlQnlUeXBlKHByb3BzLmJveFR5cGUpLmRpc3BsYXl9O1xuICBhbGlnbi1pdGVtczogZmxleC1zdGFydDtcbiAgJHttcS5yYW5nZSh7IGZyb206IGJyZWFrcG9pbnRzLnRhYmxldFdpZGUgfSl9IHtcbiAgICBwYWRkaW5nLXRvcDogNHB4O1xuICB9XG5gO1xuXG5jb25zdCBMaW5rV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIGRpc3BsYXk6IGJsb2NrO1xuICB3aWR0aDogMTAwJTtcbiAgYmFja2dyb3VuZC1jb2xvcjogI2Y5ZjRjODtcbiAgcGFkZGluZy1ib3R0b206IDIwcHg7XG4gIG1hcmdpbi10b3A6IC0ycHg7XG4gIHBhZGRpbmctbGVmdDogNThweDtcbiAgYm9yZGVyLXJhZGl1czogMHB4IDBweCA1cHggNXB4O1xuICAke21xLnJhbmdlKHsgdW50aWw6IGJyZWFrcG9pbnRzLm1vYmlsZVdpZGUgfSl9IHtcbiAgICBwYWRkaW5nLWxlZnQ6IDQ1cHg7XG4gIH1cbmA7XG5jb25zdCBMaW5rID0gc3R5bGVkLmFgXG4gIGNvbG9yOiAjMjA1ODhmO1xuICBmb250LXNpemU6IDE2cHg7XG4gIHBhZGRpbmctYm90dG9tOiAxcHg7XG4gIG1hcmdpbjogMHB4IDQwcHggMXB4IDJweDtcbiAgZm9udC1mYW1pbHk6ICR7Zm9udHMuc2Fuc307XG4gICR7bXEucmFuZ2UoeyB1bnRpbDogYnJlYWtwb2ludHMubW9iaWxlV2lkZSB9KX0ge1xuICAgIG1hcmdpbjogMHB4IDE1cHggMXB4IDVweDtcbiAgICBib3gtc2hhZG93OiBub25lO1xuICB9XG5gO1xuY29uc3QgQ2xvc2VCdXR0b25XcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgcG9zaXRpb246IGFic29sdXRlO1xuICB0b3A6IDEwcHg7XG4gIHJpZ2h0OiAxcHg7XG5gO1xuXG50eXBlIExpbmtQcm9wcyA9IHtcbiAgaHJlZj86IHN0cmluZztcbiAgdGV4dD86IHN0cmluZztcbn07XG50eXBlIFByb3BzID0ge1xuICB0eXBlPzogV3JhcHBlclByb3BzWydib3hUeXBlJ107XG4gIHN0aWNreT86IGJvb2xlYW47XG4gIGNoaWxkcmVuPzogc3RyaW5nO1xuICBsaW5rcz86IExpbmtQcm9wc1tdO1xuICBzaG93Q2xvc2VCdXR0b24/OiBib29sZWFuO1xufTtcblxuZXhwb3J0IGNvbnN0IE1lc3NhZ2VCb3ggPSAoeyB0eXBlLCBzdGlja3kgPSBmYWxzZSwgY2hpbGRyZW4sIGxpbmtzLCB0LCBzaG93Q2xvc2VCdXR0b24gfTogUHJvcHMgJiBXaXRoVHJhbnNsYXRpb24pID0+IHtcbiAgY29uc3QgW2hpZGVNZXNzYWdlQm94LCBzZXRIaWRlTWVzc2FnZUJveF0gPSB1c2VTdGF0ZShmYWxzZSk7XG4gIGNvbnN0IG9uQ2xvc2VNZXNzYWdlQm94ID0gKCkgPT4ge1xuICAgIHNldEhpZGVNZXNzYWdlQm94KHRydWUpO1xuICB9O1xuICBjb25zdCBJY29uID0gdHlwZSA9PT0gJ2dob3N0JyA/IEh1bWFuTWFsZUJvYXJkIDogSW5mb3JtYXRpb25PdXRsaW5lO1xuICByZXR1cm4gKFxuICAgIC8vU3RpY2t5U3R5bGUgdG9wOjg0IG1ha2VzIHN1cmUgdGhhdCB0aGUgbWVzc2FnZWJveCBzaXRzIGJlbmVhdGggdGhlIG1hc3RoZWFkIChoZWFkZXIgKSBhbmQgdGhlIHRvcE9mZnNldHQgc2V0cyBpdCBzbyB0aGF0IGl0IGFwcGxpZXMgd2hlbiByZWFjaGluZyB0aGUgdG9wIG9mIHRoZSBtZXNzYWdlYm94XG4gICAgPFN0aWNreSBkaXNhYmxlZD17IXN0aWNreX0gc3RpY2t5U3R5bGU9e3sgekluZGV4OiA5OTk4LCB0b3A6IDg0IH19IHRvcE9mZnNldD17LTg0fT5cbiAgICAgIDxXcmFwcGVyIGJveFR5cGU9e3R5cGV9IHN0eWxlPXt7IGRpc3BsYXk6IGhpZGVNZXNzYWdlQm94ID8gJ25vbmUnIDogJ2ZsZXgnIH19PlxuICAgICAgICA8SW5mb1dyYXBwZXIgYm94VHlwZT17dHlwZX0+XG4gICAgICAgICAgPEljb25XcmFwcGVyIGJveFR5cGU9e3R5cGV9PlxuICAgICAgICAgICAgPEljb24gc3R5bGU9e3sgd2lkdGg6ICcyNHB4JywgaGVpZ2h0OiAnMjRweCcgfX0gLz5cbiAgICAgICAgICA8L0ljb25XcmFwcGVyPlxuICAgICAgICAgIDxUZXh0V3JhcHBlcj57Y2hpbGRyZW59PC9UZXh0V3JhcHBlcj5cbiAgICAgICAgPC9JbmZvV3JhcHBlcj5cbiAgICAgICAge3Nob3dDbG9zZUJ1dHRvbiAmJiAoXG4gICAgICAgICAgPENsb3NlQnV0dG9uV3JhcHBlcj5cbiAgICAgICAgICAgIDxDbG9zZUJ1dHRvbiBvbkNsaWNrPXtvbkNsb3NlTWVzc2FnZUJveH0gLz5cbiAgICAgICAgICA8L0Nsb3NlQnV0dG9uV3JhcHBlcj5cbiAgICAgICAgKX1cbiAgICAgIDwvV3JhcHBlcj5cblxuICAgICAge2xpbmtzICYmIChcbiAgICAgICAgLy9sb29wcyB0aHJvdWdoIHRoZSBsaW5rcyBwYXNzZWQgaW4gYXMgcHJvcGVydGllcyBpZiB0aGVyZSBhcmUgYW55IGFuZCBjcmVhdGVzIGEgd29ya2luZyBsaW5rIGZvciBlYWNoIG9mIHRoZW1cbiAgICAgICAgPExpbmtXcmFwcGVyIHN0eWxlPXt7IGRpc3BsYXk6IGhpZGVNZXNzYWdlQm94ID8gJ25vbmUnIDogJ2ZsZXgnIH19PlxuICAgICAgICAgIHtsaW5rcy5tYXAoKHgpID0+IChcbiAgICAgICAgICAgIDxMaW5rIGhyZWY9e3guaHJlZn0+e3gudGV4dH08L0xpbms+XG4gICAgICAgICAgKSl9XG4gICAgICAgIDwvTGlua1dyYXBwZXI+XG4gICAgICApfVxuICAgIDwvU3RpY2t5PlxuICApO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgd2l0aFRyYW5zbGF0aW9uKCkoTWVzc2FnZUJveCk7XG4iXX0= */",
172
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["MessageBox.tsx"],"names":[],"mappings":"AAiJqC","file":"MessageBox.tsx","sourcesContent":["/**\n * Copyright (c) 2022-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, { HTMLAttributes, useState } from 'react';\nimport styled from '@emotion/styled';\nimport Sticky from 'react-sticky-el';\nimport { breakpoints, fonts, mq, spacing } from '@ndla/core';\nimport { InformationOutline, HumanMaleBoard } from '@ndla/icons/common';\nimport { WithTranslation, withTranslation } from 'react-i18next';\n\n// @ts-ignore\nimport { Remarkable } from 'remarkable';\nimport { CloseButton } from '../CloseButton';\n\nexport enum MessageBoxType {\n  ghost = 'ghost',\n  fullpage = 'fullpage',\n  medium = 'medium',\n  masthead = 'masthead',\n}\ntype WrapperProps = {\n  boxType?: MessageBoxType;\n};\n\nconst StyleByType = (type: WrapperProps['boxType']) => {\n  const styles: HTMLAttributes<HTMLElement>['style'] = {\n    margin: '1px',\n    color: '#444444',\n    backgroundColor: '#f9f4c8',\n    border: 'none',\n    display: 'flex',\n    padding: '10px',\n    width: 'auto',\n    borderRadius: '5px',\n    position: 'relative',\n    transform: 'auto',\n    left: 'auto',\n  }; //Different CSS properties for different types of message-boxes\n  switch (type) {\n    case 'fullpage':\n      styles.margin = '0 auto';\n      styles.display = 'none';\n      styles.width = '100vw';\n      styles.position = 'relative';\n      styles.left = '50%';\n      styles.padding = '0';\n      styles.transform = 'translateX(-50%)';\n      break;\n    case 'medium':\n      styles.margin = '0px';\n      break;\n    case 'ghost':\n      styles.backgroundColor = 'transparent';\n      styles.border = '1px solid #D1D6DB';\n      styles.color = '#444444';\n      break;\n    case 'masthead':\n      styles.margin = '0 auto';\n      styles.display = 'none';\n      styles.padding = '0';\n      styles.borderRadius = '0';\n      break;\n  }\n  return styles;\n};\n\nconst Wrapper = styled.div<WrapperProps>`\n  background: ${(props) => StyleByType(props.boxType).backgroundColor};\n  color: ${(props) => StyleByType(props.boxType).color};\n  font-size: 18px;\n  line-height: 32px;\n  font-family: ${fonts.sans};\n  display: flex;\n  padding: ${spacing.small};\n  position: ${(props) => StyleByType(props.boxType).position};\n  border: ${(props) => StyleByType(props.boxType).border};\n  border-radius: ${(props) => StyleByType(props.boxType).borderRadius};\n  transform: ${(props) => StyleByType(props.boxType).transform};\n  left: ${(props) => StyleByType(props.boxType).left};\n  z-index: 10;\n  width: ${(props) => StyleByType(props.boxType).width};\n`;\n\nconst InfoWrapper = styled.div<WrapperProps>`\n  margin: ${(props) => StyleByType(props.boxType).margin};\n  padding: ${(props) => StyleByType(props.boxType).padding};\n  display: flex;\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    padding: 0 90px 0 0;\n  }\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    padding: 0 5px 0 0;\n    font-size: 16px;\n  }\n`;\nconst TextWrapper = styled.div<WrapperProps>`\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    line-height: 24px;\n    font-size: 16px;\n  }\n  & p {\n    margin: 0;\n  }\n`;\n\nconst IconWrapper = styled.div<WrapperProps>`\n  padding-right: ${spacing.small};\n  display: ${(props) => StyleByType(props.boxType).display};\n  align-items: flex-start;\n  ${mq.range({ from: breakpoints.tabletWide })} {\n    padding-top: 4px;\n  }\n`;\n\nconst LinkWrapper = styled.div`\n  display: block;\n  width: 100%;\n  background-color: #f9f4c8;\n  padding-bottom: 20px;\n  margin-top: -2px;\n  padding-left: 58px;\n  border-radius: 0px 0px 5px 5px;\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    padding-left: 45px;\n  }\n`;\nconst Link = styled.a`\n  color: #20588f;\n  font-size: 16px;\n  padding-bottom: 1px;\n  margin: 0px 40px 1px 2px;\n  font-family: ${fonts.sans};\n  ${mq.range({ until: breakpoints.mobileWide })} {\n    margin: 0px 15px 1px 5px;\n    box-shadow: none;\n  }\n`;\nconst CloseButtonWrapper = styled.div`\n  position: absolute;\n  top: 10px;\n  right: 1px;\n`;\n\ntype LinkProps = {\n  href?: string;\n  text?: string;\n};\ntype Props = {\n  type?: WrapperProps['boxType'];\n  sticky?: boolean;\n  children?: string;\n  links?: LinkProps[];\n  showCloseButton?: boolean;\n  onClose?: () => void;\n};\n\nconst markdown = new Remarkable({ breaks: true });\nmarkdown.inline.ruler.enable(['sub', 'sup']);\nmarkdown.block.ruler.disable(['list', 'table']);\n\nexport const MessageBox = ({\n  type,\n  sticky = false,\n  children = '',\n  links,\n  showCloseButton,\n  onClose,\n}: Props & WithTranslation) => {\n  const [hideMessageBox, setHideMessageBox] = useState(false);\n  const onCloseMessageBox = () => {\n    setHideMessageBox(true);\n    onClose?.();\n  };\n  const Icon = type === 'ghost' ? HumanMaleBoard : InformationOutline;\n  return (\n    //StickyStyle top:84 makes sure that the messagebox sits beneath the masthead (header ) and the topOffsett sets it so that it applies when reaching the top of the messagebox\n    <Sticky disabled={!sticky} stickyStyle={{ zIndex: 9998, top: 84 }} topOffset={-84}>\n      <Wrapper boxType={type} style={{ display: hideMessageBox ? 'none' : 'flex' }}>\n        <InfoWrapper boxType={type}>\n          <IconWrapper boxType={type}>\n            <Icon style={{ width: '24px', height: '24px' }} />\n          </IconWrapper>\n          <TextWrapper dangerouslySetInnerHTML={{ __html: markdown.render(children) }}></TextWrapper>\n        </InfoWrapper>\n        {showCloseButton && (\n          <CloseButtonWrapper>\n            <CloseButton onClick={onCloseMessageBox} />\n          </CloseButtonWrapper>\n        )}\n      </Wrapper>\n\n      {links && (\n        //loops through the links passed in as properties if there are any and creates a working link for each of them\n        <LinkWrapper style={{ display: hideMessageBox ? 'none' : 'flex' }}>\n          {links.map((x) => (\n            <Link href={x.href}>{x.text}</Link>\n          ))}\n        </LinkWrapper>\n      )}\n    </Sticky>\n  );\n};\n\nexport default withTranslation()(MessageBox);\n"]} */",
170
173
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
171
174
  });
175
+ var markdown = new _remarkable.Remarkable({
176
+ breaks: true
177
+ });
178
+ markdown.inline.ruler.enable(['sub', 'sup']);
179
+ markdown.block.ruler.disable(['list', 'table']);
172
180
 
173
181
  var MessageBox = function MessageBox(_ref) {
174
182
  var type = _ref.type,
175
183
  _ref$sticky = _ref.sticky,
176
184
  sticky = _ref$sticky === void 0 ? false : _ref$sticky,
177
- children = _ref.children,
185
+ _ref$children = _ref.children,
186
+ children = _ref$children === void 0 ? '' : _ref$children,
178
187
  links = _ref.links,
179
- t = _ref.t,
180
- showCloseButton = _ref.showCloseButton;
188
+ showCloseButton = _ref.showCloseButton,
189
+ onClose = _ref.onClose;
181
190
 
182
191
  var _useState = (0, _react.useState)(false),
183
192
  _useState2 = _slicedToArray(_useState, 2),
@@ -186,6 +195,7 @@ var MessageBox = function MessageBox(_ref) {
186
195
 
187
196
  var onCloseMessageBox = function onCloseMessageBox() {
188
197
  setHideMessageBox(true);
198
+ onClose === null || onClose === void 0 ? void 0 : onClose();
189
199
  };
190
200
 
191
201
  var Icon = type === 'ghost' ? _common.HumanMaleBoard : _common.InformationOutline;
@@ -211,7 +221,11 @@ var MessageBox = function MessageBox(_ref) {
211
221
  width: '24px',
212
222
  height: '24px'
213
223
  }
214
- })), (0, _core2.jsx)(TextWrapper, null, children)), showCloseButton && (0, _core2.jsx)(CloseButtonWrapper, null, (0, _core2.jsx)(_CloseButton.CloseButton, {
224
+ })), (0, _core2.jsx)(TextWrapper, {
225
+ dangerouslySetInnerHTML: {
226
+ __html: markdown.render(children)
227
+ }
228
+ })), showCloseButton && (0, _core2.jsx)(CloseButtonWrapper, null, (0, _core2.jsx)(_CloseButton.CloseButton, {
215
229
  onClick: onCloseMessageBox
216
230
  }))), links && //loops through the links passed in as properties if there are any and creates a working link for each of them
217
231
  (0, _core2.jsx)(LinkWrapper, {
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@ndla/ui",
3
- "version": "6.2.2",
3
+ "version": "7.0.0",
4
4
  "description": "UI component library for NDLA.",
5
5
  "license": "GPL-3.0",
6
6
  "main": "lib/index.js",
@@ -57,6 +57,7 @@
57
57
  "react-sticky-el": "^2.0.6",
58
58
  "react-swipeable": "^6.2.0",
59
59
  "react-transition-group": "^2.5.3",
60
+ "remarkable": "^2.0.1",
60
61
  "shave": "^2.5.10"
61
62
  },
62
63
  "peerDependencies": {
@@ -81,5 +82,5 @@
81
82
  "publishConfig": {
82
83
  "access": "public"
83
84
  },
84
- "gitHead": "0bb6c9cfd659c54c64ce2387198eece373cc9c91"
85
+ "gitHead": "d7d87fdb7c64dfedcc057b1e3a32f2102859598d"
85
86
  }
@@ -40,13 +40,20 @@ const MastheadInfo = ({ children }: MastheadInfoProps) => (
40
40
  </div>
41
41
  );
42
42
 
43
+ interface Alert {
44
+ content: string;
45
+ closable?: boolean;
46
+ number: number;
47
+ }
48
+
43
49
  interface Props {
44
50
  children?: ReactNode;
45
51
  fixed?: boolean;
46
52
  infoContent?: ReactNode;
47
53
  ndlaFilm?: boolean;
48
54
  skipToMainContentId?: string;
49
- messages?: string[];
55
+ messages?: Alert[];
56
+ onCloseAlert?: (id: number) => void;
50
57
  }
51
58
 
52
59
  export const Masthead = ({
@@ -56,6 +63,7 @@ export const Masthead = ({
56
63
  ndlaFilm,
57
64
  skipToMainContentId,
58
65
  messages,
66
+ onCloseAlert,
59
67
  t,
60
68
  }: Props & WithTranslation) => {
61
69
  const mastheadRef = useRef<HTMLDivElement>(null);
@@ -87,7 +95,12 @@ export const Masthead = ({
87
95
  )}
88
96
  <div id="masthead" {...classes('', { fixed: !!fixed, infoContent: !!infoContent, ndlaFilm: !!ndlaFilm })}>
89
97
  {messages?.map((message) => (
90
- <MessageBox type={MessageBoxType.masthead}>{message}</MessageBox>
98
+ <MessageBox
99
+ type={MessageBoxType.masthead}
100
+ showCloseButton={message.closable}
101
+ onClose={() => onCloseAlert?.(message.number)}>
102
+ {message.content}
103
+ </MessageBox>
91
104
  ))}
92
105
  {infoContent && (
93
106
  <DisplayOnPageYOffset yOffsetMin={0} yOffsetMax={90}>
@@ -12,6 +12,9 @@ import Sticky from 'react-sticky-el';
12
12
  import { breakpoints, fonts, mq, spacing } from '@ndla/core';
13
13
  import { InformationOutline, HumanMaleBoard } from '@ndla/icons/common';
14
14
  import { WithTranslation, withTranslation } from 'react-i18next';
15
+
16
+ // @ts-ignore
17
+ import { Remarkable } from 'remarkable';
15
18
  import { CloseButton } from '../CloseButton';
16
19
 
17
20
  export enum MessageBoxType {
@@ -45,6 +48,7 @@ const StyleByType = (type: WrapperProps['boxType']) => {
45
48
  styles.width = '100vw';
46
49
  styles.position = 'relative';
47
50
  styles.left = '50%';
51
+ styles.padding = '0';
48
52
  styles.transform = 'translateX(-50%)';
49
53
  break;
50
54
  case 'medium':
@@ -102,6 +106,9 @@ const TextWrapper = styled.div<WrapperProps>`
102
106
  line-height: 24px;
103
107
  font-size: 16px;
104
108
  }
109
+ & p {
110
+ margin: 0;
111
+ }
105
112
  `;
106
113
 
107
114
  const IconWrapper = styled.div<WrapperProps>`
@@ -152,12 +159,25 @@ type Props = {
152
159
  children?: string;
153
160
  links?: LinkProps[];
154
161
  showCloseButton?: boolean;
162
+ onClose?: () => void;
155
163
  };
156
164
 
157
- export const MessageBox = ({ type, sticky = false, children, links, t, showCloseButton }: Props & WithTranslation) => {
165
+ const markdown = new Remarkable({ breaks: true });
166
+ markdown.inline.ruler.enable(['sub', 'sup']);
167
+ markdown.block.ruler.disable(['list', 'table']);
168
+
169
+ export const MessageBox = ({
170
+ type,
171
+ sticky = false,
172
+ children = '',
173
+ links,
174
+ showCloseButton,
175
+ onClose,
176
+ }: Props & WithTranslation) => {
158
177
  const [hideMessageBox, setHideMessageBox] = useState(false);
159
178
  const onCloseMessageBox = () => {
160
179
  setHideMessageBox(true);
180
+ onClose?.();
161
181
  };
162
182
  const Icon = type === 'ghost' ? HumanMaleBoard : InformationOutline;
163
183
  return (
@@ -168,7 +188,7 @@ export const MessageBox = ({ type, sticky = false, children, links, t, showClose
168
188
  <IconWrapper boxType={type}>
169
189
  <Icon style={{ width: '24px', height: '24px' }} />
170
190
  </IconWrapper>
171
- <TextWrapper>{children}</TextWrapper>
191
+ <TextWrapper dangerouslySetInnerHTML={{ __html: markdown.render(children) }}></TextWrapper>
172
192
  </InfoWrapper>
173
193
  {showCloseButton && (
174
194
  <CloseButtonWrapper>