@ndla/ui 6.2.2 → 8.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/es/Masthead/Masthead.js +7 -2
- package/es/MessageBox/MessageBox.js +26 -12
- package/es/Notion/FigureNotion.js +0 -1
- package/es/Notion/Notion.js +13 -14
- package/es/Notion/NotionVisualElement.js +1 -1
- package/lib/Masthead/Masthead.d.ts +9 -3
- package/lib/Masthead/Masthead.js +7 -2
- package/lib/MessageBox/MessageBox.d.ts +3 -2
- package/lib/MessageBox/MessageBox.js +25 -11
- package/lib/Notion/FigureNotion.js +0 -1
- package/lib/Notion/Notion.d.ts +1 -2
- package/lib/Notion/Notion.js +13 -14
- package/lib/Notion/NotionVisualElement.js +1 -1
- package/package.json +3 -2
- package/src/Masthead/Masthead.tsx +15 -2
- package/src/MessageBox/MessageBox.tsx +22 -2
- package/src/Notion/FigureNotion.tsx +0 -1
- package/src/Notion/Notion.tsx +3 -15
- package/src/Notion/NotionVisualElement.tsx +1 -1
|
@@ -26,7 +26,8 @@ declare type Props = {
|
|
|
26
26
|
children?: string;
|
|
27
27
|
links?: LinkProps[];
|
|
28
28
|
showCloseButton?: boolean;
|
|
29
|
+
onClose?: () => void;
|
|
29
30
|
};
|
|
30
|
-
export declare const MessageBox: ({ type, sticky, children, links,
|
|
31
|
-
declare const _default: React.ComponentType<Pick<Pick<Props & WithTranslation<"translation">, "sticky" | "children" | "type" | "t" | "tReady" | "links" | "showCloseButton">, "sticky" | "children" | "type" | "links" | "showCloseButton"> & import("react-i18next").WithTranslationProps>;
|
|
31
|
+
export declare const MessageBox: ({ type, sticky, children, links, showCloseButton, onClose, }: Props & WithTranslation) => JSX.Element;
|
|
32
|
+
declare const _default: React.ComponentType<Pick<Pick<Props & WithTranslation<"translation">, "sticky" | "children" | "type" | "t" | "tReady" | "onClose" | "links" | "showCloseButton">, "sticky" | "children" | "type" | "onClose" | "links" | "showCloseButton"> & import("react-i18next").WithTranslationProps>;
|
|
32
33
|
export default _default;
|
|
@@ -19,6 +19,8 @@ var _common = require("@ndla/icons/common");
|
|
|
19
19
|
|
|
20
20
|
var _reactI18next = require("react-i18next");
|
|
21
21
|
|
|
22
|
+
var _remarkable = require("remarkable");
|
|
23
|
+
|
|
22
24
|
var _CloseButton = require("../CloseButton");
|
|
23
25
|
|
|
24
26
|
var _core2 = require("@emotion/core");
|
|
@@ -75,6 +77,7 @@ var StyleByType = function StyleByType(type) {
|
|
|
75
77
|
styles.width = '100vw';
|
|
76
78
|
styles.position = 'relative';
|
|
77
79
|
styles.left = '50%';
|
|
80
|
+
styles.padding = '0';
|
|
78
81
|
styles.transform = 'translateX(-50%)';
|
|
79
82
|
break;
|
|
80
83
|
|
|
@@ -118,7 +121,7 @@ var Wrapper = (0, _styledBase["default"])("div", {
|
|
|
118
121
|
return StyleByType(props.boxType).left;
|
|
119
122
|
}, ";z-index:10;width:", function (props) {
|
|
120
123
|
return StyleByType(props.boxType).width;
|
|
121
|
-
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
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,
|
|
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,
|
|
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,
|
|
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,
|
|
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,
|
|
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,
|
|
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
|
-
|
|
180
|
-
|
|
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,
|
|
224
|
+
})), (0, _core2.jsx)(TextWrapper, {
|
|
225
|
+
dangerouslySetInnerHTML: {
|
|
226
|
+
__html: markdown.render(children)
|
|
227
|
+
}
|
|
228
|
+
})), showCloseButton && (0, _core2.jsx)(CloseButtonWrapper, null, (0, _core2.jsx)(_CloseButton.CloseButton, {
|
|
215
229
|
onClick: onCloseMessageBox
|
|
216
230
|
}))), links && //loops through the links passed in as properties if there are any and creates a working link for each of them
|
|
217
231
|
(0, _core2.jsx)(LinkWrapper, {
|
package/lib/Notion/Notion.d.ts
CHANGED
|
@@ -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,
|
|
29
|
+
declare const Notion: ({ id, labels, text, title, visualElement, imageElement, children }: NotionProps) => JSX.Element;
|
|
31
30
|
export default Notion;
|