@ndla/ui 3.3.13 → 3.3.14

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (91) hide show
  1. package/es/Figure/Figure.js +3 -1
  2. package/es/NDLAFilm/AboutNdlaFilm.js +6 -17
  3. package/es/NDLAFilm/AllMoviesAlphabetically.js +11 -11
  4. package/es/NDLAFilm/CategorySelect.js +17 -18
  5. package/es/NDLAFilm/FilmContentCard.js +8 -22
  6. package/es/NDLAFilm/FilmContentCardTags.js +4 -8
  7. package/es/NDLAFilm/FilmMovieList.js +6 -21
  8. package/es/NDLAFilm/FilmMovieSearch.js +18 -26
  9. package/es/NDLAFilm/MovieGrid.js +10 -19
  10. package/es/NDLAFilm/VisualElement.js +22 -29
  11. package/es/TopicIntroductionList/TopicIntroduction.js +14 -33
  12. package/es/TopicIntroductionList/TopicIntroductionList.js +6 -23
  13. package/es/TopicIntroductionList/TopicIntroductionShortcuts.js +71 -110
  14. package/es/TopicIntroductionList/TopicShortcutItem.js +0 -9
  15. package/es/all.css +1 -4
  16. package/es/index-javascript.js +1 -5
  17. package/es/index.js +4 -0
  18. package/es/shapes.js +0 -6
  19. package/lib/Figure/Figure.js +3 -1
  20. package/lib/NDLAFilm/AboutNdlaFilm.d.ts +15 -0
  21. package/lib/NDLAFilm/AboutNdlaFilm.js +6 -18
  22. package/lib/NDLAFilm/AllMoviesAlphabetically.d.ts +2 -2
  23. package/lib/NDLAFilm/AllMoviesAlphabetically.js +11 -11
  24. package/lib/NDLAFilm/CategorySelect.d.ts +11 -0
  25. package/lib/NDLAFilm/CategorySelect.js +20 -19
  26. package/lib/NDLAFilm/FilmContentCard.d.ts +11 -0
  27. package/lib/NDLAFilm/FilmContentCard.js +8 -23
  28. package/lib/NDLAFilm/FilmContentCardTags.d.ts +7 -0
  29. package/lib/NDLAFilm/FilmContentCardTags.js +4 -9
  30. package/lib/NDLAFilm/FilmMovieList.d.ts +19 -0
  31. package/lib/NDLAFilm/FilmMovieList.js +5 -21
  32. package/lib/NDLAFilm/FilmMovieSearch.d.ts +21 -0
  33. package/lib/NDLAFilm/FilmMovieSearch.js +25 -30
  34. package/lib/NDLAFilm/FilmSlideshow.d.ts +5 -5
  35. package/lib/NDLAFilm/MovieGrid.d.ts +13 -0
  36. package/lib/NDLAFilm/MovieGrid.js +9 -21
  37. package/lib/NDLAFilm/SlideshowIndicator.d.ts +2 -2
  38. package/lib/NDLAFilm/VisualElement.d.ts +16 -0
  39. package/lib/NDLAFilm/VisualElement.js +22 -30
  40. package/lib/NDLAFilm/index.d.ts +14 -0
  41. package/lib/NDLAFilm/types.d.ts +6 -4
  42. package/lib/TopicIntroductionList/TopicIntroduction.d.ts +21 -0
  43. package/lib/TopicIntroductionList/TopicIntroduction.js +16 -36
  44. package/lib/TopicIntroductionList/TopicIntroductionList.d.ts +35 -0
  45. package/lib/TopicIntroductionList/TopicIntroductionList.js +6 -25
  46. package/lib/TopicIntroductionList/TopicIntroductionShortcuts.d.ts +8 -0
  47. package/lib/TopicIntroductionList/TopicIntroductionShortcuts.js +72 -110
  48. package/lib/TopicIntroductionList/TopicShortcutItem.d.ts +6 -0
  49. package/lib/TopicIntroductionList/TopicShortcutItem.js +0 -11
  50. package/lib/TopicIntroductionList/index.d.ts +9 -0
  51. package/lib/all.css +1 -4
  52. package/lib/index-javascript.js +3 -137
  53. package/lib/index.d.ts +4 -0
  54. package/lib/index.js +155 -0
  55. package/lib/shapes.js +1 -10
  56. package/package.json +10 -10
  57. package/src/Figure/Figure.tsx +2 -1
  58. package/src/Figure/component.figure.scss +37 -3
  59. package/src/NDLAFilm/{AboutNdlaFilm.jsx → AboutNdlaFilm.tsx} +19 -18
  60. package/src/NDLAFilm/AllMoviesAlphabetically.tsx +3 -3
  61. package/src/NDLAFilm/{CategorySelect.jsx → CategorySelect.tsx} +23 -20
  62. package/src/NDLAFilm/{FilmContentCard.jsx → FilmContentCard.tsx} +21 -21
  63. package/src/NDLAFilm/{FilmContentCardTags.jsx → FilmContentCardTags.tsx} +7 -7
  64. package/src/NDLAFilm/{FilmMovieList.jsx → FilmMovieList.tsx} +17 -27
  65. package/src/NDLAFilm/FilmMovieSearch.tsx +71 -0
  66. package/src/NDLAFilm/FilmSlideshow.tsx +6 -6
  67. package/src/NDLAFilm/MovieGrid.tsx +76 -0
  68. package/src/NDLAFilm/SlideshowIndicator.tsx +2 -2
  69. package/src/NDLAFilm/VisualElement.tsx +40 -0
  70. package/src/NDLAFilm/{index.js → index.ts} +0 -0
  71. package/src/NDLAFilm/types.ts +7 -4
  72. package/src/TopicIntroductionList/{TopicIntroduction.jsx → TopicIntroduction.tsx} +22 -35
  73. package/src/TopicIntroductionList/{TopicIntroductionList.jsx → TopicIntroductionList.tsx} +32 -26
  74. package/src/TopicIntroductionList/TopicIntroductionShortcuts.tsx +71 -0
  75. package/src/TopicIntroductionList/{TopicShortcutItem.jsx → TopicShortcutItem.tsx} +5 -13
  76. package/src/TopicIntroductionList/{index.js → index.ts} +0 -0
  77. package/src/index-javascript.js +0 -30
  78. package/src/index.ts +31 -0
  79. package/src/shapes.js +0 -7
  80. package/es/NDLAFilm/interfaces.js +0 -0
  81. package/es/NDLAFilm/shapes.js +0 -15
  82. package/lib/NDLAFilm/interfaces.d.ts +0 -10
  83. package/lib/NDLAFilm/interfaces.js +0 -1
  84. package/lib/NDLAFilm/shapes.d.ts +0 -15
  85. package/lib/NDLAFilm/shapes.js +0 -30
  86. package/src/NDLAFilm/FilmMovieSearch.jsx +0 -66
  87. package/src/NDLAFilm/MovieGrid.jsx +0 -75
  88. package/src/NDLAFilm/VisualElement.jsx +0 -48
  89. package/src/NDLAFilm/interfaces.ts +0 -10
  90. package/src/NDLAFilm/shapes.ts +0 -17
  91. package/src/TopicIntroductionList/TopicIntroductionShortcuts.jsx +0 -92
@@ -44,12 +44,12 @@ var StyledNewLetter = _styled("h2", {
44
44
  label: "StyledNewLetter"
45
45
  })("color:#fff;margin:", spacing.large, " 0 ", spacingUnit * 0.75, "px;", fonts.sizes(26, 1.1), ";", mq.range({
46
46
  from: breakpoints.tablet
47
- }), "{text-indent:", spacingUnit * 0.75, "px;}&:after{content:'';display:block;height:1px;background:", colors.brand.greyDark, ";margin-top:", spacing.small, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["AllMoviesAlphabetically.tsx"],"names":[],"mappings":"AAqBiC","file":"AllMoviesAlphabetically.tsx","sourcesContent":["/**\n * Copyright (c) 2019-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { Fragment, useEffect, useState } from 'react';\nimport { isIE, browserVersion } from 'react-device-detect';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/core';\nimport throttle from 'lodash/throttle';\nimport { breakpoints, mq, spacing, spacingUnit, colors, fonts, animations } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\n// @ts-ignore\nimport { makeSrcQueryString } from '../Image';\nimport { movieType } from './types';\nimport { isLetter } from './isLetter';\nconst IMAGE_WIDTH = 143;\n\nconst StyledNewLetter = styled.h2`\n  color: #fff;\n  margin: ${spacing.large} 0 ${spacingUnit * 0.75}px;\n  ${fonts.sizes(26, 1.1)};\n  ${mq.range({ from: breakpoints.tablet })} {\n    text-indent: ${spacingUnit * 0.75}px;\n  }\n  &:after {\n    content: '';\n    display: block;\n    height: 1px;\n    background: ${colors.brand.greyDark};\n    margin-top: ${spacing.small};\n  }\n`;\n\nconst StyledWrapper = styled.section`\n  width: 652px;\n  max-width: 100%;\n  margin: ${spacing.large} auto;\n  padding: 0 ${spacing.normal};\n  display: flex;\n  flex-direction: column;\n`;\n\ntype MovieItemProps = {\n  inView: boolean | null;\n};\n\nconst MovieItem = styled.div<MovieItemProps>`\n  margin: 0 0 ${spacingUnit * 0.75}px;\n  display: inline-flex;\n  &:last-child {\n    margin-bottom: ${spacing.large};\n  }\n  opacity: 0;\n  transform: translateY(${spacing.xsmall});\n  transition: all ${animations.durations.slow} ease;\n  ${(props: MovieItemProps) =>\n    props.inView &&\n    css`\n      opacity: 1;\n      transform: translateY(0);\n    `};\n`;\n\nconst MovieTextWrapper = styled.div`\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.xsmall} ${spacing.xsmall} 0 0;\n  }\n  flex: 1;\n`;\n\ntype movieImageType = {\n  backgroundImage?: string | null;\n};\n\nconst MovieImage = styled.div<movieImageType>`\n  width: 104px;\n  height: 80px;\n  background-color: ${colors.ndlaFilm.filmColorLight};\n  ${(props: movieImageType) =>\n    props.backgroundImage !== null &&\n    css`\n      background-image: url(${props.backgroundImage});\n    `}\n  background-size: cover;\n  background-position: center center;\n  margin: 0 ${spacingUnit * 0.75}px 0 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    margin-left: ${spacingUnit * 0.75}px;\n    width: ${IMAGE_WIDTH}px;\n    height: 90px;\n  }\n  position: relative;\n  &:after {\n    content: '';\n    position: absolute;\n    z-index: 1;\n    background: ${colors.ndlaFilm.filmColor};\n    opacity: 0;\n    left: 0;\n    right: 0;\n    bottom: 0;\n    top: 0;\n  }\n`;\n\nconst MovieTitle = styled.h3`\n  color: #fff;\n  margin: 0 0 2px;\n  ${fonts.sizes(18, 1.3)};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes(20, 1.3)};\n  }\n`;\n\nconst MovieDescription = styled.p`\n  color: ${colors.brand.greyLighter};\n  margin: 0;\n  ${fonts.sizes(14, 1.5)};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes(16, 1.5)};\n  }\n  overflow: hidden;\n  text-overflow: ellipsis;\n  display: -webkit-box;\n  -webkit-box-orient: vertical;\n  -webkit-line-clamp: 2;\n`;\n\ntype isIEProps = {\n  isIE11: boolean;\n};\n\nconst StyledSafeLink = styled(SafeLink)<isIEProps>`\n  box-shadow: none;\n  display: flex;\n  ${(props) =>\n    props.isIE11 &&\n    css`\n      flex: 1;\n    `}\n  &:hover,\n  &:focus {\n    ${MovieTitle} {\n      text-decoration: underline;\n    }\n    ${MovieImage} {\n      &:after {\n        transition: opacity 200ms ease;\n        display: block;\n        opacity: 0.3;\n      }\n    }\n  }\n`;\n\ninterface Props {\n  movies: movieType[];\n  locale: string;\n}\n\ntype visibleImagesProps = {\n  [key: string]: boolean | null;\n};\n\nconst hasForEachPolyfill = () => {\n  // Polyfill for ie11\n  if ('NodeList' in window && !NodeList.prototype.forEach) {\n    NodeList.prototype.forEach = function (callback, thisArg) {\n      thisArg = thisArg || window;\n      for (var i = 0; i < this.length; i++) {\n        callback.call(thisArg, this[i], i, this);\n      }\n    };\n  }\n};\n\nconst AllMoviesAlphabetically: React.FunctionComponent<Props> = ({ movies, locale }) => {\n  const isIE11 = isIE && parseInt(browserVersion) < 12;\n  // Split into Letters.\n  let previousLetter = '';\n  const wrapperRef: React.RefObject<HTMLElement> = React.useRef(null);\n  const [visibleImages, setVisibleImages] = useState<visibleImagesProps>({});\n\n  const scrollEvent = () => {\n    hasForEachPolyfill();\n    const updates: visibleImagesProps = {};\n    const allChildren: NodeListOf<HTMLElement> | null =\n      wrapperRef.current && wrapperRef.current.querySelectorAll('[role=img]');\n    const windowInnerHeight = window.innerHeight;\n    if (allChildren) {\n      let started: boolean = false;\n      let ended: boolean = false;\n      allChildren.forEach((el: HTMLElement, index: number) => {\n        if (!ended) {\n          const rect: ClientRect = el.getBoundingClientRect();\n          if (!started) {\n            if (rect.top > -20) {\n              updates[index] = true;\n              started = true;\n            }\n          } else {\n            updates[index] = true;\n            if (rect.top > windowInnerHeight + 20) {\n              ended = true;\n            }\n          }\n        }\n      });\n    }\n    setVisibleImages((visibleImages) => ({ ...visibleImages, ...updates }));\n  };\n\n  useEffect(() => {\n    const throttledScrollEvent = throttle(() => {\n      scrollEvent();\n    }, 100);\n    window.addEventListener('scroll', throttledScrollEvent);\n    scrollEvent();\n    return () => {\n      window.removeEventListener('scroll', throttledScrollEvent);\n    };\n  }, []);\n\n  useEffect(() => {\n    scrollEvent();\n  }, [movies]);\n\n  return (\n    <StyledWrapper ref={wrapperRef}>\n      {movies.map((movie: movieType, index: number) => {\n        const currentLetter = movie.title.substr(0, 1);\n        const isNewLetter = currentLetter.localeCompare(previousLetter, locale) === 1 && isLetter(movie.title);\n        previousLetter = currentLetter;\n        const inView: boolean | null = visibleImages ? visibleImages[index] : null;\n        return (\n          <Fragment key={movie.id}>\n            {isNewLetter && <StyledNewLetter>{movie.title.substr(0, 1)}</StyledNewLetter>}\n            <MovieItem inView={inView}>\n              <StyledSafeLink isIE11={isIE11} to={movie.path}>\n                <MovieImage\n                  role=\"img\"\n                  backgroundImage={\n                    inView && movie.metaImage && movie.metaImage.url\n                      ? `${movie.metaImage.url}?${makeSrcQueryString(IMAGE_WIDTH * 2)}`\n                      : null\n                  }\n                  aria-label={movie.metaImage && movie.metaImage.alt}\n                  title={movie.title}\n                />\n                <MovieTextWrapper>\n                  <MovieTitle>{movie.title}</MovieTitle>\n                  <MovieDescription>{movie.metaDescription}</MovieDescription>\n                </MovieTextWrapper>\n              </StyledSafeLink>\n            </MovieItem>\n          </Fragment>\n        );\n      })}\n    </StyledWrapper>\n  );\n};\n\nexport default AllMoviesAlphabetically;\n"]} */"));
47
+ }), "{text-indent:", spacingUnit * 0.75, "px;}&:after{content:'';display:block;height:1px;background:", colors.brand.greyDark, ";margin-top:", spacing.small, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["AllMoviesAlphabetically.tsx"],"names":[],"mappings":"AAqBiC","file":"AllMoviesAlphabetically.tsx","sourcesContent":["/**\n * Copyright (c) 2019-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { Fragment, useEffect, useState } from 'react';\nimport { isIE, browserVersion } from 'react-device-detect';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/core';\nimport throttle from 'lodash/throttle';\nimport { breakpoints, mq, spacing, spacingUnit, colors, fonts, animations } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\n// @ts-ignore\nimport { makeSrcQueryString } from '../Image';\nimport { MovieType } from './types';\nimport { isLetter } from './isLetter';\nconst IMAGE_WIDTH = 143;\n\nconst StyledNewLetter = styled.h2`\n  color: #fff;\n  margin: ${spacing.large} 0 ${spacingUnit * 0.75}px;\n  ${fonts.sizes(26, 1.1)};\n  ${mq.range({ from: breakpoints.tablet })} {\n    text-indent: ${spacingUnit * 0.75}px;\n  }\n  &:after {\n    content: '';\n    display: block;\n    height: 1px;\n    background: ${colors.brand.greyDark};\n    margin-top: ${spacing.small};\n  }\n`;\n\nconst StyledWrapper = styled.section`\n  width: 652px;\n  max-width: 100%;\n  margin: ${spacing.large} auto;\n  padding: 0 ${spacing.normal};\n  display: flex;\n  flex-direction: column;\n`;\n\ntype MovieItemProps = {\n  inView: boolean | null;\n};\n\nconst MovieItem = styled.div<MovieItemProps>`\n  margin: 0 0 ${spacingUnit * 0.75}px;\n  display: inline-flex;\n  &:last-child {\n    margin-bottom: ${spacing.large};\n  }\n  opacity: 0;\n  transform: translateY(${spacing.xsmall});\n  transition: all ${animations.durations.slow} ease;\n  ${(props: MovieItemProps) =>\n    props.inView &&\n    css`\n      opacity: 1;\n      transform: translateY(0);\n    `};\n`;\n\nconst MovieTextWrapper = styled.div`\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.xsmall} ${spacing.xsmall} 0 0;\n  }\n  flex: 1;\n`;\n\ntype movieImageType = {\n  backgroundImage?: string | null;\n};\n\nconst MovieImage = styled.div<movieImageType>`\n  width: 104px;\n  height: 80px;\n  background-color: ${colors.ndlaFilm.filmColorLight};\n  ${(props: movieImageType) =>\n    props.backgroundImage !== null &&\n    css`\n      background-image: url(${props.backgroundImage});\n    `}\n  background-size: cover;\n  background-position: center center;\n  margin: 0 ${spacingUnit * 0.75}px 0 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    margin-left: ${spacingUnit * 0.75}px;\n    width: ${IMAGE_WIDTH}px;\n    height: 90px;\n  }\n  position: relative;\n  &:after {\n    content: '';\n    position: absolute;\n    z-index: 1;\n    background: ${colors.ndlaFilm.filmColor};\n    opacity: 0;\n    left: 0;\n    right: 0;\n    bottom: 0;\n    top: 0;\n  }\n`;\n\nconst MovieTitle = styled.h3`\n  color: #fff;\n  margin: 0 0 2px;\n  ${fonts.sizes(18, 1.3)};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes(20, 1.3)};\n  }\n`;\n\nconst MovieDescription = styled.p`\n  color: ${colors.brand.greyLighter};\n  margin: 0;\n  ${fonts.sizes(14, 1.5)};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes(16, 1.5)};\n  }\n  overflow: hidden;\n  text-overflow: ellipsis;\n  display: -webkit-box;\n  -webkit-box-orient: vertical;\n  -webkit-line-clamp: 2;\n`;\n\ntype isIEProps = {\n  isIE11: boolean;\n};\n\nconst StyledSafeLink = styled(SafeLink)<isIEProps>`\n  box-shadow: none;\n  display: flex;\n  ${(props) =>\n    props.isIE11 &&\n    css`\n      flex: 1;\n    `}\n  &:hover,\n  &:focus {\n    ${MovieTitle} {\n      text-decoration: underline;\n    }\n    ${MovieImage} {\n      &:after {\n        transition: opacity 200ms ease;\n        display: block;\n        opacity: 0.3;\n      }\n    }\n  }\n`;\n\ninterface Props {\n  movies: MovieType[];\n  locale: string;\n}\n\ntype visibleImagesProps = {\n  [key: string]: boolean | null;\n};\n\nconst hasForEachPolyfill = () => {\n  // Polyfill for ie11\n  if ('NodeList' in window && !NodeList.prototype.forEach) {\n    NodeList.prototype.forEach = function (callback, thisArg) {\n      thisArg = thisArg || window;\n      for (var i = 0; i < this.length; i++) {\n        callback.call(thisArg, this[i], i, this);\n      }\n    };\n  }\n};\n\nconst AllMoviesAlphabetically: React.FunctionComponent<Props> = ({ movies, locale }) => {\n  const isIE11 = isIE && parseInt(browserVersion) < 12;\n  // Split into Letters.\n  let previousLetter = '';\n  const wrapperRef: React.RefObject<HTMLElement> = React.useRef(null);\n  const [visibleImages, setVisibleImages] = useState<visibleImagesProps>({});\n\n  const scrollEvent = () => {\n    hasForEachPolyfill();\n    const updates: visibleImagesProps = {};\n    const allChildren: NodeListOf<HTMLElement> | null =\n      wrapperRef.current && wrapperRef.current.querySelectorAll('[role=img]');\n    const windowInnerHeight = window.innerHeight;\n    if (allChildren) {\n      let started: boolean = false;\n      let ended: boolean = false;\n      allChildren.forEach((el: HTMLElement, index: number) => {\n        if (!ended) {\n          const rect: ClientRect = el.getBoundingClientRect();\n          if (!started) {\n            if (rect.top > -20) {\n              updates[index] = true;\n              started = true;\n            }\n          } else {\n            updates[index] = true;\n            if (rect.top > windowInnerHeight + 20) {\n              ended = true;\n            }\n          }\n        }\n      });\n    }\n    setVisibleImages((visibleImages) => ({ ...visibleImages, ...updates }));\n  };\n\n  useEffect(() => {\n    const throttledScrollEvent = throttle(() => {\n      scrollEvent();\n    }, 100);\n    window.addEventListener('scroll', throttledScrollEvent);\n    scrollEvent();\n    return () => {\n      window.removeEventListener('scroll', throttledScrollEvent);\n    };\n  }, []);\n\n  useEffect(() => {\n    scrollEvent();\n  }, [movies]);\n\n  return (\n    <StyledWrapper ref={wrapperRef}>\n      {movies.map((movie: MovieType, index: number) => {\n        const currentLetter = movie.title.substr(0, 1);\n        const isNewLetter = currentLetter.localeCompare(previousLetter, locale) === 1 && isLetter(movie.title);\n        previousLetter = currentLetter;\n        const inView: boolean | null = visibleImages ? visibleImages[index] : null;\n        return (\n          <Fragment key={movie.id}>\n            {isNewLetter && <StyledNewLetter>{movie.title.substr(0, 1)}</StyledNewLetter>}\n            <MovieItem inView={inView}>\n              <StyledSafeLink isIE11={isIE11} to={movie.path}>\n                <MovieImage\n                  role=\"img\"\n                  backgroundImage={\n                    inView && movie.metaImage && movie.metaImage.url\n                      ? `${movie.metaImage.url}?${makeSrcQueryString(IMAGE_WIDTH * 2)}`\n                      : null\n                  }\n                  aria-label={movie.metaImage && movie.metaImage.alt}\n                  title={movie.title}\n                />\n                <MovieTextWrapper>\n                  <MovieTitle>{movie.title}</MovieTitle>\n                  <MovieDescription>{movie.metaDescription}</MovieDescription>\n                </MovieTextWrapper>\n              </StyledSafeLink>\n            </MovieItem>\n          </Fragment>\n        );\n      })}\n    </StyledWrapper>\n  );\n};\n\nexport default AllMoviesAlphabetically;\n"]} */"));
48
48
 
