@ndla/ui 50.15.0 → 50.15.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/Table/Table.js CHANGED
@@ -17,7 +17,7 @@ const MARGIN = 5;
17
17
  const ScrollBorder = /*#__PURE__*/_styled("div", {
18
18
  target: "e69565p4",
19
19
  label: "ScrollBorder"
20
- })("position:absolute;top:0;height:calc(100% - ", spacing.mediumlarge, ");width:3px;background:", colors.background.dark, ";display:none;&[data-block=\"true\"]{display:block;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Table.tsx"],"names":[],"mappings":"AA2B+B","file":"Table.tsx","sourcesContent":["/**\n * Copyright (c) 2016-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport throttle from \"lodash.throttle\";\nimport { ReactNode, UIEvent, useCallback, useEffect, useMemo, useRef, useState } from \"react\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, fonts, mq, spacing } from \"@ndla/core\";\n\ntype ScrollPosition = \"start\" | \"end\" | \"center\";\n\nconst MARGIN = 5;\n\ninterface Props {\n  id?: string;\n  children?: ReactNode;\n  dangerouslySetInnerHTML?: {\n    __html: string;\n  };\n  lang?: string;\n}\n\nconst ScrollBorder = styled.div`\n  position: absolute;\n  top: 0;\n  height: calc(100% - ${spacing.mediumlarge});\n  width: 3px;\n  background: ${colors.background.dark};\n  display: none;\n\n  &[data-block=\"true\"] {\n    display: block;\n  }\n`;\n\nconst RightScrollBorder = styled(ScrollBorder)`\n  right: 0;\n`;\n\nconst LeftScrollBorder = styled(ScrollBorder)`\n  left: 0;\n`;\n\nexport const TableStyling = css`\n  &::-webkit-scrollbar {\n    height: ${spacing.xsmall};\n  }\n  &::-webkit-scrollbar-track-piece {\n    background: ${colors.brand.lighter};\n    border-radius: ${spacing.xsmall};\n  }\n  &::-webkit-scrollbar-thumb {\n    background: ${colors.brand.dark};\n    border-radius: ${spacing.xsmall};\n  }\n  display: inline-block;\n\n  font-size: 85%;\n  max-width: 100%;\n\n  padding-left: ${spacing.xxsmall};\n  padding-right: ${spacing.xxsmall};\n\n  vertical-align: top;\n  table-layout: fixed;\n  overflow-x: auto;\n\n  // optional - enable iOS momentum scrolling\n  -webkit-overflow-scrolling: touch;\n\n  // scrolling shadows on left/right\n  &:after,\n  &:before {\n    content: \"\";\n    display: table;\n    clear: both;\n  }\n\n  > caption {\n    background-color: transparent;\n    font-weight: ${fonts.weight.bold};\n    font-family: ${fonts.sans};\n    ${fonts.sizes(\"16px\", \"20px\")}\n    text-align: left;\n    text-transform: uppercase;\n    margin-bottom: ${spacing.small};\n  }\n\n  thead {\n    overflow: hidden;\n  }\n\n  thead tr td,\n  th {\n    font-weight: ${fonts.weight.bold};\n    border-bottom: 3px solid ${colors.brand.tertiary};\n    font-family: ${fonts.sans};\n    vertical-align: text-top;\n\n    ${fonts.sizes(\"16px\", \"22px\")};\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes(\"16px\", \"30px\")};\n    }\n  }\n\n  tbody th {\n    border-bottom: 0;\n    border-right: 3px solid ${colors.brand.tertiary};\n    padding: ${spacing.xsmall};\n  }\n\n  thead tr:nth-child(2) th {\n    border: 1px solid ${colors.brand.lighter};\n    text-transform: none;\n\n    ${fonts.sizes(\"14px\", \"18px\")};\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes(\"15px\", \"26px\")};\n    }\n\n    font-weight: ${fonts.weight.semibold};\n    height: 40px;\n    background-color: ${colors.brand.lighter};\n    padding: ${spacing.xxsmall} ${spacing.normal} ${spacing.xxsmall} ${spacing.xsmall};\n\n    &:empty {\n      background-color: transparent;\n    }\n  }\n\n  td {\n    border: 1px solid ${colors.brand.lighter};\n    vertical-align: top;\n\n    ${fonts.sizes(\"14px\", \"22px\")};\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes(\"15px\", \"30px\")};\n    }\n\n    ol,\n    ul {\n      li,\n      li p {\n        ${fonts.sizes(\"14px\", \"22px\")};\n        ${mq.range({ from: breakpoints.tablet })} {\n          ${fonts.sizes(\"15px\", \"30px\")};\n        }\n        margin: ${spacing.xsmall} 0 !important;\n      }\n    }\n\n    p {\n      line-height: 1.6em;\n    }\n\n    p:last-child {\n      margin: 0;\n    }\n\n    img {\n      max-width: 100%;\n      min-width: 120px;\n    }\n  }\n\n  td,\n  th {\n    display: table-cell;\n    padding: ${spacing.xsmall} ${spacing.small};\n\n    p {\n      margin: 0;\n    }\n  }\n\n  // Remove excess spacing on headings inside table\n  h1,\n  h2,\n  h3,\n  h4,\n  h5 {\n    margin-top: 0;\n  }\n\n  ul {\n    padding: 0 0 0 ${spacing.nsmall};\n  }\n`;\n\nconst TableWrapper = styled.div`\n  display: flex;\n  justify-content: center;\n`;\n\nconst OverflowWrapper = styled.div`\n  position: relative;\n  overflow-x: auto;\n`;\n\nconst Table = ({ children, id, ...rest }: Props) => {\n  const [scrollPosition, setScrollPosition] = useState<ScrollPosition | undefined>(undefined);\n  const tableRef = useRef<HTMLTableElement>(null);\n\n  const checkScrollPosition = useCallback((el: HTMLTableElement) => {\n    const { scrollLeft, offsetWidth, scrollWidth, clientWidth } = el;\n    const hasScrollbar = scrollWidth > clientWidth;\n\n    if (!hasScrollbar) {\n      setScrollPosition(undefined);\n      return;\n    }\n\n    const isStart = scrollLeft <= MARGIN;\n    const isEnd = offsetWidth + scrollLeft >= scrollWidth - MARGIN;\n\n    if (isStart) {\n      setScrollPosition(\"start\");\n    } else if (isEnd) {\n      setScrollPosition(\"end\");\n    } else {\n      setScrollPosition(\"center\");\n    }\n  }, []);\n\n  const onScroll = useMemo(\n    () =>\n      throttle((event: UIEvent<HTMLTableElement>) => {\n        const el = event.target as HTMLTableElement | undefined;\n        if (el) {\n          checkScrollPosition(el);\n        }\n      }, 100),\n    [checkScrollPosition],\n  );\n\n  useEffect(() => {\n    const el = tableRef.current;\n    if (el) {\n      checkScrollPosition(el);\n    }\n  }, [checkScrollPosition]);\n\n  return (\n    <TableWrapper>\n      <OverflowWrapper>\n        <LeftScrollBorder data-block={scrollPosition === \"end\" || scrollPosition === \"center\"} />\n        <table ref={tableRef} id={id} onScroll={onScroll} css={TableStyling} {...rest}>\n          {children}\n        </table>\n        <RightScrollBorder data-block={scrollPosition === \"start\" || scrollPosition === \"center\"} />\n      </OverflowWrapper>\n    </TableWrapper>\n  );\n};\n\nexport default Table;\n"]} */"));
20
+ })("position:absolute;top:0;height:calc(100% - ", spacing.mediumlarge, ");width:3px;background:", colors.background.dark, ";display:none;&[data-block=\"true\"]{display:block;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Table.tsx"],"names":[],"mappings":"AA2B+B","file":"Table.tsx","sourcesContent":["/**\n * Copyright (c) 2016-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport throttle from \"lodash.throttle\";\nimport { ReactNode, UIEvent, useCallback, useEffect, useMemo, useRef, useState } from \"react\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, fonts, mq, spacing } from \"@ndla/core\";\n\ntype ScrollPosition = \"start\" | \"end\" | \"center\";\n\nconst MARGIN = 5;\n\ninterface Props {\n  id?: string;\n  children?: ReactNode;\n  dangerouslySetInnerHTML?: {\n    __html: string;\n  };\n  lang?: string;\n}\n\nconst ScrollBorder = styled.div`\n  position: absolute;\n  top: 0;\n  height: calc(100% - ${spacing.mediumlarge});\n  width: 3px;\n  background: ${colors.background.dark};\n  display: none;\n\n  &[data-block=\"true\"] {\n    display: block;\n  }\n`;\n\nconst RightScrollBorder = styled(ScrollBorder)`\n  right: 0;\n`;\n\nconst LeftScrollBorder = styled(ScrollBorder)`\n  left: 0;\n`;\n\nexport const TableStyling = css`\n  &::-webkit-scrollbar {\n    height: ${spacing.xsmall};\n  }\n  &::-webkit-scrollbar-track-piece {\n    background: ${colors.brand.lighter};\n    border-radius: ${spacing.xsmall};\n  }\n  &::-webkit-scrollbar-thumb {\n    background: ${colors.brand.dark};\n    border-radius: ${spacing.xsmall};\n  }\n  display: inline-block;\n\n  font-size: 85%;\n  max-width: 100%;\n\n  padding-left: ${spacing.xxsmall};\n  padding-right: ${spacing.xxsmall};\n\n  vertical-align: top;\n  table-layout: fixed;\n  overflow-x: auto;\n\n  // optional - enable iOS momentum scrolling\n  -webkit-overflow-scrolling: touch;\n\n  // scrolling shadows on left/right\n  &:after,\n  &:before {\n    content: \"\";\n    display: table;\n    clear: both;\n  }\n\n  > caption {\n    background-color: transparent;\n    font-weight: ${fonts.weight.bold};\n    font-family: ${fonts.sans};\n    ${fonts.sizes(\"16px\", \"20px\")}\n    text-align: left;\n    text-transform: uppercase;\n    margin-bottom: ${spacing.small};\n  }\n\n  thead {\n    overflow: hidden;\n  }\n\n  thead tr td,\n  th {\n    font-weight: ${fonts.weight.bold};\n    border-bottom: 3px solid ${colors.brand.tertiary};\n    font-family: ${fonts.sans};\n    vertical-align: text-top;\n\n    ${fonts.sizes(\"16px\", \"22px\")};\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes(\"16px\", \"30px\")};\n    }\n  }\n\n  tbody th {\n    border-bottom: 0;\n    border-right: 3px solid ${colors.brand.tertiary};\n    padding: ${spacing.xsmall};\n  }\n\n  thead tr:nth-child(2) th {\n    border: 1px solid ${colors.brand.lighter};\n    text-transform: none;\n\n    ${fonts.sizes(\"14px\", \"18px\")};\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes(\"15px\", \"26px\")};\n    }\n\n    font-weight: ${fonts.weight.semibold};\n    height: 40px;\n    background-color: ${colors.brand.lighter};\n    padding: ${spacing.xxsmall} ${spacing.normal} ${spacing.xxsmall} ${spacing.xsmall};\n\n    &:empty {\n      background-color: transparent;\n    }\n  }\n\n  td {\n    border: 1px solid ${colors.brand.lighter};\n    vertical-align: top;\n\n    ${fonts.sizes(\"14px\", \"22px\")};\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes(\"15px\", \"30px\")};\n    }\n\n    ol,\n    ul {\n      li,\n      li p {\n        ${fonts.sizes(\"14px\", \"22px\")};\n        ${mq.range({ from: breakpoints.tablet })} {\n          ${fonts.sizes(\"15px\", \"30px\")};\n        }\n        margin: ${spacing.xsmall} 0 !important;\n      }\n    }\n\n    p {\n      line-height: 1.6em;\n    }\n\n    p:last-child {\n      margin: 0;\n    }\n\n    img {\n      max-width: 100%;\n      min-width: 120px;\n    }\n  }\n\n  td,\n  th {\n    display: table-cell;\n    padding: ${spacing.xsmall} ${spacing.small};\n\n    p {\n      margin: 0;\n    }\n  }\n\n  // Remove excess spacing on headings inside table\n  h1,\n  h2,\n  h3,\n  h4,\n  h5 {\n    margin-top: 0;\n  }\n\n  ul {\n    padding: 0 0 0 ${spacing.nsmall};\n  }\n\n  figure {\n    margin: 0;\n    padding: 0;\n    width: 100% !important;\n    left: 0 !important;\n  }\n`;\n\nconst TableWrapper = styled.div`\n  display: flex;\n  justify-content: center;\n`;\n\nconst OverflowWrapper = styled.div`\n  position: relative;\n  overflow-x: auto;\n`;\n\nconst Table = ({ children, id, ...rest }: Props) => {\n  const [scrollPosition, setScrollPosition] = useState<ScrollPosition | undefined>(undefined);\n  const tableRef = useRef<HTMLTableElement>(null);\n\n  const checkScrollPosition = useCallback((el: HTMLTableElement) => {\n    const { scrollLeft, offsetWidth, scrollWidth, clientWidth } = el;\n    const hasScrollbar = scrollWidth > clientWidth;\n\n    if (!hasScrollbar) {\n      setScrollPosition(undefined);\n      return;\n    }\n\n    const isStart = scrollLeft <= MARGIN;\n    const isEnd = offsetWidth + scrollLeft >= scrollWidth - MARGIN;\n\n    if (isStart) {\n      setScrollPosition(\"start\");\n    } else if (isEnd) {\n      setScrollPosition(\"end\");\n    } else {\n      setScrollPosition(\"center\");\n    }\n  }, []);\n\n  const onScroll = useMemo(\n    () =>\n      throttle((event: UIEvent<HTMLTableElement>) => {\n        const el = event.target as HTMLTableElement | undefined;\n        if (el) {\n          checkScrollPosition(el);\n        }\n      }, 100),\n    [checkScrollPosition],\n  );\n\n  useEffect(() => {\n    const el = tableRef.current;\n    if (el) {\n      checkScrollPosition(el);\n    }\n  }, [checkScrollPosition]);\n\n  return (\n    <TableWrapper>\n      <OverflowWrapper>\n        <LeftScrollBorder data-block={scrollPosition === \"end\" || scrollPosition === \"center\"} />\n        <table ref={tableRef} id={id} onScroll={onScroll} css={TableStyling} {...rest}>\n          {children}\n        </table>\n        <RightScrollBorder data-block={scrollPosition === \"start\" || scrollPosition === \"center\"} />\n      </OverflowWrapper>\n    </TableWrapper>\n  );\n};\n\nexport default Table;\n"]} */"));
21
21
  const RightScrollBorder = /*#__PURE__*/_styled(ScrollBorder, {
22
22
  target: "e69565p3",
23
23
  label: "RightScrollBorder"
@@ -27,7 +27,7 @@ const RightScrollBorder = /*#__PURE__*/_styled(ScrollBorder, {
27
27
  } : {
28
28
  name: "1wf8jf",
29
29
  styles: "right:0",
30
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Table.tsx"],"names":[],"mappings":"AAwC8C","file":"Table.tsx","sourcesContent":["/**\n * Copyright (c) 2016-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport throttle from \"lodash.throttle\";\nimport { ReactNode, UIEvent, useCallback, useEffect, useMemo, useRef, useState } from \"react\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, fonts, mq, spacing } from \"@ndla/core\";\n\ntype ScrollPosition = \"start\" | \"end\" | \"center\";\n\nconst MARGIN = 5;\n\ninterface Props {\n  id?: string;\n  children?: ReactNode;\n  dangerouslySetInnerHTML?: {\n    __html: string;\n  };\n  lang?: string;\n}\n\nconst ScrollBorder = styled.div`\n  position: absolute;\n  top: 0;\n  height: calc(100% - ${spacing.mediumlarge});\n  width: 3px;\n  background: ${colors.background.dark};\n  display: none;\n\n  &[data-block=\"true\"] {\n    display: block;\n  }\n`;\n\nconst RightScrollBorder = styled(ScrollBorder)`\n  right: 0;\n`;\n\nconst LeftScrollBorder = styled(ScrollBorder)`\n  left: 0;\n`;\n\nexport const TableStyling = css`\n  &::-webkit-scrollbar {\n    height: ${spacing.xsmall};\n  }\n  &::-webkit-scrollbar-track-piece {\n    background: ${colors.brand.lighter};\n    border-radius: ${spacing.xsmall};\n  }\n  &::-webkit-scrollbar-thumb {\n    background: ${colors.brand.dark};\n    border-radius: ${spacing.xsmall};\n  }\n  display: inline-block;\n\n  font-size: 85%;\n  max-width: 100%;\n\n  padding-left: ${spacing.xxsmall};\n  padding-right: ${spacing.xxsmall};\n\n  vertical-align: top;\n  table-layout: fixed;\n  overflow-x: auto;\n\n  // optional - enable iOS momentum scrolling\n  -webkit-overflow-scrolling: touch;\n\n  // scrolling shadows on left/right\n  &:after,\n  &:before {\n    content: \"\";\n    display: table;\n    clear: both;\n  }\n\n  > caption {\n    background-color: transparent;\n    font-weight: ${fonts.weight.bold};\n    font-family: ${fonts.sans};\n    ${fonts.sizes(\"16px\", \"20px\")}\n    text-align: left;\n    text-transform: uppercase;\n    margin-bottom: ${spacing.small};\n  }\n\n  thead {\n    overflow: hidden;\n  }\n\n  thead tr td,\n  th {\n    font-weight: ${fonts.weight.bold};\n    border-bottom: 3px solid ${colors.brand.tertiary};\n    font-family: ${fonts.sans};\n    vertical-align: text-top;\n\n    ${fonts.sizes(\"16px\", \"22px\")};\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes(\"16px\", \"30px\")};\n    }\n  }\n\n  tbody th {\n    border-bottom: 0;\n    border-right: 3px solid ${colors.brand.tertiary};\n    padding: ${spacing.xsmall};\n  }\n\n  thead tr:nth-child(2) th {\n    border: 1px solid ${colors.brand.lighter};\n    text-transform: none;\n\n    ${fonts.sizes(\"14px\", \"18px\")};\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes(\"15px\", \"26px\")};\n    }\n\n    font-weight: ${fonts.weight.semibold};\n    height: 40px;\n    background-color: ${colors.brand.lighter};\n    padding: ${spacing.xxsmall} ${spacing.normal} ${spacing.xxsmall} ${spacing.xsmall};\n\n    &:empty {\n      background-color: transparent;\n    }\n  }\n\n  td {\n    border: 1px solid ${colors.brand.lighter};\n    vertical-align: top;\n\n    ${fonts.sizes(\"14px\", \"22px\")};\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes(\"15px\", \"30px\")};\n    }\n\n    ol,\n    ul {\n      li,\n      li p {\n        ${fonts.sizes(\"14px\", \"22px\")};\n        ${mq.range({ from: breakpoints.tablet })} {\n          ${fonts.sizes(\"15px\", \"30px\")};\n        }\n        margin: ${spacing.xsmall} 0 !important;\n      }\n    }\n\n    p {\n      line-height: 1.6em;\n    }\n\n    p:last-child {\n      margin: 0;\n    }\n\n    img {\n      max-width: 100%;\n      min-width: 120px;\n    }\n  }\n\n  td,\n  th {\n    display: table-cell;\n    padding: ${spacing.xsmall} ${spacing.small};\n\n    p {\n      margin: 0;\n    }\n  }\n\n  // Remove excess spacing on headings inside table\n  h1,\n  h2,\n  h3,\n  h4,\n  h5 {\n    margin-top: 0;\n  }\n\n  ul {\n    padding: 0 0 0 ${spacing.nsmall};\n  }\n`;\n\nconst TableWrapper = styled.div`\n  display: flex;\n  justify-content: center;\n`;\n\nconst OverflowWrapper = styled.div`\n  position: relative;\n  overflow-x: auto;\n`;\n\nconst Table = ({ children, id, ...rest }: Props) => {\n  const [scrollPosition, setScrollPosition] = useState<ScrollPosition | undefined>(undefined);\n  const tableRef = useRef<HTMLTableElement>(null);\n\n  const checkScrollPosition = useCallback((el: HTMLTableElement) => {\n    const { scrollLeft, offsetWidth, scrollWidth, clientWidth } = el;\n    const hasScrollbar = scrollWidth > clientWidth;\n\n    if (!hasScrollbar) {\n      setScrollPosition(undefined);\n      return;\n    }\n\n    const isStart = scrollLeft <= MARGIN;\n    const isEnd = offsetWidth + scrollLeft >= scrollWidth - MARGIN;\n\n    if (isStart) {\n      setScrollPosition(\"start\");\n    } else if (isEnd) {\n      setScrollPosition(\"end\");\n    } else {\n      setScrollPosition(\"center\");\n    }\n  }, []);\n\n  const onScroll = useMemo(\n    () =>\n      throttle((event: UIEvent<HTMLTableElement>) => {\n        const el = event.target as HTMLTableElement | undefined;\n        if (el) {\n          checkScrollPosition(el);\n        }\n      }, 100),\n    [checkScrollPosition],\n  );\n\n  useEffect(() => {\n    const el = tableRef.current;\n    if (el) {\n      checkScrollPosition(el);\n    }\n  }, [checkScrollPosition]);\n\n  return (\n    <TableWrapper>\n      <OverflowWrapper>\n        <LeftScrollBorder data-block={scrollPosition === \"end\" || scrollPosition === \"center\"} />\n        <table ref={tableRef} id={id} onScroll={onScroll} css={TableStyling} {...rest}>\n          {children}\n        </table>\n        <RightScrollBorder data-block={scrollPosition === \"start\" || scrollPosition === \"center\"} />\n      </OverflowWrapper>\n    </TableWrapper>\n  );\n};\n\nexport default Table;\n"]} */",
30
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Table.tsx"],"names":[],"mappings":"AAwC8C","file":"Table.tsx","sourcesContent":["/**\n * Copyright (c) 2016-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport throttle from \"lodash.throttle\";\nimport { ReactNode, UIEvent, useCallback, useEffect, useMemo, useRef, useState } from \"react\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, fonts, mq, spacing } from \"@ndla/core\";\n\ntype ScrollPosition = \"start\" | \"end\" | \"center\";\n\nconst MARGIN = 5;\n\ninterface Props {\n  id?: string;\n  children?: ReactNode;\n  dangerouslySetInnerHTML?: {\n    __html: string;\n  };\n  lang?: string;\n}\n\nconst ScrollBorder = styled.div`\n  position: absolute;\n  top: 0;\n  height: calc(100% - ${spacing.mediumlarge});\n  width: 3px;\n  background: ${colors.background.dark};\n  display: none;\n\n  &[data-block=\"true\"] {\n    display: block;\n  }\n`;\n\nconst RightScrollBorder = styled(ScrollBorder)`\n  right: 0;\n`;\n\nconst LeftScrollBorder = styled(ScrollBorder)`\n  left: 0;\n`;\n\nexport const TableStyling = css`\n  &::-webkit-scrollbar {\n    height: ${spacing.xsmall};\n  }\n  &::-webkit-scrollbar-track-piece {\n    background: ${colors.brand.lighter};\n    border-radius: ${spacing.xsmall};\n  }\n  &::-webkit-scrollbar-thumb {\n    background: ${colors.brand.dark};\n    border-radius: ${spacing.xsmall};\n  }\n  display: inline-block;\n\n  font-size: 85%;\n  max-width: 100%;\n\n  padding-left: ${spacing.xxsmall};\n  padding-right: ${spacing.xxsmall};\n\n  vertical-align: top;\n  table-layout: fixed;\n  overflow-x: auto;\n\n  // optional - enable iOS momentum scrolling\n  -webkit-overflow-scrolling: touch;\n\n  // scrolling shadows on left/right\n  &:after,\n  &:before {\n    content: \"\";\n    display: table;\n    clear: both;\n  }\n\n  > caption {\n    background-color: transparent;\n    font-weight: ${fonts.weight.bold};\n    font-family: ${fonts.sans};\n    ${fonts.sizes(\"16px\", \"20px\")}\n    text-align: left;\n    text-transform: uppercase;\n    margin-bottom: ${spacing.small};\n  }\n\n  thead {\n    overflow: hidden;\n  }\n\n  thead tr td,\n  th {\n    font-weight: ${fonts.weight.bold};\n    border-bottom: 3px solid ${colors.brand.tertiary};\n    font-family: ${fonts.sans};\n    vertical-align: text-top;\n\n    ${fonts.sizes(\"16px\", \"22px\")};\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes(\"16px\", \"30px\")};\n    }\n  }\n\n  tbody th {\n    border-bottom: 0;\n    border-right: 3px solid ${colors.brand.tertiary};\n    padding: ${spacing.xsmall};\n  }\n\n  thead tr:nth-child(2) th {\n    border: 1px solid ${colors.brand.lighter};\n    text-transform: none;\n\n    ${fonts.sizes(\"14px\", \"18px\")};\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes(\"15px\", \"26px\")};\n    }\n\n    font-weight: ${fonts.weight.semibold};\n    height: 40px;\n    background-color: ${colors.brand.lighter};\n    padding: ${spacing.xxsmall} ${spacing.normal} ${spacing.xxsmall} ${spacing.xsmall};\n\n    &:empty {\n      background-color: transparent;\n    }\n  }\n\n  td {\n    border: 1px solid ${colors.brand.lighter};\n    vertical-align: top;\n\n    ${fonts.sizes(\"14px\", \"22px\")};\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes(\"15px\", \"30px\")};\n    }\n\n    ol,\n    ul {\n      li,\n      li p {\n        ${fonts.sizes(\"14px\", \"22px\")};\n        ${mq.range({ from: breakpoints.tablet })} {\n          ${fonts.sizes(\"15px\", \"30px\")};\n        }\n        margin: ${spacing.xsmall} 0 !important;\n      }\n    }\n\n    p {\n      line-height: 1.6em;\n    }\n\n    p:last-child {\n      margin: 0;\n    }\n\n    img {\n      max-width: 100%;\n      min-width: 120px;\n    }\n  }\n\n  td,\n  th {\n    display: table-cell;\n    padding: ${spacing.xsmall} ${spacing.small};\n\n    p {\n      margin: 0;\n    }\n  }\n\n  // Remove excess spacing on headings inside table\n  h1,\n  h2,\n  h3,\n  h4,\n  h5 {\n    margin-top: 0;\n  }\n\n  ul {\n    padding: 0 0 0 ${spacing.nsmall};\n  }\n\n  figure {\n    margin: 0;\n    padding: 0;\n    width: 100% !important;\n    left: 0 !important;\n  }\n`;\n\nconst TableWrapper = styled.div`\n  display: flex;\n  justify-content: center;\n`;\n\nconst OverflowWrapper = styled.div`\n  position: relative;\n  overflow-x: auto;\n`;\n\nconst Table = ({ children, id, ...rest }: Props) => {\n  const [scrollPosition, setScrollPosition] = useState<ScrollPosition | undefined>(undefined);\n  const tableRef = useRef<HTMLTableElement>(null);\n\n  const checkScrollPosition = useCallback((el: HTMLTableElement) => {\n    const { scrollLeft, offsetWidth, scrollWidth, clientWidth } = el;\n    const hasScrollbar = scrollWidth > clientWidth;\n\n    if (!hasScrollbar) {\n      setScrollPosition(undefined);\n      return;\n    }\n\n    const isStart = scrollLeft <= MARGIN;\n    const isEnd = offsetWidth + scrollLeft >= scrollWidth - MARGIN;\n\n    if (isStart) {\n      setScrollPosition(\"start\");\n    } else if (isEnd) {\n      setScrollPosition(\"end\");\n    } else {\n      setScrollPosition(\"center\");\n    }\n  }, []);\n\n  const onScroll = useMemo(\n    () =>\n      throttle((event: UIEvent<HTMLTableElement>) => {\n        const el = event.target as HTMLTableElement | undefined;\n        if (el) {\n          checkScrollPosition(el);\n        }\n      }, 100),\n    [checkScrollPosition],\n  );\n\n  useEffect(() => {\n    const el = tableRef.current;\n    if (el) {\n      checkScrollPosition(el);\n    }\n  }, [checkScrollPosition]);\n\n  return (\n    <TableWrapper>\n      <OverflowWrapper>\n        <LeftScrollBorder data-block={scrollPosition === \"end\" || scrollPosition === \"center\"} />\n        <table ref={tableRef} id={id} onScroll={onScroll} css={TableStyling} {...rest}>\n          {children}\n        </table>\n        <RightScrollBorder data-block={scrollPosition === \"start\" || scrollPosition === \"center\"} />\n      </OverflowWrapper>\n    </TableWrapper>\n  );\n};\n\nexport default Table;\n"]} */",
31
31
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
32
32
  });
33
33
  const LeftScrollBorder = /*#__PURE__*/_styled(ScrollBorder, {
@@ -39,7 +39,7 @@ const LeftScrollBorder = /*#__PURE__*/_styled(ScrollBorder, {
39
39
  } : {
40
40
  name: "1ode3cm",
41
41
  styles: "left:0",
42
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Table.tsx"],"names":[],"mappings":"AA4C6C","file":"Table.tsx","sourcesContent":["/**\n * Copyright (c) 2016-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport throttle from \"lodash.throttle\";\nimport { ReactNode, UIEvent, useCallback, useEffect, useMemo, useRef, useState } from \"react\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, fonts, mq, spacing } from \"@ndla/core\";\n\ntype ScrollPosition = \"start\" | \"end\" | \"center\";\n\nconst MARGIN = 5;\n\ninterface Props {\n  id?: string;\n  children?: ReactNode;\n  dangerouslySetInnerHTML?: {\n    __html: string;\n  };\n  lang?: string;\n}\n\nconst ScrollBorder = styled.div`\n  position: absolute;\n  top: 0;\n  height: calc(100% - ${spacing.mediumlarge});\n  width: 3px;\n  background: ${colors.background.dark};\n  display: none;\n\n  &[data-block=\"true\"] {\n    display: block;\n  }\n`;\n\nconst RightScrollBorder = styled(ScrollBorder)`\n  right: 0;\n`;\n\nconst LeftScrollBorder = styled(ScrollBorder)`\n  left: 0;\n`;\n\nexport const TableStyling = css`\n  &::-webkit-scrollbar {\n    height: ${spacing.xsmall};\n  }\n  &::-webkit-scrollbar-track-piece {\n    background: ${colors.brand.lighter};\n    border-radius: ${spacing.xsmall};\n  }\n  &::-webkit-scrollbar-thumb {\n    background: ${colors.brand.dark};\n    border-radius: ${spacing.xsmall};\n  }\n  display: inline-block;\n\n  font-size: 85%;\n  max-width: 100%;\n\n  padding-left: ${spacing.xxsmall};\n  padding-right: ${spacing.xxsmall};\n\n  vertical-align: top;\n  table-layout: fixed;\n  overflow-x: auto;\n\n  // optional - enable iOS momentum scrolling\n  -webkit-overflow-scrolling: touch;\n\n  // scrolling shadows on left/right\n  &:after,\n  &:before {\n    content: \"\";\n    display: table;\n    clear: both;\n  }\n\n  > caption {\n    background-color: transparent;\n    font-weight: ${fonts.weight.bold};\n    font-family: ${fonts.sans};\n    ${fonts.sizes(\"16px\", \"20px\")}\n    text-align: left;\n    text-transform: uppercase;\n    margin-bottom: ${spacing.small};\n  }\n\n  thead {\n    overflow: hidden;\n  }\n\n  thead tr td,\n  th {\n    font-weight: ${fonts.weight.bold};\n    border-bottom: 3px solid ${colors.brand.tertiary};\n    font-family: ${fonts.sans};\n    vertical-align: text-top;\n\n    ${fonts.sizes(\"16px\", \"22px\")};\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes(\"16px\", \"30px\")};\n    }\n  }\n\n  tbody th {\n    border-bottom: 0;\n    border-right: 3px solid ${colors.brand.tertiary};\n    padding: ${spacing.xsmall};\n  }\n\n  thead tr:nth-child(2) th {\n    border: 1px solid ${colors.brand.lighter};\n    text-transform: none;\n\n    ${fonts.sizes(\"14px\", \"18px\")};\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes(\"15px\", \"26px\")};\n    }\n\n    font-weight: ${fonts.weight.semibold};\n    height: 40px;\n    background-color: ${colors.brand.lighter};\n    padding: ${spacing.xxsmall} ${spacing.normal} ${spacing.xxsmall} ${spacing.xsmall};\n\n    &:empty {\n      background-color: transparent;\n    }\n  }\n\n  td {\n    border: 1px solid ${colors.brand.lighter};\n    vertical-align: top;\n\n    ${fonts.sizes(\"14px\", \"22px\")};\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes(\"15px\", \"30px\")};\n    }\n\n    ol,\n    ul {\n      li,\n      li p {\n        ${fonts.sizes(\"14px\", \"22px\")};\n        ${mq.range({ from: breakpoints.tablet })} {\n          ${fonts.sizes(\"15px\", \"30px\")};\n        }\n        margin: ${spacing.xsmall} 0 !important;\n      }\n    }\n\n    p {\n      line-height: 1.6em;\n    }\n\n    p:last-child {\n      margin: 0;\n    }\n\n    img {\n      max-width: 100%;\n      min-width: 120px;\n    }\n  }\n\n  td,\n  th {\n    display: table-cell;\n    padding: ${spacing.xsmall} ${spacing.small};\n\n    p {\n      margin: 0;\n    }\n  }\n\n  // Remove excess spacing on headings inside table\n  h1,\n  h2,\n  h3,\n  h4,\n  h5 {\n    margin-top: 0;\n  }\n\n  ul {\n    padding: 0 0 0 ${spacing.nsmall};\n  }\n`;\n\nconst TableWrapper = styled.div`\n  display: flex;\n  justify-content: center;\n`;\n\nconst OverflowWrapper = styled.div`\n  position: relative;\n  overflow-x: auto;\n`;\n\nconst Table = ({ children, id, ...rest }: Props) => {\n  const [scrollPosition, setScrollPosition] = useState<ScrollPosition | undefined>(undefined);\n  const tableRef = useRef<HTMLTableElement>(null);\n\n  const checkScrollPosition = useCallback((el: HTMLTableElement) => {\n    const { scrollLeft, offsetWidth, scrollWidth, clientWidth } = el;\n    const hasScrollbar = scrollWidth > clientWidth;\n\n    if (!hasScrollbar) {\n      setScrollPosition(undefined);\n      return;\n    }\n\n    const isStart = scrollLeft <= MARGIN;\n    const isEnd = offsetWidth + scrollLeft >= scrollWidth - MARGIN;\n\n    if (isStart) {\n      setScrollPosition(\"start\");\n    } else if (isEnd) {\n      setScrollPosition(\"end\");\n    } else {\n      setScrollPosition(\"center\");\n    }\n  }, []);\n\n  const onScroll = useMemo(\n    () =>\n      throttle((event: UIEvent<HTMLTableElement>) => {\n        const el = event.target as HTMLTableElement | undefined;\n        if (el) {\n          checkScrollPosition(el);\n        }\n      }, 100),\n    [checkScrollPosition],\n  );\n\n  useEffect(() => {\n    const el = tableRef.current;\n    if (el) {\n      checkScrollPosition(el);\n    }\n  }, [checkScrollPosition]);\n\n  return (\n    <TableWrapper>\n      <OverflowWrapper>\n        <LeftScrollBorder data-block={scrollPosition === \"end\" || scrollPosition === \"center\"} />\n        <table ref={tableRef} id={id} onScroll={onScroll} css={TableStyling} {...rest}>\n          {children}\n        </table>\n        <RightScrollBorder data-block={scrollPosition === \"start\" || scrollPosition === \"center\"} />\n      </OverflowWrapper>\n    </TableWrapper>\n  );\n};\n\nexport default Table;\n"]} */",
42
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Table.tsx"],"names":[],"mappings":"AA4C6C","file":"Table.tsx","sourcesContent":["/**\n * Copyright (c) 2016-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport throttle from \"lodash.throttle\";\nimport { ReactNode, UIEvent, useCallback, useEffect, useMemo, useRef, useState } from \"react\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, fonts, mq, spacing } from \"@ndla/core\";\n\ntype ScrollPosition = \"start\" | \"end\" | \"center\";\n\nconst MARGIN = 5;\n\ninterface Props {\n  id?: string;\n  children?: ReactNode;\n  dangerouslySetInnerHTML?: {\n    __html: string;\n  };\n  lang?: string;\n}\n\nconst ScrollBorder = styled.div`\n  position: absolute;\n  top: 0;\n  height: calc(100% - ${spacing.mediumlarge});\n  width: 3px;\n  background: ${colors.background.dark};\n  display: none;\n\n  &[data-block=\"true\"] {\n    display: block;\n  }\n`;\n\nconst RightScrollBorder = styled(ScrollBorder)`\n  right: 0;\n`;\n\nconst LeftScrollBorder = styled(ScrollBorder)`\n  left: 0;\n`;\n\nexport const TableStyling = css`\n  &::-webkit-scrollbar {\n    height: ${spacing.xsmall};\n  }\n  &::-webkit-scrollbar-track-piece {\n    background: ${colors.brand.lighter};\n    border-radius: ${spacing.xsmall};\n  }\n  &::-webkit-scrollbar-thumb {\n    background: ${colors.brand.dark};\n    border-radius: ${spacing.xsmall};\n  }\n  display: inline-block;\n\n  font-size: 85%;\n  max-width: 100%;\n\n  padding-left: ${spacing.xxsmall};\n  padding-right: ${spacing.xxsmall};\n\n  vertical-align: top;\n  table-layout: fixed;\n  overflow-x: auto;\n\n  // optional - enable iOS momentum scrolling\n  -webkit-overflow-scrolling: touch;\n\n  // scrolling shadows on left/right\n  &:after,\n  &:before {\n    content: \"\";\n    display: table;\n    clear: both;\n  }\n\n  > caption {\n    background-color: transparent;\n    font-weight: ${fonts.weight.bold};\n    font-family: ${fonts.sans};\n    ${fonts.sizes(\"16px\", \"20px\")}\n    text-align: left;\n    text-transform: uppercase;\n    margin-bottom: ${spacing.small};\n  }\n\n  thead {\n    overflow: hidden;\n  }\n\n  thead tr td,\n  th {\n    font-weight: ${fonts.weight.bold};\n    border-bottom: 3px solid ${colors.brand.tertiary};\n    font-family: ${fonts.sans};\n    vertical-align: text-top;\n\n    ${fonts.sizes(\"16px\", \"22px\")};\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes(\"16px\", \"30px\")};\n    }\n  }\n\n  tbody th {\n    border-bottom: 0;\n    border-right: 3px solid ${colors.brand.tertiary};\n    padding: ${spacing.xsmall};\n  }\n\n  thead tr:nth-child(2) th {\n    border: 1px solid ${colors.brand.lighter};\n    text-transform: none;\n\n    ${fonts.sizes(\"14px\", \"18px\")};\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes(\"15px\", \"26px\")};\n    }\n\n    font-weight: ${fonts.weight.semibold};\n    height: 40px;\n    background-color: ${colors.brand.lighter};\n    padding: ${spacing.xxsmall} ${spacing.normal} ${spacing.xxsmall} ${spacing.xsmall};\n\n    &:empty {\n      background-color: transparent;\n    }\n  }\n\n  td {\n    border: 1px solid ${colors.brand.lighter};\n    vertical-align: top;\n\n    ${fonts.sizes(\"14px\", \"22px\")};\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes(\"15px\", \"30px\")};\n    }\n\n    ol,\n    ul {\n      li,\n      li p {\n        ${fonts.sizes(\"14px\", \"22px\")};\n        ${mq.range({ from: breakpoints.tablet })} {\n          ${fonts.sizes(\"15px\", \"30px\")};\n        }\n        margin: ${spacing.xsmall} 0 !important;\n      }\n    }\n\n    p {\n      line-height: 1.6em;\n    }\n\n    p:last-child {\n      margin: 0;\n    }\n\n    img {\n      max-width: 100%;\n      min-width: 120px;\n    }\n  }\n\n  td,\n  th {\n    display: table-cell;\n    padding: ${spacing.xsmall} ${spacing.small};\n\n    p {\n      margin: 0;\n    }\n  }\n\n  // Remove excess spacing on headings inside table\n  h1,\n  h2,\n  h3,\n  h4,\n  h5 {\n    margin-top: 0;\n  }\n\n  ul {\n    padding: 0 0 0 ${spacing.nsmall};\n  }\n\n  figure {\n    margin: 0;\n    padding: 0;\n    width: 100% !important;\n    left: 0 !important;\n  }\n`;\n\nconst TableWrapper = styled.div`\n  display: flex;\n  justify-content: center;\n`;\n\nconst OverflowWrapper = styled.div`\n  position: relative;\n  overflow-x: auto;\n`;\n\nconst Table = ({ children, id, ...rest }: Props) => {\n  const [scrollPosition, setScrollPosition] = useState<ScrollPosition | undefined>(undefined);\n  const tableRef = useRef<HTMLTableElement>(null);\n\n  const checkScrollPosition = useCallback((el: HTMLTableElement) => {\n    const { scrollLeft, offsetWidth, scrollWidth, clientWidth } = el;\n    const hasScrollbar = scrollWidth > clientWidth;\n\n    if (!hasScrollbar) {\n      setScrollPosition(undefined);\n      return;\n    }\n\n    const isStart = scrollLeft <= MARGIN;\n    const isEnd = offsetWidth + scrollLeft >= scrollWidth - MARGIN;\n\n    if (isStart) {\n      setScrollPosition(\"start\");\n    } else if (isEnd) {\n      setScrollPosition(\"end\");\n    } else {\n      setScrollPosition(\"center\");\n    }\n  }, []);\n\n  const onScroll = useMemo(\n    () =>\n      throttle((event: UIEvent<HTMLTableElement>) => {\n        const el = event.target as HTMLTableElement | undefined;\n        if (el) {\n          checkScrollPosition(el);\n        }\n      }, 100),\n    [checkScrollPosition],\n  );\n\n  useEffect(() => {\n    const el = tableRef.current;\n    if (el) {\n      checkScrollPosition(el);\n    }\n  }, [checkScrollPosition]);\n\n  return (\n    <TableWrapper>\n      <OverflowWrapper>\n        <LeftScrollBorder data-block={scrollPosition === \"end\" || scrollPosition === \"center\"} />\n        <table ref={tableRef} id={id} onScroll={onScroll} css={TableStyling} {...rest}>\n          {children}\n        </table>\n        <RightScrollBorder data-block={scrollPosition === \"start\" || scrollPosition === \"center\"} />\n      </OverflowWrapper>\n    </TableWrapper>\n  );\n};\n\nexport default Table;\n"]} */",
43
43
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
44
44
  });
45
45
  export const TableStyling = /*#__PURE__*/css("&::-webkit-scrollbar{height:", spacing.xsmall, ";}&::-webkit-scrollbar-track-piece{background:", colors.brand.lighter, ";border-radius:", spacing.xsmall, ";}&::-webkit-scrollbar-thumb{background:", colors.brand.dark, ";border-radius:", spacing.xsmall, ";}display:inline-block;font-size:85%;max-width:100%;padding-left:", spacing.xxsmall, ";padding-right:", spacing.xxsmall, ";vertical-align:top;table-layout:fixed;overflow-x:auto;-webkit-overflow-scrolling:touch;&:after,&:before{content:\"\";display:table;clear:both;}>caption{background-color:transparent;font-weight:", fonts.weight.bold, ";font-family:", fonts.sans, ";", fonts.sizes("16px", "20px"), " text-align:left;text-transform:uppercase;margin-bottom:", spacing.small, ";}thead{overflow:hidden;}thead tr td,th{font-weight:", fonts.weight.bold, ";border-bottom:3px solid ", colors.brand.tertiary, ";font-family:", fonts.sans, ";vertical-align:text-top;", fonts.sizes("16px", "22px"), ";", mq.range({
@@ -50,7 +50,7 @@ export const TableStyling = /*#__PURE__*/css("&::-webkit-scrollbar{height:", spa
50
50
  from: breakpoints.tablet
51
51
  }), "{", fonts.sizes("15px", "30px"), ";}ol,ul{li,li p{", fonts.sizes("14px", "22px"), ";margin:", spacing.xsmall, " 0!important;", mq.range({
52
52
  from: breakpoints.tablet
53
- }), "{", fonts.sizes("15px", "30px"), ";}}}p{line-height:1.6em;}p:last-child{margin:0;}img{max-width:100%;min-width:120px;}}td,th{display:table-cell;padding:", spacing.xsmall, " ", spacing.small, ";p{margin:0;}}h1,h2,h3,h4,h5{margin-top:0;}ul{padding:0 0 0 ", spacing.nsmall, ";};label:TableStyling;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Table.tsx"],"names":[],"mappings":"AAgD+B","file":"Table.tsx","sourcesContent":["/**\n * Copyright (c) 2016-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport throttle from \"lodash.throttle\";\nimport { ReactNode, UIEvent, useCallback, useEffect, useMemo, useRef, useState } from \"react\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, fonts, mq, spacing } from \"@ndla/core\";\n\ntype ScrollPosition = \"start\" | \"end\" | \"center\";\n\nconst MARGIN = 5;\n\ninterface Props {\n  id?: string;\n  children?: ReactNode;\n  dangerouslySetInnerHTML?: {\n    __html: string;\n  };\n  lang?: string;\n}\n\nconst ScrollBorder = styled.div`\n  position: absolute;\n  top: 0;\n  height: calc(100% - ${spacing.mediumlarge});\n  width: 3px;\n  background: ${colors.background.dark};\n  display: none;\n\n  &[data-block=\"true\"] {\n    display: block;\n  }\n`;\n\nconst RightScrollBorder = styled(ScrollBorder)`\n  right: 0;\n`;\n\nconst LeftScrollBorder = styled(ScrollBorder)`\n  left: 0;\n`;\n\nexport const TableStyling = css`\n  &::-webkit-scrollbar {\n    height: ${spacing.xsmall};\n  }\n  &::-webkit-scrollbar-track-piece {\n    background: ${colors.brand.lighter};\n    border-radius: ${spacing.xsmall};\n  }\n  &::-webkit-scrollbar-thumb {\n    background: ${colors.brand.dark};\n    border-radius: ${spacing.xsmall};\n  }\n  display: inline-block;\n\n  font-size: 85%;\n  max-width: 100%;\n\n  padding-left: ${spacing.xxsmall};\n  padding-right: ${spacing.xxsmall};\n\n  vertical-align: top;\n  table-layout: fixed;\n  overflow-x: auto;\n\n  // optional - enable iOS momentum scrolling\n  -webkit-overflow-scrolling: touch;\n\n  // scrolling shadows on left/right\n  &:after,\n  &:before {\n    content: \"\";\n    display: table;\n    clear: both;\n  }\n\n  > caption {\n    background-color: transparent;\n    font-weight: ${fonts.weight.bold};\n    font-family: ${fonts.sans};\n    ${fonts.sizes(\"16px\", \"20px\")}\n    text-align: left;\n    text-transform: uppercase;\n    margin-bottom: ${spacing.small};\n  }\n\n  thead {\n    overflow: hidden;\n  }\n\n  thead tr td,\n  th {\n    font-weight: ${fonts.weight.bold};\n    border-bottom: 3px solid ${colors.brand.tertiary};\n    font-family: ${fonts.sans};\n    vertical-align: text-top;\n\n    ${fonts.sizes(\"16px\", \"22px\")};\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes(\"16px\", \"30px\")};\n    }\n  }\n\n  tbody th {\n    border-bottom: 0;\n    border-right: 3px solid ${colors.brand.tertiary};\n    padding: ${spacing.xsmall};\n  }\n\n  thead tr:nth-child(2) th {\n    border: 1px solid ${colors.brand.lighter};\n    text-transform: none;\n\n    ${fonts.sizes(\"14px\", \"18px\")};\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes(\"15px\", \"26px\")};\n    }\n\n    font-weight: ${fonts.weight.semibold};\n    height: 40px;\n    background-color: ${colors.brand.lighter};\n    padding: ${spacing.xxsmall} ${spacing.normal} ${spacing.xxsmall} ${spacing.xsmall};\n\n    &:empty {\n      background-color: transparent;\n    }\n  }\n\n  td {\n    border: 1px solid ${colors.brand.lighter};\n    vertical-align: top;\n\n    ${fonts.sizes(\"14px\", \"22px\")};\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes(\"15px\", \"30px\")};\n    }\n\n    ol,\n    ul {\n      li,\n      li p {\n        ${fonts.sizes(\"14px\", \"22px\")};\n        ${mq.range({ from: breakpoints.tablet })} {\n          ${fonts.sizes(\"15px\", \"30px\")};\n        }\n        margin: ${spacing.xsmall} 0 !important;\n      }\n    }\n\n    p {\n      line-height: 1.6em;\n    }\n\n    p:last-child {\n      margin: 0;\n    }\n\n    img {\n      max-width: 100%;\n      min-width: 120px;\n    }\n  }\n\n  td,\n  th {\n    display: table-cell;\n    padding: ${spacing.xsmall} ${spacing.small};\n\n    p {\n      margin: 0;\n    }\n  }\n\n  // Remove excess spacing on headings inside table\n  h1,\n  h2,\n  h3,\n  h4,\n  h5 {\n    margin-top: 0;\n  }\n\n  ul {\n    padding: 0 0 0 ${spacing.nsmall};\n  }\n`;\n\nconst TableWrapper = styled.div`\n  display: flex;\n  justify-content: center;\n`;\n\nconst OverflowWrapper = styled.div`\n  position: relative;\n  overflow-x: auto;\n`;\n\nconst Table = ({ children, id, ...rest }: Props) => {\n  const [scrollPosition, setScrollPosition] = useState<ScrollPosition | undefined>(undefined);\n  const tableRef = useRef<HTMLTableElement>(null);\n\n  const checkScrollPosition = useCallback((el: HTMLTableElement) => {\n    const { scrollLeft, offsetWidth, scrollWidth, clientWidth } = el;\n    const hasScrollbar = scrollWidth > clientWidth;\n\n    if (!hasScrollbar) {\n      setScrollPosition(undefined);\n      return;\n    }\n\n    const isStart = scrollLeft <= MARGIN;\n    const isEnd = offsetWidth + scrollLeft >= scrollWidth - MARGIN;\n\n    if (isStart) {\n      setScrollPosition(\"start\");\n    } else if (isEnd) {\n      setScrollPosition(\"end\");\n    } else {\n      setScrollPosition(\"center\");\n    }\n  }, []);\n\n  const onScroll = useMemo(\n    () =>\n      throttle((event: UIEvent<HTMLTableElement>) => {\n        const el = event.target as HTMLTableElement | undefined;\n        if (el) {\n          checkScrollPosition(el);\n        }\n      }, 100),\n    [checkScrollPosition],\n  );\n\n  useEffect(() => {\n    const el = tableRef.current;\n    if (el) {\n      checkScrollPosition(el);\n    }\n  }, [checkScrollPosition]);\n\n  return (\n    <TableWrapper>\n      <OverflowWrapper>\n        <LeftScrollBorder data-block={scrollPosition === \"end\" || scrollPosition === \"center\"} />\n        <table ref={tableRef} id={id} onScroll={onScroll} css={TableStyling} {...rest}>\n          {children}\n        </table>\n        <RightScrollBorder data-block={scrollPosition === \"start\" || scrollPosition === \"center\"} />\n      </OverflowWrapper>\n    </TableWrapper>\n  );\n};\n\nexport default Table;\n"]} */"));
53
+ }), "{", fonts.sizes("15px", "30px"), ";}}}p{line-height:1.6em;}p:last-child{margin:0;}img{max-width:100%;min-width:120px;}}td,th{display:table-cell;padding:", spacing.xsmall, " ", spacing.small, ";p{margin:0;}}h1,h2,h3,h4,h5{margin-top:0;}ul{padding:0 0 0 ", spacing.nsmall, ";}figure{margin:0;padding:0;width:100%!important;left:0!important;};label:TableStyling;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Table.tsx"],"names":[],"mappings":"AAgD+B","file":"Table.tsx","sourcesContent":["/**\n * Copyright (c) 2016-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport throttle from \"lodash.throttle\";\nimport { ReactNode, UIEvent, useCallback, useEffect, useMemo, useRef, useState } from \"react\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, fonts, mq, spacing } from \"@ndla/core\";\n\ntype ScrollPosition = \"start\" | \"end\" | \"center\";\n\nconst MARGIN = 5;\n\ninterface Props {\n  id?: string;\n  children?: ReactNode;\n  dangerouslySetInnerHTML?: {\n    __html: string;\n  };\n  lang?: string;\n}\n\nconst ScrollBorder = styled.div`\n  position: absolute;\n  top: 0;\n  height: calc(100% - ${spacing.mediumlarge});\n  width: 3px;\n  background: ${colors.background.dark};\n  display: none;\n\n  &[data-block=\"true\"] {\n    display: block;\n  }\n`;\n\nconst RightScrollBorder = styled(ScrollBorder)`\n  right: 0;\n`;\n\nconst LeftScrollBorder = styled(ScrollBorder)`\n  left: 0;\n`;\n\nexport const TableStyling = css`\n  &::-webkit-scrollbar {\n    height: ${spacing.xsmall};\n  }\n  &::-webkit-scrollbar-track-piece {\n    background: ${colors.brand.lighter};\n    border-radius: ${spacing.xsmall};\n  }\n  &::-webkit-scrollbar-thumb {\n    background: ${colors.brand.dark};\n    border-radius: ${spacing.xsmall};\n  }\n  display: inline-block;\n\n  font-size: 85%;\n  max-width: 100%;\n\n  padding-left: ${spacing.xxsmall};\n  padding-right: ${spacing.xxsmall};\n\n  vertical-align: top;\n  table-layout: fixed;\n  overflow-x: auto;\n\n  // optional - enable iOS momentum scrolling\n  -webkit-overflow-scrolling: touch;\n\n  // scrolling shadows on left/right\n  &:after,\n  &:before {\n    content: \"\";\n    display: table;\n    clear: both;\n  }\n\n  > caption {\n    background-color: transparent;\n    font-weight: ${fonts.weight.bold};\n    font-family: ${fonts.sans};\n    ${fonts.sizes(\"16px\", \"20px\")}\n    text-align: left;\n    text-transform: uppercase;\n    margin-bottom: ${spacing.small};\n  }\n\n  thead {\n    overflow: hidden;\n  }\n\n  thead tr td,\n  th {\n    font-weight: ${fonts.weight.bold};\n    border-bottom: 3px solid ${colors.brand.tertiary};\n    font-family: ${fonts.sans};\n    vertical-align: text-top;\n\n    ${fonts.sizes(\"16px\", \"22px\")};\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes(\"16px\", \"30px\")};\n    }\n  }\n\n  tbody th {\n    border-bottom: 0;\n    border-right: 3px solid ${colors.brand.tertiary};\n    padding: ${spacing.xsmall};\n  }\n\n  thead tr:nth-child(2) th {\n    border: 1px solid ${colors.brand.lighter};\n    text-transform: none;\n\n    ${fonts.sizes(\"14px\", \"18px\")};\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes(\"15px\", \"26px\")};\n    }\n\n    font-weight: ${fonts.weight.semibold};\n    height: 40px;\n    background-color: ${colors.brand.lighter};\n    padding: ${spacing.xxsmall} ${spacing.normal} ${spacing.xxsmall} ${spacing.xsmall};\n\n    &:empty {\n      background-color: transparent;\n    }\n  }\n\n  td {\n    border: 1px solid ${colors.brand.lighter};\n    vertical-align: top;\n\n    ${fonts.sizes(\"14px\", \"22px\")};\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes(\"15px\", \"30px\")};\n    }\n\n    ol,\n    ul {\n      li,\n      li p {\n        ${fonts.sizes(\"14px\", \"22px\")};\n        ${mq.range({ from: breakpoints.tablet })} {\n          ${fonts.sizes(\"15px\", \"30px\")};\n        }\n        margin: ${spacing.xsmall} 0 !important;\n      }\n    }\n\n    p {\n      line-height: 1.6em;\n    }\n\n    p:last-child {\n      margin: 0;\n    }\n\n    img {\n      max-width: 100%;\n      min-width: 120px;\n    }\n  }\n\n  td,\n  th {\n    display: table-cell;\n    padding: ${spacing.xsmall} ${spacing.small};\n\n    p {\n      margin: 0;\n    }\n  }\n\n  // Remove excess spacing on headings inside table\n  h1,\n  h2,\n  h3,\n  h4,\n  h5 {\n    margin-top: 0;\n  }\n\n  ul {\n    padding: 0 0 0 ${spacing.nsmall};\n  }\n\n  figure {\n    margin: 0;\n    padding: 0;\n    width: 100% !important;\n    left: 0 !important;\n  }\n`;\n\nconst TableWrapper = styled.div`\n  display: flex;\n  justify-content: center;\n`;\n\nconst OverflowWrapper = styled.div`\n  position: relative;\n  overflow-x: auto;\n`;\n\nconst Table = ({ children, id, ...rest }: Props) => {\n  const [scrollPosition, setScrollPosition] = useState<ScrollPosition | undefined>(undefined);\n  const tableRef = useRef<HTMLTableElement>(null);\n\n  const checkScrollPosition = useCallback((el: HTMLTableElement) => {\n    const { scrollLeft, offsetWidth, scrollWidth, clientWidth } = el;\n    const hasScrollbar = scrollWidth > clientWidth;\n\n    if (!hasScrollbar) {\n      setScrollPosition(undefined);\n      return;\n    }\n\n    const isStart = scrollLeft <= MARGIN;\n    const isEnd = offsetWidth + scrollLeft >= scrollWidth - MARGIN;\n\n    if (isStart) {\n      setScrollPosition(\"start\");\n    } else if (isEnd) {\n      setScrollPosition(\"end\");\n    } else {\n      setScrollPosition(\"center\");\n    }\n  }, []);\n\n  const onScroll = useMemo(\n    () =>\n      throttle((event: UIEvent<HTMLTableElement>) => {\n        const el = event.target as HTMLTableElement | undefined;\n        if (el) {\n          checkScrollPosition(el);\n        }\n      }, 100),\n    [checkScrollPosition],\n  );\n\n  useEffect(() => {\n    const el = tableRef.current;\n    if (el) {\n      checkScrollPosition(el);\n    }\n  }, [checkScrollPosition]);\n\n  return (\n    <TableWrapper>\n      <OverflowWrapper>\n        <LeftScrollBorder data-block={scrollPosition === \"end\" || scrollPosition === \"center\"} />\n        <table ref={tableRef} id={id} onScroll={onScroll} css={TableStyling} {...rest}>\n          {children}\n        </table>\n        <RightScrollBorder data-block={scrollPosition === \"start\" || scrollPosition === \"center\"} />\n      </OverflowWrapper>\n    </TableWrapper>\n  );\n};\n\nexport default Table;\n"]} */"));
54
54
  const TableWrapper = /*#__PURE__*/_styled("div", {
55
55
  target: "e69565p1",
56
56
  label: "TableWrapper"
@@ -60,7 +60,7 @@ const TableWrapper = /*#__PURE__*/_styled("div", {
60
60
  } : {
61
61
  name: "zl1inp",
62
62
  styles: "display:flex;justify-content:center",
63
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Table.tsx"],"names":[],"mappings":"AAkM+B","file":"Table.tsx","sourcesContent":["/**\n * Copyright (c) 2016-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport throttle from \"lodash.throttle\";\nimport { ReactNode, UIEvent, useCallback, useEffect, useMemo, useRef, useState } from \"react\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, fonts, mq, spacing } from \"@ndla/core\";\n\ntype ScrollPosition = \"start\" | \"end\" | \"center\";\n\nconst MARGIN = 5;\n\ninterface Props {\n  id?: string;\n  children?: ReactNode;\n  dangerouslySetInnerHTML?: {\n    __html: string;\n  };\n  lang?: string;\n}\n\nconst ScrollBorder = styled.div`\n  position: absolute;\n  top: 0;\n  height: calc(100% - ${spacing.mediumlarge});\n  width: 3px;\n  background: ${colors.background.dark};\n  display: none;\n\n  &[data-block=\"true\"] {\n    display: block;\n  }\n`;\n\nconst RightScrollBorder = styled(ScrollBorder)`\n  right: 0;\n`;\n\nconst LeftScrollBorder = styled(ScrollBorder)`\n  left: 0;\n`;\n\nexport const TableStyling = css`\n  &::-webkit-scrollbar {\n    height: ${spacing.xsmall};\n  }\n  &::-webkit-scrollbar-track-piece {\n    background: ${colors.brand.lighter};\n    border-radius: ${spacing.xsmall};\n  }\n  &::-webkit-scrollbar-thumb {\n    background: ${colors.brand.dark};\n    border-radius: ${spacing.xsmall};\n  }\n  display: inline-block;\n\n  font-size: 85%;\n  max-width: 100%;\n\n  padding-left: ${spacing.xxsmall};\n  padding-right: ${spacing.xxsmall};\n\n  vertical-align: top;\n  table-layout: fixed;\n  overflow-x: auto;\n\n  // optional - enable iOS momentum scrolling\n  -webkit-overflow-scrolling: touch;\n\n  // scrolling shadows on left/right\n  &:after,\n  &:before {\n    content: \"\";\n    display: table;\n    clear: both;\n  }\n\n  > caption {\n    background-color: transparent;\n    font-weight: ${fonts.weight.bold};\n    font-family: ${fonts.sans};\n    ${fonts.sizes(\"16px\", \"20px\")}\n    text-align: left;\n    text-transform: uppercase;\n    margin-bottom: ${spacing.small};\n  }\n\n  thead {\n    overflow: hidden;\n  }\n\n  thead tr td,\n  th {\n    font-weight: ${fonts.weight.bold};\n    border-bottom: 3px solid ${colors.brand.tertiary};\n    font-family: ${fonts.sans};\n    vertical-align: text-top;\n\n    ${fonts.sizes(\"16px\", \"22px\")};\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes(\"16px\", \"30px\")};\n    }\n  }\n\n  tbody th {\n    border-bottom: 0;\n    border-right: 3px solid ${colors.brand.tertiary};\n    padding: ${spacing.xsmall};\n  }\n\n  thead tr:nth-child(2) th {\n    border: 1px solid ${colors.brand.lighter};\n    text-transform: none;\n\n    ${fonts.sizes(\"14px\", \"18px\")};\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes(\"15px\", \"26px\")};\n    }\n\n    font-weight: ${fonts.weight.semibold};\n    height: 40px;\n    background-color: ${colors.brand.lighter};\n    padding: ${spacing.xxsmall} ${spacing.normal} ${spacing.xxsmall} ${spacing.xsmall};\n\n    &:empty {\n      background-color: transparent;\n    }\n  }\n\n  td {\n    border: 1px solid ${colors.brand.lighter};\n    vertical-align: top;\n\n    ${fonts.sizes(\"14px\", \"22px\")};\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes(\"15px\", \"30px\")};\n    }\n\n    ol,\n    ul {\n      li,\n      li p {\n        ${fonts.sizes(\"14px\", \"22px\")};\n        ${mq.range({ from: breakpoints.tablet })} {\n          ${fonts.sizes(\"15px\", \"30px\")};\n        }\n        margin: ${spacing.xsmall} 0 !important;\n      }\n    }\n\n    p {\n      line-height: 1.6em;\n    }\n\n    p:last-child {\n      margin: 0;\n    }\n\n    img {\n      max-width: 100%;\n      min-width: 120px;\n    }\n  }\n\n  td,\n  th {\n    display: table-cell;\n    padding: ${spacing.xsmall} ${spacing.small};\n\n    p {\n      margin: 0;\n    }\n  }\n\n  // Remove excess spacing on headings inside table\n  h1,\n  h2,\n  h3,\n  h4,\n  h5 {\n    margin-top: 0;\n  }\n\n  ul {\n    padding: 0 0 0 ${spacing.nsmall};\n  }\n`;\n\nconst TableWrapper = styled.div`\n  display: flex;\n  justify-content: center;\n`;\n\nconst OverflowWrapper = styled.div`\n  position: relative;\n  overflow-x: auto;\n`;\n\nconst Table = ({ children, id, ...rest }: Props) => {\n  const [scrollPosition, setScrollPosition] = useState<ScrollPosition | undefined>(undefined);\n  const tableRef = useRef<HTMLTableElement>(null);\n\n  const checkScrollPosition = useCallback((el: HTMLTableElement) => {\n    const { scrollLeft, offsetWidth, scrollWidth, clientWidth } = el;\n    const hasScrollbar = scrollWidth > clientWidth;\n\n    if (!hasScrollbar) {\n      setScrollPosition(undefined);\n      return;\n    }\n\n    const isStart = scrollLeft <= MARGIN;\n    const isEnd = offsetWidth + scrollLeft >= scrollWidth - MARGIN;\n\n    if (isStart) {\n      setScrollPosition(\"start\");\n    } else if (isEnd) {\n      setScrollPosition(\"end\");\n    } else {\n      setScrollPosition(\"center\");\n    }\n  }, []);\n\n  const onScroll = useMemo(\n    () =>\n      throttle((event: UIEvent<HTMLTableElement>) => {\n        const el = event.target as HTMLTableElement | undefined;\n        if (el) {\n          checkScrollPosition(el);\n        }\n      }, 100),\n    [checkScrollPosition],\n  );\n\n  useEffect(() => {\n    const el = tableRef.current;\n    if (el) {\n      checkScrollPosition(el);\n    }\n  }, [checkScrollPosition]);\n\n  return (\n    <TableWrapper>\n      <OverflowWrapper>\n        <LeftScrollBorder data-block={scrollPosition === \"end\" || scrollPosition === \"center\"} />\n        <table ref={tableRef} id={id} onScroll={onScroll} css={TableStyling} {...rest}>\n          {children}\n        </table>\n        <RightScrollBorder data-block={scrollPosition === \"start\" || scrollPosition === \"center\"} />\n      </OverflowWrapper>\n    </TableWrapper>\n  );\n};\n\nexport default Table;\n"]} */",
63
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Table.tsx"],"names":[],"mappings":"AAyM+B","file":"Table.tsx","sourcesContent":["/**\n * Copyright (c) 2016-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport throttle from \"lodash.throttle\";\nimport { ReactNode, UIEvent, useCallback, useEffect, useMemo, useRef, useState } from \"react\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, fonts, mq, spacing } from \"@ndla/core\";\n\ntype ScrollPosition = \"start\" | \"end\" | \"center\";\n\nconst MARGIN = 5;\n\ninterface Props {\n  id?: string;\n  children?: ReactNode;\n  dangerouslySetInnerHTML?: {\n    __html: string;\n  };\n  lang?: string;\n}\n\nconst ScrollBorder = styled.div`\n  position: absolute;\n  top: 0;\n  height: calc(100% - ${spacing.mediumlarge});\n  width: 3px;\n  background: ${colors.background.dark};\n  display: none;\n\n  &[data-block=\"true\"] {\n    display: block;\n  }\n`;\n\nconst RightScrollBorder = styled(ScrollBorder)`\n  right: 0;\n`;\n\nconst LeftScrollBorder = styled(ScrollBorder)`\n  left: 0;\n`;\n\nexport const TableStyling = css`\n  &::-webkit-scrollbar {\n    height: ${spacing.xsmall};\n  }\n  &::-webkit-scrollbar-track-piece {\n    background: ${colors.brand.lighter};\n    border-radius: ${spacing.xsmall};\n  }\n  &::-webkit-scrollbar-thumb {\n    background: ${colors.brand.dark};\n    border-radius: ${spacing.xsmall};\n  }\n  display: inline-block;\n\n  font-size: 85%;\n  max-width: 100%;\n\n  padding-left: ${spacing.xxsmall};\n  padding-right: ${spacing.xxsmall};\n\n  vertical-align: top;\n  table-layout: fixed;\n  overflow-x: auto;\n\n  // optional - enable iOS momentum scrolling\n  -webkit-overflow-scrolling: touch;\n\n  // scrolling shadows on left/right\n  &:after,\n  &:before {\n    content: \"\";\n    display: table;\n    clear: both;\n  }\n\n  > caption {\n    background-color: transparent;\n    font-weight: ${fonts.weight.bold};\n    font-family: ${fonts.sans};\n    ${fonts.sizes(\"16px\", \"20px\")}\n    text-align: left;\n    text-transform: uppercase;\n    margin-bottom: ${spacing.small};\n  }\n\n  thead {\n    overflow: hidden;\n  }\n\n  thead tr td,\n  th {\n    font-weight: ${fonts.weight.bold};\n    border-bottom: 3px solid ${colors.brand.tertiary};\n    font-family: ${fonts.sans};\n    vertical-align: text-top;\n\n    ${fonts.sizes(\"16px\", \"22px\")};\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes(\"16px\", \"30px\")};\n    }\n  }\n\n  tbody th {\n    border-bottom: 0;\n    border-right: 3px solid ${colors.brand.tertiary};\n    padding: ${spacing.xsmall};\n  }\n\n  thead tr:nth-child(2) th {\n    border: 1px solid ${colors.brand.lighter};\n    text-transform: none;\n\n    ${fonts.sizes(\"14px\", \"18px\")};\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes(\"15px\", \"26px\")};\n    }\n\n    font-weight: ${fonts.weight.semibold};\n    height: 40px;\n    background-color: ${colors.brand.lighter};\n    padding: ${spacing.xxsmall} ${spacing.normal} ${spacing.xxsmall} ${spacing.xsmall};\n\n    &:empty {\n      background-color: transparent;\n    }\n  }\n\n  td {\n    border: 1px solid ${colors.brand.lighter};\n    vertical-align: top;\n\n    ${fonts.sizes(\"14px\", \"22px\")};\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes(\"15px\", \"30px\")};\n    }\n\n    ol,\n    ul {\n      li,\n      li p {\n        ${fonts.sizes(\"14px\", \"22px\")};\n        ${mq.range({ from: breakpoints.tablet })} {\n          ${fonts.sizes(\"15px\", \"30px\")};\n        }\n        margin: ${spacing.xsmall} 0 !important;\n      }\n    }\n\n    p {\n      line-height: 1.6em;\n    }\n\n    p:last-child {\n      margin: 0;\n    }\n\n    img {\n      max-width: 100%;\n      min-width: 120px;\n    }\n  }\n\n  td,\n  th {\n    display: table-cell;\n    padding: ${spacing.xsmall} ${spacing.small};\n\n    p {\n      margin: 0;\n    }\n  }\n\n  // Remove excess spacing on headings inside table\n  h1,\n  h2,\n  h3,\n  h4,\n  h5 {\n    margin-top: 0;\n  }\n\n  ul {\n    padding: 0 0 0 ${spacing.nsmall};\n  }\n\n  figure {\n    margin: 0;\n    padding: 0;\n    width: 100% !important;\n    left: 0 !important;\n  }\n`;\n\nconst TableWrapper = styled.div`\n  display: flex;\n  justify-content: center;\n`;\n\nconst OverflowWrapper = styled.div`\n  position: relative;\n  overflow-x: auto;\n`;\n\nconst Table = ({ children, id, ...rest }: Props) => {\n  const [scrollPosition, setScrollPosition] = useState<ScrollPosition | undefined>(undefined);\n  const tableRef = useRef<HTMLTableElement>(null);\n\n  const checkScrollPosition = useCallback((el: HTMLTableElement) => {\n    const { scrollLeft, offsetWidth, scrollWidth, clientWidth } = el;\n    const hasScrollbar = scrollWidth > clientWidth;\n\n    if (!hasScrollbar) {\n      setScrollPosition(undefined);\n      return;\n    }\n\n    const isStart = scrollLeft <= MARGIN;\n    const isEnd = offsetWidth + scrollLeft >= scrollWidth - MARGIN;\n\n    if (isStart) {\n      setScrollPosition(\"start\");\n    } else if (isEnd) {\n      setScrollPosition(\"end\");\n    } else {\n      setScrollPosition(\"center\");\n    }\n  }, []);\n\n  const onScroll = useMemo(\n    () =>\n      throttle((event: UIEvent<HTMLTableElement>) => {\n        const el = event.target as HTMLTableElement | undefined;\n        if (el) {\n          checkScrollPosition(el);\n        }\n      }, 100),\n    [checkScrollPosition],\n  );\n\n  useEffect(() => {\n    const el = tableRef.current;\n    if (el) {\n      checkScrollPosition(el);\n    }\n  }, [checkScrollPosition]);\n\n  return (\n    <TableWrapper>\n      <OverflowWrapper>\n        <LeftScrollBorder data-block={scrollPosition === \"end\" || scrollPosition === \"center\"} />\n        <table ref={tableRef} id={id} onScroll={onScroll} css={TableStyling} {...rest}>\n          {children}\n        </table>\n        <RightScrollBorder data-block={scrollPosition === \"start\" || scrollPosition === \"center\"} />\n      </OverflowWrapper>\n    </TableWrapper>\n  );\n};\n\nexport default Table;\n"]} */",
64
64
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
65
65
  });
66
66
  const OverflowWrapper = /*#__PURE__*/_styled("div", {
@@ -72,7 +72,7 @@ const OverflowWrapper = /*#__PURE__*/_styled("div", {
72
72
  } : {
73
73
  name: "149vo96",
74
74
  styles: "position:relative;overflow-x:auto",
75
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Table.tsx"],"names":[],"mappings":"AAuMkC","file":"Table.tsx","sourcesContent":["/**\n * Copyright (c) 2016-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport throttle from \"lodash.throttle\";\nimport { ReactNode, UIEvent, useCallback, useEffect, useMemo, useRef, useState } from \"react\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, fonts, mq, spacing } from \"@ndla/core\";\n\ntype ScrollPosition = \"start\" | \"end\" | \"center\";\n\nconst MARGIN = 5;\n\ninterface Props {\n  id?: string;\n  children?: ReactNode;\n  dangerouslySetInnerHTML?: {\n    __html: string;\n  };\n  lang?: string;\n}\n\nconst ScrollBorder = styled.div`\n  position: absolute;\n  top: 0;\n  height: calc(100% - ${spacing.mediumlarge});\n  width: 3px;\n  background: ${colors.background.dark};\n  display: none;\n\n  &[data-block=\"true\"] {\n    display: block;\n  }\n`;\n\nconst RightScrollBorder = styled(ScrollBorder)`\n  right: 0;\n`;\n\nconst LeftScrollBorder = styled(ScrollBorder)`\n  left: 0;\n`;\n\nexport const TableStyling = css`\n  &::-webkit-scrollbar {\n    height: ${spacing.xsmall};\n  }\n  &::-webkit-scrollbar-track-piece {\n    background: ${colors.brand.lighter};\n    border-radius: ${spacing.xsmall};\n  }\n  &::-webkit-scrollbar-thumb {\n    background: ${colors.brand.dark};\n    border-radius: ${spacing.xsmall};\n  }\n  display: inline-block;\n\n  font-size: 85%;\n  max-width: 100%;\n\n  padding-left: ${spacing.xxsmall};\n  padding-right: ${spacing.xxsmall};\n\n  vertical-align: top;\n  table-layout: fixed;\n  overflow-x: auto;\n\n  // optional - enable iOS momentum scrolling\n  -webkit-overflow-scrolling: touch;\n\n  // scrolling shadows on left/right\n  &:after,\n  &:before {\n    content: \"\";\n    display: table;\n    clear: both;\n  }\n\n  > caption {\n    background-color: transparent;\n    font-weight: ${fonts.weight.bold};\n    font-family: ${fonts.sans};\n    ${fonts.sizes(\"16px\", \"20px\")}\n    text-align: left;\n    text-transform: uppercase;\n    margin-bottom: ${spacing.small};\n  }\n\n  thead {\n    overflow: hidden;\n  }\n\n  thead tr td,\n  th {\n    font-weight: ${fonts.weight.bold};\n    border-bottom: 3px solid ${colors.brand.tertiary};\n    font-family: ${fonts.sans};\n    vertical-align: text-top;\n\n    ${fonts.sizes(\"16px\", \"22px\")};\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes(\"16px\", \"30px\")};\n    }\n  }\n\n  tbody th {\n    border-bottom: 0;\n    border-right: 3px solid ${colors.brand.tertiary};\n    padding: ${spacing.xsmall};\n  }\n\n  thead tr:nth-child(2) th {\n    border: 1px solid ${colors.brand.lighter};\n    text-transform: none;\n\n    ${fonts.sizes(\"14px\", \"18px\")};\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes(\"15px\", \"26px\")};\n    }\n\n    font-weight: ${fonts.weight.semibold};\n    height: 40px;\n    background-color: ${colors.brand.lighter};\n    padding: ${spacing.xxsmall} ${spacing.normal} ${spacing.xxsmall} ${spacing.xsmall};\n\n    &:empty {\n      background-color: transparent;\n    }\n  }\n\n  td {\n    border: 1px solid ${colors.brand.lighter};\n    vertical-align: top;\n\n    ${fonts.sizes(\"14px\", \"22px\")};\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes(\"15px\", \"30px\")};\n    }\n\n    ol,\n    ul {\n      li,\n      li p {\n        ${fonts.sizes(\"14px\", \"22px\")};\n        ${mq.range({ from: breakpoints.tablet })} {\n          ${fonts.sizes(\"15px\", \"30px\")};\n        }\n        margin: ${spacing.xsmall} 0 !important;\n      }\n    }\n\n    p {\n      line-height: 1.6em;\n    }\n\n    p:last-child {\n      margin: 0;\n    }\n\n    img {\n      max-width: 100%;\n      min-width: 120px;\n    }\n  }\n\n  td,\n  th {\n    display: table-cell;\n    padding: ${spacing.xsmall} ${spacing.small};\n\n    p {\n      margin: 0;\n    }\n  }\n\n  // Remove excess spacing on headings inside table\n  h1,\n  h2,\n  h3,\n  h4,\n  h5 {\n    margin-top: 0;\n  }\n\n  ul {\n    padding: 0 0 0 ${spacing.nsmall};\n  }\n`;\n\nconst TableWrapper = styled.div`\n  display: flex;\n  justify-content: center;\n`;\n\nconst OverflowWrapper = styled.div`\n  position: relative;\n  overflow-x: auto;\n`;\n\nconst Table = ({ children, id, ...rest }: Props) => {\n  const [scrollPosition, setScrollPosition] = useState<ScrollPosition | undefined>(undefined);\n  const tableRef = useRef<HTMLTableElement>(null);\n\n  const checkScrollPosition = useCallback((el: HTMLTableElement) => {\n    const { scrollLeft, offsetWidth, scrollWidth, clientWidth } = el;\n    const hasScrollbar = scrollWidth > clientWidth;\n\n    if (!hasScrollbar) {\n      setScrollPosition(undefined);\n      return;\n    }\n\n    const isStart = scrollLeft <= MARGIN;\n    const isEnd = offsetWidth + scrollLeft >= scrollWidth - MARGIN;\n\n    if (isStart) {\n      setScrollPosition(\"start\");\n    } else if (isEnd) {\n      setScrollPosition(\"end\");\n    } else {\n      setScrollPosition(\"center\");\n    }\n  }, []);\n\n  const onScroll = useMemo(\n    () =>\n      throttle((event: UIEvent<HTMLTableElement>) => {\n        const el = event.target as HTMLTableElement | undefined;\n        if (el) {\n          checkScrollPosition(el);\n        }\n      }, 100),\n    [checkScrollPosition],\n  );\n\n  useEffect(() => {\n    const el = tableRef.current;\n    if (el) {\n      checkScrollPosition(el);\n    }\n  }, [checkScrollPosition]);\n\n  return (\n    <TableWrapper>\n      <OverflowWrapper>\n        <LeftScrollBorder data-block={scrollPosition === \"end\" || scrollPosition === \"center\"} />\n        <table ref={tableRef} id={id} onScroll={onScroll} css={TableStyling} {...rest}>\n          {children}\n        </table>\n        <RightScrollBorder data-block={scrollPosition === \"start\" || scrollPosition === \"center\"} />\n      </OverflowWrapper>\n    </TableWrapper>\n  );\n};\n\nexport default Table;\n"]} */",
75
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Table.tsx"],"names":[],"mappings":"AA8MkC","file":"Table.tsx","sourcesContent":["/**\n * Copyright (c) 2016-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport throttle from \"lodash.throttle\";\nimport { ReactNode, UIEvent, useCallback, useEffect, useMemo, useRef, useState } from \"react\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, fonts, mq, spacing } from \"@ndla/core\";\n\ntype ScrollPosition = \"start\" | \"end\" | \"center\";\n\nconst MARGIN = 5;\n\ninterface Props {\n  id?: string;\n  children?: ReactNode;\n  dangerouslySetInnerHTML?: {\n    __html: string;\n  };\n  lang?: string;\n}\n\nconst ScrollBorder = styled.div`\n  position: absolute;\n  top: 0;\n  height: calc(100% - ${spacing.mediumlarge});\n  width: 3px;\n  background: ${colors.background.dark};\n  display: none;\n\n  &[data-block=\"true\"] {\n    display: block;\n  }\n`;\n\nconst RightScrollBorder = styled(ScrollBorder)`\n  right: 0;\n`;\n\nconst LeftScrollBorder = styled(ScrollBorder)`\n  left: 0;\n`;\n\nexport const TableStyling = css`\n  &::-webkit-scrollbar {\n    height: ${spacing.xsmall};\n  }\n  &::-webkit-scrollbar-track-piece {\n    background: ${colors.brand.lighter};\n    border-radius: ${spacing.xsmall};\n  }\n  &::-webkit-scrollbar-thumb {\n    background: ${colors.brand.dark};\n    border-radius: ${spacing.xsmall};\n  }\n  display: inline-block;\n\n  font-size: 85%;\n  max-width: 100%;\n\n  padding-left: ${spacing.xxsmall};\n  padding-right: ${spacing.xxsmall};\n\n  vertical-align: top;\n  table-layout: fixed;\n  overflow-x: auto;\n\n  // optional - enable iOS momentum scrolling\n  -webkit-overflow-scrolling: touch;\n\n  // scrolling shadows on left/right\n  &:after,\n  &:before {\n    content: \"\";\n    display: table;\n    clear: both;\n  }\n\n  > caption {\n    background-color: transparent;\n    font-weight: ${fonts.weight.bold};\n    font-family: ${fonts.sans};\n    ${fonts.sizes(\"16px\", \"20px\")}\n    text-align: left;\n    text-transform: uppercase;\n    margin-bottom: ${spacing.small};\n  }\n\n  thead {\n    overflow: hidden;\n  }\n\n  thead tr td,\n  th {\n    font-weight: ${fonts.weight.bold};\n    border-bottom: 3px solid ${colors.brand.tertiary};\n    font-family: ${fonts.sans};\n    vertical-align: text-top;\n\n    ${fonts.sizes(\"16px\", \"22px\")};\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes(\"16px\", \"30px\")};\n    }\n  }\n\n  tbody th {\n    border-bottom: 0;\n    border-right: 3px solid ${colors.brand.tertiary};\n    padding: ${spacing.xsmall};\n  }\n\n  thead tr:nth-child(2) th {\n    border: 1px solid ${colors.brand.lighter};\n    text-transform: none;\n\n    ${fonts.sizes(\"14px\", \"18px\")};\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes(\"15px\", \"26px\")};\n    }\n\n    font-weight: ${fonts.weight.semibold};\n    height: 40px;\n    background-color: ${colors.brand.lighter};\n    padding: ${spacing.xxsmall} ${spacing.normal} ${spacing.xxsmall} ${spacing.xsmall};\n\n    &:empty {\n      background-color: transparent;\n    }\n  }\n\n  td {\n    border: 1px solid ${colors.brand.lighter};\n    vertical-align: top;\n\n    ${fonts.sizes(\"14px\", \"22px\")};\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes(\"15px\", \"30px\")};\n    }\n\n    ol,\n    ul {\n      li,\n      li p {\n        ${fonts.sizes(\"14px\", \"22px\")};\n        ${mq.range({ from: breakpoints.tablet })} {\n          ${fonts.sizes(\"15px\", \"30px\")};\n        }\n        margin: ${spacing.xsmall} 0 !important;\n      }\n    }\n\n    p {\n      line-height: 1.6em;\n    }\n\n    p:last-child {\n      margin: 0;\n    }\n\n    img {\n      max-width: 100%;\n      min-width: 120px;\n    }\n  }\n\n  td,\n  th {\n    display: table-cell;\n    padding: ${spacing.xsmall} ${spacing.small};\n\n    p {\n      margin: 0;\n    }\n  }\n\n  // Remove excess spacing on headings inside table\n  h1,\n  h2,\n  h3,\n  h4,\n  h5 {\n    margin-top: 0;\n  }\n\n  ul {\n    padding: 0 0 0 ${spacing.nsmall};\n  }\n\n  figure {\n    margin: 0;\n    padding: 0;\n    width: 100% !important;\n    left: 0 !important;\n  }\n`;\n\nconst TableWrapper = styled.div`\n  display: flex;\n  justify-content: center;\n`;\n\nconst OverflowWrapper = styled.div`\n  position: relative;\n  overflow-x: auto;\n`;\n\nconst Table = ({ children, id, ...rest }: Props) => {\n  const [scrollPosition, setScrollPosition] = useState<ScrollPosition | undefined>(undefined);\n  const tableRef = useRef<HTMLTableElement>(null);\n\n  const checkScrollPosition = useCallback((el: HTMLTableElement) => {\n    const { scrollLeft, offsetWidth, scrollWidth, clientWidth } = el;\n    const hasScrollbar = scrollWidth > clientWidth;\n\n    if (!hasScrollbar) {\n      setScrollPosition(undefined);\n      return;\n    }\n\n    const isStart = scrollLeft <= MARGIN;\n    const isEnd = offsetWidth + scrollLeft >= scrollWidth - MARGIN;\n\n    if (isStart) {\n      setScrollPosition(\"start\");\n    } else if (isEnd) {\n      setScrollPosition(\"end\");\n    } else {\n      setScrollPosition(\"center\");\n    }\n  }, []);\n\n  const onScroll = useMemo(\n    () =>\n      throttle((event: UIEvent<HTMLTableElement>) => {\n        const el = event.target as HTMLTableElement | undefined;\n        if (el) {\n          checkScrollPosition(el);\n        }\n      }, 100),\n    [checkScrollPosition],\n  );\n\n  useEffect(() => {\n    const el = tableRef.current;\n    if (el) {\n      checkScrollPosition(el);\n    }\n  }, [checkScrollPosition]);\n\n  return (\n    <TableWrapper>\n      <OverflowWrapper>\n        <LeftScrollBorder data-block={scrollPosition === \"end\" || scrollPosition === \"center\"} />\n        <table ref={tableRef} id={id} onScroll={onScroll} css={TableStyling} {...rest}>\n          {children}\n        </table>\n        <RightScrollBorder data-block={scrollPosition === \"start\" || scrollPosition === \"center\"} />\n      </OverflowWrapper>\n    </TableWrapper>\n  );\n};\n\nexport default Table;\n"]} */",
76
76
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
77
77
  });
78
78
  const Table = _ref => {
@@ -22,7 +22,7 @@ const MARGIN = 5;
22
22
  const ScrollBorder = /*#__PURE__*/(0, _base.default)("div", {
23
23
  target: "e69565p4",
24
24
  label: "ScrollBorder"
25
- })("position:absolute;top:0;height:calc(100% - ", _core.spacing.mediumlarge, ");width:3px;background:", _core.colors.background.dark, ";display:none;&[data-block=\"true\"]{display:block;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Table.tsx"],"names":[],"mappings":"AA2B+B","file":"Table.tsx","sourcesContent":["/**\n * Copyright (c) 2016-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport throttle from \"lodash.throttle\";\nimport { ReactNode, UIEvent, useCallback, useEffect, useMemo, useRef, useState } from \"react\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, fonts, mq, spacing } from \"@ndla/core\";\n\ntype ScrollPosition = \"start\" | \"end\" | \"center\";\n\nconst MARGIN = 5;\n\ninterface Props {\n  id?: string;\n  children?: ReactNode;\n  dangerouslySetInnerHTML?: {\n    __html: string;\n  };\n  lang?: string;\n}\n\nconst ScrollBorder = styled.div`\n  position: absolute;\n  top: 0;\n  height: calc(100% - ${spacing.mediumlarge});\n  width: 3px;\n  background: ${colors.background.dark};\n  display: none;\n\n  &[data-block=\"true\"] {\n    display: block;\n  }\n`;\n\nconst RightScrollBorder = styled(ScrollBorder)`\n  right: 0;\n`;\n\nconst LeftScrollBorder = styled(ScrollBorder)`\n  left: 0;\n`;\n\nexport const TableStyling = css`\n  &::-webkit-scrollbar {\n    height: ${spacing.xsmall};\n  }\n  &::-webkit-scrollbar-track-piece {\n    background: ${colors.brand.lighter};\n    border-radius: ${spacing.xsmall};\n  }\n  &::-webkit-scrollbar-thumb {\n    background: ${colors.brand.dark};\n    border-radius: ${spacing.xsmall};\n  }\n  display: inline-block;\n\n  font-size: 85%;\n  max-width: 100%;\n\n  padding-left: ${spacing.xxsmall};\n  padding-right: ${spacing.xxsmall};\n\n  vertical-align: top;\n  table-layout: fixed;\n  overflow-x: auto;\n\n  // optional - enable iOS momentum scrolling\n  -webkit-overflow-scrolling: touch;\n\n  // scrolling shadows on left/right\n  &:after,\n  &:before {\n    content: \"\";\n    display: table;\n    clear: both;\n  }\n\n  > caption {\n    background-color: transparent;\n    font-weight: ${fonts.weight.bold};\n    font-family: ${fonts.sans};\n    ${fonts.sizes(\"16px\", \"20px\")}\n    text-align: left;\n    text-transform: uppercase;\n    margin-bottom: ${spacing.small};\n  }\n\n  thead {\n    overflow: hidden;\n  }\n\n  thead tr td,\n  th {\n    font-weight: ${fonts.weight.bold};\n    border-bottom: 3px solid ${colors.brand.tertiary};\n    font-family: ${fonts.sans};\n    vertical-align: text-top;\n\n    ${fonts.sizes(\"16px\", \"22px\")};\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes(\"16px\", \"30px\")};\n    }\n  }\n\n  tbody th {\n    border-bottom: 0;\n    border-right: 3px solid ${colors.brand.tertiary};\n    padding: ${spacing.xsmall};\n  }\n\n  thead tr:nth-child(2) th {\n    border: 1px solid ${colors.brand.lighter};\n    text-transform: none;\n\n    ${fonts.sizes(\"14px\", \"18px\")};\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes(\"15px\", \"26px\")};\n    }\n\n    font-weight: ${fonts.weight.semibold};\n    height: 40px;\n    background-color: ${colors.brand.lighter};\n    padding: ${spacing.xxsmall} ${spacing.normal} ${spacing.xxsmall} ${spacing.xsmall};\n\n    &:empty {\n      background-color: transparent;\n    }\n  }\n\n  td {\n    border: 1px solid ${colors.brand.lighter};\n    vertical-align: top;\n\n    ${fonts.sizes(\"14px\", \"22px\")};\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes(\"15px\", \"30px\")};\n    }\n\n    ol,\n    ul {\n      li,\n      li p {\n        ${fonts.sizes(\"14px\", \"22px\")};\n        ${mq.range({ from: breakpoints.tablet })} {\n          ${fonts.sizes(\"15px\", \"30px\")};\n        }\n        margin: ${spacing.xsmall} 0 !important;\n      }\n    }\n\n    p {\n      line-height: 1.6em;\n    }\n\n    p:last-child {\n      margin: 0;\n    }\n\n    img {\n      max-width: 100%;\n      min-width: 120px;\n    }\n  }\n\n  td,\n  th {\n    display: table-cell;\n    padding: ${spacing.xsmall} ${spacing.small};\n\n    p {\n      margin: 0;\n    }\n  }\n\n  // Remove excess spacing on headings inside table\n  h1,\n  h2,\n  h3,\n  h4,\n  h5 {\n    margin-top: 0;\n  }\n\n  ul {\n    padding: 0 0 0 ${spacing.nsmall};\n  }\n`;\n\nconst TableWrapper = styled.div`\n  display: flex;\n  justify-content: center;\n`;\n\nconst OverflowWrapper = styled.div`\n  position: relative;\n  overflow-x: auto;\n`;\n\nconst Table = ({ children, id, ...rest }: Props) => {\n  const [scrollPosition, setScrollPosition] = useState<ScrollPosition | undefined>(undefined);\n  const tableRef = useRef<HTMLTableElement>(null);\n\n  const checkScrollPosition = useCallback((el: HTMLTableElement) => {\n    const { scrollLeft, offsetWidth, scrollWidth, clientWidth } = el;\n    const hasScrollbar = scrollWidth > clientWidth;\n\n    if (!hasScrollbar) {\n      setScrollPosition(undefined);\n      return;\n    }\n\n    const isStart = scrollLeft <= MARGIN;\n    const isEnd = offsetWidth + scrollLeft >= scrollWidth - MARGIN;\n\n    if (isStart) {\n      setScrollPosition(\"start\");\n    } else if (isEnd) {\n      setScrollPosition(\"end\");\n    } else {\n      setScrollPosition(\"center\");\n    }\n  }, []);\n\n  const onScroll = useMemo(\n    () =>\n      throttle((event: UIEvent<HTMLTableElement>) => {\n        const el = event.target as HTMLTableElement | undefined;\n        if (el) {\n          checkScrollPosition(el);\n        }\n      }, 100),\n    [checkScrollPosition],\n  );\n\n  useEffect(() => {\n    const el = tableRef.current;\n    if (el) {\n      checkScrollPosition(el);\n    }\n  }, [checkScrollPosition]);\n\n  return (\n    <TableWrapper>\n      <OverflowWrapper>\n        <LeftScrollBorder data-block={scrollPosition === \"end\" || scrollPosition === \"center\"} />\n        <table ref={tableRef} id={id} onScroll={onScroll} css={TableStyling} {...rest}>\n          {children}\n        </table>\n        <RightScrollBorder data-block={scrollPosition === \"start\" || scrollPosition === \"center\"} />\n      </OverflowWrapper>\n    </TableWrapper>\n  );\n};\n\nexport default Table;\n"]} */"));
25
+ })("position:absolute;top:0;height:calc(100% - ", _core.spacing.mediumlarge, ");width:3px;background:", _core.colors.background.dark, ";display:none;&[data-block=\"true\"]{display:block;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Table.tsx"],"names":[],"mappings":"AA2B+B","file":"Table.tsx","sourcesContent":["/**\n * Copyright (c) 2016-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport throttle from \"lodash.throttle\";\nimport { ReactNode, UIEvent, useCallback, useEffect, useMemo, useRef, useState } from \"react\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, fonts, mq, spacing } from \"@ndla/core\";\n\ntype ScrollPosition = \"start\" | \"end\" | \"center\";\n\nconst MARGIN = 5;\n\ninterface Props {\n  id?: string;\n  children?: ReactNode;\n  dangerouslySetInnerHTML?: {\n    __html: string;\n  };\n  lang?: string;\n}\n\nconst ScrollBorder = styled.div`\n  position: absolute;\n  top: 0;\n  height: calc(100% - ${spacing.mediumlarge});\n  width: 3px;\n  background: ${colors.background.dark};\n  display: none;\n\n  &[data-block=\"true\"] {\n    display: block;\n  }\n`;\n\nconst RightScrollBorder = styled(ScrollBorder)`\n  right: 0;\n`;\n\nconst LeftScrollBorder = styled(ScrollBorder)`\n  left: 0;\n`;\n\nexport const TableStyling = css`\n  &::-webkit-scrollbar {\n    height: ${spacing.xsmall};\n  }\n  &::-webkit-scrollbar-track-piece {\n    background: ${colors.brand.lighter};\n    border-radius: ${spacing.xsmall};\n  }\n  &::-webkit-scrollbar-thumb {\n    background: ${colors.brand.dark};\n    border-radius: ${spacing.xsmall};\n  }\n  display: inline-block;\n\n  font-size: 85%;\n  max-width: 100%;\n\n  padding-left: ${spacing.xxsmall};\n  padding-right: ${spacing.xxsmall};\n\n  vertical-align: top;\n  table-layout: fixed;\n  overflow-x: auto;\n\n  // optional - enable iOS momentum scrolling\n  -webkit-overflow-scrolling: touch;\n\n  // scrolling shadows on left/right\n  &:after,\n  &:before {\n    content: \"\";\n    display: table;\n    clear: both;\n  }\n\n  > caption {\n    background-color: transparent;\n    font-weight: ${fonts.weight.bold};\n    font-family: ${fonts.sans};\n    ${fonts.sizes(\"16px\", \"20px\")}\n    text-align: left;\n    text-transform: uppercase;\n    margin-bottom: ${spacing.small};\n  }\n\n  thead {\n    overflow: hidden;\n  }\n\n  thead tr td,\n  th {\n    font-weight: ${fonts.weight.bold};\n    border-bottom: 3px solid ${colors.brand.tertiary};\n    font-family: ${fonts.sans};\n    vertical-align: text-top;\n\n    ${fonts.sizes(\"16px\", \"22px\")};\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes(\"16px\", \"30px\")};\n    }\n  }\n\n  tbody th {\n    border-bottom: 0;\n    border-right: 3px solid ${colors.brand.tertiary};\n    padding: ${spacing.xsmall};\n  }\n\n  thead tr:nth-child(2) th {\n    border: 1px solid ${colors.brand.lighter};\n    text-transform: none;\n\n    ${fonts.sizes(\"14px\", \"18px\")};\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes(\"15px\", \"26px\")};\n    }\n\n    font-weight: ${fonts.weight.semibold};\n    height: 40px;\n    background-color: ${colors.brand.lighter};\n    padding: ${spacing.xxsmall} ${spacing.normal} ${spacing.xxsmall} ${spacing.xsmall};\n\n    &:empty {\n      background-color: transparent;\n    }\n  }\n\n  td {\n    border: 1px solid ${colors.brand.lighter};\n    vertical-align: top;\n\n    ${fonts.sizes(\"14px\", \"22px\")};\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes(\"15px\", \"30px\")};\n    }\n\n    ol,\n    ul {\n      li,\n      li p {\n        ${fonts.sizes(\"14px\", \"22px\")};\n        ${mq.range({ from: breakpoints.tablet })} {\n          ${fonts.sizes(\"15px\", \"30px\")};\n        }\n        margin: ${spacing.xsmall} 0 !important;\n      }\n    }\n\n    p {\n      line-height: 1.6em;\n    }\n\n    p:last-child {\n      margin: 0;\n    }\n\n    img {\n      max-width: 100%;\n      min-width: 120px;\n    }\n  }\n\n  td,\n  th {\n    display: table-cell;\n    padding: ${spacing.xsmall} ${spacing.small};\n\n    p {\n      margin: 0;\n    }\n  }\n\n  // Remove excess spacing on headings inside table\n  h1,\n  h2,\n  h3,\n  h4,\n  h5 {\n    margin-top: 0;\n  }\n\n  ul {\n    padding: 0 0 0 ${spacing.nsmall};\n  }\n\n  figure {\n    margin: 0;\n    padding: 0;\n    width: 100% !important;\n    left: 0 !important;\n  }\n`;\n\nconst TableWrapper = styled.div`\n  display: flex;\n  justify-content: center;\n`;\n\nconst OverflowWrapper = styled.div`\n  position: relative;\n  overflow-x: auto;\n`;\n\nconst Table = ({ children, id, ...rest }: Props) => {\n  const [scrollPosition, setScrollPosition] = useState<ScrollPosition | undefined>(undefined);\n  const tableRef = useRef<HTMLTableElement>(null);\n\n  const checkScrollPosition = useCallback((el: HTMLTableElement) => {\n    const { scrollLeft, offsetWidth, scrollWidth, clientWidth } = el;\n    const hasScrollbar = scrollWidth > clientWidth;\n\n    if (!hasScrollbar) {\n      setScrollPosition(undefined);\n      return;\n    }\n\n    const isStart = scrollLeft <= MARGIN;\n    const isEnd = offsetWidth + scrollLeft >= scrollWidth - MARGIN;\n\n    if (isStart) {\n      setScrollPosition(\"start\");\n    } else if (isEnd) {\n      setScrollPosition(\"end\");\n    } else {\n      setScrollPosition(\"center\");\n    }\n  }, []);\n\n  const onScroll = useMemo(\n    () =>\n      throttle((event: UIEvent<HTMLTableElement>) => {\n        const el = event.target as HTMLTableElement | undefined;\n        if (el) {\n          checkScrollPosition(el);\n        }\n      }, 100),\n    [checkScrollPosition],\n  );\n\n  useEffect(() => {\n    const el = tableRef.current;\n    if (el) {\n      checkScrollPosition(el);\n    }\n  }, [checkScrollPosition]);\n\n  return (\n    <TableWrapper>\n      <OverflowWrapper>\n        <LeftScrollBorder data-block={scrollPosition === \"end\" || scrollPosition === \"center\"} />\n        <table ref={tableRef} id={id} onScroll={onScroll} css={TableStyling} {...rest}>\n          {children}\n        </table>\n        <RightScrollBorder data-block={scrollPosition === \"start\" || scrollPosition === \"center\"} />\n      </OverflowWrapper>\n    </TableWrapper>\n  );\n};\n\nexport default Table;\n"]} */"));
26
26
  const RightScrollBorder = /*#__PURE__*/(0, _base.default)(ScrollBorder, {
27
27
  target: "e69565p3",
28
28
  label: "RightScrollBorder"
@@ -32,7 +32,7 @@ const RightScrollBorder = /*#__PURE__*/(0, _base.default)(ScrollBorder, {
32
32
  } : {
33
33
  name: "1wf8jf",
34
34
  styles: "right:0",
35
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Table.tsx"],"names":[],"mappings":"AAwC8C","file":"Table.tsx","sourcesContent":["/**\n * Copyright (c) 2016-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport throttle from \"lodash.throttle\";\nimport { ReactNode, UIEvent, useCallback, useEffect, useMemo, useRef, useState } from \"react\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, fonts, mq, spacing } from \"@ndla/core\";\n\ntype ScrollPosition = \"start\" | \"end\" | \"center\";\n\nconst MARGIN = 5;\n\ninterface Props {\n  id?: string;\n  children?: ReactNode;\n  dangerouslySetInnerHTML?: {\n    __html: string;\n  };\n  lang?: string;\n}\n\nconst ScrollBorder = styled.div`\n  position: absolute;\n  top: 0;\n  height: calc(100% - ${spacing.mediumlarge});\n  width: 3px;\n  background: ${colors.background.dark};\n  display: none;\n\n  &[data-block=\"true\"] {\n    display: block;\n  }\n`;\n\nconst RightScrollBorder = styled(ScrollBorder)`\n  right: 0;\n`;\n\nconst LeftScrollBorder = styled(ScrollBorder)`\n  left: 0;\n`;\n\nexport const TableStyling = css`\n  &::-webkit-scrollbar {\n    height: ${spacing.xsmall};\n  }\n  &::-webkit-scrollbar-track-piece {\n    background: ${colors.brand.lighter};\n    border-radius: ${spacing.xsmall};\n  }\n  &::-webkit-scrollbar-thumb {\n    background: ${colors.brand.dark};\n    border-radius: ${spacing.xsmall};\n  }\n  display: inline-block;\n\n  font-size: 85%;\n  max-width: 100%;\n\n  padding-left: ${spacing.xxsmall};\n  padding-right: ${spacing.xxsmall};\n\n  vertical-align: top;\n  table-layout: fixed;\n  overflow-x: auto;\n\n  // optional - enable iOS momentum scrolling\n  -webkit-overflow-scrolling: touch;\n\n  // scrolling shadows on left/right\n  &:after,\n  &:before {\n    content: \"\";\n    display: table;\n    clear: both;\n  }\n\n  > caption {\n    background-color: transparent;\n    font-weight: ${fonts.weight.bold};\n    font-family: ${fonts.sans};\n    ${fonts.sizes(\"16px\", \"20px\")}\n    text-align: left;\n    text-transform: uppercase;\n    margin-bottom: ${spacing.small};\n  }\n\n  thead {\n    overflow: hidden;\n  }\n\n  thead tr td,\n  th {\n    font-weight: ${fonts.weight.bold};\n    border-bottom: 3px solid ${colors.brand.tertiary};\n    font-family: ${fonts.sans};\n    vertical-align: text-top;\n\n    ${fonts.sizes(\"16px\", \"22px\")};\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes(\"16px\", \"30px\")};\n    }\n  }\n\n  tbody th {\n    border-bottom: 0;\n    border-right: 3px solid ${colors.brand.tertiary};\n    padding: ${spacing.xsmall};\n  }\n\n  thead tr:nth-child(2) th {\n    border: 1px solid ${colors.brand.lighter};\n    text-transform: none;\n\n    ${fonts.sizes(\"14px\", \"18px\")};\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes(\"15px\", \"26px\")};\n    }\n\n    font-weight: ${fonts.weight.semibold};\n    height: 40px;\n    background-color: ${colors.brand.lighter};\n    padding: ${spacing.xxsmall} ${spacing.normal} ${spacing.xxsmall} ${spacing.xsmall};\n\n    &:empty {\n      background-color: transparent;\n    }\n  }\n\n  td {\n    border: 1px solid ${colors.brand.lighter};\n    vertical-align: top;\n\n    ${fonts.sizes(\"14px\", \"22px\")};\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes(\"15px\", \"30px\")};\n    }\n\n    ol,\n    ul {\n      li,\n      li p {\n        ${fonts.sizes(\"14px\", \"22px\")};\n        ${mq.range({ from: breakpoints.tablet })} {\n          ${fonts.sizes(\"15px\", \"30px\")};\n        }\n        margin: ${spacing.xsmall} 0 !important;\n      }\n    }\n\n    p {\n      line-height: 1.6em;\n    }\n\n    p:last-child {\n      margin: 0;\n    }\n\n    img {\n      max-width: 100%;\n      min-width: 120px;\n    }\n  }\n\n  td,\n  th {\n    display: table-cell;\n    padding: ${spacing.xsmall} ${spacing.small};\n\n    p {\n      margin: 0;\n    }\n  }\n\n  // Remove excess spacing on headings inside table\n  h1,\n  h2,\n  h3,\n  h4,\n  h5 {\n    margin-top: 0;\n  }\n\n  ul {\n    padding: 0 0 0 ${spacing.nsmall};\n  }\n`;\n\nconst TableWrapper = styled.div`\n  display: flex;\n  justify-content: center;\n`;\n\nconst OverflowWrapper = styled.div`\n  position: relative;\n  overflow-x: auto;\n`;\n\nconst Table = ({ children, id, ...rest }: Props) => {\n  const [scrollPosition, setScrollPosition] = useState<ScrollPosition | undefined>(undefined);\n  const tableRef = useRef<HTMLTableElement>(null);\n\n  const checkScrollPosition = useCallback((el: HTMLTableElement) => {\n    const { scrollLeft, offsetWidth, scrollWidth, clientWidth } = el;\n    const hasScrollbar = scrollWidth > clientWidth;\n\n    if (!hasScrollbar) {\n      setScrollPosition(undefined);\n      return;\n    }\n\n    const isStart = scrollLeft <= MARGIN;\n    const isEnd = offsetWidth + scrollLeft >= scrollWidth - MARGIN;\n\n    if (isStart) {\n      setScrollPosition(\"start\");\n    } else if (isEnd) {\n      setScrollPosition(\"end\");\n    } else {\n      setScrollPosition(\"center\");\n    }\n  }, []);\n\n  const onScroll = useMemo(\n    () =>\n      throttle((event: UIEvent<HTMLTableElement>) => {\n        const el = event.target as HTMLTableElement | undefined;\n        if (el) {\n          checkScrollPosition(el);\n        }\n      }, 100),\n    [checkScrollPosition],\n  );\n\n  useEffect(() => {\n    const el = tableRef.current;\n    if (el) {\n      checkScrollPosition(el);\n    }\n  }, [checkScrollPosition]);\n\n  return (\n    <TableWrapper>\n      <OverflowWrapper>\n        <LeftScrollBorder data-block={scrollPosition === \"end\" || scrollPosition === \"center\"} />\n        <table ref={tableRef} id={id} onScroll={onScroll} css={TableStyling} {...rest}>\n          {children}\n        </table>\n        <RightScrollBorder data-block={scrollPosition === \"start\" || scrollPosition === \"center\"} />\n      </OverflowWrapper>\n    </TableWrapper>\n  );\n};\n\nexport default Table;\n"]} */",
35
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Table.tsx"],"names":[],"mappings":"AAwC8C","file":"Table.tsx","sourcesContent":["/**\n * Copyright (c) 2016-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport throttle from \"lodash.throttle\";\nimport { ReactNode, UIEvent, useCallback, useEffect, useMemo, useRef, useState } from \"react\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, fonts, mq, spacing } from \"@ndla/core\";\n\ntype ScrollPosition = \"start\" | \"end\" | \"center\";\n\nconst MARGIN = 5;\n\ninterface Props {\n  id?: string;\n  children?: ReactNode;\n  dangerouslySetInnerHTML?: {\n    __html: string;\n  };\n  lang?: string;\n}\n\nconst ScrollBorder = styled.div`\n  position: absolute;\n  top: 0;\n  height: calc(100% - ${spacing.mediumlarge});\n  width: 3px;\n  background: ${colors.background.dark};\n  display: none;\n\n  &[data-block=\"true\"] {\n    display: block;\n  }\n`;\n\nconst RightScrollBorder = styled(ScrollBorder)`\n  right: 0;\n`;\n\nconst LeftScrollBorder = styled(ScrollBorder)`\n  left: 0;\n`;\n\nexport const TableStyling = css`\n  &::-webkit-scrollbar {\n    height: ${spacing.xsmall};\n  }\n  &::-webkit-scrollbar-track-piece {\n    background: ${colors.brand.lighter};\n    border-radius: ${spacing.xsmall};\n  }\n  &::-webkit-scrollbar-thumb {\n    background: ${colors.brand.dark};\n    border-radius: ${spacing.xsmall};\n  }\n  display: inline-block;\n\n  font-size: 85%;\n  max-width: 100%;\n\n  padding-left: ${spacing.xxsmall};\n  padding-right: ${spacing.xxsmall};\n\n  vertical-align: top;\n  table-layout: fixed;\n  overflow-x: auto;\n\n  // optional - enable iOS momentum scrolling\n  -webkit-overflow-scrolling: touch;\n\n  // scrolling shadows on left/right\n  &:after,\n  &:before {\n    content: \"\";\n    display: table;\n    clear: both;\n  }\n\n  > caption {\n    background-color: transparent;\n    font-weight: ${fonts.weight.bold};\n    font-family: ${fonts.sans};\n    ${fonts.sizes(\"16px\", \"20px\")}\n    text-align: left;\n    text-transform: uppercase;\n    margin-bottom: ${spacing.small};\n  }\n\n  thead {\n    overflow: hidden;\n  }\n\n  thead tr td,\n  th {\n    font-weight: ${fonts.weight.bold};\n    border-bottom: 3px solid ${colors.brand.tertiary};\n    font-family: ${fonts.sans};\n    vertical-align: text-top;\n\n    ${fonts.sizes(\"16px\", \"22px\")};\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes(\"16px\", \"30px\")};\n    }\n  }\n\n  tbody th {\n    border-bottom: 0;\n    border-right: 3px solid ${colors.brand.tertiary};\n    padding: ${spacing.xsmall};\n  }\n\n  thead tr:nth-child(2) th {\n    border: 1px solid ${colors.brand.lighter};\n    text-transform: none;\n\n    ${fonts.sizes(\"14px\", \"18px\")};\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes(\"15px\", \"26px\")};\n    }\n\n    font-weight: ${fonts.weight.semibold};\n    height: 40px;\n    background-color: ${colors.brand.lighter};\n    padding: ${spacing.xxsmall} ${spacing.normal} ${spacing.xxsmall} ${spacing.xsmall};\n\n    &:empty {\n      background-color: transparent;\n    }\n  }\n\n  td {\n    border: 1px solid ${colors.brand.lighter};\n    vertical-align: top;\n\n    ${fonts.sizes(\"14px\", \"22px\")};\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes(\"15px\", \"30px\")};\n    }\n\n    ol,\n    ul {\n      li,\n      li p {\n        ${fonts.sizes(\"14px\", \"22px\")};\n        ${mq.range({ from: breakpoints.tablet })} {\n          ${fonts.sizes(\"15px\", \"30px\")};\n        }\n        margin: ${spacing.xsmall} 0 !important;\n      }\n    }\n\n    p {\n      line-height: 1.6em;\n    }\n\n    p:last-child {\n      margin: 0;\n    }\n\n    img {\n      max-width: 100%;\n      min-width: 120px;\n    }\n  }\n\n  td,\n  th {\n    display: table-cell;\n    padding: ${spacing.xsmall} ${spacing.small};\n\n    p {\n      margin: 0;\n    }\n  }\n\n  // Remove excess spacing on headings inside table\n  h1,\n  h2,\n  h3,\n  h4,\n  h5 {\n    margin-top: 0;\n  }\n\n  ul {\n    padding: 0 0 0 ${spacing.nsmall};\n  }\n\n  figure {\n    margin: 0;\n    padding: 0;\n    width: 100% !important;\n    left: 0 !important;\n  }\n`;\n\nconst TableWrapper = styled.div`\n  display: flex;\n  justify-content: center;\n`;\n\nconst OverflowWrapper = styled.div`\n  position: relative;\n  overflow-x: auto;\n`;\n\nconst Table = ({ children, id, ...rest }: Props) => {\n  const [scrollPosition, setScrollPosition] = useState<ScrollPosition | undefined>(undefined);\n  const tableRef = useRef<HTMLTableElement>(null);\n\n  const checkScrollPosition = useCallback((el: HTMLTableElement) => {\n    const { scrollLeft, offsetWidth, scrollWidth, clientWidth } = el;\n    const hasScrollbar = scrollWidth > clientWidth;\n\n    if (!hasScrollbar) {\n      setScrollPosition(undefined);\n      return;\n    }\n\n    const isStart = scrollLeft <= MARGIN;\n    const isEnd = offsetWidth + scrollLeft >= scrollWidth - MARGIN;\n\n    if (isStart) {\n      setScrollPosition(\"start\");\n    } else if (isEnd) {\n      setScrollPosition(\"end\");\n    } else {\n      setScrollPosition(\"center\");\n    }\n  }, []);\n\n  const onScroll = useMemo(\n    () =>\n      throttle((event: UIEvent<HTMLTableElement>) => {\n        const el = event.target as HTMLTableElement | undefined;\n        if (el) {\n          checkScrollPosition(el);\n        }\n      }, 100),\n    [checkScrollPosition],\n  );\n\n  useEffect(() => {\n    const el = tableRef.current;\n    if (el) {\n      checkScrollPosition(el);\n    }\n  }, [checkScrollPosition]);\n\n  return (\n    <TableWrapper>\n      <OverflowWrapper>\n        <LeftScrollBorder data-block={scrollPosition === \"end\" || scrollPosition === \"center\"} />\n        <table ref={tableRef} id={id} onScroll={onScroll} css={TableStyling} {...rest}>\n          {children}\n        </table>\n        <RightScrollBorder data-block={scrollPosition === \"start\" || scrollPosition === \"center\"} />\n      </OverflowWrapper>\n    </TableWrapper>\n  );\n};\n\nexport default Table;\n"]} */",
36
36
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
37
37
  });
38
38
  const LeftScrollBorder = /*#__PURE__*/(0, _base.default)(ScrollBorder, {
@@ -44,7 +44,7 @@ const LeftScrollBorder = /*#__PURE__*/(0, _base.default)(ScrollBorder, {
44
44
  } : {
45
45
  name: "1ode3cm",
46
46
  styles: "left:0",
47
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Table.tsx"],"names":[],"mappings":"AA4C6C","file":"Table.tsx","sourcesContent":["/**\n * Copyright (c) 2016-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport throttle from \"lodash.throttle\";\nimport { ReactNode, UIEvent, useCallback, useEffect, useMemo, useRef, useState } from \"react\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, fonts, mq, spacing } from \"@ndla/core\";\n\ntype ScrollPosition = \"start\" | \"end\" | \"center\";\n\nconst MARGIN = 5;\n\ninterface Props {\n  id?: string;\n  children?: ReactNode;\n  dangerouslySetInnerHTML?: {\n    __html: string;\n  };\n  lang?: string;\n}\n\nconst ScrollBorder = styled.div`\n  position: absolute;\n  top: 0;\n  height: calc(100% - ${spacing.mediumlarge});\n  width: 3px;\n  background: ${colors.background.dark};\n  display: none;\n\n  &[data-block=\"true\"] {\n    display: block;\n  }\n`;\n\nconst RightScrollBorder = styled(ScrollBorder)`\n  right: 0;\n`;\n\nconst LeftScrollBorder = styled(ScrollBorder)`\n  left: 0;\n`;\n\nexport const TableStyling = css`\n  &::-webkit-scrollbar {\n    height: ${spacing.xsmall};\n  }\n  &::-webkit-scrollbar-track-piece {\n    background: ${colors.brand.lighter};\n    border-radius: ${spacing.xsmall};\n  }\n  &::-webkit-scrollbar-thumb {\n    background: ${colors.brand.dark};\n    border-radius: ${spacing.xsmall};\n  }\n  display: inline-block;\n\n  font-size: 85%;\n  max-width: 100%;\n\n  padding-left: ${spacing.xxsmall};\n  padding-right: ${spacing.xxsmall};\n\n  vertical-align: top;\n  table-layout: fixed;\n  overflow-x: auto;\n\n  // optional - enable iOS momentum scrolling\n  -webkit-overflow-scrolling: touch;\n\n  // scrolling shadows on left/right\n  &:after,\n  &:before {\n    content: \"\";\n    display: table;\n    clear: both;\n  }\n\n  > caption {\n    background-color: transparent;\n    font-weight: ${fonts.weight.bold};\n    font-family: ${fonts.sans};\n    ${fonts.sizes(\"16px\", \"20px\")}\n    text-align: left;\n    text-transform: uppercase;\n    margin-bottom: ${spacing.small};\n  }\n\n  thead {\n    overflow: hidden;\n  }\n\n  thead tr td,\n  th {\n    font-weight: ${fonts.weight.bold};\n    border-bottom: 3px solid ${colors.brand.tertiary};\n    font-family: ${fonts.sans};\n    vertical-align: text-top;\n\n    ${fonts.sizes(\"16px\", \"22px\")};\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes(\"16px\", \"30px\")};\n    }\n  }\n\n  tbody th {\n    border-bottom: 0;\n    border-right: 3px solid ${colors.brand.tertiary};\n    padding: ${spacing.xsmall};\n  }\n\n  thead tr:nth-child(2) th {\n    border: 1px solid ${colors.brand.lighter};\n    text-transform: none;\n\n    ${fonts.sizes(\"14px\", \"18px\")};\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes(\"15px\", \"26px\")};\n    }\n\n    font-weight: ${fonts.weight.semibold};\n    height: 40px;\n    background-color: ${colors.brand.lighter};\n    padding: ${spacing.xxsmall} ${spacing.normal} ${spacing.xxsmall} ${spacing.xsmall};\n\n    &:empty {\n      background-color: transparent;\n    }\n  }\n\n  td {\n    border: 1px solid ${colors.brand.lighter};\n    vertical-align: top;\n\n    ${fonts.sizes(\"14px\", \"22px\")};\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes(\"15px\", \"30px\")};\n    }\n\n    ol,\n    ul {\n      li,\n      li p {\n        ${fonts.sizes(\"14px\", \"22px\")};\n        ${mq.range({ from: breakpoints.tablet })} {\n          ${fonts.sizes(\"15px\", \"30px\")};\n        }\n        margin: ${spacing.xsmall} 0 !important;\n      }\n    }\n\n    p {\n      line-height: 1.6em;\n    }\n\n    p:last-child {\n      margin: 0;\n    }\n\n    img {\n      max-width: 100%;\n      min-width: 120px;\n    }\n  }\n\n  td,\n  th {\n    display: table-cell;\n    padding: ${spacing.xsmall} ${spacing.small};\n\n    p {\n      margin: 0;\n    }\n  }\n\n  // Remove excess spacing on headings inside table\n  h1,\n  h2,\n  h3,\n  h4,\n  h5 {\n    margin-top: 0;\n  }\n\n  ul {\n    padding: 0 0 0 ${spacing.nsmall};\n  }\n`;\n\nconst TableWrapper = styled.div`\n  display: flex;\n  justify-content: center;\n`;\n\nconst OverflowWrapper = styled.div`\n  position: relative;\n  overflow-x: auto;\n`;\n\nconst Table = ({ children, id, ...rest }: Props) => {\n  const [scrollPosition, setScrollPosition] = useState<ScrollPosition | undefined>(undefined);\n  const tableRef = useRef<HTMLTableElement>(null);\n\n  const checkScrollPosition = useCallback((el: HTMLTableElement) => {\n    const { scrollLeft, offsetWidth, scrollWidth, clientWidth } = el;\n    const hasScrollbar = scrollWidth > clientWidth;\n\n    if (!hasScrollbar) {\n      setScrollPosition(undefined);\n      return;\n    }\n\n    const isStart = scrollLeft <= MARGIN;\n    const isEnd = offsetWidth + scrollLeft >= scrollWidth - MARGIN;\n\n    if (isStart) {\n      setScrollPosition(\"start\");\n    } else if (isEnd) {\n      setScrollPosition(\"end\");\n    } else {\n      setScrollPosition(\"center\");\n    }\n  }, []);\n\n  const onScroll = useMemo(\n    () =>\n      throttle((event: UIEvent<HTMLTableElement>) => {\n        const el = event.target as HTMLTableElement | undefined;\n        if (el) {\n          checkScrollPosition(el);\n        }\n      }, 100),\n    [checkScrollPosition],\n  );\n\n  useEffect(() => {\n    const el = tableRef.current;\n    if (el) {\n      checkScrollPosition(el);\n    }\n  }, [checkScrollPosition]);\n\n  return (\n    <TableWrapper>\n      <OverflowWrapper>\n        <LeftScrollBorder data-block={scrollPosition === \"end\" || scrollPosition === \"center\"} />\n        <table ref={tableRef} id={id} onScroll={onScroll} css={TableStyling} {...rest}>\n          {children}\n        </table>\n        <RightScrollBorder data-block={scrollPosition === \"start\" || scrollPosition === \"center\"} />\n      </OverflowWrapper>\n    </TableWrapper>\n  );\n};\n\nexport default Table;\n"]} */",
47
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Table.tsx"],"names":[],"mappings":"AA4C6C","file":"Table.tsx","sourcesContent":["/**\n * Copyright (c) 2016-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport throttle from \"lodash.throttle\";\nimport { ReactNode, UIEvent, useCallback, useEffect, useMemo, useRef, useState } from \"react\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, fonts, mq, spacing } from \"@ndla/core\";\n\ntype ScrollPosition = \"start\" | \"end\" | \"center\";\n\nconst MARGIN = 5;\n\ninterface Props {\n  id?: string;\n  children?: ReactNode;\n  dangerouslySetInnerHTML?: {\n    __html: string;\n  };\n  lang?: string;\n}\n\nconst ScrollBorder = styled.div`\n  position: absolute;\n  top: 0;\n  height: calc(100% - ${spacing.mediumlarge});\n  width: 3px;\n  background: ${colors.background.dark};\n  display: none;\n\n  &[data-block=\"true\"] {\n    display: block;\n  }\n`;\n\nconst RightScrollBorder = styled(ScrollBorder)`\n  right: 0;\n`;\n\nconst LeftScrollBorder = styled(ScrollBorder)`\n  left: 0;\n`;\n\nexport const TableStyling = css`\n  &::-webkit-scrollbar {\n    height: ${spacing.xsmall};\n  }\n  &::-webkit-scrollbar-track-piece {\n    background: ${colors.brand.lighter};\n    border-radius: ${spacing.xsmall};\n  }\n  &::-webkit-scrollbar-thumb {\n    background: ${colors.brand.dark};\n    border-radius: ${spacing.xsmall};\n  }\n  display: inline-block;\n\n  font-size: 85%;\n  max-width: 100%;\n\n  padding-left: ${spacing.xxsmall};\n  padding-right: ${spacing.xxsmall};\n\n  vertical-align: top;\n  table-layout: fixed;\n  overflow-x: auto;\n\n  // optional - enable iOS momentum scrolling\n  -webkit-overflow-scrolling: touch;\n\n  // scrolling shadows on left/right\n  &:after,\n  &:before {\n    content: \"\";\n    display: table;\n    clear: both;\n  }\n\n  > caption {\n    background-color: transparent;\n    font-weight: ${fonts.weight.bold};\n    font-family: ${fonts.sans};\n    ${fonts.sizes(\"16px\", \"20px\")}\n    text-align: left;\n    text-transform: uppercase;\n    margin-bottom: ${spacing.small};\n  }\n\n  thead {\n    overflow: hidden;\n  }\n\n  thead tr td,\n  th {\n    font-weight: ${fonts.weight.bold};\n    border-bottom: 3px solid ${colors.brand.tertiary};\n    font-family: ${fonts.sans};\n    vertical-align: text-top;\n\n    ${fonts.sizes(\"16px\", \"22px\")};\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes(\"16px\", \"30px\")};\n    }\n  }\n\n  tbody th {\n    border-bottom: 0;\n    border-right: 3px solid ${colors.brand.tertiary};\n    padding: ${spacing.xsmall};\n  }\n\n  thead tr:nth-child(2) th {\n    border: 1px solid ${colors.brand.lighter};\n    text-transform: none;\n\n    ${fonts.sizes(\"14px\", \"18px\")};\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes(\"15px\", \"26px\")};\n    }\n\n    font-weight: ${fonts.weight.semibold};\n    height: 40px;\n    background-color: ${colors.brand.lighter};\n    padding: ${spacing.xxsmall} ${spacing.normal} ${spacing.xxsmall} ${spacing.xsmall};\n\n    &:empty {\n      background-color: transparent;\n    }\n  }\n\n  td {\n    border: 1px solid ${colors.brand.lighter};\n    vertical-align: top;\n\n    ${fonts.sizes(\"14px\", \"22px\")};\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes(\"15px\", \"30px\")};\n    }\n\n    ol,\n    ul {\n      li,\n      li p {\n        ${fonts.sizes(\"14px\", \"22px\")};\n        ${mq.range({ from: breakpoints.tablet })} {\n          ${fonts.sizes(\"15px\", \"30px\")};\n        }\n        margin: ${spacing.xsmall} 0 !important;\n      }\n    }\n\n    p {\n      line-height: 1.6em;\n    }\n\n    p:last-child {\n      margin: 0;\n    }\n\n    img {\n      max-width: 100%;\n      min-width: 120px;\n    }\n  }\n\n  td,\n  th {\n    display: table-cell;\n    padding: ${spacing.xsmall} ${spacing.small};\n\n    p {\n      margin: 0;\n    }\n  }\n\n  // Remove excess spacing on headings inside table\n  h1,\n  h2,\n  h3,\n  h4,\n  h5 {\n    margin-top: 0;\n  }\n\n  ul {\n    padding: 0 0 0 ${spacing.nsmall};\n  }\n\n  figure {\n    margin: 0;\n    padding: 0;\n    width: 100% !important;\n    left: 0 !important;\n  }\n`;\n\nconst TableWrapper = styled.div`\n  display: flex;\n  justify-content: center;\n`;\n\nconst OverflowWrapper = styled.div`\n  position: relative;\n  overflow-x: auto;\n`;\n\nconst Table = ({ children, id, ...rest }: Props) => {\n  const [scrollPosition, setScrollPosition] = useState<ScrollPosition | undefined>(undefined);\n  const tableRef = useRef<HTMLTableElement>(null);\n\n  const checkScrollPosition = useCallback((el: HTMLTableElement) => {\n    const { scrollLeft, offsetWidth, scrollWidth, clientWidth } = el;\n    const hasScrollbar = scrollWidth > clientWidth;\n\n    if (!hasScrollbar) {\n      setScrollPosition(undefined);\n      return;\n    }\n\n    const isStart = scrollLeft <= MARGIN;\n    const isEnd = offsetWidth + scrollLeft >= scrollWidth - MARGIN;\n\n    if (isStart) {\n      setScrollPosition(\"start\");\n    } else if (isEnd) {\n      setScrollPosition(\"end\");\n    } else {\n      setScrollPosition(\"center\");\n    }\n  }, []);\n\n  const onScroll = useMemo(\n    () =>\n      throttle((event: UIEvent<HTMLTableElement>) => {\n        const el = event.target as HTMLTableElement | undefined;\n        if (el) {\n          checkScrollPosition(el);\n        }\n      }, 100),\n    [checkScrollPosition],\n  );\n\n  useEffect(() => {\n    const el = tableRef.current;\n    if (el) {\n      checkScrollPosition(el);\n    }\n  }, [checkScrollPosition]);\n\n  return (\n    <TableWrapper>\n      <OverflowWrapper>\n        <LeftScrollBorder data-block={scrollPosition === \"end\" || scrollPosition === \"center\"} />\n        <table ref={tableRef} id={id} onScroll={onScroll} css={TableStyling} {...rest}>\n          {children}\n        </table>\n        <RightScrollBorder data-block={scrollPosition === \"start\" || scrollPosition === \"center\"} />\n      </OverflowWrapper>\n    </TableWrapper>\n  );\n};\n\nexport default Table;\n"]} */",
48
48
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
49
49
  });
50
50
  const TableStyling = exports.TableStyling = /*#__PURE__*/(0, _react2.css)("&::-webkit-scrollbar{height:", _core.spacing.xsmall, ";}&::-webkit-scrollbar-track-piece{background:", _core.colors.brand.lighter, ";border-radius:", _core.spacing.xsmall, ";}&::-webkit-scrollbar-thumb{background:", _core.colors.brand.dark, ";border-radius:", _core.spacing.xsmall, ";}display:inline-block;font-size:85%;max-width:100%;padding-left:", _core.spacing.xxsmall, ";padding-right:", _core.spacing.xxsmall, ";vertical-align:top;table-layout:fixed;overflow-x:auto;-webkit-overflow-scrolling:touch;&:after,&:before{content:\"\";display:table;clear:both;}>caption{background-color:transparent;font-weight:", _core.fonts.weight.bold, ";font-family:", _core.fonts.sans, ";", _core.fonts.sizes("16px", "20px"), " text-align:left;text-transform:uppercase;margin-bottom:", _core.spacing.small, ";}thead{overflow:hidden;}thead tr td,th{font-weight:", _core.fonts.weight.bold, ";border-bottom:3px solid ", _core.colors.brand.tertiary, ";font-family:", _core.fonts.sans, ";vertical-align:text-top;", _core.fonts.sizes("16px", "22px"), ";", _core.mq.range({
@@ -55,7 +55,7 @@ const TableStyling = exports.TableStyling = /*#__PURE__*/(0, _react2.css)("&::-w
55
55
  from: _core.breakpoints.tablet
56
56
  }), "{", _core.fonts.sizes("15px", "30px"), ";}ol,ul{li,li p{", _core.fonts.sizes("14px", "22px"), ";margin:", _core.spacing.xsmall, " 0!important;", _core.mq.range({
57
57
  from: _core.breakpoints.tablet
58
- }), "{", _core.fonts.sizes("15px", "30px"), ";}}}p{line-height:1.6em;}p:last-child{margin:0;}img{max-width:100%;min-width:120px;}}td,th{display:table-cell;padding:", _core.spacing.xsmall, " ", _core.spacing.small, ";p{margin:0;}}h1,h2,h3,h4,h5{margin-top:0;}ul{padding:0 0 0 ", _core.spacing.nsmall, ";};label:TableStyling;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Table.tsx"],"names":[],"mappings":"AAgD+B","file":"Table.tsx","sourcesContent":["/**\n * Copyright (c) 2016-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport throttle from \"lodash.throttle\";\nimport { ReactNode, UIEvent, useCallback, useEffect, useMemo, useRef, useState } from \"react\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, fonts, mq, spacing } from \"@ndla/core\";\n\ntype ScrollPosition = \"start\" | \"end\" | \"center\";\n\nconst MARGIN = 5;\n\ninterface Props {\n  id?: string;\n  children?: ReactNode;\n  dangerouslySetInnerHTML?: {\n    __html: string;\n  };\n  lang?: string;\n}\n\nconst ScrollBorder = styled.div`\n  position: absolute;\n  top: 0;\n  height: calc(100% - ${spacing.mediumlarge});\n  width: 3px;\n  background: ${colors.background.dark};\n  display: none;\n\n  &[data-block=\"true\"] {\n    display: block;\n  }\n`;\n\nconst RightScrollBorder = styled(ScrollBorder)`\n  right: 0;\n`;\n\nconst LeftScrollBorder = styled(ScrollBorder)`\n  left: 0;\n`;\n\nexport const TableStyling = css`\n  &::-webkit-scrollbar {\n    height: ${spacing.xsmall};\n  }\n  &::-webkit-scrollbar-track-piece {\n    background: ${colors.brand.lighter};\n    border-radius: ${spacing.xsmall};\n  }\n  &::-webkit-scrollbar-thumb {\n    background: ${colors.brand.dark};\n    border-radius: ${spacing.xsmall};\n  }\n  display: inline-block;\n\n  font-size: 85%;\n  max-width: 100%;\n\n  padding-left: ${spacing.xxsmall};\n  padding-right: ${spacing.xxsmall};\n\n  vertical-align: top;\n  table-layout: fixed;\n  overflow-x: auto;\n\n  // optional - enable iOS momentum scrolling\n  -webkit-overflow-scrolling: touch;\n\n  // scrolling shadows on left/right\n  &:after,\n  &:before {\n    content: \"\";\n    display: table;\n    clear: both;\n  }\n\n  > caption {\n    background-color: transparent;\n    font-weight: ${fonts.weight.bold};\n    font-family: ${fonts.sans};\n    ${fonts.sizes(\"16px\", \"20px\")}\n    text-align: left;\n    text-transform: uppercase;\n    margin-bottom: ${spacing.small};\n  }\n\n  thead {\n    overflow: hidden;\n  }\n\n  thead tr td,\n  th {\n    font-weight: ${fonts.weight.bold};\n    border-bottom: 3px solid ${colors.brand.tertiary};\n    font-family: ${fonts.sans};\n    vertical-align: text-top;\n\n    ${fonts.sizes(\"16px\", \"22px\")};\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes(\"16px\", \"30px\")};\n    }\n  }\n\n  tbody th {\n    border-bottom: 0;\n    border-right: 3px solid ${colors.brand.tertiary};\n    padding: ${spacing.xsmall};\n  }\n\n  thead tr:nth-child(2) th {\n    border: 1px solid ${colors.brand.lighter};\n    text-transform: none;\n\n    ${fonts.sizes(\"14px\", \"18px\")};\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes(\"15px\", \"26px\")};\n    }\n\n    font-weight: ${fonts.weight.semibold};\n    height: 40px;\n    background-color: ${colors.brand.lighter};\n    padding: ${spacing.xxsmall} ${spacing.normal} ${spacing.xxsmall} ${spacing.xsmall};\n\n    &:empty {\n      background-color: transparent;\n    }\n  }\n\n  td {\n    border: 1px solid ${colors.brand.lighter};\n    vertical-align: top;\n\n    ${fonts.sizes(\"14px\", \"22px\")};\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes(\"15px\", \"30px\")};\n    }\n\n    ol,\n    ul {\n      li,\n      li p {\n        ${fonts.sizes(\"14px\", \"22px\")};\n        ${mq.range({ from: breakpoints.tablet })} {\n          ${fonts.sizes(\"15px\", \"30px\")};\n        }\n        margin: ${spacing.xsmall} 0 !important;\n      }\n    }\n\n    p {\n      line-height: 1.6em;\n    }\n\n    p:last-child {\n      margin: 0;\n    }\n\n    img {\n      max-width: 100%;\n      min-width: 120px;\n    }\n  }\n\n  td,\n  th {\n    display: table-cell;\n    padding: ${spacing.xsmall} ${spacing.small};\n\n    p {\n      margin: 0;\n    }\n  }\n\n  // Remove excess spacing on headings inside table\n  h1,\n  h2,\n  h3,\n  h4,\n  h5 {\n    margin-top: 0;\n  }\n\n  ul {\n    padding: 0 0 0 ${spacing.nsmall};\n  }\n`;\n\nconst TableWrapper = styled.div`\n  display: flex;\n  justify-content: center;\n`;\n\nconst OverflowWrapper = styled.div`\n  position: relative;\n  overflow-x: auto;\n`;\n\nconst Table = ({ children, id, ...rest }: Props) => {\n  const [scrollPosition, setScrollPosition] = useState<ScrollPosition | undefined>(undefined);\n  const tableRef = useRef<HTMLTableElement>(null);\n\n  const checkScrollPosition = useCallback((el: HTMLTableElement) => {\n    const { scrollLeft, offsetWidth, scrollWidth, clientWidth } = el;\n    const hasScrollbar = scrollWidth > clientWidth;\n\n    if (!hasScrollbar) {\n      setScrollPosition(undefined);\n      return;\n    }\n\n    const isStart = scrollLeft <= MARGIN;\n    const isEnd = offsetWidth + scrollLeft >= scrollWidth - MARGIN;\n\n    if (isStart) {\n      setScrollPosition(\"start\");\n    } else if (isEnd) {\n      setScrollPosition(\"end\");\n    } else {\n      setScrollPosition(\"center\");\n    }\n  }, []);\n\n  const onScroll = useMemo(\n    () =>\n      throttle((event: UIEvent<HTMLTableElement>) => {\n        const el = event.target as HTMLTableElement | undefined;\n        if (el) {\n          checkScrollPosition(el);\n        }\n      }, 100),\n    [checkScrollPosition],\n  );\n\n  useEffect(() => {\n    const el = tableRef.current;\n    if (el) {\n      checkScrollPosition(el);\n    }\n  }, [checkScrollPosition]);\n\n  return (\n    <TableWrapper>\n      <OverflowWrapper>\n        <LeftScrollBorder data-block={scrollPosition === \"end\" || scrollPosition === \"center\"} />\n        <table ref={tableRef} id={id} onScroll={onScroll} css={TableStyling} {...rest}>\n          {children}\n        </table>\n        <RightScrollBorder data-block={scrollPosition === \"start\" || scrollPosition === \"center\"} />\n      </OverflowWrapper>\n    </TableWrapper>\n  );\n};\n\nexport default Table;\n"]} */"));
58
+ }), "{", _core.fonts.sizes("15px", "30px"), ";}}}p{line-height:1.6em;}p:last-child{margin:0;}img{max-width:100%;min-width:120px;}}td,th{display:table-cell;padding:", _core.spacing.xsmall, " ", _core.spacing.small, ";p{margin:0;}}h1,h2,h3,h4,h5{margin-top:0;}ul{padding:0 0 0 ", _core.spacing.nsmall, ";}figure{margin:0;padding:0;width:100%!important;left:0!important;};label:TableStyling;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Table.tsx"],"names":[],"mappings":"AAgD+B","file":"Table.tsx","sourcesContent":["/**\n * Copyright (c) 2016-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport throttle from \"lodash.throttle\";\nimport { ReactNode, UIEvent, useCallback, useEffect, useMemo, useRef, useState } from \"react\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, fonts, mq, spacing } from \"@ndla/core\";\n\ntype ScrollPosition = \"start\" | \"end\" | \"center\";\n\nconst MARGIN = 5;\n\ninterface Props {\n  id?: string;\n  children?: ReactNode;\n  dangerouslySetInnerHTML?: {\n    __html: string;\n  };\n  lang?: string;\n}\n\nconst ScrollBorder = styled.div`\n  position: absolute;\n  top: 0;\n  height: calc(100% - ${spacing.mediumlarge});\n  width: 3px;\n  background: ${colors.background.dark};\n  display: none;\n\n  &[data-block=\"true\"] {\n    display: block;\n  }\n`;\n\nconst RightScrollBorder = styled(ScrollBorder)`\n  right: 0;\n`;\n\nconst LeftScrollBorder = styled(ScrollBorder)`\n  left: 0;\n`;\n\nexport const TableStyling = css`\n  &::-webkit-scrollbar {\n    height: ${spacing.xsmall};\n  }\n  &::-webkit-scrollbar-track-piece {\n    background: ${colors.brand.lighter};\n    border-radius: ${spacing.xsmall};\n  }\n  &::-webkit-scrollbar-thumb {\n    background: ${colors.brand.dark};\n    border-radius: ${spacing.xsmall};\n  }\n  display: inline-block;\n\n  font-size: 85%;\n  max-width: 100%;\n\n  padding-left: ${spacing.xxsmall};\n  padding-right: ${spacing.xxsmall};\n\n  vertical-align: top;\n  table-layout: fixed;\n  overflow-x: auto;\n\n  // optional - enable iOS momentum scrolling\n  -webkit-overflow-scrolling: touch;\n\n  // scrolling shadows on left/right\n  &:after,\n  &:before {\n    content: \"\";\n    display: table;\n    clear: both;\n  }\n\n  > caption {\n    background-color: transparent;\n    font-weight: ${fonts.weight.bold};\n    font-family: ${fonts.sans};\n    ${fonts.sizes(\"16px\", \"20px\")}\n    text-align: left;\n    text-transform: uppercase;\n    margin-bottom: ${spacing.small};\n  }\n\n  thead {\n    overflow: hidden;\n  }\n\n  thead tr td,\n  th {\n    font-weight: ${fonts.weight.bold};\n    border-bottom: 3px solid ${colors.brand.tertiary};\n    font-family: ${fonts.sans};\n    vertical-align: text-top;\n\n    ${fonts.sizes(\"16px\", \"22px\")};\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes(\"16px\", \"30px\")};\n    }\n  }\n\n  tbody th {\n    border-bottom: 0;\n    border-right: 3px solid ${colors.brand.tertiary};\n    padding: ${spacing.xsmall};\n  }\n\n  thead tr:nth-child(2) th {\n    border: 1px solid ${colors.brand.lighter};\n    text-transform: none;\n\n    ${fonts.sizes(\"14px\", \"18px\")};\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes(\"15px\", \"26px\")};\n    }\n\n    font-weight: ${fonts.weight.semibold};\n    height: 40px;\n    background-color: ${colors.brand.lighter};\n    padding: ${spacing.xxsmall} ${spacing.normal} ${spacing.xxsmall} ${spacing.xsmall};\n\n    &:empty {\n      background-color: transparent;\n    }\n  }\n\n  td {\n    border: 1px solid ${colors.brand.lighter};\n    vertical-align: top;\n\n    ${fonts.sizes(\"14px\", \"22px\")};\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes(\"15px\", \"30px\")};\n    }\n\n    ol,\n    ul {\n      li,\n      li p {\n        ${fonts.sizes(\"14px\", \"22px\")};\n        ${mq.range({ from: breakpoints.tablet })} {\n          ${fonts.sizes(\"15px\", \"30px\")};\n        }\n        margin: ${spacing.xsmall} 0 !important;\n      }\n    }\n\n    p {\n      line-height: 1.6em;\n    }\n\n    p:last-child {\n      margin: 0;\n    }\n\n    img {\n      max-width: 100%;\n      min-width: 120px;\n    }\n  }\n\n  td,\n  th {\n    display: table-cell;\n    padding: ${spacing.xsmall} ${spacing.small};\n\n    p {\n      margin: 0;\n    }\n  }\n\n  // Remove excess spacing on headings inside table\n  h1,\n  h2,\n  h3,\n  h4,\n  h5 {\n    margin-top: 0;\n  }\n\n  ul {\n    padding: 0 0 0 ${spacing.nsmall};\n  }\n\n  figure {\n    margin: 0;\n    padding: 0;\n    width: 100% !important;\n    left: 0 !important;\n  }\n`;\n\nconst TableWrapper = styled.div`\n  display: flex;\n  justify-content: center;\n`;\n\nconst OverflowWrapper = styled.div`\n  position: relative;\n  overflow-x: auto;\n`;\n\nconst Table = ({ children, id, ...rest }: Props) => {\n  const [scrollPosition, setScrollPosition] = useState<ScrollPosition | undefined>(undefined);\n  const tableRef = useRef<HTMLTableElement>(null);\n\n  const checkScrollPosition = useCallback((el: HTMLTableElement) => {\n    const { scrollLeft, offsetWidth, scrollWidth, clientWidth } = el;\n    const hasScrollbar = scrollWidth > clientWidth;\n\n    if (!hasScrollbar) {\n      setScrollPosition(undefined);\n      return;\n    }\n\n    const isStart = scrollLeft <= MARGIN;\n    const isEnd = offsetWidth + scrollLeft >= scrollWidth - MARGIN;\n\n    if (isStart) {\n      setScrollPosition(\"start\");\n    } else if (isEnd) {\n      setScrollPosition(\"end\");\n    } else {\n      setScrollPosition(\"center\");\n    }\n  }, []);\n\n  const onScroll = useMemo(\n    () =>\n      throttle((event: UIEvent<HTMLTableElement>) => {\n        const el = event.target as HTMLTableElement | undefined;\n        if (el) {\n          checkScrollPosition(el);\n        }\n      }, 100),\n    [checkScrollPosition],\n  );\n\n  useEffect(() => {\n    const el = tableRef.current;\n    if (el) {\n      checkScrollPosition(el);\n    }\n  }, [checkScrollPosition]);\n\n  return (\n    <TableWrapper>\n      <OverflowWrapper>\n        <LeftScrollBorder data-block={scrollPosition === \"end\" || scrollPosition === \"center\"} />\n        <table ref={tableRef} id={id} onScroll={onScroll} css={TableStyling} {...rest}>\n          {children}\n        </table>\n        <RightScrollBorder data-block={scrollPosition === \"start\" || scrollPosition === \"center\"} />\n      </OverflowWrapper>\n    </TableWrapper>\n  );\n};\n\nexport default Table;\n"]} */"));
59
59
  const TableWrapper = /*#__PURE__*/(0, _base.default)("div", {
60
60
  target: "e69565p1",
61
61
  label: "TableWrapper"
@@ -65,7 +65,7 @@ const TableWrapper = /*#__PURE__*/(0, _base.default)("div", {
65
65
  } : {
66
66
  name: "zl1inp",
67
67
  styles: "display:flex;justify-content:center",
68
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Table.tsx"],"names":[],"mappings":"AAkM+B","file":"Table.tsx","sourcesContent":["/**\n * Copyright (c) 2016-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport throttle from \"lodash.throttle\";\nimport { ReactNode, UIEvent, useCallback, useEffect, useMemo, useRef, useState } from \"react\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, fonts, mq, spacing } from \"@ndla/core\";\n\ntype ScrollPosition = \"start\" | \"end\" | \"center\";\n\nconst MARGIN = 5;\n\ninterface Props {\n  id?: string;\n  children?: ReactNode;\n  dangerouslySetInnerHTML?: {\n    __html: string;\n  };\n  lang?: string;\n}\n\nconst ScrollBorder = styled.div`\n  position: absolute;\n  top: 0;\n  height: calc(100% - ${spacing.mediumlarge});\n  width: 3px;\n  background: ${colors.background.dark};\n  display: none;\n\n  &[data-block=\"true\"] {\n    display: block;\n  }\n`;\n\nconst RightScrollBorder = styled(ScrollBorder)`\n  right: 0;\n`;\n\nconst LeftScrollBorder = styled(ScrollBorder)`\n  left: 0;\n`;\n\nexport const TableStyling = css`\n  &::-webkit-scrollbar {\n    height: ${spacing.xsmall};\n  }\n  &::-webkit-scrollbar-track-piece {\n    background: ${colors.brand.lighter};\n    border-radius: ${spacing.xsmall};\n  }\n  &::-webkit-scrollbar-thumb {\n    background: ${colors.brand.dark};\n    border-radius: ${spacing.xsmall};\n  }\n  display: inline-block;\n\n  font-size: 85%;\n  max-width: 100%;\n\n  padding-left: ${spacing.xxsmall};\n  padding-right: ${spacing.xxsmall};\n\n  vertical-align: top;\n  table-layout: fixed;\n  overflow-x: auto;\n\n  // optional - enable iOS momentum scrolling\n  -webkit-overflow-scrolling: touch;\n\n  // scrolling shadows on left/right\n  &:after,\n  &:before {\n    content: \"\";\n    display: table;\n    clear: both;\n  }\n\n  > caption {\n    background-color: transparent;\n    font-weight: ${fonts.weight.bold};\n    font-family: ${fonts.sans};\n    ${fonts.sizes(\"16px\", \"20px\")}\n    text-align: left;\n    text-transform: uppercase;\n    margin-bottom: ${spacing.small};\n  }\n\n  thead {\n    overflow: hidden;\n  }\n\n  thead tr td,\n  th {\n    font-weight: ${fonts.weight.bold};\n    border-bottom: 3px solid ${colors.brand.tertiary};\n    font-family: ${fonts.sans};\n    vertical-align: text-top;\n\n    ${fonts.sizes(\"16px\", \"22px\")};\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes(\"16px\", \"30px\")};\n    }\n  }\n\n  tbody th {\n    border-bottom: 0;\n    border-right: 3px solid ${colors.brand.tertiary};\n    padding: ${spacing.xsmall};\n  }\n\n  thead tr:nth-child(2) th {\n    border: 1px solid ${colors.brand.lighter};\n    text-transform: none;\n\n    ${fonts.sizes(\"14px\", \"18px\")};\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes(\"15px\", \"26px\")};\n    }\n\n    font-weight: ${fonts.weight.semibold};\n    height: 40px;\n    background-color: ${colors.brand.lighter};\n    padding: ${spacing.xxsmall} ${spacing.normal} ${spacing.xxsmall} ${spacing.xsmall};\n\n    &:empty {\n      background-color: transparent;\n    }\n  }\n\n  td {\n    border: 1px solid ${colors.brand.lighter};\n    vertical-align: top;\n\n    ${fonts.sizes(\"14px\", \"22px\")};\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes(\"15px\", \"30px\")};\n    }\n\n    ol,\n    ul {\n      li,\n      li p {\n        ${fonts.sizes(\"14px\", \"22px\")};\n        ${mq.range({ from: breakpoints.tablet })} {\n          ${fonts.sizes(\"15px\", \"30px\")};\n        }\n        margin: ${spacing.xsmall} 0 !important;\n      }\n    }\n\n    p {\n      line-height: 1.6em;\n    }\n\n    p:last-child {\n      margin: 0;\n    }\n\n    img {\n      max-width: 100%;\n      min-width: 120px;\n    }\n  }\n\n  td,\n  th {\n    display: table-cell;\n    padding: ${spacing.xsmall} ${spacing.small};\n\n    p {\n      margin: 0;\n    }\n  }\n\n  // Remove excess spacing on headings inside table\n  h1,\n  h2,\n  h3,\n  h4,\n  h5 {\n    margin-top: 0;\n  }\n\n  ul {\n    padding: 0 0 0 ${spacing.nsmall};\n  }\n`;\n\nconst TableWrapper = styled.div`\n  display: flex;\n  justify-content: center;\n`;\n\nconst OverflowWrapper = styled.div`\n  position: relative;\n  overflow-x: auto;\n`;\n\nconst Table = ({ children, id, ...rest }: Props) => {\n  const [scrollPosition, setScrollPosition] = useState<ScrollPosition | undefined>(undefined);\n  const tableRef = useRef<HTMLTableElement>(null);\n\n  const checkScrollPosition = useCallback((el: HTMLTableElement) => {\n    const { scrollLeft, offsetWidth, scrollWidth, clientWidth } = el;\n    const hasScrollbar = scrollWidth > clientWidth;\n\n    if (!hasScrollbar) {\n      setScrollPosition(undefined);\n      return;\n    }\n\n    const isStart = scrollLeft <= MARGIN;\n    const isEnd = offsetWidth + scrollLeft >= scrollWidth - MARGIN;\n\n    if (isStart) {\n      setScrollPosition(\"start\");\n    } else if (isEnd) {\n      setScrollPosition(\"end\");\n    } else {\n      setScrollPosition(\"center\");\n    }\n  }, []);\n\n  const onScroll = useMemo(\n    () =>\n      throttle((event: UIEvent<HTMLTableElement>) => {\n        const el = event.target as HTMLTableElement | undefined;\n        if (el) {\n          checkScrollPosition(el);\n        }\n      }, 100),\n    [checkScrollPosition],\n  );\n\n  useEffect(() => {\n    const el = tableRef.current;\n    if (el) {\n      checkScrollPosition(el);\n    }\n  }, [checkScrollPosition]);\n\n  return (\n    <TableWrapper>\n      <OverflowWrapper>\n        <LeftScrollBorder data-block={scrollPosition === \"end\" || scrollPosition === \"center\"} />\n        <table ref={tableRef} id={id} onScroll={onScroll} css={TableStyling} {...rest}>\n          {children}\n        </table>\n        <RightScrollBorder data-block={scrollPosition === \"start\" || scrollPosition === \"center\"} />\n      </OverflowWrapper>\n    </TableWrapper>\n  );\n};\n\nexport default Table;\n"]} */",
68
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Table.tsx"],"names":[],"mappings":"AAyM+B","file":"Table.tsx","sourcesContent":["/**\n * Copyright (c) 2016-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport throttle from \"lodash.throttle\";\nimport { ReactNode, UIEvent, useCallback, useEffect, useMemo, useRef, useState } from \"react\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, fonts, mq, spacing } from \"@ndla/core\";\n\ntype ScrollPosition = \"start\" | \"end\" | \"center\";\n\nconst MARGIN = 5;\n\ninterface Props {\n  id?: string;\n  children?: ReactNode;\n  dangerouslySetInnerHTML?: {\n    __html: string;\n  };\n  lang?: string;\n}\n\nconst ScrollBorder = styled.div`\n  position: absolute;\n  top: 0;\n  height: calc(100% - ${spacing.mediumlarge});\n  width: 3px;\n  background: ${colors.background.dark};\n  display: none;\n\n  &[data-block=\"true\"] {\n    display: block;\n  }\n`;\n\nconst RightScrollBorder = styled(ScrollBorder)`\n  right: 0;\n`;\n\nconst LeftScrollBorder = styled(ScrollBorder)`\n  left: 0;\n`;\n\nexport const TableStyling = css`\n  &::-webkit-scrollbar {\n    height: ${spacing.xsmall};\n  }\n  &::-webkit-scrollbar-track-piece {\n    background: ${colors.brand.lighter};\n    border-radius: ${spacing.xsmall};\n  }\n  &::-webkit-scrollbar-thumb {\n    background: ${colors.brand.dark};\n    border-radius: ${spacing.xsmall};\n  }\n  display: inline-block;\n\n  font-size: 85%;\n  max-width: 100%;\n\n  padding-left: ${spacing.xxsmall};\n  padding-right: ${spacing.xxsmall};\n\n  vertical-align: top;\n  table-layout: fixed;\n  overflow-x: auto;\n\n  // optional - enable iOS momentum scrolling\n  -webkit-overflow-scrolling: touch;\n\n  // scrolling shadows on left/right\n  &:after,\n  &:before {\n    content: \"\";\n    display: table;\n    clear: both;\n  }\n\n  > caption {\n    background-color: transparent;\n    font-weight: ${fonts.weight.bold};\n    font-family: ${fonts.sans};\n    ${fonts.sizes(\"16px\", \"20px\")}\n    text-align: left;\n    text-transform: uppercase;\n    margin-bottom: ${spacing.small};\n  }\n\n  thead {\n    overflow: hidden;\n  }\n\n  thead tr td,\n  th {\n    font-weight: ${fonts.weight.bold};\n    border-bottom: 3px solid ${colors.brand.tertiary};\n    font-family: ${fonts.sans};\n    vertical-align: text-top;\n\n    ${fonts.sizes(\"16px\", \"22px\")};\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes(\"16px\", \"30px\")};\n    }\n  }\n\n  tbody th {\n    border-bottom: 0;\n    border-right: 3px solid ${colors.brand.tertiary};\n    padding: ${spacing.xsmall};\n  }\n\n  thead tr:nth-child(2) th {\n    border: 1px solid ${colors.brand.lighter};\n    text-transform: none;\n\n    ${fonts.sizes(\"14px\", \"18px\")};\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes(\"15px\", \"26px\")};\n    }\n\n    font-weight: ${fonts.weight.semibold};\n    height: 40px;\n    background-color: ${colors.brand.lighter};\n    padding: ${spacing.xxsmall} ${spacing.normal} ${spacing.xxsmall} ${spacing.xsmall};\n\n    &:empty {\n      background-color: transparent;\n    }\n  }\n\n  td {\n    border: 1px solid ${colors.brand.lighter};\n    vertical-align: top;\n\n    ${fonts.sizes(\"14px\", \"22px\")};\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes(\"15px\", \"30px\")};\n    }\n\n    ol,\n    ul {\n      li,\n      li p {\n        ${fonts.sizes(\"14px\", \"22px\")};\n        ${mq.range({ from: breakpoints.tablet })} {\n          ${fonts.sizes(\"15px\", \"30px\")};\n        }\n        margin: ${spacing.xsmall} 0 !important;\n      }\n    }\n\n    p {\n      line-height: 1.6em;\n    }\n\n    p:last-child {\n      margin: 0;\n    }\n\n    img {\n      max-width: 100%;\n      min-width: 120px;\n    }\n  }\n\n  td,\n  th {\n    display: table-cell;\n    padding: ${spacing.xsmall} ${spacing.small};\n\n    p {\n      margin: 0;\n    }\n  }\n\n  // Remove excess spacing on headings inside table\n  h1,\n  h2,\n  h3,\n  h4,\n  h5 {\n    margin-top: 0;\n  }\n\n  ul {\n    padding: 0 0 0 ${spacing.nsmall};\n  }\n\n  figure {\n    margin: 0;\n    padding: 0;\n    width: 100% !important;\n    left: 0 !important;\n  }\n`;\n\nconst TableWrapper = styled.div`\n  display: flex;\n  justify-content: center;\n`;\n\nconst OverflowWrapper = styled.div`\n  position: relative;\n  overflow-x: auto;\n`;\n\nconst Table = ({ children, id, ...rest }: Props) => {\n  const [scrollPosition, setScrollPosition] = useState<ScrollPosition | undefined>(undefined);\n  const tableRef = useRef<HTMLTableElement>(null);\n\n  const checkScrollPosition = useCallback((el: HTMLTableElement) => {\n    const { scrollLeft, offsetWidth, scrollWidth, clientWidth } = el;\n    const hasScrollbar = scrollWidth > clientWidth;\n\n    if (!hasScrollbar) {\n      setScrollPosition(undefined);\n      return;\n    }\n\n    const isStart = scrollLeft <= MARGIN;\n    const isEnd = offsetWidth + scrollLeft >= scrollWidth - MARGIN;\n\n    if (isStart) {\n      setScrollPosition(\"start\");\n    } else if (isEnd) {\n      setScrollPosition(\"end\");\n    } else {\n      setScrollPosition(\"center\");\n    }\n  }, []);\n\n  const onScroll = useMemo(\n    () =>\n      throttle((event: UIEvent<HTMLTableElement>) => {\n        const el = event.target as HTMLTableElement | undefined;\n        if (el) {\n          checkScrollPosition(el);\n        }\n      }, 100),\n    [checkScrollPosition],\n  );\n\n  useEffect(() => {\n    const el = tableRef.current;\n    if (el) {\n      checkScrollPosition(el);\n    }\n  }, [checkScrollPosition]);\n\n  return (\n    <TableWrapper>\n      <OverflowWrapper>\n        <LeftScrollBorder data-block={scrollPosition === \"end\" || scrollPosition === \"center\"} />\n        <table ref={tableRef} id={id} onScroll={onScroll} css={TableStyling} {...rest}>\n          {children}\n        </table>\n        <RightScrollBorder data-block={scrollPosition === \"start\" || scrollPosition === \"center\"} />\n      </OverflowWrapper>\n    </TableWrapper>\n  );\n};\n\nexport default Table;\n"]} */",
69
69
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
70
70
  });
71
71
  const OverflowWrapper = /*#__PURE__*/(0, _base.default)("div", {
@@ -77,7 +77,7 @@ const OverflowWrapper = /*#__PURE__*/(0, _base.default)("div", {
77
77
  } : {
78
78
  name: "149vo96",
79
79
  styles: "position:relative;overflow-x:auto",
80
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Table.tsx"],"names":[],"mappings":"AAuMkC","file":"Table.tsx","sourcesContent":["/**\n * Copyright (c) 2016-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport throttle from \"lodash.throttle\";\nimport { ReactNode, UIEvent, useCallback, useEffect, useMemo, useRef, useState } from \"react\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, fonts, mq, spacing } from \"@ndla/core\";\n\ntype ScrollPosition = \"start\" | \"end\" | \"center\";\n\nconst MARGIN = 5;\n\ninterface Props {\n  id?: string;\n  children?: ReactNode;\n  dangerouslySetInnerHTML?: {\n    __html: string;\n  };\n  lang?: string;\n}\n\nconst ScrollBorder = styled.div`\n  position: absolute;\n  top: 0;\n  height: calc(100% - ${spacing.mediumlarge});\n  width: 3px;\n  background: ${colors.background.dark};\n  display: none;\n\n  &[data-block=\"true\"] {\n    display: block;\n  }\n`;\n\nconst RightScrollBorder = styled(ScrollBorder)`\n  right: 0;\n`;\n\nconst LeftScrollBorder = styled(ScrollBorder)`\n  left: 0;\n`;\n\nexport const TableStyling = css`\n  &::-webkit-scrollbar {\n    height: ${spacing.xsmall};\n  }\n  &::-webkit-scrollbar-track-piece {\n    background: ${colors.brand.lighter};\n    border-radius: ${spacing.xsmall};\n  }\n  &::-webkit-scrollbar-thumb {\n    background: ${colors.brand.dark};\n    border-radius: ${spacing.xsmall};\n  }\n  display: inline-block;\n\n  font-size: 85%;\n  max-width: 100%;\n\n  padding-left: ${spacing.xxsmall};\n  padding-right: ${spacing.xxsmall};\n\n  vertical-align: top;\n  table-layout: fixed;\n  overflow-x: auto;\n\n  // optional - enable iOS momentum scrolling\n  -webkit-overflow-scrolling: touch;\n\n  // scrolling shadows on left/right\n  &:after,\n  &:before {\n    content: \"\";\n    display: table;\n    clear: both;\n  }\n\n  > caption {\n    background-color: transparent;\n    font-weight: ${fonts.weight.bold};\n    font-family: ${fonts.sans};\n    ${fonts.sizes(\"16px\", \"20px\")}\n    text-align: left;\n    text-transform: uppercase;\n    margin-bottom: ${spacing.small};\n  }\n\n  thead {\n    overflow: hidden;\n  }\n\n  thead tr td,\n  th {\n    font-weight: ${fonts.weight.bold};\n    border-bottom: 3px solid ${colors.brand.tertiary};\n    font-family: ${fonts.sans};\n    vertical-align: text-top;\n\n    ${fonts.sizes(\"16px\", \"22px\")};\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes(\"16px\", \"30px\")};\n    }\n  }\n\n  tbody th {\n    border-bottom: 0;\n    border-right: 3px solid ${colors.brand.tertiary};\n    padding: ${spacing.xsmall};\n  }\n\n  thead tr:nth-child(2) th {\n    border: 1px solid ${colors.brand.lighter};\n    text-transform: none;\n\n    ${fonts.sizes(\"14px\", \"18px\")};\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes(\"15px\", \"26px\")};\n    }\n\n    font-weight: ${fonts.weight.semibold};\n    height: 40px;\n    background-color: ${colors.brand.lighter};\n    padding: ${spacing.xxsmall} ${spacing.normal} ${spacing.xxsmall} ${spacing.xsmall};\n\n    &:empty {\n      background-color: transparent;\n    }\n  }\n\n  td {\n    border: 1px solid ${colors.brand.lighter};\n    vertical-align: top;\n\n    ${fonts.sizes(\"14px\", \"22px\")};\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes(\"15px\", \"30px\")};\n    }\n\n    ol,\n    ul {\n      li,\n      li p {\n        ${fonts.sizes(\"14px\", \"22px\")};\n        ${mq.range({ from: breakpoints.tablet })} {\n          ${fonts.sizes(\"15px\", \"30px\")};\n        }\n        margin: ${spacing.xsmall} 0 !important;\n      }\n    }\n\n    p {\n      line-height: 1.6em;\n    }\n\n    p:last-child {\n      margin: 0;\n    }\n\n    img {\n      max-width: 100%;\n      min-width: 120px;\n    }\n  }\n\n  td,\n  th {\n    display: table-cell;\n    padding: ${spacing.xsmall} ${spacing.small};\n\n    p {\n      margin: 0;\n    }\n  }\n\n  // Remove excess spacing on headings inside table\n  h1,\n  h2,\n  h3,\n  h4,\n  h5 {\n    margin-top: 0;\n  }\n\n  ul {\n    padding: 0 0 0 ${spacing.nsmall};\n  }\n`;\n\nconst TableWrapper = styled.div`\n  display: flex;\n  justify-content: center;\n`;\n\nconst OverflowWrapper = styled.div`\n  position: relative;\n  overflow-x: auto;\n`;\n\nconst Table = ({ children, id, ...rest }: Props) => {\n  const [scrollPosition, setScrollPosition] = useState<ScrollPosition | undefined>(undefined);\n  const tableRef = useRef<HTMLTableElement>(null);\n\n  const checkScrollPosition = useCallback((el: HTMLTableElement) => {\n    const { scrollLeft, offsetWidth, scrollWidth, clientWidth } = el;\n    const hasScrollbar = scrollWidth > clientWidth;\n\n    if (!hasScrollbar) {\n      setScrollPosition(undefined);\n      return;\n    }\n\n    const isStart = scrollLeft <= MARGIN;\n    const isEnd = offsetWidth + scrollLeft >= scrollWidth - MARGIN;\n\n    if (isStart) {\n      setScrollPosition(\"start\");\n    } else if (isEnd) {\n      setScrollPosition(\"end\");\n    } else {\n      setScrollPosition(\"center\");\n    }\n  }, []);\n\n  const onScroll = useMemo(\n    () =>\n      throttle((event: UIEvent<HTMLTableElement>) => {\n        const el = event.target as HTMLTableElement | undefined;\n        if (el) {\n          checkScrollPosition(el);\n        }\n      }, 100),\n    [checkScrollPosition],\n  );\n\n  useEffect(() => {\n    const el = tableRef.current;\n    if (el) {\n      checkScrollPosition(el);\n    }\n  }, [checkScrollPosition]);\n\n  return (\n    <TableWrapper>\n      <OverflowWrapper>\n        <LeftScrollBorder data-block={scrollPosition === \"end\" || scrollPosition === \"center\"} />\n        <table ref={tableRef} id={id} onScroll={onScroll} css={TableStyling} {...rest}>\n          {children}\n        </table>\n        <RightScrollBorder data-block={scrollPosition === \"start\" || scrollPosition === \"center\"} />\n      </OverflowWrapper>\n    </TableWrapper>\n  );\n};\n\nexport default Table;\n"]} */",
80
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Table.tsx"],"names":[],"mappings":"AA8MkC","file":"Table.tsx","sourcesContent":["/**\n * Copyright (c) 2016-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport throttle from \"lodash.throttle\";\nimport { ReactNode, UIEvent, useCallback, useEffect, useMemo, useRef, useState } from \"react\";\nimport { css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport { breakpoints, colors, fonts, mq, spacing } from \"@ndla/core\";\n\ntype ScrollPosition = \"start\" | \"end\" | \"center\";\n\nconst MARGIN = 5;\n\ninterface Props {\n  id?: string;\n  children?: ReactNode;\n  dangerouslySetInnerHTML?: {\n    __html: string;\n  };\n  lang?: string;\n}\n\nconst ScrollBorder = styled.div`\n  position: absolute;\n  top: 0;\n  height: calc(100% - ${spacing.mediumlarge});\n  width: 3px;\n  background: ${colors.background.dark};\n  display: none;\n\n  &[data-block=\"true\"] {\n    display: block;\n  }\n`;\n\nconst RightScrollBorder = styled(ScrollBorder)`\n  right: 0;\n`;\n\nconst LeftScrollBorder = styled(ScrollBorder)`\n  left: 0;\n`;\n\nexport const TableStyling = css`\n  &::-webkit-scrollbar {\n    height: ${spacing.xsmall};\n  }\n  &::-webkit-scrollbar-track-piece {\n    background: ${colors.brand.lighter};\n    border-radius: ${spacing.xsmall};\n  }\n  &::-webkit-scrollbar-thumb {\n    background: ${colors.brand.dark};\n    border-radius: ${spacing.xsmall};\n  }\n  display: inline-block;\n\n  font-size: 85%;\n  max-width: 100%;\n\n  padding-left: ${spacing.xxsmall};\n  padding-right: ${spacing.xxsmall};\n\n  vertical-align: top;\n  table-layout: fixed;\n  overflow-x: auto;\n\n  // optional - enable iOS momentum scrolling\n  -webkit-overflow-scrolling: touch;\n\n  // scrolling shadows on left/right\n  &:after,\n  &:before {\n    content: \"\";\n    display: table;\n    clear: both;\n  }\n\n  > caption {\n    background-color: transparent;\n    font-weight: ${fonts.weight.bold};\n    font-family: ${fonts.sans};\n    ${fonts.sizes(\"16px\", \"20px\")}\n    text-align: left;\n    text-transform: uppercase;\n    margin-bottom: ${spacing.small};\n  }\n\n  thead {\n    overflow: hidden;\n  }\n\n  thead tr td,\n  th {\n    font-weight: ${fonts.weight.bold};\n    border-bottom: 3px solid ${colors.brand.tertiary};\n    font-family: ${fonts.sans};\n    vertical-align: text-top;\n\n    ${fonts.sizes(\"16px\", \"22px\")};\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes(\"16px\", \"30px\")};\n    }\n  }\n\n  tbody th {\n    border-bottom: 0;\n    border-right: 3px solid ${colors.brand.tertiary};\n    padding: ${spacing.xsmall};\n  }\n\n  thead tr:nth-child(2) th {\n    border: 1px solid ${colors.brand.lighter};\n    text-transform: none;\n\n    ${fonts.sizes(\"14px\", \"18px\")};\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes(\"15px\", \"26px\")};\n    }\n\n    font-weight: ${fonts.weight.semibold};\n    height: 40px;\n    background-color: ${colors.brand.lighter};\n    padding: ${spacing.xxsmall} ${spacing.normal} ${spacing.xxsmall} ${spacing.xsmall};\n\n    &:empty {\n      background-color: transparent;\n    }\n  }\n\n  td {\n    border: 1px solid ${colors.brand.lighter};\n    vertical-align: top;\n\n    ${fonts.sizes(\"14px\", \"22px\")};\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes(\"15px\", \"30px\")};\n    }\n\n    ol,\n    ul {\n      li,\n      li p {\n        ${fonts.sizes(\"14px\", \"22px\")};\n        ${mq.range({ from: breakpoints.tablet })} {\n          ${fonts.sizes(\"15px\", \"30px\")};\n        }\n        margin: ${spacing.xsmall} 0 !important;\n      }\n    }\n\n    p {\n      line-height: 1.6em;\n    }\n\n    p:last-child {\n      margin: 0;\n    }\n\n    img {\n      max-width: 100%;\n      min-width: 120px;\n    }\n  }\n\n  td,\n  th {\n    display: table-cell;\n    padding: ${spacing.xsmall} ${spacing.small};\n\n    p {\n      margin: 0;\n    }\n  }\n\n  // Remove excess spacing on headings inside table\n  h1,\n  h2,\n  h3,\n  h4,\n  h5 {\n    margin-top: 0;\n  }\n\n  ul {\n    padding: 0 0 0 ${spacing.nsmall};\n  }\n\n  figure {\n    margin: 0;\n    padding: 0;\n    width: 100% !important;\n    left: 0 !important;\n  }\n`;\n\nconst TableWrapper = styled.div`\n  display: flex;\n  justify-content: center;\n`;\n\nconst OverflowWrapper = styled.div`\n  position: relative;\n  overflow-x: auto;\n`;\n\nconst Table = ({ children, id, ...rest }: Props) => {\n  const [scrollPosition, setScrollPosition] = useState<ScrollPosition | undefined>(undefined);\n  const tableRef = useRef<HTMLTableElement>(null);\n\n  const checkScrollPosition = useCallback((el: HTMLTableElement) => {\n    const { scrollLeft, offsetWidth, scrollWidth, clientWidth } = el;\n    const hasScrollbar = scrollWidth > clientWidth;\n\n    if (!hasScrollbar) {\n      setScrollPosition(undefined);\n      return;\n    }\n\n    const isStart = scrollLeft <= MARGIN;\n    const isEnd = offsetWidth + scrollLeft >= scrollWidth - MARGIN;\n\n    if (isStart) {\n      setScrollPosition(\"start\");\n    } else if (isEnd) {\n      setScrollPosition(\"end\");\n    } else {\n      setScrollPosition(\"center\");\n    }\n  }, []);\n\n  const onScroll = useMemo(\n    () =>\n      throttle((event: UIEvent<HTMLTableElement>) => {\n        const el = event.target as HTMLTableElement | undefined;\n        if (el) {\n          checkScrollPosition(el);\n        }\n      }, 100),\n    [checkScrollPosition],\n  );\n\n  useEffect(() => {\n    const el = tableRef.current;\n    if (el) {\n      checkScrollPosition(el);\n    }\n  }, [checkScrollPosition]);\n\n  return (\n    <TableWrapper>\n      <OverflowWrapper>\n        <LeftScrollBorder data-block={scrollPosition === \"end\" || scrollPosition === \"center\"} />\n        <table ref={tableRef} id={id} onScroll={onScroll} css={TableStyling} {...rest}>\n          {children}\n        </table>\n        <RightScrollBorder data-block={scrollPosition === \"start\" || scrollPosition === \"center\"} />\n      </OverflowWrapper>\n    </TableWrapper>\n  );\n};\n\nexport default Table;\n"]} */",
81
81
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
82
82
  });
83
83
  const Table = _ref => {
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@ndla/ui",
3
- "version": "50.15.0",
3
+ "version": "50.15.1",
4
4
  "description": "UI component library for NDLA.",
5
5
  "license": "GPL-3.0",
6
6
  "main": "lib/index.js",
@@ -82,5 +82,5 @@
82
82
  "publishConfig": {
83
83
  "access": "public"
84
84
  },
85
- "gitHead": "f6949c46c9b1b0876c2d5e5d5ec4f1b31db1c28b"
85
+ "gitHead": "4874cd7ef8ec00314fe8de62b5fc77b334cacb82"
86
86
  }
@@ -190,6 +190,13 @@ export const TableStyling = css`
190
190
  ul {
191
191
  padding: 0 0 0 ${spacing.nsmall};
192
192
  }
193
+
194
+ figure {
195
+ margin: 0;
196
+ padding: 0;
197
+ width: 100% !important;
198
+ left: 0 !important;
199
+ }
193
200
  `;
194
201
 
195
202
  const TableWrapper = styled.div`