@ndla/ui 6.2.1 → 8.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.
@@ -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, {
@@ -71,7 +71,6 @@ var FigureNotion = function FigureNotion(_ref) {
71
71
  hideFigcaption: hideFigCaption,
72
72
  figureId: figureId,
73
73
  id: id,
74
- caption: title,
75
74
  reuseLabel: t("".concat(type, ".reuse")),
76
75
  authors: contributors,
77
76
  licenseRights: license.rights
@@ -20,12 +20,11 @@ declare type VisualElementProps = {
20
20
  export declare type NotionProps = {
21
21
  id: string | number;
22
22
  labels?: string[];
23
- renderMarkdown?: (text: string) => string;
24
23
  text: ReactNode;
25
24
  title: string;
26
25
  visualElement?: VisualElementProps;
27
26
  imageElement?: ReactNode;
28
27
  children?: ReactNode;
29
28
  };
30
- declare const Notion: ({ id, labels, renderMarkdown, text, title, visualElement, imageElement, children, }: NotionProps) => JSX.Element;
29
+ declare const Notion: ({ id, labels, text, title, visualElement, imageElement, children }: NotionProps) => JSX.Element;
31
30
  export default Notion;