49
49
  var StyledWrapper = _styled("section", {
50
50
  target: "e1ul1xui1",
51
51
  label: "StyledWrapper"
52
- })("width:652px;max-width:100%;margin:", spacing.large, " auto;padding:0 ", spacing.normal, ";display:flex;flex-direction:column;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["AllMoviesAlphabetically.tsx"],"names":[],"mappings":"AAqCoC","file":"AllMoviesAlphabetically.tsx","sourcesContent":["/**\n * Copyright (c) 2019-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { Fragment, useEffect, useState } from 'react';\nimport { isIE, browserVersion } from 'react-device-detect';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/core';\nimport throttle from 'lodash/throttle';\nimport { breakpoints, mq, spacing, spacingUnit, colors, fonts, animations } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\n// @ts-ignore\nimport { makeSrcQueryString } from '../Image';\nimport { movieType } from './types';\nimport { isLetter } from './isLetter';\nconst IMAGE_WIDTH = 143;\n\nconst StyledNewLetter = styled.h2`\n  color: #fff;\n  margin: ${spacing.large} 0 ${spacingUnit * 0.75}px;\n  ${fonts.sizes(26, 1.1)};\n  ${mq.range({ from: breakpoints.tablet })} {\n    text-indent: ${spacingUnit * 0.75}px;\n  }\n  &:after {\n    content: '';\n    display: block;\n    height: 1px;\n    background: ${colors.brand.greyDark};\n    margin-top: ${spacing.small};\n  }\n`;\n\nconst StyledWrapper = styled.section`\n  width: 652px;\n  max-width: 100%;\n  margin: ${spacing.large} auto;\n  padding: 0 ${spacing.normal};\n  display: flex;\n  flex-direction: column;\n`;\n\ntype MovieItemProps = {\n  inView: boolean | null;\n};\n\nconst MovieItem = styled.div<MovieItemProps>`\n  margin: 0 0 ${spacingUnit * 0.75}px;\n  display: inline-flex;\n  &:last-child {\n    margin-bottom: ${spacing.large};\n  }\n  opacity: 0;\n  transform: translateY(${spacing.xsmall});\n  transition: all ${animations.durations.slow} ease;\n  ${(props: MovieItemProps) =>\n    props.inView &&\n    css`\n      opacity: 1;\n      transform: translateY(0);\n    `};\n`;\n\nconst MovieTextWrapper = styled.div`\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.xsmall} ${spacing.xsmall} 0 0;\n  }\n  flex: 1;\n`;\n\ntype movieImageType = {\n  backgroundImage?: string | null;\n};\n\nconst MovieImage = styled.div<movieImageType>`\n  width: 104px;\n  height: 80px;\n  background-color: ${colors.ndlaFilm.filmColorLight};\n  ${(props: movieImageType) =>\n    props.backgroundImage !== null &&\n    css`\n      background-image: url(${props.backgroundImage});\n    `}\n  background-size: cover;\n  background-position: center center;\n  margin: 0 ${spacingUnit * 0.75}px 0 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    margin-left: ${spacingUnit * 0.75}px;\n    width: ${IMAGE_WIDTH}px;\n    height: 90px;\n  }\n  position: relative;\n  &:after {\n    content: '';\n    position: absolute;\n    z-index: 1;\n    background: ${colors.ndlaFilm.filmColor};\n    opacity: 0;\n    left: 0;\n    right: 0;\n    bottom: 0;\n    top: 0;\n  }\n`;\n\nconst MovieTitle = styled.h3`\n  color: #fff;\n  margin: 0 0 2px;\n  ${fonts.sizes(18, 1.3)};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes(20, 1.3)};\n  }\n`;\n\nconst MovieDescription = styled.p`\n  color: ${colors.brand.greyLighter};\n  margin: 0;\n  ${fonts.sizes(14, 1.5)};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes(16, 1.5)};\n  }\n  overflow: hidden;\n  text-overflow: ellipsis;\n  display: -webkit-box;\n  -webkit-box-orient: vertical;\n  -webkit-line-clamp: 2;\n`;\n\ntype isIEProps = {\n  isIE11: boolean;\n};\n\nconst StyledSafeLink = styled(SafeLink)<isIEProps>`\n  box-shadow: none;\n  display: flex;\n  ${(props) =>\n    props.isIE11 &&\n    css`\n      flex: 1;\n    `}\n  &:hover,\n  &:focus {\n    ${MovieTitle} {\n      text-decoration: underline;\n    }\n    ${MovieImage} {\n      &:after {\n        transition: opacity 200ms ease;\n        display: block;\n        opacity: 0.3;\n      }\n    }\n  }\n`;\n\ninterface Props {\n  movies: movieType[];\n  locale: string;\n}\n\ntype visibleImagesProps = {\n  [key: string]: boolean | null;\n};\n\nconst hasForEachPolyfill = () => {\n  // Polyfill for ie11\n  if ('NodeList' in window && !NodeList.prototype.forEach) {\n    NodeList.prototype.forEach = function (callback, thisArg) {\n      thisArg = thisArg || window;\n      for (var i = 0; i < this.length; i++) {\n        callback.call(thisArg, this[i], i, this);\n      }\n    };\n  }\n};\n\nconst AllMoviesAlphabetically: React.FunctionComponent<Props> = ({ movies, locale }) => {\n  const isIE11 = isIE && parseInt(browserVersion) < 12;\n  // Split into Letters.\n  let previousLetter = '';\n  const wrapperRef: React.RefObject<HTMLElement> = React.useRef(null);\n  const [visibleImages, setVisibleImages] = useState<visibleImagesProps>({});\n\n  const scrollEvent = () => {\n    hasForEachPolyfill();\n    const updates: visibleImagesProps = {};\n    const allChildren: NodeListOf<HTMLElement> | null =\n      wrapperRef.current && wrapperRef.current.querySelectorAll('[role=img]');\n    const windowInnerHeight = window.innerHeight;\n    if (allChildren) {\n      let started: boolean = false;\n      let ended: boolean = false;\n      allChildren.forEach((el: HTMLElement, index: number) => {\n        if (!ended) {\n          const rect: ClientRect = el.getBoundingClientRect();\n          if (!started) {\n            if (rect.top > -20) {\n              updates[index] = true;\n              started = true;\n            }\n          } else {\n            updates[index] = true;\n            if (rect.top > windowInnerHeight + 20) {\n              ended = true;\n            }\n          }\n        }\n      });\n    }\n    setVisibleImages((visibleImages) => ({ ...visibleImages, ...updates }));\n  };\n\n  useEffect(() => {\n    const throttledScrollEvent = throttle(() => {\n      scrollEvent();\n    }, 100);\n    window.addEventListener('scroll', throttledScrollEvent);\n    scrollEvent();\n    return () => {\n      window.removeEventListener('scroll', throttledScrollEvent);\n    };\n  }, []);\n\n  useEffect(() => {\n    scrollEvent();\n  }, [movies]);\n\n  return (\n    <StyledWrapper ref={wrapperRef}>\n      {movies.map((movie: movieType, index: number) => {\n        const currentLetter = movie.title.substr(0, 1);\n        const isNewLetter = currentLetter.localeCompare(previousLetter, locale) === 1 && isLetter(movie.title);\n        previousLetter = currentLetter;\n        const inView: boolean | null = visibleImages ? visibleImages[index] : null;\n        return (\n          <Fragment key={movie.id}>\n            {isNewLetter && <StyledNewLetter>{movie.title.substr(0, 1)}</StyledNewLetter>}\n            <MovieItem inView={inView}>\n              <StyledSafeLink isIE11={isIE11} to={movie.path}>\n                <MovieImage\n                  role=\"img\"\n                  backgroundImage={\n                    inView && movie.metaImage && movie.metaImage.url\n                      ? `${movie.metaImage.url}?${makeSrcQueryString(IMAGE_WIDTH * 2)}`\n                      : null\n                  }\n                  aria-label={movie.metaImage && movie.metaImage.alt}\n                  title={movie.title}\n                />\n                <MovieTextWrapper>\n                  <MovieTitle>{movie.title}</MovieTitle>\n                  <MovieDescription>{movie.metaDescription}</MovieDescription>\n                </MovieTextWrapper>\n              </StyledSafeLink>\n            </MovieItem>\n          </Fragment>\n        );\n      })}\n    </StyledWrapper>\n  );\n};\n\nexport default AllMoviesAlphabetically;\n"]} */"));
52
+ })("width:652px;max-width:100%;margin:", spacing.large, " auto;padding:0 ", spacing.normal, ";display:flex;flex-direction:column;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["AllMoviesAlphabetically.tsx"],"names":[],"mappings":"AAqCoC","file":"AllMoviesAlphabetically.tsx","sourcesContent":["/**\n * Copyright (c) 2019-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { Fragment, useEffect, useState } from 'react';\nimport { isIE, browserVersion } from 'react-device-detect';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/core';\nimport throttle from 'lodash/throttle';\nimport { breakpoints, mq, spacing, spacingUnit, colors, fonts, animations } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\n// @ts-ignore\nimport { makeSrcQueryString } from '../Image';\nimport { MovieType } from './types';\nimport { isLetter } from './isLetter';\nconst IMAGE_WIDTH = 143;\n\nconst StyledNewLetter = styled.h2`\n  color: #fff;\n  margin: ${spacing.large} 0 ${spacingUnit * 0.75}px;\n  ${fonts.sizes(26, 1.1)};\n  ${mq.range({ from: breakpoints.tablet })} {\n    text-indent: ${spacingUnit * 0.75}px;\n  }\n  &:after {\n    content: '';\n    display: block;\n    height: 1px;\n    background: ${colors.brand.greyDark};\n    margin-top: ${spacing.small};\n  }\n`;\n\nconst StyledWrapper = styled.section`\n  width: 652px;\n  max-width: 100%;\n  margin: ${spacing.large} auto;\n  padding: 0 ${spacing.normal};\n  display: flex;\n  flex-direction: column;\n`;\n\ntype MovieItemProps = {\n  inView: boolean | null;\n};\n\nconst MovieItem = styled.div<MovieItemProps>`\n  margin: 0 0 ${spacingUnit * 0.75}px;\n  display: inline-flex;\n  &:last-child {\n    margin-bottom: ${spacing.large};\n  }\n  opacity: 0;\n  transform: translateY(${spacing.xsmall});\n  transition: all ${animations.durations.slow} ease;\n  ${(props: MovieItemProps) =>\n    props.inView &&\n    css`\n      opacity: 1;\n      transform: translateY(0);\n    `};\n`;\n\nconst MovieTextWrapper = styled.div`\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.xsmall} ${spacing.xsmall} 0 0;\n  }\n  flex: 1;\n`;\n\ntype movieImageType = {\n  backgroundImage?: string | null;\n};\n\nconst MovieImage = styled.div<movieImageType>`\n  width: 104px;\n  height: 80px;\n  background-color: ${colors.ndlaFilm.filmColorLight};\n  ${(props: movieImageType) =>\n    props.backgroundImage !== null &&\n    css`\n      background-image: url(${props.backgroundImage});\n    `}\n  background-size: cover;\n  background-position: center center;\n  margin: 0 ${spacingUnit * 0.75}px 0 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    margin-left: ${spacingUnit * 0.75}px;\n    width: ${IMAGE_WIDTH}px;\n    height: 90px;\n  }\n  position: relative;\n  &:after {\n    content: '';\n    position: absolute;\n    z-index: 1;\n    background: ${colors.ndlaFilm.filmColor};\n    opacity: 0;\n    left: 0;\n    right: 0;\n    bottom: 0;\n    top: 0;\n  }\n`;\n\nconst MovieTitle = styled.h3`\n  color: #fff;\n  margin: 0 0 2px;\n  ${fonts.sizes(18, 1.3)};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes(20, 1.3)};\n  }\n`;\n\nconst MovieDescription = styled.p`\n  color: ${colors.brand.greyLighter};\n  margin: 0;\n  ${fonts.sizes(14, 1.5)};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes(16, 1.5)};\n  }\n  overflow: hidden;\n  text-overflow: ellipsis;\n  display: -webkit-box;\n  -webkit-box-orient: vertical;\n  -webkit-line-clamp: 2;\n`;\n\ntype isIEProps = {\n  isIE11: boolean;\n};\n\nconst StyledSafeLink = styled(SafeLink)<isIEProps>`\n  box-shadow: none;\n  display: flex;\n  ${(props) =>\n    props.isIE11 &&\n    css`\n      flex: 1;\n    `}\n  &:hover,\n  &:focus {\n    ${MovieTitle} {\n      text-decoration: underline;\n    }\n    ${MovieImage} {\n      &:after {\n        transition: opacity 200ms ease;\n        display: block;\n        opacity: 0.3;\n      }\n    }\n  }\n`;\n\ninterface Props {\n  movies: MovieType[];\n  locale: string;\n}\n\ntype visibleImagesProps = {\n  [key: string]: boolean | null;\n};\n\nconst hasForEachPolyfill = () => {\n  // Polyfill for ie11\n  if ('NodeList' in window && !NodeList.prototype.forEach) {\n    NodeList.prototype.forEach = function (callback, thisArg) {\n      thisArg = thisArg || window;\n      for (var i = 0; i < this.length; i++) {\n        callback.call(thisArg, this[i], i, this);\n      }\n    };\n  }\n};\n\nconst AllMoviesAlphabetically: React.FunctionComponent<Props> = ({ movies, locale }) => {\n  const isIE11 = isIE && parseInt(browserVersion) < 12;\n  // Split into Letters.\n  let previousLetter = '';\n  const wrapperRef: React.RefObject<HTMLElement> = React.useRef(null);\n  const [visibleImages, setVisibleImages] = useState<visibleImagesProps>({});\n\n  const scrollEvent = () => {\n    hasForEachPolyfill();\n    const updates: visibleImagesProps = {};\n    const allChildren: NodeListOf<HTMLElement> | null =\n      wrapperRef.current && wrapperRef.current.querySelectorAll('[role=img]');\n    const windowInnerHeight = window.innerHeight;\n    if (allChildren) {\n      let started: boolean = false;\n      let ended: boolean = false;\n      allChildren.forEach((el: HTMLElement, index: number) => {\n        if (!ended) {\n          const rect: ClientRect = el.getBoundingClientRect();\n          if (!started) {\n            if (rect.top > -20) {\n              updates[index] = true;\n              started = true;\n            }\n          } else {\n            updates[index] = true;\n            if (rect.top > windowInnerHeight + 20) {\n              ended = true;\n            }\n          }\n        }\n      });\n    }\n    setVisibleImages((visibleImages) => ({ ...visibleImages, ...updates }));\n  };\n\n  useEffect(() => {\n    const throttledScrollEvent = throttle(() => {\n      scrollEvent();\n    }, 100);\n    window.addEventListener('scroll', throttledScrollEvent);\n    scrollEvent();\n    return () => {\n      window.removeEventListener('scroll', throttledScrollEvent);\n    };\n  }, []);\n\n  useEffect(() => {\n    scrollEvent();\n  }, [movies]);\n\n  return (\n    <StyledWrapper ref={wrapperRef}>\n      {movies.map((movie: MovieType, index: number) => {\n        const currentLetter = movie.title.substr(0, 1);\n        const isNewLetter = currentLetter.localeCompare(previousLetter, locale) === 1 && isLetter(movie.title);\n        previousLetter = currentLetter;\n        const inView: boolean | null = visibleImages ? visibleImages[index] : null;\n        return (\n          <Fragment key={movie.id}>\n            {isNewLetter && <StyledNewLetter>{movie.title.substr(0, 1)}</StyledNewLetter>}\n            <MovieItem inView={inView}>\n              <StyledSafeLink isIE11={isIE11} to={movie.path}>\n                <MovieImage\n                  role=\"img\"\n                  backgroundImage={\n                    inView && movie.metaImage && movie.metaImage.url\n                      ? `${movie.metaImage.url}?${makeSrcQueryString(IMAGE_WIDTH * 2)}`\n                      : null\n                  }\n                  aria-label={movie.metaImage && movie.metaImage.alt}\n                  title={movie.title}\n                />\n                <MovieTextWrapper>\n                  <MovieTitle>{movie.title}</MovieTitle>\n                  <MovieDescription>{movie.metaDescription}</MovieDescription>\n                </MovieTextWrapper>\n              </StyledSafeLink>\n            </MovieItem>\n          </Fragment>\n        );\n      })}\n    </StyledWrapper>\n  );\n};\n\nexport default AllMoviesAlphabetically;\n"]} */"));
53
53
 
54
54
  var _ref = process.env.NODE_ENV === "production" ? {
55
55
  name: "6t3ohw-MovieItem",
@@ -57,7 +57,7 @@ var _ref = process.env.NODE_ENV === "production" ? {
57
57
  } : {
58
58
  name: "6t3ohw-MovieItem",
59
59
  styles: "opacity:1;transform:translateY(0);;label:MovieItem;",
60
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["AllMoviesAlphabetically.tsx"],"names":[],"mappings":"AA6DO","file":"AllMoviesAlphabetically.tsx","sourcesContent":["/**\n * Copyright (c) 2019-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { Fragment, useEffect, useState } from 'react';\nimport { isIE, browserVersion } from 'react-device-detect';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/core';\nimport throttle from 'lodash/throttle';\nimport { breakpoints, mq, spacing, spacingUnit, colors, fonts, animations } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\n// @ts-ignore\nimport { makeSrcQueryString } from '../Image';\nimport { movieType } from './types';\nimport { isLetter } from './isLetter';\nconst IMAGE_WIDTH = 143;\n\nconst StyledNewLetter = styled.h2`\n  color: #fff;\n  margin: ${spacing.large} 0 ${spacingUnit * 0.75}px;\n  ${fonts.sizes(26, 1.1)};\n  ${mq.range({ from: breakpoints.tablet })} {\n    text-indent: ${spacingUnit * 0.75}px;\n  }\n  &:after {\n    content: '';\n    display: block;\n    height: 1px;\n    background: ${colors.brand.greyDark};\n    margin-top: ${spacing.small};\n  }\n`;\n\nconst StyledWrapper = styled.section`\n  width: 652px;\n  max-width: 100%;\n  margin: ${spacing.large} auto;\n  padding: 0 ${spacing.normal};\n  display: flex;\n  flex-direction: column;\n`;\n\ntype MovieItemProps = {\n  inView: boolean | null;\n};\n\nconst MovieItem = styled.div<MovieItemProps>`\n  margin: 0 0 ${spacingUnit * 0.75}px;\n  display: inline-flex;\n  &:last-child {\n    margin-bottom: ${spacing.large};\n  }\n  opacity: 0;\n  transform: translateY(${spacing.xsmall});\n  transition: all ${animations.durations.slow} ease;\n  ${(props: MovieItemProps) =>\n    props.inView &&\n    css`\n      opacity: 1;\n      transform: translateY(0);\n    `};\n`;\n\nconst MovieTextWrapper = styled.div`\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.xsmall} ${spacing.xsmall} 0 0;\n  }\n  flex: 1;\n`;\n\ntype movieImageType = {\n  backgroundImage?: string | null;\n};\n\nconst MovieImage = styled.div<movieImageType>`\n  width: 104px;\n  height: 80px;\n  background-color: ${colors.ndlaFilm.filmColorLight};\n  ${(props: movieImageType) =>\n    props.backgroundImage !== null &&\n    css`\n      background-image: url(${props.backgroundImage});\n    `}\n  background-size: cover;\n  background-position: center center;\n  margin: 0 ${spacingUnit * 0.75}px 0 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    margin-left: ${spacingUnit * 0.75}px;\n    width: ${IMAGE_WIDTH}px;\n    height: 90px;\n  }\n  position: relative;\n  &:after {\n    content: '';\n    position: absolute;\n    z-index: 1;\n    background: ${colors.ndlaFilm.filmColor};\n    opacity: 0;\n    left: 0;\n    right: 0;\n    bottom: 0;\n    top: 0;\n  }\n`;\n\nconst MovieTitle = styled.h3`\n  color: #fff;\n  margin: 0 0 2px;\n  ${fonts.sizes(18, 1.3)};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes(20, 1.3)};\n  }\n`;\n\nconst MovieDescription = styled.p`\n  color: ${colors.brand.greyLighter};\n  margin: 0;\n  ${fonts.sizes(14, 1.5)};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes(16, 1.5)};\n  }\n  overflow: hidden;\n  text-overflow: ellipsis;\n  display: -webkit-box;\n  -webkit-box-orient: vertical;\n  -webkit-line-clamp: 2;\n`;\n\ntype isIEProps = {\n  isIE11: boolean;\n};\n\nconst StyledSafeLink = styled(SafeLink)<isIEProps>`\n  box-shadow: none;\n  display: flex;\n  ${(props) =>\n    props.isIE11 &&\n    css`\n      flex: 1;\n    `}\n  &:hover,\n  &:focus {\n    ${MovieTitle} {\n      text-decoration: underline;\n    }\n    ${MovieImage} {\n      &:after {\n        transition: opacity 200ms ease;\n        display: block;\n        opacity: 0.3;\n      }\n    }\n  }\n`;\n\ninterface Props {\n  movies: movieType[];\n  locale: string;\n}\n\ntype visibleImagesProps = {\n  [key: string]: boolean | null;\n};\n\nconst hasForEachPolyfill = () => {\n  // Polyfill for ie11\n  if ('NodeList' in window && !NodeList.prototype.forEach) {\n    NodeList.prototype.forEach = function (callback, thisArg) {\n      thisArg = thisArg || window;\n      for (var i = 0; i < this.length; i++) {\n        callback.call(thisArg, this[i], i, this);\n      }\n    };\n  }\n};\n\nconst AllMoviesAlphabetically: React.FunctionComponent<Props> = ({ movies, locale }) => {\n  const isIE11 = isIE && parseInt(browserVersion) < 12;\n  // Split into Letters.\n  let previousLetter = '';\n  const wrapperRef: React.RefObject<HTMLElement> = React.useRef(null);\n  const [visibleImages, setVisibleImages] = useState<visibleImagesProps>({});\n\n  const scrollEvent = () => {\n    hasForEachPolyfill();\n    const updates: visibleImagesProps = {};\n    const allChildren: NodeListOf<HTMLElement> | null =\n      wrapperRef.current && wrapperRef.current.querySelectorAll('[role=img]');\n    const windowInnerHeight = window.innerHeight;\n    if (allChildren) {\n      let started: boolean = false;\n      let ended: boolean = false;\n      allChildren.forEach((el: HTMLElement, index: number) => {\n        if (!ended) {\n          const rect: ClientRect = el.getBoundingClientRect();\n          if (!started) {\n            if (rect.top > -20) {\n              updates[index] = true;\n              started = true;\n            }\n          } else {\n            updates[index] = true;\n            if (rect.top > windowInnerHeight + 20) {\n              ended = true;\n            }\n          }\n        }\n      });\n    }\n    setVisibleImages((visibleImages) => ({ ...visibleImages, ...updates }));\n  };\n\n  useEffect(() => {\n    const throttledScrollEvent = throttle(() => {\n      scrollEvent();\n    }, 100);\n    window.addEventListener('scroll', throttledScrollEvent);\n    scrollEvent();\n    return () => {\n      window.removeEventListener('scroll', throttledScrollEvent);\n    };\n  }, []);\n\n  useEffect(() => {\n    scrollEvent();\n  }, [movies]);\n\n  return (\n    <StyledWrapper ref={wrapperRef}>\n      {movies.map((movie: movieType, index: number) => {\n        const currentLetter = movie.title.substr(0, 1);\n        const isNewLetter = currentLetter.localeCompare(previousLetter, locale) === 1 && isLetter(movie.title);\n        previousLetter = currentLetter;\n        const inView: boolean | null = visibleImages ? visibleImages[index] : null;\n        return (\n          <Fragment key={movie.id}>\n            {isNewLetter && <StyledNewLetter>{movie.title.substr(0, 1)}</StyledNewLetter>}\n            <MovieItem inView={inView}>\n              <StyledSafeLink isIE11={isIE11} to={movie.path}>\n                <MovieImage\n                  role=\"img\"\n                  backgroundImage={\n                    inView && movie.metaImage && movie.metaImage.url\n                      ? `${movie.metaImage.url}?${makeSrcQueryString(IMAGE_WIDTH * 2)}`\n                      : null\n                  }\n                  aria-label={movie.metaImage && movie.metaImage.alt}\n                  title={movie.title}\n                />\n                <MovieTextWrapper>\n                  <MovieTitle>{movie.title}</MovieTitle>\n                  <MovieDescription>{movie.metaDescription}</MovieDescription>\n                </MovieTextWrapper>\n              </StyledSafeLink>\n            </MovieItem>\n          </Fragment>\n        );\n      })}\n    </StyledWrapper>\n  );\n};\n\nexport default AllMoviesAlphabetically;\n"]} */",
60
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["AllMoviesAlphabetically.tsx"],"names":[],"mappings":"AA6DO","file":"AllMoviesAlphabetically.tsx","sourcesContent":["/**\n * Copyright (c) 2019-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { Fragment, useEffect, useState } from 'react';\nimport { isIE, browserVersion } from 'react-device-detect';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/core';\nimport throttle from 'lodash/throttle';\nimport { breakpoints, mq, spacing, spacingUnit, colors, fonts, animations } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\n// @ts-ignore\nimport { makeSrcQueryString } from '../Image';\nimport { MovieType } from './types';\nimport { isLetter } from './isLetter';\nconst IMAGE_WIDTH = 143;\n\nconst StyledNewLetter = styled.h2`\n  color: #fff;\n  margin: ${spacing.large} 0 ${spacingUnit * 0.75}px;\n  ${fonts.sizes(26, 1.1)};\n  ${mq.range({ from: breakpoints.tablet })} {\n    text-indent: ${spacingUnit * 0.75}px;\n  }\n  &:after {\n    content: '';\n    display: block;\n    height: 1px;\n    background: ${colors.brand.greyDark};\n    margin-top: ${spacing.small};\n  }\n`;\n\nconst StyledWrapper = styled.section`\n  width: 652px;\n  max-width: 100%;\n  margin: ${spacing.large} auto;\n  padding: 0 ${spacing.normal};\n  display: flex;\n  flex-direction: column;\n`;\n\ntype MovieItemProps = {\n  inView: boolean | null;\n};\n\nconst MovieItem = styled.div<MovieItemProps>`\n  margin: 0 0 ${spacingUnit * 0.75}px;\n  display: inline-flex;\n  &:last-child {\n    margin-bottom: ${spacing.large};\n  }\n  opacity: 0;\n  transform: translateY(${spacing.xsmall});\n  transition: all ${animations.durations.slow} ease;\n  ${(props: MovieItemProps) =>\n    props.inView &&\n    css`\n      opacity: 1;\n      transform: translateY(0);\n    `};\n`;\n\nconst MovieTextWrapper = styled.div`\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.xsmall} ${spacing.xsmall} 0 0;\n  }\n  flex: 1;\n`;\n\ntype movieImageType = {\n  backgroundImage?: string | null;\n};\n\nconst MovieImage = styled.div<movieImageType>`\n  width: 104px;\n  height: 80px;\n  background-color: ${colors.ndlaFilm.filmColorLight};\n  ${(props: movieImageType) =>\n    props.backgroundImage !== null &&\n    css`\n      background-image: url(${props.backgroundImage});\n    `}\n  background-size: cover;\n  background-position: center center;\n  margin: 0 ${spacingUnit * 0.75}px 0 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    margin-left: ${spacingUnit * 0.75}px;\n    width: ${IMAGE_WIDTH}px;\n    height: 90px;\n  }\n  position: relative;\n  &:after {\n    content: '';\n    position: absolute;\n    z-index: 1;\n    background: ${colors.ndlaFilm.filmColor};\n    opacity: 0;\n    left: 0;\n    right: 0;\n    bottom: 0;\n    top: 0;\n  }\n`;\n\nconst MovieTitle = styled.h3`\n  color: #fff;\n  margin: 0 0 2px;\n  ${fonts.sizes(18, 1.3)};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes(20, 1.3)};\n  }\n`;\n\nconst MovieDescription = styled.p`\n  color: ${colors.brand.greyLighter};\n  margin: 0;\n  ${fonts.sizes(14, 1.5)};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes(16, 1.5)};\n  }\n  overflow: hidden;\n  text-overflow: ellipsis;\n  display: -webkit-box;\n  -webkit-box-orient: vertical;\n  -webkit-line-clamp: 2;\n`;\n\ntype isIEProps = {\n  isIE11: boolean;\n};\n\nconst StyledSafeLink = styled(SafeLink)<isIEProps>`\n  box-shadow: none;\n  display: flex;\n  ${(props) =>\n    props.isIE11 &&\n    css`\n      flex: 1;\n    `}\n  &:hover,\n  &:focus {\n    ${MovieTitle} {\n      text-decoration: underline;\n    }\n    ${MovieImage} {\n      &:after {\n        transition: opacity 200ms ease;\n        display: block;\n        opacity: 0.3;\n      }\n    }\n  }\n`;\n\ninterface Props {\n  movies: MovieType[];\n  locale: string;\n}\n\ntype visibleImagesProps = {\n  [key: string]: boolean | null;\n};\n\nconst hasForEachPolyfill = () => {\n  // Polyfill for ie11\n  if ('NodeList' in window && !NodeList.prototype.forEach) {\n    NodeList.prototype.forEach = function (callback, thisArg) {\n      thisArg = thisArg || window;\n      for (var i = 0; i < this.length; i++) {\n        callback.call(thisArg, this[i], i, this);\n      }\n    };\n  }\n};\n\nconst AllMoviesAlphabetically: React.FunctionComponent<Props> = ({ movies, locale }) => {\n  const isIE11 = isIE && parseInt(browserVersion) < 12;\n  // Split into Letters.\n  let previousLetter = '';\n  const wrapperRef: React.RefObject<HTMLElement> = React.useRef(null);\n  const [visibleImages, setVisibleImages] = useState<visibleImagesProps>({});\n\n  const scrollEvent = () => {\n    hasForEachPolyfill();\n    const updates: visibleImagesProps = {};\n    const allChildren: NodeListOf<HTMLElement> | null =\n      wrapperRef.current && wrapperRef.current.querySelectorAll('[role=img]');\n    const windowInnerHeight = window.innerHeight;\n    if (allChildren) {\n      let started: boolean = false;\n      let ended: boolean = false;\n      allChildren.forEach((el: HTMLElement, index: number) => {\n        if (!ended) {\n          const rect: ClientRect = el.getBoundingClientRect();\n          if (!started) {\n            if (rect.top > -20) {\n              updates[index] = true;\n              started = true;\n            }\n          } else {\n            updates[index] = true;\n            if (rect.top > windowInnerHeight + 20) {\n              ended = true;\n            }\n          }\n        }\n      });\n    }\n    setVisibleImages((visibleImages) => ({ ...visibleImages, ...updates }));\n  };\n\n  useEffect(() => {\n    const throttledScrollEvent = throttle(() => {\n      scrollEvent();\n    }, 100);\n    window.addEventListener('scroll', throttledScrollEvent);\n    scrollEvent();\n    return () => {\n      window.removeEventListener('scroll', throttledScrollEvent);\n    };\n  }, []);\n\n  useEffect(() => {\n    scrollEvent();\n  }, [movies]);\n\n  return (\n    <StyledWrapper ref={wrapperRef}>\n      {movies.map((movie: MovieType, index: number) => {\n        const currentLetter = movie.title.substr(0, 1);\n        const isNewLetter = currentLetter.localeCompare(previousLetter, locale) === 1 && isLetter(movie.title);\n        previousLetter = currentLetter;\n        const inView: boolean | null = visibleImages ? visibleImages[index] : null;\n        return (\n          <Fragment key={movie.id}>\n            {isNewLetter && <StyledNewLetter>{movie.title.substr(0, 1)}</StyledNewLetter>}\n            <MovieItem inView={inView}>\n              <StyledSafeLink isIE11={isIE11} to={movie.path}>\n                <MovieImage\n                  role=\"img\"\n                  backgroundImage={\n                    inView && movie.metaImage && movie.metaImage.url\n                      ? `${movie.metaImage.url}?${makeSrcQueryString(IMAGE_WIDTH * 2)}`\n                      : null\n                  }\n                  aria-label={movie.metaImage && movie.metaImage.alt}\n                  title={movie.title}\n                />\n                <MovieTextWrapper>\n                  <MovieTitle>{movie.title}</MovieTitle>\n                  <MovieDescription>{movie.metaDescription}</MovieDescription>\n                </MovieTextWrapper>\n              </StyledSafeLink>\n            </MovieItem>\n          </Fragment>\n        );\n      })}\n    </StyledWrapper>\n  );\n};\n\nexport default AllMoviesAlphabetically;\n"]} */",
61
61
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
62
62
  };
63
63
 
@@ -66,37 +66,37 @@ var MovieItem = _styled("div", {
66
66
  label: "MovieItem"
67
67
  })("margin:0 0 ", spacingUnit * 0.75, "px;display:inline-flex;&:last-child{margin-bottom:", spacing.large, ";}opacity:0;transform:translateY(", spacing.xsmall, ");transition:all ", animations.durations.slow, " ease;", function (props) {
68
68
  return props.inView && _ref;
69
- }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["AllMoviesAlphabetically.tsx"],"names":[],"mappings":"AAkD4C","file":"AllMoviesAlphabetically.tsx","sourcesContent":["/**\n * Copyright (c) 2019-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { Fragment, useEffect, useState } from 'react';\nimport { isIE, browserVersion } from 'react-device-detect';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/core';\nimport throttle from 'lodash/throttle';\nimport { breakpoints, mq, spacing, spacingUnit, colors, fonts, animations } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\n// @ts-ignore\nimport { makeSrcQueryString } from '../Image';\nimport { movieType } from './types';\nimport { isLetter } from './isLetter';\nconst IMAGE_WIDTH = 143;\n\nconst StyledNewLetter = styled.h2`\n  color: #fff;\n  margin: ${spacing.large} 0 ${spacingUnit * 0.75}px;\n  ${fonts.sizes(26, 1.1)};\n  ${mq.range({ from: breakpoints.tablet })} {\n    text-indent: ${spacingUnit * 0.75}px;\n  }\n  &:after {\n    content: '';\n    display: block;\n    height: 1px;\n    background: ${colors.brand.greyDark};\n    margin-top: ${spacing.small};\n  }\n`;\n\nconst StyledWrapper = styled.section`\n  width: 652px;\n  max-width: 100%;\n  margin: ${spacing.large} auto;\n  padding: 0 ${spacing.normal};\n  display: flex;\n  flex-direction: column;\n`;\n\ntype MovieItemProps = {\n  inView: boolean | null;\n};\n\nconst MovieItem = styled.div<MovieItemProps>`\n  margin: 0 0 ${spacingUnit * 0.75}px;\n  display: inline-flex;\n  &:last-child {\n    margin-bottom: ${spacing.large};\n  }\n  opacity: 0;\n  transform: translateY(${spacing.xsmall});\n  transition: all ${animations.durations.slow} ease;\n  ${(props: MovieItemProps) =>\n    props.inView &&\n    css`\n      opacity: 1;\n      transform: translateY(0);\n    `};\n`;\n\nconst MovieTextWrapper = styled.div`\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.xsmall} ${spacing.xsmall} 0 0;\n  }\n  flex: 1;\n`;\n\ntype movieImageType = {\n  backgroundImage?: string | null;\n};\n\nconst MovieImage = styled.div<movieImageType>`\n  width: 104px;\n  height: 80px;\n  background-color: ${colors.ndlaFilm.filmColorLight};\n  ${(props: movieImageType) =>\n    props.backgroundImage !== null &&\n    css`\n      background-image: url(${props.backgroundImage});\n    `}\n  background-size: cover;\n  background-position: center center;\n  margin: 0 ${spacingUnit * 0.75}px 0 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    margin-left: ${spacingUnit * 0.75}px;\n    width: ${IMAGE_WIDTH}px;\n    height: 90px;\n  }\n  position: relative;\n  &:after {\n    content: '';\n    position: absolute;\n    z-index: 1;\n    background: ${colors.ndlaFilm.filmColor};\n    opacity: 0;\n    left: 0;\n    right: 0;\n    bottom: 0;\n    top: 0;\n  }\n`;\n\nconst MovieTitle = styled.h3`\n  color: #fff;\n  margin: 0 0 2px;\n  ${fonts.sizes(18, 1.3)};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes(20, 1.3)};\n  }\n`;\n\nconst MovieDescription = styled.p`\n  color: ${colors.brand.greyLighter};\n  margin: 0;\n  ${fonts.sizes(14, 1.5)};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes(16, 1.5)};\n  }\n  overflow: hidden;\n  text-overflow: ellipsis;\n  display: -webkit-box;\n  -webkit-box-orient: vertical;\n  -webkit-line-clamp: 2;\n`;\n\ntype isIEProps = {\n  isIE11: boolean;\n};\n\nconst StyledSafeLink = styled(SafeLink)<isIEProps>`\n  box-shadow: none;\n  display: flex;\n  ${(props) =>\n    props.isIE11 &&\n    css`\n      flex: 1;\n    `}\n  &:hover,\n  &:focus {\n    ${MovieTitle} {\n      text-decoration: underline;\n    }\n    ${MovieImage} {\n      &:after {\n        transition: opacity 200ms ease;\n        display: block;\n        opacity: 0.3;\n      }\n    }\n  }\n`;\n\ninterface Props {\n  movies: movieType[];\n  locale: string;\n}\n\ntype visibleImagesProps = {\n  [key: string]: boolean | null;\n};\n\nconst hasForEachPolyfill = () => {\n  // Polyfill for ie11\n  if ('NodeList' in window && !NodeList.prototype.forEach) {\n    NodeList.prototype.forEach = function (callback, thisArg) {\n      thisArg = thisArg || window;\n      for (var i = 0; i < this.length; i++) {\n        callback.call(thisArg, this[i], i, this);\n      }\n    };\n  }\n};\n\nconst AllMoviesAlphabetically: React.FunctionComponent<Props> = ({ movies, locale }) => {\n  const isIE11 = isIE && parseInt(browserVersion) < 12;\n  // Split into Letters.\n  let previousLetter = '';\n  const wrapperRef: React.RefObject<HTMLElement> = React.useRef(null);\n  const [visibleImages, setVisibleImages] = useState<visibleImagesProps>({});\n\n  const scrollEvent = () => {\n    hasForEachPolyfill();\n    const updates: visibleImagesProps = {};\n    const allChildren: NodeListOf<HTMLElement> | null =\n      wrapperRef.current && wrapperRef.current.querySelectorAll('[role=img]');\n    const windowInnerHeight = window.innerHeight;\n    if (allChildren) {\n      let started: boolean = false;\n      let ended: boolean = false;\n      allChildren.forEach((el: HTMLElement, index: number) => {\n        if (!ended) {\n          const rect: ClientRect = el.getBoundingClientRect();\n          if (!started) {\n            if (rect.top > -20) {\n              updates[index] = true;\n              started = true;\n            }\n          } else {\n            updates[index] = true;\n            if (rect.top > windowInnerHeight + 20) {\n              ended = true;\n            }\n          }\n        }\n      });\n    }\n    setVisibleImages((visibleImages) => ({ ...visibleImages, ...updates }));\n  };\n\n  useEffect(() => {\n    const throttledScrollEvent = throttle(() => {\n      scrollEvent();\n    }, 100);\n    window.addEventListener('scroll', throttledScrollEvent);\n    scrollEvent();\n    return () => {\n      window.removeEventListener('scroll', throttledScrollEvent);\n    };\n  }, []);\n\n  useEffect(() => {\n    scrollEvent();\n  }, [movies]);\n\n  return (\n    <StyledWrapper ref={wrapperRef}>\n      {movies.map((movie: movieType, index: number) => {\n        const currentLetter = movie.title.substr(0, 1);\n        const isNewLetter = currentLetter.localeCompare(previousLetter, locale) === 1 && isLetter(movie.title);\n        previousLetter = currentLetter;\n        const inView: boolean | null = visibleImages ? visibleImages[index] : null;\n        return (\n          <Fragment key={movie.id}>\n            {isNewLetter && <StyledNewLetter>{movie.title.substr(0, 1)}</StyledNewLetter>}\n            <MovieItem inView={inView}>\n              <StyledSafeLink isIE11={isIE11} to={movie.path}>\n                <MovieImage\n                  role=\"img\"\n                  backgroundImage={\n                    inView && movie.metaImage && movie.metaImage.url\n                      ? `${movie.metaImage.url}?${makeSrcQueryString(IMAGE_WIDTH * 2)}`\n                      : null\n                  }\n                  aria-label={movie.metaImage && movie.metaImage.alt}\n                  title={movie.title}\n                />\n                <MovieTextWrapper>\n                  <MovieTitle>{movie.title}</MovieTitle>\n                  <MovieDescription>{movie.metaDescription}</MovieDescription>\n                </MovieTextWrapper>\n              </StyledSafeLink>\n            </MovieItem>\n          </Fragment>\n        );\n      })}\n    </StyledWrapper>\n  );\n};\n\nexport default AllMoviesAlphabetically;\n"]} */"));
69
+ }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["AllMoviesAlphabetically.tsx"],"names":[],"mappings":"AAkD4C","file":"AllMoviesAlphabetically.tsx","sourcesContent":["/**\n * Copyright (c) 2019-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { Fragment, useEffect, useState } from 'react';\nimport { isIE, browserVersion } from 'react-device-detect';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/core';\nimport throttle from 'lodash/throttle';\nimport { breakpoints, mq, spacing, spacingUnit, colors, fonts, animations } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\n// @ts-ignore\nimport { makeSrcQueryString } from '../Image';\nimport { MovieType } from './types';\nimport { isLetter } from './isLetter';\nconst IMAGE_WIDTH = 143;\n\nconst StyledNewLetter = styled.h2`\n  color: #fff;\n  margin: ${spacing.large} 0 ${spacingUnit * 0.75}px;\n  ${fonts.sizes(26, 1.1)};\n  ${mq.range({ from: breakpoints.tablet })} {\n    text-indent: ${spacingUnit * 0.75}px;\n  }\n  &:after {\n    content: '';\n    display: block;\n    height: 1px;\n    background: ${colors.brand.greyDark};\n    margin-top: ${spacing.small};\n  }\n`;\n\nconst StyledWrapper = styled.section`\n  width: 652px;\n  max-width: 100%;\n  margin: ${spacing.large} auto;\n  padding: 0 ${spacing.normal};\n  display: flex;\n  flex-direction: column;\n`;\n\ntype MovieItemProps = {\n  inView: boolean | null;\n};\n\nconst MovieItem = styled.div<MovieItemProps>`\n  margin: 0 0 ${spacingUnit * 0.75}px;\n  display: inline-flex;\n  &:last-child {\n    margin-bottom: ${spacing.large};\n  }\n  opacity: 0;\n  transform: translateY(${spacing.xsmall});\n  transition: all ${animations.durations.slow} ease;\n  ${(props: MovieItemProps) =>\n    props.inView &&\n    css`\n      opacity: 1;\n      transform: translateY(0);\n    `};\n`;\n\nconst MovieTextWrapper = styled.div`\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.xsmall} ${spacing.xsmall} 0 0;\n  }\n  flex: 1;\n`;\n\ntype movieImageType = {\n  backgroundImage?: string | null;\n};\n\nconst MovieImage = styled.div<movieImageType>`\n  width: 104px;\n  height: 80px;\n  background-color: ${colors.ndlaFilm.filmColorLight};\n  ${(props: movieImageType) =>\n    props.backgroundImage !== null &&\n    css`\n      background-image: url(${props.backgroundImage});\n    `}\n  background-size: cover;\n  background-position: center center;\n  margin: 0 ${spacingUnit * 0.75}px 0 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    margin-left: ${spacingUnit * 0.75}px;\n    width: ${IMAGE_WIDTH}px;\n    height: 90px;\n  }\n  position: relative;\n  &:after {\n    content: '';\n    position: absolute;\n    z-index: 1;\n    background: ${colors.ndlaFilm.filmColor};\n    opacity: 0;\n    left: 0;\n    right: 0;\n    bottom: 0;\n    top: 0;\n  }\n`;\n\nconst MovieTitle = styled.h3`\n  color: #fff;\n  margin: 0 0 2px;\n  ${fonts.sizes(18, 1.3)};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes(20, 1.3)};\n  }\n`;\n\nconst MovieDescription = styled.p`\n  color: ${colors.brand.greyLighter};\n  margin: 0;\n  ${fonts.sizes(14, 1.5)};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes(16, 1.5)};\n  }\n  overflow: hidden;\n  text-overflow: ellipsis;\n  display: -webkit-box;\n  -webkit-box-orient: vertical;\n  -webkit-line-clamp: 2;\n`;\n\ntype isIEProps = {\n  isIE11: boolean;\n};\n\nconst StyledSafeLink = styled(SafeLink)<isIEProps>`\n  box-shadow: none;\n  display: flex;\n  ${(props) =>\n    props.isIE11 &&\n    css`\n      flex: 1;\n    `}\n  &:hover,\n  &:focus {\n    ${MovieTitle} {\n      text-decoration: underline;\n    }\n    ${MovieImage} {\n      &:after {\n        transition: opacity 200ms ease;\n        display: block;\n        opacity: 0.3;\n      }\n    }\n  }\n`;\n\ninterface Props {\n  movies: MovieType[];\n  locale: string;\n}\n\ntype visibleImagesProps = {\n  [key: string]: boolean | null;\n};\n\nconst hasForEachPolyfill = () => {\n  // Polyfill for ie11\n  if ('NodeList' in window && !NodeList.prototype.forEach) {\n    NodeList.prototype.forEach = function (callback, thisArg) {\n      thisArg = thisArg || window;\n      for (var i = 0; i < this.length; i++) {\n        callback.call(thisArg, this[i], i, this);\n      }\n    };\n  }\n};\n\nconst AllMoviesAlphabetically: React.FunctionComponent<Props> = ({ movies, locale }) => {\n  const isIE11 = isIE && parseInt(browserVersion) < 12;\n  // Split into Letters.\n  let previousLetter = '';\n  const wrapperRef: React.RefObject<HTMLElement> = React.useRef(null);\n  const [visibleImages, setVisibleImages] = useState<visibleImagesProps>({});\n\n  const scrollEvent = () => {\n    hasForEachPolyfill();\n    const updates: visibleImagesProps = {};\n    const allChildren: NodeListOf<HTMLElement> | null =\n      wrapperRef.current && wrapperRef.current.querySelectorAll('[role=img]');\n    const windowInnerHeight = window.innerHeight;\n    if (allChildren) {\n      let started: boolean = false;\n      let ended: boolean = false;\n      allChildren.forEach((el: HTMLElement, index: number) => {\n        if (!ended) {\n          const rect: ClientRect = el.getBoundingClientRect();\n          if (!started) {\n            if (rect.top > -20) {\n              updates[index] = true;\n              started = true;\n            }\n          } else {\n            updates[index] = true;\n            if (rect.top > windowInnerHeight + 20) {\n              ended = true;\n            }\n          }\n        }\n      });\n    }\n    setVisibleImages((visibleImages) => ({ ...visibleImages, ...updates }));\n  };\n\n  useEffect(() => {\n    const throttledScrollEvent = throttle(() => {\n      scrollEvent();\n    }, 100);\n    window.addEventListener('scroll', throttledScrollEvent);\n    scrollEvent();\n    return () => {\n      window.removeEventListener('scroll', throttledScrollEvent);\n    };\n  }, []);\n\n  useEffect(() => {\n    scrollEvent();\n  }, [movies]);\n\n  return (\n    <StyledWrapper ref={wrapperRef}>\n      {movies.map((movie: MovieType, index: number) => {\n        const currentLetter = movie.title.substr(0, 1);\n        const isNewLetter = currentLetter.localeCompare(previousLetter, locale) === 1 && isLetter(movie.title);\n        previousLetter = currentLetter;\n        const inView: boolean | null = visibleImages ? visibleImages[index] : null;\n        return (\n          <Fragment key={movie.id}>\n            {isNewLetter && <StyledNewLetter>{movie.title.substr(0, 1)}</StyledNewLetter>}\n            <MovieItem inView={inView}>\n              <StyledSafeLink isIE11={isIE11} to={movie.path}>\n                <MovieImage\n                  role=\"img\"\n                  backgroundImage={\n                    inView && movie.metaImage && movie.metaImage.url\n                      ? `${movie.metaImage.url}?${makeSrcQueryString(IMAGE_WIDTH * 2)}`\n                      : null\n                  }\n                  aria-label={movie.metaImage && movie.metaImage.alt}\n                  title={movie.title}\n                />\n                <MovieTextWrapper>\n                  <MovieTitle>{movie.title}</MovieTitle>\n                  <MovieDescription>{movie.metaDescription}</MovieDescription>\n                </MovieTextWrapper>\n              </StyledSafeLink>\n            </MovieItem>\n          </Fragment>\n        );\n      })}\n    </StyledWrapper>\n  );\n};\n\nexport default AllMoviesAlphabetically;\n"]} */"));
70
70
 
71
71
  var MovieTextWrapper = _styled("div", {
72
72
  target: "e1ul1xui3",
73
73
  label: "MovieTextWrapper"
74
74
  })(mq.range({
75
75
  from: breakpoints.tablet
76
- }), "{padding:", spacing.xsmall, " ", spacing.xsmall, " 0 0;}flex:1;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["AllMoviesAlphabetically.tsx"],"names":[],"mappings":"AAmEmC","file":"AllMoviesAlphabetically.tsx","sourcesContent":["/**\n * Copyright (c) 2019-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { Fragment, useEffect, useState } from 'react';\nimport { isIE, browserVersion } from 'react-device-detect';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/core';\nimport throttle from 'lodash/throttle';\nimport { breakpoints, mq, spacing, spacingUnit, colors, fonts, animations } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\n// @ts-ignore\nimport { makeSrcQueryString } from '../Image';\nimport { movieType } from './types';\nimport { isLetter } from './isLetter';\nconst IMAGE_WIDTH = 143;\n\nconst StyledNewLetter = styled.h2`\n  color: #fff;\n  margin: ${spacing.large} 0 ${spacingUnit * 0.75}px;\n  ${fonts.sizes(26, 1.1)};\n  ${mq.range({ from: breakpoints.tablet })} {\n    text-indent: ${spacingUnit * 0.75}px;\n  }\n  &:after {\n    content: '';\n    display: block;\n    height: 1px;\n    background: ${colors.brand.greyDark};\n    margin-top: ${spacing.small};\n  }\n`;\n\nconst StyledWrapper = styled.section`\n  width: 652px;\n  max-width: 100%;\n  margin: ${spacing.large} auto;\n  padding: 0 ${spacing.normal};\n  display: flex;\n  flex-direction: column;\n`;\n\ntype MovieItemProps = {\n  inView: boolean | null;\n};\n\nconst MovieItem = styled.div<MovieItemProps>`\n  margin: 0 0 ${spacingUnit * 0.75}px;\n  display: inline-flex;\n  &:last-child {\n    margin-bottom: ${spacing.large};\n  }\n  opacity: 0;\n  transform: translateY(${spacing.xsmall});\n  transition: all ${animations.durations.slow} ease;\n  ${(props: MovieItemProps) =>\n    props.inView &&\n    css`\n      opacity: 1;\n      transform: translateY(0);\n    `};\n`;\n\nconst MovieTextWrapper = styled.div`\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.xsmall} ${spacing.xsmall} 0 0;\n  }\n  flex: 1;\n`;\n\ntype movieImageType = {\n  backgroundImage?: string | null;\n};\n\nconst MovieImage = styled.div<movieImageType>`\n  width: 104px;\n  height: 80px;\n  background-color: ${colors.ndlaFilm.filmColorLight};\n  ${(props: movieImageType) =>\n    props.backgroundImage !== null &&\n    css`\n      background-image: url(${props.backgroundImage});\n    `}\n  background-size: cover;\n  background-position: center center;\n  margin: 0 ${spacingUnit * 0.75}px 0 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    margin-left: ${spacingUnit * 0.75}px;\n    width: ${IMAGE_WIDTH}px;\n    height: 90px;\n  }\n  position: relative;\n  &:after {\n    content: '';\n    position: absolute;\n    z-index: 1;\n    background: ${colors.ndlaFilm.filmColor};\n    opacity: 0;\n    left: 0;\n    right: 0;\n    bottom: 0;\n    top: 0;\n  }\n`;\n\nconst MovieTitle = styled.h3`\n  color: #fff;\n  margin: 0 0 2px;\n  ${fonts.sizes(18, 1.3)};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes(20, 1.3)};\n  }\n`;\n\nconst MovieDescription = styled.p`\n  color: ${colors.brand.greyLighter};\n  margin: 0;\n  ${fonts.sizes(14, 1.5)};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes(16, 1.5)};\n  }\n  overflow: hidden;\n  text-overflow: ellipsis;\n  display: -webkit-box;\n  -webkit-box-orient: vertical;\n  -webkit-line-clamp: 2;\n`;\n\ntype isIEProps = {\n  isIE11: boolean;\n};\n\nconst StyledSafeLink = styled(SafeLink)<isIEProps>`\n  box-shadow: none;\n  display: flex;\n  ${(props) =>\n    props.isIE11 &&\n    css`\n      flex: 1;\n    `}\n  &:hover,\n  &:focus {\n    ${MovieTitle} {\n      text-decoration: underline;\n    }\n    ${MovieImage} {\n      &:after {\n        transition: opacity 200ms ease;\n        display: block;\n        opacity: 0.3;\n      }\n    }\n  }\n`;\n\ninterface Props {\n  movies: movieType[];\n  locale: string;\n}\n\ntype visibleImagesProps = {\n  [key: string]: boolean | null;\n};\n\nconst hasForEachPolyfill = () => {\n  // Polyfill for ie11\n  if ('NodeList' in window && !NodeList.prototype.forEach) {\n    NodeList.prototype.forEach = function (callback, thisArg) {\n      thisArg = thisArg || window;\n      for (var i = 0; i < this.length; i++) {\n        callback.call(thisArg, this[i], i, this);\n      }\n    };\n  }\n};\n\nconst AllMoviesAlphabetically: React.FunctionComponent<Props> = ({ movies, locale }) => {\n  const isIE11 = isIE && parseInt(browserVersion) < 12;\n  // Split into Letters.\n  let previousLetter = '';\n  const wrapperRef: React.RefObject<HTMLElement> = React.useRef(null);\n  const [visibleImages, setVisibleImages] = useState<visibleImagesProps>({});\n\n  const scrollEvent = () => {\n    hasForEachPolyfill();\n    const updates: visibleImagesProps = {};\n    const allChildren: NodeListOf<HTMLElement> | null =\n      wrapperRef.current && wrapperRef.current.querySelectorAll('[role=img]');\n    const windowInnerHeight = window.innerHeight;\n    if (allChildren) {\n      let started: boolean = false;\n      let ended: boolean = false;\n      allChildren.forEach((el: HTMLElement, index: number) => {\n        if (!ended) {\n          const rect: ClientRect = el.getBoundingClientRect();\n          if (!started) {\n            if (rect.top > -20) {\n              updates[index] = true;\n              started = true;\n            }\n          } else {\n            updates[index] = true;\n            if (rect.top > windowInnerHeight + 20) {\n              ended = true;\n            }\n          }\n        }\n      });\n    }\n    setVisibleImages((visibleImages) => ({ ...visibleImages, ...updates }));\n  };\n\n  useEffect(() => {\n    const throttledScrollEvent = throttle(() => {\n      scrollEvent();\n    }, 100);\n    window.addEventListener('scroll', throttledScrollEvent);\n    scrollEvent();\n    return () => {\n      window.removeEventListener('scroll', throttledScrollEvent);\n    };\n  }, []);\n\n  useEffect(() => {\n    scrollEvent();\n  }, [movies]);\n\n  return (\n    <StyledWrapper ref={wrapperRef}>\n      {movies.map((movie: movieType, index: number) => {\n        const currentLetter = movie.title.substr(0, 1);\n        const isNewLetter = currentLetter.localeCompare(previousLetter, locale) === 1 && isLetter(movie.title);\n        previousLetter = currentLetter;\n        const inView: boolean | null = visibleImages ? visibleImages[index] : null;\n        return (\n          <Fragment key={movie.id}>\n            {isNewLetter && <StyledNewLetter>{movie.title.substr(0, 1)}</StyledNewLetter>}\n            <MovieItem inView={inView}>\n              <StyledSafeLink isIE11={isIE11} to={movie.path}>\n                <MovieImage\n                  role=\"img\"\n                  backgroundImage={\n                    inView && movie.metaImage && movie.metaImage.url\n                      ? `${movie.metaImage.url}?${makeSrcQueryString(IMAGE_WIDTH * 2)}`\n                      : null\n                  }\n                  aria-label={movie.metaImage && movie.metaImage.alt}\n                  title={movie.title}\n                />\n                <MovieTextWrapper>\n                  <MovieTitle>{movie.title}</MovieTitle>\n                  <MovieDescription>{movie.metaDescription}</MovieDescription>\n                </MovieTextWrapper>\n              </StyledSafeLink>\n            </MovieItem>\n          </Fragment>\n        );\n      })}\n    </StyledWrapper>\n  );\n};\n\nexport default AllMoviesAlphabetically;\n"]} */"));
76
+ }), "{padding:", spacing.xsmall, " ", spacing.xsmall, " 0 0;}flex:1;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["AllMoviesAlphabetically.tsx"],"names":[],"mappings":"AAmEmC","file":"AllMoviesAlphabetically.tsx","sourcesContent":["/**\n * Copyright (c) 2019-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { Fragment, useEffect, useState } from 'react';\nimport { isIE, browserVersion } from 'react-device-detect';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/core';\nimport throttle from 'lodash/throttle';\nimport { breakpoints, mq, spacing, spacingUnit, colors, fonts, animations } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\n// @ts-ignore\nimport { makeSrcQueryString } from '../Image';\nimport { MovieType } from './types';\nimport { isLetter } from './isLetter';\nconst IMAGE_WIDTH = 143;\n\nconst StyledNewLetter = styled.h2`\n  color: #fff;\n  margin: ${spacing.large} 0 ${spacingUnit * 0.75}px;\n  ${fonts.sizes(26, 1.1)};\n  ${mq.range({ from: breakpoints.tablet })} {\n    text-indent: ${spacingUnit * 0.75}px;\n  }\n  &:after {\n    content: '';\n    display: block;\n    height: 1px;\n    background: ${colors.brand.greyDark};\n    margin-top: ${spacing.small};\n  }\n`;\n\nconst StyledWrapper = styled.section`\n  width: 652px;\n  max-width: 100%;\n  margin: ${spacing.large} auto;\n  padding: 0 ${spacing.normal};\n  display: flex;\n  flex-direction: column;\n`;\n\ntype MovieItemProps = {\n  inView: boolean | null;\n};\n\nconst MovieItem = styled.div<MovieItemProps>`\n  margin: 0 0 ${spacingUnit * 0.75}px;\n  display: inline-flex;\n  &:last-child {\n    margin-bottom: ${spacing.large};\n  }\n  opacity: 0;\n  transform: translateY(${spacing.xsmall});\n  transition: all ${animations.durations.slow} ease;\n  ${(props: MovieItemProps) =>\n    props.inView &&\n    css`\n      opacity: 1;\n      transform: translateY(0);\n    `};\n`;\n\nconst MovieTextWrapper = styled.div`\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.xsmall} ${spacing.xsmall} 0 0;\n  }\n  flex: 1;\n`;\n\ntype movieImageType = {\n  backgroundImage?: string | null;\n};\n\nconst MovieImage = styled.div<movieImageType>`\n  width: 104px;\n  height: 80px;\n  background-color: ${colors.ndlaFilm.filmColorLight};\n  ${(props: movieImageType) =>\n    props.backgroundImage !== null &&\n    css`\n      background-image: url(${props.backgroundImage});\n    `}\n  background-size: cover;\n  background-position: center center;\n  margin: 0 ${spacingUnit * 0.75}px 0 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    margin-left: ${spacingUnit * 0.75}px;\n    width: ${IMAGE_WIDTH}px;\n    height: 90px;\n  }\n  position: relative;\n  &:after {\n    content: '';\n    position: absolute;\n    z-index: 1;\n    background: ${colors.ndlaFilm.filmColor};\n    opacity: 0;\n    left: 0;\n    right: 0;\n    bottom: 0;\n    top: 0;\n  }\n`;\n\nconst MovieTitle = styled.h3`\n  color: #fff;\n  margin: 0 0 2px;\n  ${fonts.sizes(18, 1.3)};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes(20, 1.3)};\n  }\n`;\n\nconst MovieDescription = styled.p`\n  color: ${colors.brand.greyLighter};\n  margin: 0;\n  ${fonts.sizes(14, 1.5)};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes(16, 1.5)};\n  }\n  overflow: hidden;\n  text-overflow: ellipsis;\n  display: -webkit-box;\n  -webkit-box-orient: vertical;\n  -webkit-line-clamp: 2;\n`;\n\ntype isIEProps = {\n  isIE11: boolean;\n};\n\nconst StyledSafeLink = styled(SafeLink)<isIEProps>`\n  box-shadow: none;\n  display: flex;\n  ${(props) =>\n    props.isIE11 &&\n    css`\n      flex: 1;\n    `}\n  &:hover,\n  &:focus {\n    ${MovieTitle} {\n      text-decoration: underline;\n    }\n    ${MovieImage} {\n      &:after {\n        transition: opacity 200ms ease;\n        display: block;\n        opacity: 0.3;\n      }\n    }\n  }\n`;\n\ninterface Props {\n  movies: MovieType[];\n  locale: string;\n}\n\ntype visibleImagesProps = {\n  [key: string]: boolean | null;\n};\n\nconst hasForEachPolyfill = () => {\n  // Polyfill for ie11\n  if ('NodeList' in window && !NodeList.prototype.forEach) {\n    NodeList.prototype.forEach = function (callback, thisArg) {\n      thisArg = thisArg || window;\n      for (var i = 0; i < this.length; i++) {\n        callback.call(thisArg, this[i], i, this);\n      }\n    };\n  }\n};\n\nconst AllMoviesAlphabetically: React.FunctionComponent<Props> = ({ movies, locale }) => {\n  const isIE11 = isIE && parseInt(browserVersion) < 12;\n  // Split into Letters.\n  let previousLetter = '';\n  const wrapperRef: React.RefObject<HTMLElement> = React.useRef(null);\n  const [visibleImages, setVisibleImages] = useState<visibleImagesProps>({});\n\n  const scrollEvent = () => {\n    hasForEachPolyfill();\n    const updates: visibleImagesProps = {};\n    const allChildren: NodeListOf<HTMLElement> | null =\n      wrapperRef.current && wrapperRef.current.querySelectorAll('[role=img]');\n    const windowInnerHeight = window.innerHeight;\n    if (allChildren) {\n      let started: boolean = false;\n      let ended: boolean = false;\n      allChildren.forEach((el: HTMLElement, index: number) => {\n        if (!ended) {\n          const rect: ClientRect = el.getBoundingClientRect();\n          if (!started) {\n            if (rect.top > -20) {\n              updates[index] = true;\n              started = true;\n            }\n          } else {\n            updates[index] = true;\n            if (rect.top > windowInnerHeight + 20) {\n              ended = true;\n            }\n          }\n        }\n      });\n    }\n    setVisibleImages((visibleImages) => ({ ...visibleImages, ...updates }));\n  };\n\n  useEffect(() => {\n    const throttledScrollEvent = throttle(() => {\n      scrollEvent();\n    }, 100);\n    window.addEventListener('scroll', throttledScrollEvent);\n    scrollEvent();\n    return () => {\n      window.removeEventListener('scroll', throttledScrollEvent);\n    };\n  }, []);\n\n  useEffect(() => {\n    scrollEvent();\n  }, [movies]);\n\n  return (\n    <StyledWrapper ref={wrapperRef}>\n      {movies.map((movie: MovieType, index: number) => {\n        const currentLetter = movie.title.substr(0, 1);\n        const isNewLetter = currentLetter.localeCompare(previousLetter, locale) === 1 && isLetter(movie.title);\n        previousLetter = currentLetter;\n        const inView: boolean | null = visibleImages ? visibleImages[index] : null;\n        return (\n          <Fragment key={movie.id}>\n            {isNewLetter && <StyledNewLetter>{movie.title.substr(0, 1)}</StyledNewLetter>}\n            <MovieItem inView={inView}>\n              <StyledSafeLink isIE11={isIE11} to={movie.path}>\n                <MovieImage\n                  role=\"img\"\n                  backgroundImage={\n                    inView && movie.metaImage && movie.metaImage.url\n                      ? `${movie.metaImage.url}?${makeSrcQueryString(IMAGE_WIDTH * 2)}`\n                      : null\n                  }\n                  aria-label={movie.metaImage && movie.metaImage.alt}\n                  title={movie.title}\n                />\n                <MovieTextWrapper>\n                  <MovieTitle>{movie.title}</MovieTitle>\n                  <MovieDescription>{movie.metaDescription}</MovieDescription>\n                </MovieTextWrapper>\n              </StyledSafeLink>\n            </MovieItem>\n          </Fragment>\n        );\n      })}\n    </StyledWrapper>\n  );\n};\n\nexport default AllMoviesAlphabetically;\n"]} */"));
77
77
 
78
78
  var MovieImage = _styled("div", {
79
79
  target: "e1ul1xui4",
80
80
  label: "MovieImage"
81
81
  })("width:104px;height:80px;background-color:", colors.ndlaFilm.filmColorLight, ";", function (props) {
82
- return props.backgroundImage !== null && /*#__PURE__*/css("background-image:url(", props.backgroundImage, ");;label:MovieImage;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["AllMoviesAlphabetically.tsx"],"names":[],"mappings":"AAoFO","file":"AllMoviesAlphabetically.tsx","sourcesContent":["/**\n * Copyright (c) 2019-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { Fragment, useEffect, useState } from 'react';\nimport { isIE, browserVersion } from 'react-device-detect';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/core';\nimport throttle from 'lodash/throttle';\nimport { breakpoints, mq, spacing, spacingUnit, colors, fonts, animations } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\n// @ts-ignore\nimport { makeSrcQueryString } from '../Image';\nimport { movieType } from './types';\nimport { isLetter } from './isLetter';\nconst IMAGE_WIDTH = 143;\n\nconst StyledNewLetter = styled.h2`\n  color: #fff;\n  margin: ${spacing.large} 0 ${spacingUnit * 0.75}px;\n  ${fonts.sizes(26, 1.1)};\n  ${mq.range({ from: breakpoints.tablet })} {\n    text-indent: ${spacingUnit * 0.75}px;\n  }\n  &:after {\n    content: '';\n    display: block;\n    height: 1px;\n    background: ${colors.brand.greyDark};\n    margin-top: ${spacing.small};\n  }\n`;\n\nconst StyledWrapper = styled.section`\n  width: 652px;\n  max-width: 100%;\n  margin: ${spacing.large} auto;\n  padding: 0 ${spacing.normal};\n  display: flex;\n  flex-direction: column;\n`;\n\ntype MovieItemProps = {\n  inView: boolean | null;\n};\n\nconst MovieItem = styled.div<MovieItemProps>`\n  margin: 0 0 ${spacingUnit * 0.75}px;\n  display: inline-flex;\n  &:last-child {\n    margin-bottom: ${spacing.large};\n  }\n  opacity: 0;\n  transform: translateY(${spacing.xsmall});\n  transition: all ${animations.durations.slow} ease;\n  ${(props: MovieItemProps) =>\n    props.inView &&\n    css`\n      opacity: 1;\n      transform: translateY(0);\n    `};\n`;\n\nconst MovieTextWrapper = styled.div`\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.xsmall} ${spacing.xsmall} 0 0;\n  }\n  flex: 1;\n`;\n\ntype movieImageType = {\n  backgroundImage?: string | null;\n};\n\nconst MovieImage = styled.div<movieImageType>`\n  width: 104px;\n  height: 80px;\n  background-color: ${colors.ndlaFilm.filmColorLight};\n  ${(props: movieImageType) =>\n    props.backgroundImage !== null &&\n    css`\n      background-image: url(${props.backgroundImage});\n    `}\n  background-size: cover;\n  background-position: center center;\n  margin: 0 ${spacingUnit * 0.75}px 0 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    margin-left: ${spacingUnit * 0.75}px;\n    width: ${IMAGE_WIDTH}px;\n    height: 90px;\n  }\n  position: relative;\n  &:after {\n    content: '';\n    position: absolute;\n    z-index: 1;\n    background: ${colors.ndlaFilm.filmColor};\n    opacity: 0;\n    left: 0;\n    right: 0;\n    bottom: 0;\n    top: 0;\n  }\n`;\n\nconst MovieTitle = styled.h3`\n  color: #fff;\n  margin: 0 0 2px;\n  ${fonts.sizes(18, 1.3)};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes(20, 1.3)};\n  }\n`;\n\nconst MovieDescription = styled.p`\n  color: ${colors.brand.greyLighter};\n  margin: 0;\n  ${fonts.sizes(14, 1.5)};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes(16, 1.5)};\n  }\n  overflow: hidden;\n  text-overflow: ellipsis;\n  display: -webkit-box;\n  -webkit-box-orient: vertical;\n  -webkit-line-clamp: 2;\n`;\n\ntype isIEProps = {\n  isIE11: boolean;\n};\n\nconst StyledSafeLink = styled(SafeLink)<isIEProps>`\n  box-shadow: none;\n  display: flex;\n  ${(props) =>\n    props.isIE11 &&\n    css`\n      flex: 1;\n    `}\n  &:hover,\n  &:focus {\n    ${MovieTitle} {\n      text-decoration: underline;\n    }\n    ${MovieImage} {\n      &:after {\n        transition: opacity 200ms ease;\n        display: block;\n        opacity: 0.3;\n      }\n    }\n  }\n`;\n\ninterface Props {\n  movies: movieType[];\n  locale: string;\n}\n\ntype visibleImagesProps = {\n  [key: string]: boolean | null;\n};\n\nconst hasForEachPolyfill = () => {\n  // Polyfill for ie11\n  if ('NodeList' in window && !NodeList.prototype.forEach) {\n    NodeList.prototype.forEach = function (callback, thisArg) {\n      thisArg = thisArg || window;\n      for (var i = 0; i < this.length; i++) {\n        callback.call(thisArg, this[i], i, this);\n      }\n    };\n  }\n};\n\nconst AllMoviesAlphabetically: React.FunctionComponent<Props> = ({ movies, locale }) => {\n  const isIE11 = isIE && parseInt(browserVersion) < 12;\n  // Split into Letters.\n  let previousLetter = '';\n  const wrapperRef: React.RefObject<HTMLElement> = React.useRef(null);\n  const [visibleImages, setVisibleImages] = useState<visibleImagesProps>({});\n\n  const scrollEvent = () => {\n    hasForEachPolyfill();\n    const updates: visibleImagesProps = {};\n    const allChildren: NodeListOf<HTMLElement> | null =\n      wrapperRef.current && wrapperRef.current.querySelectorAll('[role=img]');\n    const windowInnerHeight = window.innerHeight;\n    if (allChildren) {\n      let started: boolean = false;\n      let ended: boolean = false;\n      allChildren.forEach((el: HTMLElement, index: number) => {\n        if (!ended) {\n          const rect: ClientRect = el.getBoundingClientRect();\n          if (!started) {\n            if (rect.top > -20) {\n              updates[index] = true;\n              started = true;\n            }\n          } else {\n            updates[index] = true;\n            if (rect.top > windowInnerHeight + 20) {\n              ended = true;\n            }\n          }\n        }\n      });\n    }\n    setVisibleImages((visibleImages) => ({ ...visibleImages, ...updates }));\n  };\n\n  useEffect(() => {\n    const throttledScrollEvent = throttle(() => {\n      scrollEvent();\n    }, 100);\n    window.addEventListener('scroll', throttledScrollEvent);\n    scrollEvent();\n    return () => {\n      window.removeEventListener('scroll', throttledScrollEvent);\n    };\n  }, []);\n\n  useEffect(() => {\n    scrollEvent();\n  }, [movies]);\n\n  return (\n    <StyledWrapper ref={wrapperRef}>\n      {movies.map((movie: movieType, index: number) => {\n        const currentLetter = movie.title.substr(0, 1);\n        const isNewLetter = currentLetter.localeCompare(previousLetter, locale) === 1 && isLetter(movie.title);\n        previousLetter = currentLetter;\n        const inView: boolean | null = visibleImages ? visibleImages[index] : null;\n        return (\n          <Fragment key={movie.id}>\n            {isNewLetter && <StyledNewLetter>{movie.title.substr(0, 1)}</StyledNewLetter>}\n            <MovieItem inView={inView}>\n              <StyledSafeLink isIE11={isIE11} to={movie.path}>\n                <MovieImage\n                  role=\"img\"\n                  backgroundImage={\n                    inView && movie.metaImage && movie.metaImage.url\n                      ? `${movie.metaImage.url}?${makeSrcQueryString(IMAGE_WIDTH * 2)}`\n                      : null\n                  }\n                  aria-label={movie.metaImage && movie.metaImage.alt}\n                  title={movie.title}\n                />\n                <MovieTextWrapper>\n                  <MovieTitle>{movie.title}</MovieTitle>\n                  <MovieDescription>{movie.metaDescription}</MovieDescription>\n                </MovieTextWrapper>\n              </StyledSafeLink>\n            </MovieItem>\n          </Fragment>\n        );\n      })}\n    </StyledWrapper>\n  );\n};\n\nexport default AllMoviesAlphabetically;\n"]} */"));
82
+ return props.backgroundImage !== null && /*#__PURE__*/css("background-image:url(", props.backgroundImage, ");;label:MovieImage;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["AllMoviesAlphabetically.tsx"],"names":[],"mappings":"AAoFO","file":"AllMoviesAlphabetically.tsx","sourcesContent":["/**\n * Copyright (c) 2019-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { Fragment, useEffect, useState } from 'react';\nimport { isIE, browserVersion } from 'react-device-detect';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/core';\nimport throttle from 'lodash/throttle';\nimport { breakpoints, mq, spacing, spacingUnit, colors, fonts, animations } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\n// @ts-ignore\nimport { makeSrcQueryString } from '../Image';\nimport { MovieType } from './types';\nimport { isLetter } from './isLetter';\nconst IMAGE_WIDTH = 143;\n\nconst StyledNewLetter = styled.h2`\n  color: #fff;\n  margin: ${spacing.large} 0 ${spacingUnit * 0.75}px;\n  ${fonts.sizes(26, 1.1)};\n  ${mq.range({ from: breakpoints.tablet })} {\n    text-indent: ${spacingUnit * 0.75}px;\n  }\n  &:after {\n    content: '';\n    display: block;\n    height: 1px;\n    background: ${colors.brand.greyDark};\n    margin-top: ${spacing.small};\n  }\n`;\n\nconst StyledWrapper = styled.section`\n  width: 652px;\n  max-width: 100%;\n  margin: ${spacing.large} auto;\n  padding: 0 ${spacing.normal};\n  display: flex;\n  flex-direction: column;\n`;\n\ntype MovieItemProps = {\n  inView: boolean | null;\n};\n\nconst MovieItem = styled.div<MovieItemProps>`\n  margin: 0 0 ${spacingUnit * 0.75}px;\n  display: inline-flex;\n  &:last-child {\n    margin-bottom: ${spacing.large};\n  }\n  opacity: 0;\n  transform: translateY(${spacing.xsmall});\n  transition: all ${animations.durations.slow} ease;\n  ${(props: MovieItemProps) =>\n    props.inView &&\n    css`\n      opacity: 1;\n      transform: translateY(0);\n    `};\n`;\n\nconst MovieTextWrapper = styled.div`\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.xsmall} ${spacing.xsmall} 0 0;\n  }\n  flex: 1;\n`;\n\ntype movieImageType = {\n  backgroundImage?: string | null;\n};\n\nconst MovieImage = styled.div<movieImageType>`\n  width: 104px;\n  height: 80px;\n  background-color: ${colors.ndlaFilm.filmColorLight};\n  ${(props: movieImageType) =>\n    props.backgroundImage !== null &&\n    css`\n      background-image: url(${props.backgroundImage});\n    `}\n  background-size: cover;\n  background-position: center center;\n  margin: 0 ${spacingUnit * 0.75}px 0 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    margin-left: ${spacingUnit * 0.75}px;\n    width: ${IMAGE_WIDTH}px;\n    height: 90px;\n  }\n  position: relative;\n  &:after {\n    content: '';\n    position: absolute;\n    z-index: 1;\n    background: ${colors.ndlaFilm.filmColor};\n    opacity: 0;\n    left: 0;\n    right: 0;\n    bottom: 0;\n    top: 0;\n  }\n`;\n\nconst MovieTitle = styled.h3`\n  color: #fff;\n  margin: 0 0 2px;\n  ${fonts.sizes(18, 1.3)};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes(20, 1.3)};\n  }\n`;\n\nconst MovieDescription = styled.p`\n  color: ${colors.brand.greyLighter};\n  margin: 0;\n  ${fonts.sizes(14, 1.5)};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes(16, 1.5)};\n  }\n  overflow: hidden;\n  text-overflow: ellipsis;\n  display: -webkit-box;\n  -webkit-box-orient: vertical;\n  -webkit-line-clamp: 2;\n`;\n\ntype isIEProps = {\n  isIE11: boolean;\n};\n\nconst StyledSafeLink = styled(SafeLink)<isIEProps>`\n  box-shadow: none;\n  display: flex;\n  ${(props) =>\n    props.isIE11 &&\n    css`\n      flex: 1;\n    `}\n  &:hover,\n  &:focus {\n    ${MovieTitle} {\n      text-decoration: underline;\n    }\n    ${MovieImage} {\n      &:after {\n        transition: opacity 200ms ease;\n        display: block;\n        opacity: 0.3;\n      }\n    }\n  }\n`;\n\ninterface Props {\n  movies: MovieType[];\n  locale: string;\n}\n\ntype visibleImagesProps = {\n  [key: string]: boolean | null;\n};\n\nconst hasForEachPolyfill = () => {\n  // Polyfill for ie11\n  if ('NodeList' in window && !NodeList.prototype.forEach) {\n    NodeList.prototype.forEach = function (callback, thisArg) {\n      thisArg = thisArg || window;\n      for (var i = 0; i < this.length; i++) {\n        callback.call(thisArg, this[i], i, this);\n      }\n    };\n  }\n};\n\nconst AllMoviesAlphabetically: React.FunctionComponent<Props> = ({ movies, locale }) => {\n  const isIE11 = isIE && parseInt(browserVersion) < 12;\n  // Split into Letters.\n  let previousLetter = '';\n  const wrapperRef: React.RefObject<HTMLElement> = React.useRef(null);\n  const [visibleImages, setVisibleImages] = useState<visibleImagesProps>({});\n\n  const scrollEvent = () => {\n    hasForEachPolyfill();\n    const updates: visibleImagesProps = {};\n    const allChildren: NodeListOf<HTMLElement> | null =\n      wrapperRef.current && wrapperRef.current.querySelectorAll('[role=img]');\n    const windowInnerHeight = window.innerHeight;\n    if (allChildren) {\n      let started: boolean = false;\n      let ended: boolean = false;\n      allChildren.forEach((el: HTMLElement, index: number) => {\n        if (!ended) {\n          const rect: ClientRect = el.getBoundingClientRect();\n          if (!started) {\n            if (rect.top > -20) {\n              updates[index] = true;\n              started = true;\n            }\n          } else {\n            updates[index] = true;\n            if (rect.top > windowInnerHeight + 20) {\n              ended = true;\n            }\n          }\n        }\n      });\n    }\n    setVisibleImages((visibleImages) => ({ ...visibleImages, ...updates }));\n  };\n\n  useEffect(() => {\n    const throttledScrollEvent = throttle(() => {\n      scrollEvent();\n    }, 100);\n    window.addEventListener('scroll', throttledScrollEvent);\n    scrollEvent();\n    return () => {\n      window.removeEventListener('scroll', throttledScrollEvent);\n    };\n  }, []);\n\n  useEffect(() => {\n    scrollEvent();\n  }, [movies]);\n\n  return (\n    <StyledWrapper ref={wrapperRef}>\n      {movies.map((movie: MovieType, index: number) => {\n        const currentLetter = movie.title.substr(0, 1);\n        const isNewLetter = currentLetter.localeCompare(previousLetter, locale) === 1 && isLetter(movie.title);\n        previousLetter = currentLetter;\n        const inView: boolean | null = visibleImages ? visibleImages[index] : null;\n        return (\n          <Fragment key={movie.id}>\n            {isNewLetter && <StyledNewLetter>{movie.title.substr(0, 1)}</StyledNewLetter>}\n            <MovieItem inView={inView}>\n              <StyledSafeLink isIE11={isIE11} to={movie.path}>\n                <MovieImage\n                  role=\"img\"\n                  backgroundImage={\n                    inView && movie.metaImage && movie.metaImage.url\n                      ? `${movie.metaImage.url}?${makeSrcQueryString(IMAGE_WIDTH * 2)}`\n                      : null\n                  }\n                  aria-label={movie.metaImage && movie.metaImage.alt}\n                  title={movie.title}\n                />\n                <MovieTextWrapper>\n                  <MovieTitle>{movie.title}</MovieTitle>\n                  <MovieDescription>{movie.metaDescription}</MovieDescription>\n                </MovieTextWrapper>\n              </StyledSafeLink>\n            </MovieItem>\n          </Fragment>\n        );\n      })}\n    </StyledWrapper>\n  );\n};\n\nexport default AllMoviesAlphabetically;\n"]} */"));
83
83
  }, " background-size:cover;background-position:center center;margin:0 ", spacingUnit * 0.75, "px 0 0;", mq.range({
84
84
  from: breakpoints.tablet
85
- }), "{margin-left:", spacingUnit * 0.75, "px;width:", IMAGE_WIDTH, "px;height:90px;}position:relative;&:after{content:'';position:absolute;z-index:1;background:", colors.ndlaFilm.filmColor, ";opacity:0;left:0;right:0;bottom:0;top:0;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["AllMoviesAlphabetically.tsx"],"names":[],"mappings":"AA8E6C","file":"AllMoviesAlphabetically.tsx","sourcesContent":["/**\n * Copyright (c) 2019-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { Fragment, useEffect, useState } from 'react';\nimport { isIE, browserVersion } from 'react-device-detect';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/core';\nimport throttle from 'lodash/throttle';\nimport { breakpoints, mq, spacing, spacingUnit, colors, fonts, animations } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\n// @ts-ignore\nimport { makeSrcQueryString } from '../Image';\nimport { movieType } from './types';\nimport { isLetter } from './isLetter';\nconst IMAGE_WIDTH = 143;\n\nconst StyledNewLetter = styled.h2`\n  color: #fff;\n  margin: ${spacing.large} 0 ${spacingUnit * 0.75}px;\n  ${fonts.sizes(26, 1.1)};\n  ${mq.range({ from: breakpoints.tablet })} {\n    text-indent: ${spacingUnit * 0.75}px;\n  }\n  &:after {\n    content: '';\n    display: block;\n    height: 1px;\n    background: ${colors.brand.greyDark};\n    margin-top: ${spacing.small};\n  }\n`;\n\nconst StyledWrapper = styled.section`\n  width: 652px;\n  max-width: 100%;\n  margin: ${spacing.large} auto;\n  padding: 0 ${spacing.normal};\n  display: flex;\n  flex-direction: column;\n`;\n\ntype MovieItemProps = {\n  inView: boolean | null;\n};\n\nconst MovieItem = styled.div<MovieItemProps>`\n  margin: 0 0 ${spacingUnit * 0.75}px;\n  display: inline-flex;\n  &:last-child {\n    margin-bottom: ${spacing.large};\n  }\n  opacity: 0;\n  transform: translateY(${spacing.xsmall});\n  transition: all ${animations.durations.slow} ease;\n  ${(props: MovieItemProps) =>\n    props.inView &&\n    css`\n      opacity: 1;\n      transform: translateY(0);\n    `};\n`;\n\nconst MovieTextWrapper = styled.div`\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.xsmall} ${spacing.xsmall} 0 0;\n  }\n  flex: 1;\n`;\n\ntype movieImageType = {\n  backgroundImage?: string | null;\n};\n\nconst MovieImage = styled.div<movieImageType>`\n  width: 104px;\n  height: 80px;\n  background-color: ${colors.ndlaFilm.filmColorLight};\n  ${(props: movieImageType) =>\n    props.backgroundImage !== null &&\n    css`\n      background-image: url(${props.backgroundImage});\n    `}\n  background-size: cover;\n  background-position: center center;\n  margin: 0 ${spacingUnit * 0.75}px 0 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    margin-left: ${spacingUnit * 0.75}px;\n    width: ${IMAGE_WIDTH}px;\n    height: 90px;\n  }\n  position: relative;\n  &:after {\n    content: '';\n    position: absolute;\n    z-index: 1;\n    background: ${colors.ndlaFilm.filmColor};\n    opacity: 0;\n    left: 0;\n    right: 0;\n    bottom: 0;\n    top: 0;\n  }\n`;\n\nconst MovieTitle = styled.h3`\n  color: #fff;\n  margin: 0 0 2px;\n  ${fonts.sizes(18, 1.3)};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes(20, 1.3)};\n  }\n`;\n\nconst MovieDescription = styled.p`\n  color: ${colors.brand.greyLighter};\n  margin: 0;\n  ${fonts.sizes(14, 1.5)};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes(16, 1.5)};\n  }\n  overflow: hidden;\n  text-overflow: ellipsis;\n  display: -webkit-box;\n  -webkit-box-orient: vertical;\n  -webkit-line-clamp: 2;\n`;\n\ntype isIEProps = {\n  isIE11: boolean;\n};\n\nconst StyledSafeLink = styled(SafeLink)<isIEProps>`\n  box-shadow: none;\n  display: flex;\n  ${(props) =>\n    props.isIE11 &&\n    css`\n      flex: 1;\n    `}\n  &:hover,\n  &:focus {\n    ${MovieTitle} {\n      text-decoration: underline;\n    }\n    ${MovieImage} {\n      &:after {\n        transition: opacity 200ms ease;\n        display: block;\n        opacity: 0.3;\n      }\n    }\n  }\n`;\n\ninterface Props {\n  movies: movieType[];\n  locale: string;\n}\n\ntype visibleImagesProps = {\n  [key: string]: boolean | null;\n};\n\nconst hasForEachPolyfill = () => {\n  // Polyfill for ie11\n  if ('NodeList' in window && !NodeList.prototype.forEach) {\n    NodeList.prototype.forEach = function (callback, thisArg) {\n      thisArg = thisArg || window;\n      for (var i = 0; i < this.length; i++) {\n        callback.call(thisArg, this[i], i, this);\n      }\n    };\n  }\n};\n\nconst AllMoviesAlphabetically: React.FunctionComponent<Props> = ({ movies, locale }) => {\n  const isIE11 = isIE && parseInt(browserVersion) < 12;\n  // Split into Letters.\n  let previousLetter = '';\n  const wrapperRef: React.RefObject<HTMLElement> = React.useRef(null);\n  const [visibleImages, setVisibleImages] = useState<visibleImagesProps>({});\n\n  const scrollEvent = () => {\n    hasForEachPolyfill();\n    const updates: visibleImagesProps = {};\n    const allChildren: NodeListOf<HTMLElement> | null =\n      wrapperRef.current && wrapperRef.current.querySelectorAll('[role=img]');\n    const windowInnerHeight = window.innerHeight;\n    if (allChildren) {\n      let started: boolean = false;\n      let ended: boolean = false;\n      allChildren.forEach((el: HTMLElement, index: number) => {\n        if (!ended) {\n          const rect: ClientRect = el.getBoundingClientRect();\n          if (!started) {\n            if (rect.top > -20) {\n              updates[index] = true;\n              started = true;\n            }\n          } else {\n            updates[index] = true;\n            if (rect.top > windowInnerHeight + 20) {\n              ended = true;\n            }\n          }\n        }\n      });\n    }\n    setVisibleImages((visibleImages) => ({ ...visibleImages, ...updates }));\n  };\n\n  useEffect(() => {\n    const throttledScrollEvent = throttle(() => {\n      scrollEvent();\n    }, 100);\n    window.addEventListener('scroll', throttledScrollEvent);\n    scrollEvent();\n    return () => {\n      window.removeEventListener('scroll', throttledScrollEvent);\n    };\n  }, []);\n\n  useEffect(() => {\n    scrollEvent();\n  }, [movies]);\n\n  return (\n    <StyledWrapper ref={wrapperRef}>\n      {movies.map((movie: movieType, index: number) => {\n        const currentLetter = movie.title.substr(0, 1);\n        const isNewLetter = currentLetter.localeCompare(previousLetter, locale) === 1 && isLetter(movie.title);\n        previousLetter = currentLetter;\n        const inView: boolean | null = visibleImages ? visibleImages[index] : null;\n        return (\n          <Fragment key={movie.id}>\n            {isNewLetter && <StyledNewLetter>{movie.title.substr(0, 1)}</StyledNewLetter>}\n            <MovieItem inView={inView}>\n              <StyledSafeLink isIE11={isIE11} to={movie.path}>\n                <MovieImage\n                  role=\"img\"\n                  backgroundImage={\n                    inView && movie.metaImage && movie.metaImage.url\n                      ? `${movie.metaImage.url}?${makeSrcQueryString(IMAGE_WIDTH * 2)}`\n                      : null\n                  }\n                  aria-label={movie.metaImage && movie.metaImage.alt}\n                  title={movie.title}\n                />\n                <MovieTextWrapper>\n                  <MovieTitle>{movie.title}</MovieTitle>\n                  <MovieDescription>{movie.metaDescription}</MovieDescription>\n                </MovieTextWrapper>\n              </StyledSafeLink>\n            </MovieItem>\n          </Fragment>\n        );\n      })}\n    </StyledWrapper>\n  );\n};\n\nexport default AllMoviesAlphabetically;\n"]} */"));
85
+ }), "{margin-left:", spacingUnit * 0.75, "px;width:", IMAGE_WIDTH, "px;height:90px;}position:relative;&:after{content:'';position:absolute;z-index:1;background:", colors.ndlaFilm.filmColor, ";opacity:0;left:0;right:0;bottom:0;top:0;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["AllMoviesAlphabetically.tsx"],"names":[],"mappings":"AA8E6C","file":"AllMoviesAlphabetically.tsx","sourcesContent":["/**\n * Copyright (c) 2019-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { Fragment, useEffect, useState } from 'react';\nimport { isIE, browserVersion } from 'react-device-detect';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/core';\nimport throttle from 'lodash/throttle';\nimport { breakpoints, mq, spacing, spacingUnit, colors, fonts, animations } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\n// @ts-ignore\nimport { makeSrcQueryString } from '../Image';\nimport { MovieType } from './types';\nimport { isLetter } from './isLetter';\nconst IMAGE_WIDTH = 143;\n\nconst StyledNewLetter = styled.h2`\n  color: #fff;\n  margin: ${spacing.large} 0 ${spacingUnit * 0.75}px;\n  ${fonts.sizes(26, 1.1)};\n  ${mq.range({ from: breakpoints.tablet })} {\n    text-indent: ${spacingUnit * 0.75}px;\n  }\n  &:after {\n    content: '';\n    display: block;\n    height: 1px;\n    background: ${colors.brand.greyDark};\n    margin-top: ${spacing.small};\n  }\n`;\n\nconst StyledWrapper = styled.section`\n  width: 652px;\n  max-width: 100%;\n  margin: ${spacing.large} auto;\n  padding: 0 ${spacing.normal};\n  display: flex;\n  flex-direction: column;\n`;\n\ntype MovieItemProps = {\n  inView: boolean | null;\n};\n\nconst MovieItem = styled.div<MovieItemProps>`\n  margin: 0 0 ${spacingUnit * 0.75}px;\n  display: inline-flex;\n  &:last-child {\n    margin-bottom: ${spacing.large};\n  }\n  opacity: 0;\n  transform: translateY(${spacing.xsmall});\n  transition: all ${animations.durations.slow} ease;\n  ${(props: MovieItemProps) =>\n    props.inView &&\n    css`\n      opacity: 1;\n      transform: translateY(0);\n    `};\n`;\n\nconst MovieTextWrapper = styled.div`\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.xsmall} ${spacing.xsmall} 0 0;\n  }\n  flex: 1;\n`;\n\ntype movieImageType = {\n  backgroundImage?: string | null;\n};\n\nconst MovieImage = styled.div<movieImageType>`\n  width: 104px;\n  height: 80px;\n  background-color: ${colors.ndlaFilm.filmColorLight};\n  ${(props: movieImageType) =>\n    props.backgroundImage !== null &&\n    css`\n      background-image: url(${props.backgroundImage});\n    `}\n  background-size: cover;\n  background-position: center center;\n  margin: 0 ${spacingUnit * 0.75}px 0 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    margin-left: ${spacingUnit * 0.75}px;\n    width: ${IMAGE_WIDTH}px;\n    height: 90px;\n  }\n  position: relative;\n  &:after {\n    content: '';\n    position: absolute;\n    z-index: 1;\n    background: ${colors.ndlaFilm.filmColor};\n    opacity: 0;\n    left: 0;\n    right: 0;\n    bottom: 0;\n    top: 0;\n  }\n`;\n\nconst MovieTitle = styled.h3`\n  color: #fff;\n  margin: 0 0 2px;\n  ${fonts.sizes(18, 1.3)};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes(20, 1.3)};\n  }\n`;\n\nconst MovieDescription = styled.p`\n  color: ${colors.brand.greyLighter};\n  margin: 0;\n  ${fonts.sizes(14, 1.5)};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes(16, 1.5)};\n  }\n  overflow: hidden;\n  text-overflow: ellipsis;\n  display: -webkit-box;\n  -webkit-box-orient: vertical;\n  -webkit-line-clamp: 2;\n`;\n\ntype isIEProps = {\n  isIE11: boolean;\n};\n\nconst StyledSafeLink = styled(SafeLink)<isIEProps>`\n  box-shadow: none;\n  display: flex;\n  ${(props) =>\n    props.isIE11 &&\n    css`\n      flex: 1;\n    `}\n  &:hover,\n  &:focus {\n    ${MovieTitle} {\n      text-decoration: underline;\n    }\n    ${MovieImage} {\n      &:after {\n        transition: opacity 200ms ease;\n        display: block;\n        opacity: 0.3;\n      }\n    }\n  }\n`;\n\ninterface Props {\n  movies: MovieType[];\n  locale: string;\n}\n\ntype visibleImagesProps = {\n  [key: string]: boolean | null;\n};\n\nconst hasForEachPolyfill = () => {\n  // Polyfill for ie11\n  if ('NodeList' in window && !NodeList.prototype.forEach) {\n    NodeList.prototype.forEach = function (callback, thisArg) {\n      thisArg = thisArg || window;\n      for (var i = 0; i < this.length; i++) {\n        callback.call(thisArg, this[i], i, this);\n      }\n    };\n  }\n};\n\nconst AllMoviesAlphabetically: React.FunctionComponent<Props> = ({ movies, locale }) => {\n  const isIE11 = isIE && parseInt(browserVersion) < 12;\n  // Split into Letters.\n  let previousLetter = '';\n  const wrapperRef: React.RefObject<HTMLElement> = React.useRef(null);\n  const [visibleImages, setVisibleImages] = useState<visibleImagesProps>({});\n\n  const scrollEvent = () => {\n    hasForEachPolyfill();\n    const updates: visibleImagesProps = {};\n    const allChildren: NodeListOf<HTMLElement> | null =\n      wrapperRef.current && wrapperRef.current.querySelectorAll('[role=img]');\n    const windowInnerHeight = window.innerHeight;\n    if (allChildren) {\n      let started: boolean = false;\n      let ended: boolean = false;\n      allChildren.forEach((el: HTMLElement, index: number) => {\n        if (!ended) {\n          const rect: ClientRect = el.getBoundingClientRect();\n          if (!started) {\n            if (rect.top > -20) {\n              updates[index] = true;\n              started = true;\n            }\n          } else {\n            updates[index] = true;\n            if (rect.top > windowInnerHeight + 20) {\n              ended = true;\n            }\n          }\n        }\n      });\n    }\n    setVisibleImages((visibleImages) => ({ ...visibleImages, ...updates }));\n  };\n\n  useEffect(() => {\n    const throttledScrollEvent = throttle(() => {\n      scrollEvent();\n    }, 100);\n    window.addEventListener('scroll', throttledScrollEvent);\n    scrollEvent();\n    return () => {\n      window.removeEventListener('scroll', throttledScrollEvent);\n    };\n  }, []);\n\n  useEffect(() => {\n    scrollEvent();\n  }, [movies]);\n\n  return (\n    <StyledWrapper ref={wrapperRef}>\n      {movies.map((movie: MovieType, index: number) => {\n        const currentLetter = movie.title.substr(0, 1);\n        const isNewLetter = currentLetter.localeCompare(previousLetter, locale) === 1 && isLetter(movie.title);\n        previousLetter = currentLetter;\n        const inView: boolean | null = visibleImages ? visibleImages[index] : null;\n        return (\n          <Fragment key={movie.id}>\n            {isNewLetter && <StyledNewLetter>{movie.title.substr(0, 1)}</StyledNewLetter>}\n            <MovieItem inView={inView}>\n              <StyledSafeLink isIE11={isIE11} to={movie.path}>\n                <MovieImage\n                  role=\"img\"\n                  backgroundImage={\n                    inView && movie.metaImage && movie.metaImage.url\n                      ? `${movie.metaImage.url}?${makeSrcQueryString(IMAGE_WIDTH * 2)}`\n                      : null\n                  }\n                  aria-label={movie.metaImage && movie.metaImage.alt}\n                  title={movie.title}\n                />\n                <MovieTextWrapper>\n                  <MovieTitle>{movie.title}</MovieTitle>\n                  <MovieDescription>{movie.metaDescription}</MovieDescription>\n                </MovieTextWrapper>\n              </StyledSafeLink>\n            </MovieItem>\n          </Fragment>\n        );\n      })}\n    </StyledWrapper>\n  );\n};\n\nexport default AllMoviesAlphabetically;\n"]} */"));
86
86
 
87
87
  var MovieTitle = _styled("h3", {
88
88
  target: "e1ul1xui5",
89
89
  label: "MovieTitle"
90
90
  })("color:#fff;margin:0 0 2px;", fonts.sizes(18, 1.3), ";", mq.range({
91
91
  from: breakpoints.tablet
92
- }), "{", fonts.sizes(20, 1.3), ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["AllMoviesAlphabetically.tsx"],"names":[],"mappings":"AA6G4B","file":"AllMoviesAlphabetically.tsx","sourcesContent":["/**\n * Copyright (c) 2019-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { Fragment, useEffect, useState } from 'react';\nimport { isIE, browserVersion } from 'react-device-detect';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/core';\nimport throttle from 'lodash/throttle';\nimport { breakpoints, mq, spacing, spacingUnit, colors, fonts, animations } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\n// @ts-ignore\nimport { makeSrcQueryString } from '../Image';\nimport { movieType } from './types';\nimport { isLetter } from './isLetter';\nconst IMAGE_WIDTH = 143;\n\nconst StyledNewLetter = styled.h2`\n  color: #fff;\n  margin: ${spacing.large} 0 ${spacingUnit * 0.75}px;\n  ${fonts.sizes(26, 1.1)};\n  ${mq.range({ from: breakpoints.tablet })} {\n    text-indent: ${spacingUnit * 0.75}px;\n  }\n  &:after {\n    content: '';\n    display: block;\n    height: 1px;\n    background: ${colors.brand.greyDark};\n    margin-top: ${spacing.small};\n  }\n`;\n\nconst StyledWrapper = styled.section`\n  width: 652px;\n  max-width: 100%;\n  margin: ${spacing.large} auto;\n  padding: 0 ${spacing.normal};\n  display: flex;\n  flex-direction: column;\n`;\n\ntype MovieItemProps = {\n  inView: boolean | null;\n};\n\nconst MovieItem = styled.div<MovieItemProps>`\n  margin: 0 0 ${spacingUnit * 0.75}px;\n  display: inline-flex;\n  &:last-child {\n    margin-bottom: ${spacing.large};\n  }\n  opacity: 0;\n  transform: translateY(${spacing.xsmall});\n  transition: all ${animations.durations.slow} ease;\n  ${(props: MovieItemProps) =>\n    props.inView &&\n    css`\n      opacity: 1;\n      transform: translateY(0);\n    `};\n`;\n\nconst MovieTextWrapper = styled.div`\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.xsmall} ${spacing.xsmall} 0 0;\n  }\n  flex: 1;\n`;\n\ntype movieImageType = {\n  backgroundImage?: string | null;\n};\n\nconst MovieImage = styled.div<movieImageType>`\n  width: 104px;\n  height: 80px;\n  background-color: ${colors.ndlaFilm.filmColorLight};\n  ${(props: movieImageType) =>\n    props.backgroundImage !== null &&\n    css`\n      background-image: url(${props.backgroundImage});\n    `}\n  background-size: cover;\n  background-position: center center;\n  margin: 0 ${spacingUnit * 0.75}px 0 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    margin-left: ${spacingUnit * 0.75}px;\n    width: ${IMAGE_WIDTH}px;\n    height: 90px;\n  }\n  position: relative;\n  &:after {\n    content: '';\n    position: absolute;\n    z-index: 1;\n    background: ${colors.ndlaFilm.filmColor};\n    opacity: 0;\n    left: 0;\n    right: 0;\n    bottom: 0;\n    top: 0;\n  }\n`;\n\nconst MovieTitle = styled.h3`\n  color: #fff;\n  margin: 0 0 2px;\n  ${fonts.sizes(18, 1.3)};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes(20, 1.3)};\n  }\n`;\n\nconst MovieDescription = styled.p`\n  color: ${colors.brand.greyLighter};\n  margin: 0;\n  ${fonts.sizes(14, 1.5)};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes(16, 1.5)};\n  }\n  overflow: hidden;\n  text-overflow: ellipsis;\n  display: -webkit-box;\n  -webkit-box-orient: vertical;\n  -webkit-line-clamp: 2;\n`;\n\ntype isIEProps = {\n  isIE11: boolean;\n};\n\nconst StyledSafeLink = styled(SafeLink)<isIEProps>`\n  box-shadow: none;\n  display: flex;\n  ${(props) =>\n    props.isIE11 &&\n    css`\n      flex: 1;\n    `}\n  &:hover,\n  &:focus {\n    ${MovieTitle} {\n      text-decoration: underline;\n    }\n    ${MovieImage} {\n      &:after {\n        transition: opacity 200ms ease;\n        display: block;\n        opacity: 0.3;\n      }\n    }\n  }\n`;\n\ninterface Props {\n  movies: movieType[];\n  locale: string;\n}\n\ntype visibleImagesProps = {\n  [key: string]: boolean | null;\n};\n\nconst hasForEachPolyfill = () => {\n  // Polyfill for ie11\n  if ('NodeList' in window && !NodeList.prototype.forEach) {\n    NodeList.prototype.forEach = function (callback, thisArg) {\n      thisArg = thisArg || window;\n      for (var i = 0; i < this.length; i++) {\n        callback.call(thisArg, this[i], i, this);\n      }\n    };\n  }\n};\n\nconst AllMoviesAlphabetically: React.FunctionComponent<Props> = ({ movies, locale }) => {\n  const isIE11 = isIE && parseInt(browserVersion) < 12;\n  // Split into Letters.\n  let previousLetter = '';\n  const wrapperRef: React.RefObject<HTMLElement> = React.useRef(null);\n  const [visibleImages, setVisibleImages] = useState<visibleImagesProps>({});\n\n  const scrollEvent = () => {\n    hasForEachPolyfill();\n    const updates: visibleImagesProps = {};\n    const allChildren: NodeListOf<HTMLElement> | null =\n      wrapperRef.current && wrapperRef.current.querySelectorAll('[role=img]');\n    const windowInnerHeight = window.innerHeight;\n    if (allChildren) {\n      let started: boolean = false;\n      let ended: boolean = false;\n      allChildren.forEach((el: HTMLElement, index: number) => {\n        if (!ended) {\n          const rect: ClientRect = el.getBoundingClientRect();\n          if (!started) {\n            if (rect.top > -20) {\n              updates[index] = true;\n              started = true;\n            }\n          } else {\n            updates[index] = true;\n            if (rect.top > windowInnerHeight + 20) {\n              ended = true;\n            }\n          }\n        }\n      });\n    }\n    setVisibleImages((visibleImages) => ({ ...visibleImages, ...updates }));\n  };\n\n  useEffect(() => {\n    const throttledScrollEvent = throttle(() => {\n      scrollEvent();\n    }, 100);\n    window.addEventListener('scroll', throttledScrollEvent);\n    scrollEvent();\n    return () => {\n      window.removeEventListener('scroll', throttledScrollEvent);\n    };\n  }, []);\n\n  useEffect(() => {\n    scrollEvent();\n  }, [movies]);\n\n  return (\n    <StyledWrapper ref={wrapperRef}>\n      {movies.map((movie: movieType, index: number) => {\n        const currentLetter = movie.title.substr(0, 1);\n        const isNewLetter = currentLetter.localeCompare(previousLetter, locale) === 1 && isLetter(movie.title);\n        previousLetter = currentLetter;\n        const inView: boolean | null = visibleImages ? visibleImages[index] : null;\n        return (\n          <Fragment key={movie.id}>\n            {isNewLetter && <StyledNewLetter>{movie.title.substr(0, 1)}</StyledNewLetter>}\n            <MovieItem inView={inView}>\n              <StyledSafeLink isIE11={isIE11} to={movie.path}>\n                <MovieImage\n                  role=\"img\"\n                  backgroundImage={\n                    inView && movie.metaImage && movie.metaImage.url\n                      ? `${movie.metaImage.url}?${makeSrcQueryString(IMAGE_WIDTH * 2)}`\n                      : null\n                  }\n                  aria-label={movie.metaImage && movie.metaImage.alt}\n                  title={movie.title}\n                />\n                <MovieTextWrapper>\n                  <MovieTitle>{movie.title}</MovieTitle>\n                  <MovieDescription>{movie.metaDescription}</MovieDescription>\n                </MovieTextWrapper>\n              </StyledSafeLink>\n            </MovieItem>\n          </Fragment>\n        );\n      })}\n    </StyledWrapper>\n  );\n};\n\nexport default AllMoviesAlphabetically;\n"]} */"));
92
+ }), "{", fonts.sizes(20, 1.3), ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["AllMoviesAlphabetically.tsx"],"names":[],"mappings":"AA6G4B","file":"AllMoviesAlphabetically.tsx","sourcesContent":["/**\n * Copyright (c) 2019-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { Fragment, useEffect, useState } from 'react';\nimport { isIE, browserVersion } from 'react-device-detect';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/core';\nimport throttle from 'lodash/throttle';\nimport { breakpoints, mq, spacing, spacingUnit, colors, fonts, animations } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\n// @ts-ignore\nimport { makeSrcQueryString } from '../Image';\nimport { MovieType } from './types';\nimport { isLetter } from './isLetter';\nconst IMAGE_WIDTH = 143;\n\nconst StyledNewLetter = styled.h2`\n  color: #fff;\n  margin: ${spacing.large} 0 ${spacingUnit * 0.75}px;\n  ${fonts.sizes(26, 1.1)};\n  ${mq.range({ from: breakpoints.tablet })} {\n    text-indent: ${spacingUnit * 0.75}px;\n  }\n  &:after {\n    content: '';\n    display: block;\n    height: 1px;\n    background: ${colors.brand.greyDark};\n    margin-top: ${spacing.small};\n  }\n`;\n\nconst StyledWrapper = styled.section`\n  width: 652px;\n  max-width: 100%;\n  margin: ${spacing.large} auto;\n  padding: 0 ${spacing.normal};\n  display: flex;\n  flex-direction: column;\n`;\n\ntype MovieItemProps = {\n  inView: boolean | null;\n};\n\nconst MovieItem = styled.div<MovieItemProps>`\n  margin: 0 0 ${spacingUnit * 0.75}px;\n  display: inline-flex;\n  &:last-child {\n    margin-bottom: ${spacing.large};\n  }\n  opacity: 0;\n  transform: translateY(${spacing.xsmall});\n  transition: all ${animations.durations.slow} ease;\n  ${(props: MovieItemProps) =>\n    props.inView &&\n    css`\n      opacity: 1;\n      transform: translateY(0);\n    `};\n`;\n\nconst MovieTextWrapper = styled.div`\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.xsmall} ${spacing.xsmall} 0 0;\n  }\n  flex: 1;\n`;\n\ntype movieImageType = {\n  backgroundImage?: string | null;\n};\n\nconst MovieImage = styled.div<movieImageType>`\n  width: 104px;\n  height: 80px;\n  background-color: ${colors.ndlaFilm.filmColorLight};\n  ${(props: movieImageType) =>\n    props.backgroundImage !== null &&\n    css`\n      background-image: url(${props.backgroundImage});\n    `}\n  background-size: cover;\n  background-position: center center;\n  margin: 0 ${spacingUnit * 0.75}px 0 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    margin-left: ${spacingUnit * 0.75}px;\n    width: ${IMAGE_WIDTH}px;\n    height: 90px;\n  }\n  position: relative;\n  &:after {\n    content: '';\n    position: absolute;\n    z-index: 1;\n    background: ${colors.ndlaFilm.filmColor};\n    opacity: 0;\n    left: 0;\n    right: 0;\n    bottom: 0;\n    top: 0;\n  }\n`;\n\nconst MovieTitle = styled.h3`\n  color: #fff;\n  margin: 0 0 2px;\n  ${fonts.sizes(18, 1.3)};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes(20, 1.3)};\n  }\n`;\n\nconst MovieDescription = styled.p`\n  color: ${colors.brand.greyLighter};\n  margin: 0;\n  ${fonts.sizes(14, 1.5)};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes(16, 1.5)};\n  }\n  overflow: hidden;\n  text-overflow: ellipsis;\n  display: -webkit-box;\n  -webkit-box-orient: vertical;\n  -webkit-line-clamp: 2;\n`;\n\ntype isIEProps = {\n  isIE11: boolean;\n};\n\nconst StyledSafeLink = styled(SafeLink)<isIEProps>`\n  box-shadow: none;\n  display: flex;\n  ${(props) =>\n    props.isIE11 &&\n    css`\n      flex: 1;\n    `}\n  &:hover,\n  &:focus {\n    ${MovieTitle} {\n      text-decoration: underline;\n    }\n    ${MovieImage} {\n      &:after {\n        transition: opacity 200ms ease;\n        display: block;\n        opacity: 0.3;\n      }\n    }\n  }\n`;\n\ninterface Props {\n  movies: MovieType[];\n  locale: string;\n}\n\ntype visibleImagesProps = {\n  [key: string]: boolean | null;\n};\n\nconst hasForEachPolyfill = () => {\n  // Polyfill for ie11\n  if ('NodeList' in window && !NodeList.prototype.forEach) {\n    NodeList.prototype.forEach = function (callback, thisArg) {\n      thisArg = thisArg || window;\n      for (var i = 0; i < this.length; i++) {\n        callback.call(thisArg, this[i], i, this);\n      }\n    };\n  }\n};\n\nconst AllMoviesAlphabetically: React.FunctionComponent<Props> = ({ movies, locale }) => {\n  const isIE11 = isIE && parseInt(browserVersion) < 12;\n  // Split into Letters.\n  let previousLetter = '';\n  const wrapperRef: React.RefObject<HTMLElement> = React.useRef(null);\n  const [visibleImages, setVisibleImages] = useState<visibleImagesProps>({});\n\n  const scrollEvent = () => {\n    hasForEachPolyfill();\n    const updates: visibleImagesProps = {};\n    const allChildren: NodeListOf<HTMLElement> | null =\n      wrapperRef.current && wrapperRef.current.querySelectorAll('[role=img]');\n    const windowInnerHeight = window.innerHeight;\n    if (allChildren) {\n      let started: boolean = false;\n      let ended: boolean = false;\n      allChildren.forEach((el: HTMLElement, index: number) => {\n        if (!ended) {\n          const rect: ClientRect = el.getBoundingClientRect();\n          if (!started) {\n            if (rect.top > -20) {\n              updates[index] = true;\n              started = true;\n            }\n          } else {\n            updates[index] = true;\n            if (rect.top > windowInnerHeight + 20) {\n              ended = true;\n            }\n          }\n        }\n      });\n    }\n    setVisibleImages((visibleImages) => ({ ...visibleImages, ...updates }));\n  };\n\n  useEffect(() => {\n    const throttledScrollEvent = throttle(() => {\n      scrollEvent();\n    }, 100);\n    window.addEventListener('scroll', throttledScrollEvent);\n    scrollEvent();\n    return () => {\n      window.removeEventListener('scroll', throttledScrollEvent);\n    };\n  }, []);\n\n  useEffect(() => {\n    scrollEvent();\n  }, [movies]);\n\n  return (\n    <StyledWrapper ref={wrapperRef}>\n      {movies.map((movie: MovieType, index: number) => {\n        const currentLetter = movie.title.substr(0, 1);\n        const isNewLetter = currentLetter.localeCompare(previousLetter, locale) === 1 && isLetter(movie.title);\n        previousLetter = currentLetter;\n        const inView: boolean | null = visibleImages ? visibleImages[index] : null;\n        return (\n          <Fragment key={movie.id}>\n            {isNewLetter && <StyledNewLetter>{movie.title.substr(0, 1)}</StyledNewLetter>}\n            <MovieItem inView={inView}>\n              <StyledSafeLink isIE11={isIE11} to={movie.path}>\n                <MovieImage\n                  role=\"img\"\n                  backgroundImage={\n                    inView && movie.metaImage && movie.metaImage.url\n                      ? `${movie.metaImage.url}?${makeSrcQueryString(IMAGE_WIDTH * 2)}`\n                      : null\n                  }\n                  aria-label={movie.metaImage && movie.metaImage.alt}\n                  title={movie.title}\n                />\n                <MovieTextWrapper>\n                  <MovieTitle>{movie.title}</MovieTitle>\n                  <MovieDescription>{movie.metaDescription}</MovieDescription>\n                </MovieTextWrapper>\n              </StyledSafeLink>\n            </MovieItem>\n          </Fragment>\n        );\n      })}\n    </StyledWrapper>\n  );\n};\n\nexport default AllMoviesAlphabetically;\n"]} */"));
93
93
 
94
94
  var MovieDescription = _styled("p", {
95
95
  target: "e1ul1xui6",
96
96
  label: "MovieDescription"
97
97
  })("color:", colors.brand.greyLighter, ";margin:0;", fonts.sizes(14, 1.5), ";", mq.range({
98
98
  from: breakpoints.tablet
99
- }), "{", fonts.sizes(16, 1.5), ";}overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["AllMoviesAlphabetically.tsx"],"names":[],"mappings":"AAsHiC","file":"AllMoviesAlphabetically.tsx","sourcesContent":["/**\n * Copyright (c) 2019-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { Fragment, useEffect, useState } from 'react';\nimport { isIE, browserVersion } from 'react-device-detect';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/core';\nimport throttle from 'lodash/throttle';\nimport { breakpoints, mq, spacing, spacingUnit, colors, fonts, animations } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\n// @ts-ignore\nimport { makeSrcQueryString } from '../Image';\nimport { movieType } from './types';\nimport { isLetter } from './isLetter';\nconst IMAGE_WIDTH = 143;\n\nconst StyledNewLetter = styled.h2`\n  color: #fff;\n  margin: ${spacing.large} 0 ${spacingUnit * 0.75}px;\n  ${fonts.sizes(26, 1.1)};\n  ${mq.range({ from: breakpoints.tablet })} {\n    text-indent: ${spacingUnit * 0.75}px;\n  }\n  &:after {\n    content: '';\n    display: block;\n    height: 1px;\n    background: ${colors.brand.greyDark};\n    margin-top: ${spacing.small};\n  }\n`;\n\nconst StyledWrapper = styled.section`\n  width: 652px;\n  max-width: 100%;\n  margin: ${spacing.large} auto;\n  padding: 0 ${spacing.normal};\n  display: flex;\n  flex-direction: column;\n`;\n\ntype MovieItemProps = {\n  inView: boolean | null;\n};\n\nconst MovieItem = styled.div<MovieItemProps>`\n  margin: 0 0 ${spacingUnit * 0.75}px;\n  display: inline-flex;\n  &:last-child {\n    margin-bottom: ${spacing.large};\n  }\n  opacity: 0;\n  transform: translateY(${spacing.xsmall});\n  transition: all ${animations.durations.slow} ease;\n  ${(props: MovieItemProps) =>\n    props.inView &&\n    css`\n      opacity: 1;\n      transform: translateY(0);\n    `};\n`;\n\nconst MovieTextWrapper = styled.div`\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.xsmall} ${spacing.xsmall} 0 0;\n  }\n  flex: 1;\n`;\n\ntype movieImageType = {\n  backgroundImage?: string | null;\n};\n\nconst MovieImage = styled.div<movieImageType>`\n  width: 104px;\n  height: 80px;\n  background-color: ${colors.ndlaFilm.filmColorLight};\n  ${(props: movieImageType) =>\n    props.backgroundImage !== null &&\n    css`\n      background-image: url(${props.backgroundImage});\n    `}\n  background-size: cover;\n  background-position: center center;\n  margin: 0 ${spacingUnit * 0.75}px 0 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    margin-left: ${spacingUnit * 0.75}px;\n    width: ${IMAGE_WIDTH}px;\n    height: 90px;\n  }\n  position: relative;\n  &:after {\n    content: '';\n    position: absolute;\n    z-index: 1;\n    background: ${colors.ndlaFilm.filmColor};\n    opacity: 0;\n    left: 0;\n    right: 0;\n    bottom: 0;\n    top: 0;\n  }\n`;\n\nconst MovieTitle = styled.h3`\n  color: #fff;\n  margin: 0 0 2px;\n  ${fonts.sizes(18, 1.3)};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes(20, 1.3)};\n  }\n`;\n\nconst MovieDescription = styled.p`\n  color: ${colors.brand.greyLighter};\n  margin: 0;\n  ${fonts.sizes(14, 1.5)};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes(16, 1.5)};\n  }\n  overflow: hidden;\n  text-overflow: ellipsis;\n  display: -webkit-box;\n  -webkit-box-orient: vertical;\n  -webkit-line-clamp: 2;\n`;\n\ntype isIEProps = {\n  isIE11: boolean;\n};\n\nconst StyledSafeLink = styled(SafeLink)<isIEProps>`\n  box-shadow: none;\n  display: flex;\n  ${(props) =>\n    props.isIE11 &&\n    css`\n      flex: 1;\n    `}\n  &:hover,\n  &:focus {\n    ${MovieTitle} {\n      text-decoration: underline;\n    }\n    ${MovieImage} {\n      &:after {\n        transition: opacity 200ms ease;\n        display: block;\n        opacity: 0.3;\n      }\n    }\n  }\n`;\n\ninterface Props {\n  movies: movieType[];\n  locale: string;\n}\n\ntype visibleImagesProps = {\n  [key: string]: boolean | null;\n};\n\nconst hasForEachPolyfill = () => {\n  // Polyfill for ie11\n  if ('NodeList' in window && !NodeList.prototype.forEach) {\n    NodeList.prototype.forEach = function (callback, thisArg) {\n      thisArg = thisArg || window;\n      for (var i = 0; i < this.length; i++) {\n        callback.call(thisArg, this[i], i, this);\n      }\n    };\n  }\n};\n\nconst AllMoviesAlphabetically: React.FunctionComponent<Props> = ({ movies, locale }) => {\n  const isIE11 = isIE && parseInt(browserVersion) < 12;\n  // Split into Letters.\n  let previousLetter = '';\n  const wrapperRef: React.RefObject<HTMLElement> = React.useRef(null);\n  const [visibleImages, setVisibleImages] = useState<visibleImagesProps>({});\n\n  const scrollEvent = () => {\n    hasForEachPolyfill();\n    const updates: visibleImagesProps = {};\n    const allChildren: NodeListOf<HTMLElement> | null =\n      wrapperRef.current && wrapperRef.current.querySelectorAll('[role=img]');\n    const windowInnerHeight = window.innerHeight;\n    if (allChildren) {\n      let started: boolean = false;\n      let ended: boolean = false;\n      allChildren.forEach((el: HTMLElement, index: number) => {\n        if (!ended) {\n          const rect: ClientRect = el.getBoundingClientRect();\n          if (!started) {\n            if (rect.top > -20) {\n              updates[index] = true;\n              started = true;\n            }\n          } else {\n            updates[index] = true;\n            if (rect.top > windowInnerHeight + 20) {\n              ended = true;\n            }\n          }\n        }\n      });\n    }\n    setVisibleImages((visibleImages) => ({ ...visibleImages, ...updates }));\n  };\n\n  useEffect(() => {\n    const throttledScrollEvent = throttle(() => {\n      scrollEvent();\n    }, 100);\n    window.addEventListener('scroll', throttledScrollEvent);\n    scrollEvent();\n    return () => {\n      window.removeEventListener('scroll', throttledScrollEvent);\n    };\n  }, []);\n\n  useEffect(() => {\n    scrollEvent();\n  }, [movies]);\n\n  return (\n    <StyledWrapper ref={wrapperRef}>\n      {movies.map((movie: movieType, index: number) => {\n        const currentLetter = movie.title.substr(0, 1);\n        const isNewLetter = currentLetter.localeCompare(previousLetter, locale) === 1 && isLetter(movie.title);\n        previousLetter = currentLetter;\n        const inView: boolean | null = visibleImages ? visibleImages[index] : null;\n        return (\n          <Fragment key={movie.id}>\n            {isNewLetter && <StyledNewLetter>{movie.title.substr(0, 1)}</StyledNewLetter>}\n            <MovieItem inView={inView}>\n              <StyledSafeLink isIE11={isIE11} to={movie.path}>\n                <MovieImage\n                  role=\"img\"\n                  backgroundImage={\n                    inView && movie.metaImage && movie.metaImage.url\n                      ? `${movie.metaImage.url}?${makeSrcQueryString(IMAGE_WIDTH * 2)}`\n                      : null\n                  }\n                  aria-label={movie.metaImage && movie.metaImage.alt}\n                  title={movie.title}\n                />\n                <MovieTextWrapper>\n                  <MovieTitle>{movie.title}</MovieTitle>\n                  <MovieDescription>{movie.metaDescription}</MovieDescription>\n                </MovieTextWrapper>\n              </StyledSafeLink>\n            </MovieItem>\n          </Fragment>\n        );\n      })}\n    </StyledWrapper>\n  );\n};\n\nexport default AllMoviesAlphabetically;\n"]} */"));
99
+ }), "{", fonts.sizes(16, 1.5), ";}overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["AllMoviesAlphabetically.tsx"],"names":[],"mappings":"AAsHiC","file":"AllMoviesAlphabetically.tsx","sourcesContent":["/**\n * Copyright (c) 2019-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { Fragment, useEffect, useState } from 'react';\nimport { isIE, browserVersion } from 'react-device-detect';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/core';\nimport throttle from 'lodash/throttle';\nimport { breakpoints, mq, spacing, spacingUnit, colors, fonts, animations } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\n// @ts-ignore\nimport { makeSrcQueryString } from '../Image';\nimport { MovieType } from './types';\nimport { isLetter } from './isLetter';\nconst IMAGE_WIDTH = 143;\n\nconst StyledNewLetter = styled.h2`\n  color: #fff;\n  margin: ${spacing.large} 0 ${spacingUnit * 0.75}px;\n  ${fonts.sizes(26, 1.1)};\n  ${mq.range({ from: breakpoints.tablet })} {\n    text-indent: ${spacingUnit * 0.75}px;\n  }\n  &:after {\n    content: '';\n    display: block;\n    height: 1px;\n    background: ${colors.brand.greyDark};\n    margin-top: ${spacing.small};\n  }\n`;\n\nconst StyledWrapper = styled.section`\n  width: 652px;\n  max-width: 100%;\n  margin: ${spacing.large} auto;\n  padding: 0 ${spacing.normal};\n  display: flex;\n  flex-direction: column;\n`;\n\ntype MovieItemProps = {\n  inView: boolean | null;\n};\n\nconst MovieItem = styled.div<MovieItemProps>`\n  margin: 0 0 ${spacingUnit * 0.75}px;\n  display: inline-flex;\n  &:last-child {\n    margin-bottom: ${spacing.large};\n  }\n  opacity: 0;\n  transform: translateY(${spacing.xsmall});\n  transition: all ${animations.durations.slow} ease;\n  ${(props: MovieItemProps) =>\n    props.inView &&\n    css`\n      opacity: 1;\n      transform: translateY(0);\n    `};\n`;\n\nconst MovieTextWrapper = styled.div`\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.xsmall} ${spacing.xsmall} 0 0;\n  }\n  flex: 1;\n`;\n\ntype movieImageType = {\n  backgroundImage?: string | null;\n};\n\nconst MovieImage = styled.div<movieImageType>`\n  width: 104px;\n  height: 80px;\n  background-color: ${colors.ndlaFilm.filmColorLight};\n  ${(props: movieImageType) =>\n    props.backgroundImage !== null &&\n    css`\n      background-image: url(${props.backgroundImage});\n    `}\n  background-size: cover;\n  background-position: center center;\n  margin: 0 ${spacingUnit * 0.75}px 0 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    margin-left: ${spacingUnit * 0.75}px;\n    width: ${IMAGE_WIDTH}px;\n    height: 90px;\n  }\n  position: relative;\n  &:after {\n    content: '';\n    position: absolute;\n    z-index: 1;\n    background: ${colors.ndlaFilm.filmColor};\n    opacity: 0;\n    left: 0;\n    right: 0;\n    bottom: 0;\n    top: 0;\n  }\n`;\n\nconst MovieTitle = styled.h3`\n  color: #fff;\n  margin: 0 0 2px;\n  ${fonts.sizes(18, 1.3)};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes(20, 1.3)};\n  }\n`;\n\nconst MovieDescription = styled.p`\n  color: ${colors.brand.greyLighter};\n  margin: 0;\n  ${fonts.sizes(14, 1.5)};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes(16, 1.5)};\n  }\n  overflow: hidden;\n  text-overflow: ellipsis;\n  display: -webkit-box;\n  -webkit-box-orient: vertical;\n  -webkit-line-clamp: 2;\n`;\n\ntype isIEProps = {\n  isIE11: boolean;\n};\n\nconst StyledSafeLink = styled(SafeLink)<isIEProps>`\n  box-shadow: none;\n  display: flex;\n  ${(props) =>\n    props.isIE11 &&\n    css`\n      flex: 1;\n    `}\n  &:hover,\n  &:focus {\n    ${MovieTitle} {\n      text-decoration: underline;\n    }\n    ${MovieImage} {\n      &:after {\n        transition: opacity 200ms ease;\n        display: block;\n        opacity: 0.3;\n      }\n    }\n  }\n`;\n\ninterface Props {\n  movies: MovieType[];\n  locale: string;\n}\n\ntype visibleImagesProps = {\n  [key: string]: boolean | null;\n};\n\nconst hasForEachPolyfill = () => {\n  // Polyfill for ie11\n  if ('NodeList' in window && !NodeList.prototype.forEach) {\n    NodeList.prototype.forEach = function (callback, thisArg) {\n      thisArg = thisArg || window;\n      for (var i = 0; i < this.length; i++) {\n        callback.call(thisArg, this[i], i, this);\n      }\n    };\n  }\n};\n\nconst AllMoviesAlphabetically: React.FunctionComponent<Props> = ({ movies, locale }) => {\n  const isIE11 = isIE && parseInt(browserVersion) < 12;\n  // Split into Letters.\n  let previousLetter = '';\n  const wrapperRef: React.RefObject<HTMLElement> = React.useRef(null);\n  const [visibleImages, setVisibleImages] = useState<visibleImagesProps>({});\n\n  const scrollEvent = () => {\n    hasForEachPolyfill();\n    const updates: visibleImagesProps = {};\n    const allChildren: NodeListOf<HTMLElement> | null =\n      wrapperRef.current && wrapperRef.current.querySelectorAll('[role=img]');\n    const windowInnerHeight = window.innerHeight;\n    if (allChildren) {\n      let started: boolean = false;\n      let ended: boolean = false;\n      allChildren.forEach((el: HTMLElement, index: number) => {\n        if (!ended) {\n          const rect: ClientRect = el.getBoundingClientRect();\n          if (!started) {\n            if (rect.top > -20) {\n              updates[index] = true;\n              started = true;\n            }\n          } else {\n            updates[index] = true;\n            if (rect.top > windowInnerHeight + 20) {\n              ended = true;\n            }\n          }\n        }\n      });\n    }\n    setVisibleImages((visibleImages) => ({ ...visibleImages, ...updates }));\n  };\n\n  useEffect(() => {\n    const throttledScrollEvent = throttle(() => {\n      scrollEvent();\n    }, 100);\n    window.addEventListener('scroll', throttledScrollEvent);\n    scrollEvent();\n    return () => {\n      window.removeEventListener('scroll', throttledScrollEvent);\n    };\n  }, []);\n\n  useEffect(() => {\n    scrollEvent();\n  }, [movies]);\n\n  return (\n    <StyledWrapper ref={wrapperRef}>\n      {movies.map((movie: MovieType, index: number) => {\n        const currentLetter = movie.title.substr(0, 1);\n        const isNewLetter = currentLetter.localeCompare(previousLetter, locale) === 1 && isLetter(movie.title);\n        previousLetter = currentLetter;\n        const inView: boolean | null = visibleImages ? visibleImages[index] : null;\n        return (\n          <Fragment key={movie.id}>\n            {isNewLetter && <StyledNewLetter>{movie.title.substr(0, 1)}</StyledNewLetter>}\n            <MovieItem inView={inView}>\n              <StyledSafeLink isIE11={isIE11} to={movie.path}>\n                <MovieImage\n                  role=\"img\"\n                  backgroundImage={\n                    inView && movie.metaImage && movie.metaImage.url\n                      ? `${movie.metaImage.url}?${makeSrcQueryString(IMAGE_WIDTH * 2)}`\n                      : null\n                  }\n                  aria-label={movie.metaImage && movie.metaImage.alt}\n                  title={movie.title}\n                />\n                <MovieTextWrapper>\n                  <MovieTitle>{movie.title}</MovieTitle>\n                  <MovieDescription>{movie.metaDescription}</MovieDescription>\n                </MovieTextWrapper>\n              </StyledSafeLink>\n            </MovieItem>\n          </Fragment>\n        );\n      })}\n    </StyledWrapper>\n  );\n};\n\nexport default AllMoviesAlphabetically;\n"]} */"));
100
100
 
101
101
  var _ref2 = process.env.NODE_ENV === "production" ? {
102
102
  name: "vnq6xf-StyledSafeLink",
@@ -104,7 +104,7 @@ var _ref2 = process.env.NODE_ENV === "production" ? {
104
104
  } : {
105
105
  name: "vnq6xf-StyledSafeLink",
106
106
  styles: "flex:1;;label:StyledSafeLink;",
107
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["AllMoviesAlphabetically.tsx"],"names":[],"mappings":"AA6IO","file":"AllMoviesAlphabetically.tsx","sourcesContent":["/**\n * Copyright (c) 2019-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { Fragment, useEffect, useState } from 'react';\nimport { isIE, browserVersion } from 'react-device-detect';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/core';\nimport throttle from 'lodash/throttle';\nimport { breakpoints, mq, spacing, spacingUnit, colors, fonts, animations } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\n// @ts-ignore\nimport { makeSrcQueryString } from '../Image';\nimport { movieType } from './types';\nimport { isLetter } from './isLetter';\nconst IMAGE_WIDTH = 143;\n\nconst StyledNewLetter = styled.h2`\n  color: #fff;\n  margin: ${spacing.large} 0 ${spacingUnit * 0.75}px;\n  ${fonts.sizes(26, 1.1)};\n  ${mq.range({ from: breakpoints.tablet })} {\n    text-indent: ${spacingUnit * 0.75}px;\n  }\n  &:after {\n    content: '';\n    display: block;\n    height: 1px;\n    background: ${colors.brand.greyDark};\n    margin-top: ${spacing.small};\n  }\n`;\n\nconst StyledWrapper = styled.section`\n  width: 652px;\n  max-width: 100%;\n  margin: ${spacing.large} auto;\n  padding: 0 ${spacing.normal};\n  display: flex;\n  flex-direction: column;\n`;\n\ntype MovieItemProps = {\n  inView: boolean | null;\n};\n\nconst MovieItem = styled.div<MovieItemProps>`\n  margin: 0 0 ${spacingUnit * 0.75}px;\n  display: inline-flex;\n  &:last-child {\n    margin-bottom: ${spacing.large};\n  }\n  opacity: 0;\n  transform: translateY(${spacing.xsmall});\n  transition: all ${animations.durations.slow} ease;\n  ${(props: MovieItemProps) =>\n    props.inView &&\n    css`\n      opacity: 1;\n      transform: translateY(0);\n    `};\n`;\n\nconst MovieTextWrapper = styled.div`\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.xsmall} ${spacing.xsmall} 0 0;\n  }\n  flex: 1;\n`;\n\ntype movieImageType = {\n  backgroundImage?: string | null;\n};\n\nconst MovieImage = styled.div<movieImageType>`\n  width: 104px;\n  height: 80px;\n  background-color: ${colors.ndlaFilm.filmColorLight};\n  ${(props: movieImageType) =>\n    props.backgroundImage !== null &&\n    css`\n      background-image: url(${props.backgroundImage});\n    `}\n  background-size: cover;\n  background-position: center center;\n  margin: 0 ${spacingUnit * 0.75}px 0 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    margin-left: ${spacingUnit * 0.75}px;\n    width: ${IMAGE_WIDTH}px;\n    height: 90px;\n  }\n  position: relative;\n  &:after {\n    content: '';\n    position: absolute;\n    z-index: 1;\n    background: ${colors.ndlaFilm.filmColor};\n    opacity: 0;\n    left: 0;\n    right: 0;\n    bottom: 0;\n    top: 0;\n  }\n`;\n\nconst MovieTitle = styled.h3`\n  color: #fff;\n  margin: 0 0 2px;\n  ${fonts.sizes(18, 1.3)};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes(20, 1.3)};\n  }\n`;\n\nconst MovieDescription = styled.p`\n  color: ${colors.brand.greyLighter};\n  margin: 0;\n  ${fonts.sizes(14, 1.5)};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes(16, 1.5)};\n  }\n  overflow: hidden;\n  text-overflow: ellipsis;\n  display: -webkit-box;\n  -webkit-box-orient: vertical;\n  -webkit-line-clamp: 2;\n`;\n\ntype isIEProps = {\n  isIE11: boolean;\n};\n\nconst StyledSafeLink = styled(SafeLink)<isIEProps>`\n  box-shadow: none;\n  display: flex;\n  ${(props) =>\n    props.isIE11 &&\n    css`\n      flex: 1;\n    `}\n  &:hover,\n  &:focus {\n    ${MovieTitle} {\n      text-decoration: underline;\n    }\n    ${MovieImage} {\n      &:after {\n        transition: opacity 200ms ease;\n        display: block;\n        opacity: 0.3;\n      }\n    }\n  }\n`;\n\ninterface Props {\n  movies: movieType[];\n  locale: string;\n}\n\ntype visibleImagesProps = {\n  [key: string]: boolean | null;\n};\n\nconst hasForEachPolyfill = () => {\n  // Polyfill for ie11\n  if ('NodeList' in window && !NodeList.prototype.forEach) {\n    NodeList.prototype.forEach = function (callback, thisArg) {\n      thisArg = thisArg || window;\n      for (var i = 0; i < this.length; i++) {\n        callback.call(thisArg, this[i], i, this);\n      }\n    };\n  }\n};\n\nconst AllMoviesAlphabetically: React.FunctionComponent<Props> = ({ movies, locale }) => {\n  const isIE11 = isIE && parseInt(browserVersion) < 12;\n  // Split into Letters.\n  let previousLetter = '';\n  const wrapperRef: React.RefObject<HTMLElement> = React.useRef(null);\n  const [visibleImages, setVisibleImages] = useState<visibleImagesProps>({});\n\n  const scrollEvent = () => {\n    hasForEachPolyfill();\n    const updates: visibleImagesProps = {};\n    const allChildren: NodeListOf<HTMLElement> | null =\n      wrapperRef.current && wrapperRef.current.querySelectorAll('[role=img]');\n    const windowInnerHeight = window.innerHeight;\n    if (allChildren) {\n      let started: boolean = false;\n      let ended: boolean = false;\n      allChildren.forEach((el: HTMLElement, index: number) => {\n        if (!ended) {\n          const rect: ClientRect = el.getBoundingClientRect();\n          if (!started) {\n            if (rect.top > -20) {\n              updates[index] = true;\n              started = true;\n            }\n          } else {\n            updates[index] = true;\n            if (rect.top > windowInnerHeight + 20) {\n              ended = true;\n            }\n          }\n        }\n      });\n    }\n    setVisibleImages((visibleImages) => ({ ...visibleImages, ...updates }));\n  };\n\n  useEffect(() => {\n    const throttledScrollEvent = throttle(() => {\n      scrollEvent();\n    }, 100);\n    window.addEventListener('scroll', throttledScrollEvent);\n    scrollEvent();\n    return () => {\n      window.removeEventListener('scroll', throttledScrollEvent);\n    };\n  }, []);\n\n  useEffect(() => {\n    scrollEvent();\n  }, [movies]);\n\n  return (\n    <StyledWrapper ref={wrapperRef}>\n      {movies.map((movie: movieType, index: number) => {\n        const currentLetter = movie.title.substr(0, 1);\n        const isNewLetter = currentLetter.localeCompare(previousLetter, locale) === 1 && isLetter(movie.title);\n        previousLetter = currentLetter;\n        const inView: boolean | null = visibleImages ? visibleImages[index] : null;\n        return (\n          <Fragment key={movie.id}>\n            {isNewLetter && <StyledNewLetter>{movie.title.substr(0, 1)}</StyledNewLetter>}\n            <MovieItem inView={inView}>\n              <StyledSafeLink isIE11={isIE11} to={movie.path}>\n                <MovieImage\n                  role=\"img\"\n                  backgroundImage={\n                    inView && movie.metaImage && movie.metaImage.url\n                      ? `${movie.metaImage.url}?${makeSrcQueryString(IMAGE_WIDTH * 2)}`\n                      : null\n                  }\n                  aria-label={movie.metaImage && movie.metaImage.alt}\n                  title={movie.title}\n                />\n                <MovieTextWrapper>\n                  <MovieTitle>{movie.title}</MovieTitle>\n                  <MovieDescription>{movie.metaDescription}</MovieDescription>\n                </MovieTextWrapper>\n              </StyledSafeLink>\n            </MovieItem>\n          </Fragment>\n        );\n      })}\n    </StyledWrapper>\n  );\n};\n\nexport default AllMoviesAlphabetically;\n"]} */",
107
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["AllMoviesAlphabetically.tsx"],"names":[],"mappings":"AA6IO","file":"AllMoviesAlphabetically.tsx","sourcesContent":["/**\n * Copyright (c) 2019-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { Fragment, useEffect, useState } from 'react';\nimport { isIE, browserVersion } from 'react-device-detect';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/core';\nimport throttle from 'lodash/throttle';\nimport { breakpoints, mq, spacing, spacingUnit, colors, fonts, animations } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\n// @ts-ignore\nimport { makeSrcQueryString } from '../Image';\nimport { MovieType } from './types';\nimport { isLetter } from './isLetter';\nconst IMAGE_WIDTH = 143;\n\nconst StyledNewLetter = styled.h2`\n  color: #fff;\n  margin: ${spacing.large} 0 ${spacingUnit * 0.75}px;\n  ${fonts.sizes(26, 1.1)};\n  ${mq.range({ from: breakpoints.tablet })} {\n    text-indent: ${spacingUnit * 0.75}px;\n  }\n  &:after {\n    content: '';\n    display: block;\n    height: 1px;\n    background: ${colors.brand.greyDark};\n    margin-top: ${spacing.small};\n  }\n`;\n\nconst StyledWrapper = styled.section`\n  width: 652px;\n  max-width: 100%;\n  margin: ${spacing.large} auto;\n  padding: 0 ${spacing.normal};\n  display: flex;\n  flex-direction: column;\n`;\n\ntype MovieItemProps = {\n  inView: boolean | null;\n};\n\nconst MovieItem = styled.div<MovieItemProps>`\n  margin: 0 0 ${spacingUnit * 0.75}px;\n  display: inline-flex;\n  &:last-child {\n    margin-bottom: ${spacing.large};\n  }\n  opacity: 0;\n  transform: translateY(${spacing.xsmall});\n  transition: all ${animations.durations.slow} ease;\n  ${(props: MovieItemProps) =>\n    props.inView &&\n    css`\n      opacity: 1;\n      transform: translateY(0);\n    `};\n`;\n\nconst MovieTextWrapper = styled.div`\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.xsmall} ${spacing.xsmall} 0 0;\n  }\n  flex: 1;\n`;\n\ntype movieImageType = {\n  backgroundImage?: string | null;\n};\n\nconst MovieImage = styled.div<movieImageType>`\n  width: 104px;\n  height: 80px;\n  background-color: ${colors.ndlaFilm.filmColorLight};\n  ${(props: movieImageType) =>\n    props.backgroundImage !== null &&\n    css`\n      background-image: url(${props.backgroundImage});\n    `}\n  background-size: cover;\n  background-position: center center;\n  margin: 0 ${spacingUnit * 0.75}px 0 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    margin-left: ${spacingUnit * 0.75}px;\n    width: ${IMAGE_WIDTH}px;\n    height: 90px;\n  }\n  position: relative;\n  &:after {\n    content: '';\n    position: absolute;\n    z-index: 1;\n    background: ${colors.ndlaFilm.filmColor};\n    opacity: 0;\n    left: 0;\n    right: 0;\n    bottom: 0;\n    top: 0;\n  }\n`;\n\nconst MovieTitle = styled.h3`\n  color: #fff;\n  margin: 0 0 2px;\n  ${fonts.sizes(18, 1.3)};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes(20, 1.3)};\n  }\n`;\n\nconst MovieDescription = styled.p`\n  color: ${colors.brand.greyLighter};\n  margin: 0;\n  ${fonts.sizes(14, 1.5)};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes(16, 1.5)};\n  }\n  overflow: hidden;\n  text-overflow: ellipsis;\n  display: -webkit-box;\n  -webkit-box-orient: vertical;\n  -webkit-line-clamp: 2;\n`;\n\ntype isIEProps = {\n  isIE11: boolean;\n};\n\nconst StyledSafeLink = styled(SafeLink)<isIEProps>`\n  box-shadow: none;\n  display: flex;\n  ${(props) =>\n    props.isIE11 &&\n    css`\n      flex: 1;\n    `}\n  &:hover,\n  &:focus {\n    ${MovieTitle} {\n      text-decoration: underline;\n    }\n    ${MovieImage} {\n      &:after {\n        transition: opacity 200ms ease;\n        display: block;\n        opacity: 0.3;\n      }\n    }\n  }\n`;\n\ninterface Props {\n  movies: MovieType[];\n  locale: string;\n}\n\ntype visibleImagesProps = {\n  [key: string]: boolean | null;\n};\n\nconst hasForEachPolyfill = () => {\n  // Polyfill for ie11\n  if ('NodeList' in window && !NodeList.prototype.forEach) {\n    NodeList.prototype.forEach = function (callback, thisArg) {\n      thisArg = thisArg || window;\n      for (var i = 0; i < this.length; i++) {\n        callback.call(thisArg, this[i], i, this);\n      }\n    };\n  }\n};\n\nconst AllMoviesAlphabetically: React.FunctionComponent<Props> = ({ movies, locale }) => {\n  const isIE11 = isIE && parseInt(browserVersion) < 12;\n  // Split into Letters.\n  let previousLetter = '';\n  const wrapperRef: React.RefObject<HTMLElement> = React.useRef(null);\n  const [visibleImages, setVisibleImages] = useState<visibleImagesProps>({});\n\n  const scrollEvent = () => {\n    hasForEachPolyfill();\n    const updates: visibleImagesProps = {};\n    const allChildren: NodeListOf<HTMLElement> | null =\n      wrapperRef.current && wrapperRef.current.querySelectorAll('[role=img]');\n    const windowInnerHeight = window.innerHeight;\n    if (allChildren) {\n      let started: boolean = false;\n      let ended: boolean = false;\n      allChildren.forEach((el: HTMLElement, index: number) => {\n        if (!ended) {\n          const rect: ClientRect = el.getBoundingClientRect();\n          if (!started) {\n            if (rect.top > -20) {\n              updates[index] = true;\n              started = true;\n            }\n          } else {\n            updates[index] = true;\n            if (rect.top > windowInnerHeight + 20) {\n              ended = true;\n            }\n          }\n        }\n      });\n    }\n    setVisibleImages((visibleImages) => ({ ...visibleImages, ...updates }));\n  };\n\n  useEffect(() => {\n    const throttledScrollEvent = throttle(() => {\n      scrollEvent();\n    }, 100);\n    window.addEventListener('scroll', throttledScrollEvent);\n    scrollEvent();\n    return () => {\n      window.removeEventListener('scroll', throttledScrollEvent);\n    };\n  }, []);\n\n  useEffect(() => {\n    scrollEvent();\n  }, [movies]);\n\n  return (\n    <StyledWrapper ref={wrapperRef}>\n      {movies.map((movie: MovieType, index: number) => {\n        const currentLetter = movie.title.substr(0, 1);\n        const isNewLetter = currentLetter.localeCompare(previousLetter, locale) === 1 && isLetter(movie.title);\n        previousLetter = currentLetter;\n        const inView: boolean | null = visibleImages ? visibleImages[index] : null;\n        return (\n          <Fragment key={movie.id}>\n            {isNewLetter && <StyledNewLetter>{movie.title.substr(0, 1)}</StyledNewLetter>}\n            <MovieItem inView={inView}>\n              <StyledSafeLink isIE11={isIE11} to={movie.path}>\n                <MovieImage\n                  role=\"img\"\n                  backgroundImage={\n                    inView && movie.metaImage && movie.metaImage.url\n                      ? `${movie.metaImage.url}?${makeSrcQueryString(IMAGE_WIDTH * 2)}`\n                      : null\n                  }\n                  aria-label={movie.metaImage && movie.metaImage.alt}\n                  title={movie.title}\n                />\n                <MovieTextWrapper>\n                  <MovieTitle>{movie.title}</MovieTitle>\n                  <MovieDescription>{movie.metaDescription}</MovieDescription>\n                </MovieTextWrapper>\n              </StyledSafeLink>\n            </MovieItem>\n          </Fragment>\n        );\n      })}\n    </StyledWrapper>\n  );\n};\n\nexport default AllMoviesAlphabetically;\n"]} */",
108
108
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
109
109
  };
110
110
 
@@ -113,7 +113,7 @@ var StyledSafeLink = /*#__PURE__*/_styled(SafeLink, {
113
113
  label: "StyledSafeLink"
114
114
  })("box-shadow:none;display:flex;", function (props) {
115
115
  return props.isIE11 && _ref2;
116
- }, " &:hover,&:focus{", MovieTitle, "{text-decoration:underline;}", MovieImage, "{&:after{transition:opacity 200ms ease;display:block;opacity:0.3;}}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["AllMoviesAlphabetically.tsx"],"names":[],"mappings":"AAwIkD","file":"AllMoviesAlphabetically.tsx","sourcesContent":["/**\n * Copyright (c) 2019-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { Fragment, useEffect, useState } from 'react';\nimport { isIE, browserVersion } from 'react-device-detect';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/core';\nimport throttle from 'lodash/throttle';\nimport { breakpoints, mq, spacing, spacingUnit, colors, fonts, animations } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\n// @ts-ignore\nimport { makeSrcQueryString } from '../Image';\nimport { movieType } from './types';\nimport { isLetter } from './isLetter';\nconst IMAGE_WIDTH = 143;\n\nconst StyledNewLetter = styled.h2`\n  color: #fff;\n  margin: ${spacing.large} 0 ${spacingUnit * 0.75}px;\n  ${fonts.sizes(26, 1.1)};\n  ${mq.range({ from: breakpoints.tablet })} {\n    text-indent: ${spacingUnit * 0.75}px;\n  }\n  &:after {\n    content: '';\n    display: block;\n    height: 1px;\n    background: ${colors.brand.greyDark};\n    margin-top: ${spacing.small};\n  }\n`;\n\nconst StyledWrapper = styled.section`\n  width: 652px;\n  max-width: 100%;\n  margin: ${spacing.large} auto;\n  padding: 0 ${spacing.normal};\n  display: flex;\n  flex-direction: column;\n`;\n\ntype MovieItemProps = {\n  inView: boolean | null;\n};\n\nconst MovieItem = styled.div<MovieItemProps>`\n  margin: 0 0 ${spacingUnit * 0.75}px;\n  display: inline-flex;\n  &:last-child {\n    margin-bottom: ${spacing.large};\n  }\n  opacity: 0;\n  transform: translateY(${spacing.xsmall});\n  transition: all ${animations.durations.slow} ease;\n  ${(props: MovieItemProps) =>\n    props.inView &&\n    css`\n      opacity: 1;\n      transform: translateY(0);\n    `};\n`;\n\nconst MovieTextWrapper = styled.div`\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.xsmall} ${spacing.xsmall} 0 0;\n  }\n  flex: 1;\n`;\n\ntype movieImageType = {\n  backgroundImage?: string | null;\n};\n\nconst MovieImage = styled.div<movieImageType>`\n  width: 104px;\n  height: 80px;\n  background-color: ${colors.ndlaFilm.filmColorLight};\n  ${(props: movieImageType) =>\n    props.backgroundImage !== null &&\n    css`\n      background-image: url(${props.backgroundImage});\n    `}\n  background-size: cover;\n  background-position: center center;\n  margin: 0 ${spacingUnit * 0.75}px 0 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    margin-left: ${spacingUnit * 0.75}px;\n    width: ${IMAGE_WIDTH}px;\n    height: 90px;\n  }\n  position: relative;\n  &:after {\n    content: '';\n    position: absolute;\n    z-index: 1;\n    background: ${colors.ndlaFilm.filmColor};\n    opacity: 0;\n    left: 0;\n    right: 0;\n    bottom: 0;\n    top: 0;\n  }\n`;\n\nconst MovieTitle = styled.h3`\n  color: #fff;\n  margin: 0 0 2px;\n  ${fonts.sizes(18, 1.3)};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes(20, 1.3)};\n  }\n`;\n\nconst MovieDescription = styled.p`\n  color: ${colors.brand.greyLighter};\n  margin: 0;\n  ${fonts.sizes(14, 1.5)};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes(16, 1.5)};\n  }\n  overflow: hidden;\n  text-overflow: ellipsis;\n  display: -webkit-box;\n  -webkit-box-orient: vertical;\n  -webkit-line-clamp: 2;\n`;\n\ntype isIEProps = {\n  isIE11: boolean;\n};\n\nconst StyledSafeLink = styled(SafeLink)<isIEProps>`\n  box-shadow: none;\n  display: flex;\n  ${(props) =>\n    props.isIE11 &&\n    css`\n      flex: 1;\n    `}\n  &:hover,\n  &:focus {\n    ${MovieTitle} {\n      text-decoration: underline;\n    }\n    ${MovieImage} {\n      &:after {\n        transition: opacity 200ms ease;\n        display: block;\n        opacity: 0.3;\n      }\n    }\n  }\n`;\n\ninterface Props {\n  movies: movieType[];\n  locale: string;\n}\n\ntype visibleImagesProps = {\n  [key: string]: boolean | null;\n};\n\nconst hasForEachPolyfill = () => {\n  // Polyfill for ie11\n  if ('NodeList' in window && !NodeList.prototype.forEach) {\n    NodeList.prototype.forEach = function (callback, thisArg) {\n      thisArg = thisArg || window;\n      for (var i = 0; i < this.length; i++) {\n        callback.call(thisArg, this[i], i, this);\n      }\n    };\n  }\n};\n\nconst AllMoviesAlphabetically: React.FunctionComponent<Props> = ({ movies, locale }) => {\n  const isIE11 = isIE && parseInt(browserVersion) < 12;\n  // Split into Letters.\n  let previousLetter = '';\n  const wrapperRef: React.RefObject<HTMLElement> = React.useRef(null);\n  const [visibleImages, setVisibleImages] = useState<visibleImagesProps>({});\n\n  const scrollEvent = () => {\n    hasForEachPolyfill();\n    const updates: visibleImagesProps = {};\n    const allChildren: NodeListOf<HTMLElement> | null =\n      wrapperRef.current && wrapperRef.current.querySelectorAll('[role=img]');\n    const windowInnerHeight = window.innerHeight;\n    if (allChildren) {\n      let started: boolean = false;\n      let ended: boolean = false;\n      allChildren.forEach((el: HTMLElement, index: number) => {\n        if (!ended) {\n          const rect: ClientRect = el.getBoundingClientRect();\n          if (!started) {\n            if (rect.top > -20) {\n              updates[index] = true;\n              started = true;\n            }\n          } else {\n            updates[index] = true;\n            if (rect.top > windowInnerHeight + 20) {\n              ended = true;\n            }\n          }\n        }\n      });\n    }\n    setVisibleImages((visibleImages) => ({ ...visibleImages, ...updates }));\n  };\n\n  useEffect(() => {\n    const throttledScrollEvent = throttle(() => {\n      scrollEvent();\n    }, 100);\n    window.addEventListener('scroll', throttledScrollEvent);\n    scrollEvent();\n    return () => {\n      window.removeEventListener('scroll', throttledScrollEvent);\n    };\n  }, []);\n\n  useEffect(() => {\n    scrollEvent();\n  }, [movies]);\n\n  return (\n    <StyledWrapper ref={wrapperRef}>\n      {movies.map((movie: movieType, index: number) => {\n        const currentLetter = movie.title.substr(0, 1);\n        const isNewLetter = currentLetter.localeCompare(previousLetter, locale) === 1 && isLetter(movie.title);\n        previousLetter = currentLetter;\n        const inView: boolean | null = visibleImages ? visibleImages[index] : null;\n        return (\n          <Fragment key={movie.id}>\n            {isNewLetter && <StyledNewLetter>{movie.title.substr(0, 1)}</StyledNewLetter>}\n            <MovieItem inView={inView}>\n              <StyledSafeLink isIE11={isIE11} to={movie.path}>\n                <MovieImage\n                  role=\"img\"\n                  backgroundImage={\n                    inView && movie.metaImage && movie.metaImage.url\n                      ? `${movie.metaImage.url}?${makeSrcQueryString(IMAGE_WIDTH * 2)}`\n                      : null\n                  }\n                  aria-label={movie.metaImage && movie.metaImage.alt}\n                  title={movie.title}\n                />\n                <MovieTextWrapper>\n                  <MovieTitle>{movie.title}</MovieTitle>\n                  <MovieDescription>{movie.metaDescription}</MovieDescription>\n                </MovieTextWrapper>\n              </StyledSafeLink>\n            </MovieItem>\n          </Fragment>\n        );\n      })}\n    </StyledWrapper>\n  );\n};\n\nexport default AllMoviesAlphabetically;\n"]} */"));
116
+ }, " &:hover,&:focus{", MovieTitle, "{text-decoration:underline;}", MovieImage, "{&:after{transition:opacity 200ms ease;display:block;opacity:0.3;}}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["AllMoviesAlphabetically.tsx"],"names":[],"mappings":"AAwIkD","file":"AllMoviesAlphabetically.tsx","sourcesContent":["/**\n * Copyright (c) 2019-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { Fragment, useEffect, useState } from 'react';\nimport { isIE, browserVersion } from 'react-device-detect';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/core';\nimport throttle from 'lodash/throttle';\nimport { breakpoints, mq, spacing, spacingUnit, colors, fonts, animations } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\n// @ts-ignore\nimport { makeSrcQueryString } from '../Image';\nimport { MovieType } from './types';\nimport { isLetter } from './isLetter';\nconst IMAGE_WIDTH = 143;\n\nconst StyledNewLetter = styled.h2`\n  color: #fff;\n  margin: ${spacing.large} 0 ${spacingUnit * 0.75}px;\n  ${fonts.sizes(26, 1.1)};\n  ${mq.range({ from: breakpoints.tablet })} {\n    text-indent: ${spacingUnit * 0.75}px;\n  }\n  &:after {\n    content: '';\n    display: block;\n    height: 1px;\n    background: ${colors.brand.greyDark};\n    margin-top: ${spacing.small};\n  }\n`;\n\nconst StyledWrapper = styled.section`\n  width: 652px;\n  max-width: 100%;\n  margin: ${spacing.large} auto;\n  padding: 0 ${spacing.normal};\n  display: flex;\n  flex-direction: column;\n`;\n\ntype MovieItemProps = {\n  inView: boolean | null;\n};\n\nconst MovieItem = styled.div<MovieItemProps>`\n  margin: 0 0 ${spacingUnit * 0.75}px;\n  display: inline-flex;\n  &:last-child {\n    margin-bottom: ${spacing.large};\n  }\n  opacity: 0;\n  transform: translateY(${spacing.xsmall});\n  transition: all ${animations.durations.slow} ease;\n  ${(props: MovieItemProps) =>\n    props.inView &&\n    css`\n      opacity: 1;\n      transform: translateY(0);\n    `};\n`;\n\nconst MovieTextWrapper = styled.div`\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.xsmall} ${spacing.xsmall} 0 0;\n  }\n  flex: 1;\n`;\n\ntype movieImageType = {\n  backgroundImage?: string | null;\n};\n\nconst MovieImage = styled.div<movieImageType>`\n  width: 104px;\n  height: 80px;\n  background-color: ${colors.ndlaFilm.filmColorLight};\n  ${(props: movieImageType) =>\n    props.backgroundImage !== null &&\n    css`\n      background-image: url(${props.backgroundImage});\n    `}\n  background-size: cover;\n  background-position: center center;\n  margin: 0 ${spacingUnit * 0.75}px 0 0;\n  ${mq.range({ from: breakpoints.tablet })} {\n    margin-left: ${spacingUnit * 0.75}px;\n    width: ${IMAGE_WIDTH}px;\n    height: 90px;\n  }\n  position: relative;\n  &:after {\n    content: '';\n    position: absolute;\n    z-index: 1;\n    background: ${colors.ndlaFilm.filmColor};\n    opacity: 0;\n    left: 0;\n    right: 0;\n    bottom: 0;\n    top: 0;\n  }\n`;\n\nconst MovieTitle = styled.h3`\n  color: #fff;\n  margin: 0 0 2px;\n  ${fonts.sizes(18, 1.3)};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes(20, 1.3)};\n  }\n`;\n\nconst MovieDescription = styled.p`\n  color: ${colors.brand.greyLighter};\n  margin: 0;\n  ${fonts.sizes(14, 1.5)};\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes(16, 1.5)};\n  }\n  overflow: hidden;\n  text-overflow: ellipsis;\n  display: -webkit-box;\n  -webkit-box-orient: vertical;\n  -webkit-line-clamp: 2;\n`;\n\ntype isIEProps = {\n  isIE11: boolean;\n};\n\nconst StyledSafeLink = styled(SafeLink)<isIEProps>`\n  box-shadow: none;\n  display: flex;\n  ${(props) =>\n    props.isIE11 &&\n    css`\n      flex: 1;\n    `}\n  &:hover,\n  &:focus {\n    ${MovieTitle} {\n      text-decoration: underline;\n    }\n    ${MovieImage} {\n      &:after {\n        transition: opacity 200ms ease;\n        display: block;\n        opacity: 0.3;\n      }\n    }\n  }\n`;\n\ninterface Props {\n  movies: MovieType[];\n  locale: string;\n}\n\ntype visibleImagesProps = {\n  [key: string]: boolean | null;\n};\n\nconst hasForEachPolyfill = () => {\n  // Polyfill for ie11\n  if ('NodeList' in window && !NodeList.prototype.forEach) {\n    NodeList.prototype.forEach = function (callback, thisArg) {\n      thisArg = thisArg || window;\n      for (var i = 0; i < this.length; i++) {\n        callback.call(thisArg, this[i], i, this);\n      }\n    };\n  }\n};\n\nconst AllMoviesAlphabetically: React.FunctionComponent<Props> = ({ movies, locale }) => {\n  const isIE11 = isIE && parseInt(browserVersion) < 12;\n  // Split into Letters.\n  let previousLetter = '';\n  const wrapperRef: React.RefObject<HTMLElement> = React.useRef(null);\n  const [visibleImages, setVisibleImages] = useState<visibleImagesProps>({});\n\n  const scrollEvent = () => {\n    hasForEachPolyfill();\n    const updates: visibleImagesProps = {};\n    const allChildren: NodeListOf<HTMLElement> | null =\n      wrapperRef.current && wrapperRef.current.querySelectorAll('[role=img]');\n    const windowInnerHeight = window.innerHeight;\n    if (allChildren) {\n      let started: boolean = false;\n      let ended: boolean = false;\n      allChildren.forEach((el: HTMLElement, index: number) => {\n        if (!ended) {\n          const rect: ClientRect = el.getBoundingClientRect();\n          if (!started) {\n            if (rect.top > -20) {\n              updates[index] = true;\n              started = true;\n            }\n          } else {\n            updates[index] = true;\n            if (rect.top > windowInnerHeight + 20) {\n              ended = true;\n            }\n          }\n        }\n      });\n    }\n    setVisibleImages((visibleImages) => ({ ...visibleImages, ...updates }));\n  };\n\n  useEffect(() => {\n    const throttledScrollEvent = throttle(() => {\n      scrollEvent();\n    }, 100);\n    window.addEventListener('scroll', throttledScrollEvent);\n    scrollEvent();\n    return () => {\n      window.removeEventListener('scroll', throttledScrollEvent);\n    };\n  }, []);\n\n  useEffect(() => {\n    scrollEvent();\n  }, [movies]);\n\n  return (\n    <StyledWrapper ref={wrapperRef}>\n      {movies.map((movie: MovieType, index: number) => {\n        const currentLetter = movie.title.substr(0, 1);\n        const isNewLetter = currentLetter.localeCompare(previousLetter, locale) === 1 && isLetter(movie.title);\n        previousLetter = currentLetter;\n        const inView: boolean | null = visibleImages ? visibleImages[index] : null;\n        return (\n          <Fragment key={movie.id}>\n            {isNewLetter && <StyledNewLetter>{movie.title.substr(0, 1)}</StyledNewLetter>}\n            <MovieItem inView={inView}>\n              <StyledSafeLink isIE11={isIE11} to={movie.path}>\n                <MovieImage\n                  role=\"img\"\n                  backgroundImage={\n                    inView && movie.metaImage && movie.metaImage.url\n                      ? `${movie.metaImage.url}?${makeSrcQueryString(IMAGE_WIDTH * 2)}`\n                      : null\n                  }\n                  aria-label={movie.metaImage && movie.metaImage.alt}\n                  title={movie.title}\n                />\n                <MovieTextWrapper>\n                  <MovieTitle>{movie.title}</MovieTitle>\n                  <MovieDescription>{movie.metaDescription}</MovieDescription>\n                </MovieTextWrapper>\n              </StyledSafeLink>\n            </MovieItem>\n          </Fragment>\n        );\n      })}\n    </StyledWrapper>\n  );\n};\n\nexport default AllMoviesAlphabetically;\n"]} */"));
117
117
 
118
118
  var hasForEachPolyfill = function hasForEachPolyfill() {
119
119
  // Polyfill for ie11