@ndla/ui 34.0.1 → 34.1.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (91) hide show
  1. package/es/Figure/Figure.js +3 -2
  2. package/es/FileList/File.js +6 -6
  3. package/es/LanguageSelector/LanguageSelector.js +68 -99
  4. package/es/NDLAFilm/AboutNdlaFilm.js +13 -12
  5. package/es/NDLAFilm/AllMoviesAlphabetically.js +79 -144
  6. package/es/NDLAFilm/FilmContentCard.js +41 -26
  7. package/es/NDLAFilm/FilmContentCardTags.js +5 -3
  8. package/es/NDLAFilm/FilmMovieList.js +13 -8
  9. package/es/NDLAFilm/FilmMovieSearch.js +6 -5
  10. package/es/NDLAFilm/FilmSlideshow.js +44 -20
  11. package/es/NDLAFilm/filmStyles.js +2 -2
  12. package/es/ResourceGroup/ResourceItem.js +72 -48
  13. package/es/Search/ActiveFilterContent.js +6 -5
  14. package/es/Search/ContentTypeResult.js +6 -3
  15. package/es/SearchTypeResult/ActiveFilterContent.js +9 -10
  16. package/es/Topic/Topic.js +171 -213
  17. package/es/all.css +1 -1
  18. package/es/locale/messages-en.js +3 -1
  19. package/es/locale/messages-nb.js +3 -1
  20. package/es/locale/messages-nn.js +7 -5
  21. package/es/locale/messages-se.js +2 -0
  22. package/es/locale/messages-sma.js +3 -1
  23. package/lib/Figure/Figure.d.ts +2 -1
  24. package/lib/Figure/Figure.js +3 -2
  25. package/lib/FileList/File.js +6 -6
  26. package/lib/LanguageSelector/LanguageSelector.d.ts +6 -15
  27. package/lib/LanguageSelector/LanguageSelector.js +65 -99
  28. package/lib/NDLAFilm/AboutNdlaFilm.js +11 -14
  29. package/lib/NDLAFilm/AllMoviesAlphabetically.d.ts +1 -2
  30. package/lib/NDLAFilm/AllMoviesAlphabetically.js +77 -142
  31. package/lib/NDLAFilm/FilmContentCard.d.ts +7 -0
  32. package/lib/NDLAFilm/FilmContentCard.js +41 -26
  33. package/lib/NDLAFilm/FilmContentCardTags.d.ts +2 -1
  34. package/lib/NDLAFilm/FilmContentCardTags.js +5 -3
  35. package/lib/NDLAFilm/FilmMovieList.js +12 -7
  36. package/lib/NDLAFilm/FilmMovieSearch.js +5 -4
  37. package/lib/NDLAFilm/FilmSlideshow.js +44 -20
  38. package/lib/NDLAFilm/filmStyles.js +2 -2
  39. package/lib/Resource/resourceComponents.d.ts +1 -1
  40. package/lib/ResourceGroup/ResourceItem.d.ts +2 -2
  41. package/lib/ResourceGroup/ResourceItem.js +72 -48
  42. package/lib/Search/ActiveFilterContent.d.ts +1 -1
  43. package/lib/Search/ActiveFilterContent.js +9 -5
  44. package/lib/Search/ContentTypeResult.js +6 -3
  45. package/lib/SearchTypeResult/ActiveFilterContent.d.ts +1 -1
  46. package/lib/SearchTypeResult/ActiveFilterContent.js +12 -10
  47. package/lib/Topic/Topic.js +170 -215
  48. package/lib/all.css +1 -1
  49. package/lib/locale/messages-en.d.ts +2 -0
  50. package/lib/locale/messages-en.js +3 -1
  51. package/lib/locale/messages-nb.d.ts +2 -0
  52. package/lib/locale/messages-nb.js +3 -1
  53. package/lib/locale/messages-nn.d.ts +4 -2
  54. package/lib/locale/messages-nn.js +7 -5
  55. package/lib/locale/messages-se.d.ts +2 -0
  56. package/lib/locale/messages-se.js +2 -0
  57. package/lib/locale/messages-sma.d.ts +2 -0
  58. package/lib/locale/messages-sma.js +3 -1
  59. package/package.json +15 -14
  60. package/src/Figure/Figure.tsx +6 -2
  61. package/src/FileList/File.tsx +4 -4
  62. package/src/LanguageSelector/LanguageSelector.stories.tsx +48 -0
  63. package/src/LanguageSelector/LanguageSelector.tsx +71 -149
  64. package/src/NDLAFilm/AboutNdlaFilm.tsx +11 -14
  65. package/src/NDLAFilm/AllMoviesAlphabetically.tsx +44 -160
  66. package/src/NDLAFilm/FilmContentCard.tsx +40 -21
  67. package/src/NDLAFilm/FilmContentCardTags.tsx +3 -2
  68. package/src/NDLAFilm/FilmMovieList.tsx +14 -7
  69. package/src/NDLAFilm/FilmMovieSearch.tsx +2 -2
  70. package/src/NDLAFilm/FilmSlideshow.tsx +49 -40
  71. package/src/NDLAFilm/filmStyles.ts +1 -1
  72. package/src/ResourceGroup/ResourceItem.tsx +79 -94
  73. package/src/Search/ActiveFilterContent.tsx +4 -3
  74. package/src/Search/ContentTypeResult.tsx +3 -1
  75. package/src/SearchTypeResult/ActiveFilterContent.tsx +7 -8
  76. package/src/Topic/Topic.tsx +166 -193
  77. package/src/locale/messages-en.ts +3 -1
  78. package/src/locale/messages-nb.ts +3 -1
  79. package/src/locale/messages-nn.ts +5 -4
  80. package/src/locale/messages-se.ts +2 -0
  81. package/src/locale/messages-sma.ts +3 -1
  82. package/src/main.scss +0 -1
  83. package/es/LanguageSelector/LanguageSelectorContent.js +0 -61
  84. package/es/Subject/SubjectCarousel.js +0 -133
  85. package/lib/LanguageSelector/LanguageSelectorContent.d.ts +0 -15
  86. package/lib/LanguageSelector/LanguageSelectorContent.js +0 -68
  87. package/lib/Subject/SubjectCarousel.d.ts +0 -18
  88. package/lib/Subject/SubjectCarousel.js +0 -138
  89. package/src/LanguageSelector/LanguageSelectorContent.tsx +0 -80
  90. package/src/NDLAFilm/component.film-movielist.scss +0 -105
  91. package/src/Subject/SubjectCarousel.tsx +0 -162
@@ -1,14 +1,10 @@
1
1
  import _styled from "@emotion/styled/base";
2
- function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
3
- function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
4
- function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
5
2
  function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
6
3
  function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
7
4
  function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
8
5
  function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
9
6
  function _iterableToArrayLimit(arr, i) { var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"]; if (_i == null) return; var _arr = []; var _n = true; var _d = false; var _s, _e; try { for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"] != null) _i["return"](); } finally { if (_d) throw _e; } } return _arr; }
10
7
  function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
11
- function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
12
8
  /**
13
9
  * Copyright (c) 2019-present, NDLA.
14
10
  *
@@ -17,177 +13,116 @@ function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringif
17
13
  *
18
14
  */
19
15
 
20
- import React, { Fragment, useEffect, useRef, useState } from 'react';
21
- import { isIE, browserVersion } from 'react-device-detect';
22
- import { css } from '@emotion/react';
23
- import throttle from 'lodash/throttle';
24
- import { breakpoints, mq, spacing, spacingUnit, colors, fonts, animations } from '@ndla/core';
16
+ import React, { useMemo, useRef } from 'react';
17
+ import { breakpoints, mq, spacing, spacingUnit, colors } from '@ndla/core';
25
18
  import SafeLink from '@ndla/safelink';
19
+ import groupBy from 'lodash/groupBy';
20
+ import sortBy from 'lodash/sortBy';
21
+ import { useTranslation } from 'react-i18next';
26
22
  import { makeSrcQueryString } from '../Image';
27
- import { isLetter } from './isLetter';
28
23
  import { jsx as _jsx } from "@emotion/react/jsx-runtime";
29
24
  import { jsxs as _jsxs } from "@emotion/react/jsx-runtime";
30
25
  var IMAGE_WIDTH = 143;
31
- var StyledNewLetter = /*#__PURE__*/_styled("h2", {
32
- target: "e1ul1xui7",
33
- label: "StyledNewLetter"
34
- })("color:#fff;margin:", spacing.large, " 0 ", spacingUnit * 0.75, "px;", fonts.sizes(26, 1.1), ";", mq.range({
26
+ var Letter = /*#__PURE__*/_styled("h2", {
27
+ target: "e1ul1xui8",
28
+ label: "Letter"
29
+ })("color:", colors.white, ";", mq.range({
35
30
  from: breakpoints.tablet
36
- }), "{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":"AAoBiC","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, RefObject, useEffect, useRef, useState } from 'react';\nimport { isIE, browserVersion } from 'react-device-detect';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport throttle from 'lodash/throttle';\nimport { breakpoints, mq, spacing, spacingUnit, colors, fonts, animations } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\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 (let i = 0; i < this.length; i++) {\n        callback.call(thisArg, this[i], i, this);\n      }\n    };\n  }\n};\n\nconst AllMoviesAlphabetically = ({ movies, locale }: Props) => {\n  const isIE11 = isIE && parseInt(browserVersion) < 12;\n  // Split into Letters.\n  let previousLetter = '';\n  const wrapperRef: RefObject<HTMLElement> = 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"]} */"));
31
+ }), "{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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkFsbE1vdmllc0FscGhhYmV0aWNhbGx5LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFvQndCIiwiZmlsZSI6IkFsbE1vdmllc0FscGhhYmV0aWNhbGx5LnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDE5LXByZXNlbnQsIE5ETEEuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgR1BMdjMgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqXG4gKi9cblxuaW1wb3J0IFJlYWN0LCB7IFJlZk9iamVjdCwgdXNlTWVtbywgdXNlUmVmIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgYnJlYWtwb2ludHMsIG1xLCBzcGFjaW5nLCBzcGFjaW5nVW5pdCwgY29sb3JzIH0gZnJvbSAnQG5kbGEvY29yZSc7XG5pbXBvcnQgU2FmZUxpbmsgZnJvbSAnQG5kbGEvc2FmZWxpbmsnO1xuaW1wb3J0IGdyb3VwQnkgZnJvbSAnbG9kYXNoL2dyb3VwQnknO1xuaW1wb3J0IHNvcnRCeSBmcm9tICdsb2Rhc2gvc29ydEJ5JztcbmltcG9ydCB7IHVzZVRyYW5zbGF0aW9uIH0gZnJvbSAncmVhY3QtaTE4bmV4dCc7XG5pbXBvcnQgeyBtYWtlU3JjUXVlcnlTdHJpbmcgfSBmcm9tICcuLi9JbWFnZSc7XG5pbXBvcnQgeyBNb3ZpZVR5cGUgfSBmcm9tICcuL3R5cGVzJztcblxuY29uc3QgSU1BR0VfV0lEVEggPSAxNDM7XG5cbmNvbnN0IExldHRlciA9IHN0eWxlZC5oMmBcbiAgY29sb3I6ICR7Y29sb3JzLndoaXRlfTtcbiAgJHttcS5yYW5nZSh7IGZyb206IGJyZWFrcG9pbnRzLnRhYmxldCB9KX0ge1xuICAgIHRleHQtaW5kZW50OiAke3NwYWNpbmdVbml0ICogMC43NX1weDtcbiAgfVxuICAmOmFmdGVyIHtcbiAgICBjb250ZW50OiAnJztcbiAgICBkaXNwbGF5OiBibG9jaztcbiAgICBoZWlnaHQ6IDFweDtcbiAgICBiYWNrZ3JvdW5kOiAke2NvbG9ycy5icmFuZC5ncmV5RGFya307XG4gICAgbWFyZ2luLXRvcDogJHtzcGFjaW5nLnNtYWxsfTtcbiAgfVxuYDtcblxuY29uc3QgU3R5bGVkV3JhcHBlciA9IHN0eWxlZC5zZWN0aW9uYFxuICB3aWR0aDogNjUycHg7XG4gIG1heC13aWR0aDogMTAwJTtcbiAgbWFyZ2luOiAke3NwYWNpbmcubGFyZ2V9IGF1dG87XG4gIHBhZGRpbmc6IDAgJHtzcGFjaW5nLm5vcm1hbH07XG5gO1xuXG5jb25zdCBNb3ZpZUl0ZW0gPSBzdHlsZWQuZGl2YFxuICBkaXNwbGF5OiBmbGV4O1xuICBnYXA6ICR7c3BhY2luZy5zbWFsbH07XG4gIGNvbG9yOiAke2NvbG9ycy53aGl0ZX07XG5gO1xuXG5jb25zdCBNb3ZpZVRleHRXcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgJHttcS5yYW5nZSh7IGZyb206IGJyZWFrcG9pbnRzLnRhYmxldCB9KX0ge1xuICAgIHBhZGRpbmc6ICR7c3BhY2luZy54c21hbGx9ICR7c3BhY2luZy54c21hbGx9IDAgMDtcbiAgfVxuICBmbGV4OiAxO1xuYDtcblxuY29uc3QgTW92aWVJbWFnZSA9IHN0eWxlZC5pbWdgXG4gIHdpZHRoOiAxMDRweDtcbiAgaGVpZ2h0OiA4MHB4O1xuICAke21xLnJhbmdlKHsgZnJvbTogYnJlYWtwb2ludHMudGFibGV0IH0pfSB7XG4gICAgd2lkdGg6ICR7SU1BR0VfV0lEVEh9cHg7XG4gICAgaGVpZ2h0OiA5MHB4O1xuICB9XG5gO1xuXG5jb25zdCBNb3ZpZVRpdGxlID0gc3R5bGVkLmgzYFxuICBjb2xvcjogJHtjb2xvcnMud2hpdGV9O1xuICBtYXJnaW46IDA7XG5gO1xuXG5jb25zdCBNb3ZpZURlc2NyaXB0aW9uID0gc3R5bGVkLnBgXG4gIGNvbG9yOiAke2NvbG9ycy5icmFuZC5ncmV5TGlnaHRlcn07XG4gIG1hcmdpbjogMDtcbiAgb3ZlcmZsb3c6IGhpZGRlbjtcbiAgdGV4dC1vdmVyZmxvdzogZWxsaXBzaXM7XG4gIGRpc3BsYXk6IC13ZWJraXQtYm94O1xuICAtd2Via2l0LWJveC1vcmllbnQ6IHZlcnRpY2FsO1xuICAtd2Via2l0LWxpbmUtY2xhbXA6IDI7XG5gO1xuXG5jb25zdCBTdHlsZWRTYWZlTGluayA9IHN0eWxlZChTYWZlTGluaylgXG4gIGJveC1zaGFkb3c6IG5vbmU7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGdhcDogJHtzcGFjaW5nLnNtYWxsfTtcbiAgJjpob3ZlcixcbiAgJjpmb2N1cyB7XG4gICAgJHtNb3ZpZVRpdGxlfSB7XG4gICAgICB0ZXh0LWRlY29yYXRpb246IHVuZGVybGluZTtcbiAgICB9XG4gICAgJHtNb3ZpZUltYWdlfSB7XG4gICAgICAmOmFmdGVyIHtcbiAgICAgICAgdHJhbnNpdGlvbjogb3BhY2l0eSAyMDBtcyBlYXNlO1xuICAgICAgICBkaXNwbGF5OiBibG9jaztcbiAgICAgICAgb3BhY2l0eTogMC4zO1xuICAgICAgfVxuICAgIH1cbiAgfVxuYDtcblxuaW50ZXJmYWNlIFByb3BzIHtcbiAgbW92aWVzOiBNb3ZpZVR5cGVbXTtcbn1cblxuY29uc3QgTW92aWVHcm91cCA9IHN0eWxlZC5zZWN0aW9uYFxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICBnYXA6ICR7c3BhY2luZy5ub3JtYWx9O1xuYDtcblxuY29uc3QgZ3JvdXBNb3ZpZXMgPSAobW92aWVzOiBNb3ZpZVR5cGVbXSkgPT4ge1xuICBjb25zdCBzb3J0ZWRNb3ZpZXMgPSBzb3J0QnkobW92aWVzLCAobSkgPT4gbS50aXRsZSk7XG4gIGNvbnN0IGdyb3VwZWQgPSBncm91cEJ5KHNvcnRlZE1vdmllcywgKG1vdmllKSA9PiB7XG4gICAgY29uc3QgZmlyc3RDaGFyID0gbW92aWUudGl0bGVbMF0/LnRvVXBwZXJDYXNlKCk7XG4gICAgY29uc3QgaXNMZXR0ZXIgPSBmaXJzdENoYXI/Lm1hdGNoKC9bQS1aXFxXw4bDmMOFXSsvKTtcbiAgICByZXR1cm4gaXNMZXR0ZXIgPyBmaXJzdENoYXIgOiAnIyc7XG4gIH0pO1xuICByZXR1cm4gT2JqZWN0LmVudHJpZXMoZ3JvdXBlZCkubWFwKChbbGV0dGVyLCBtb3ZpZXNdKSA9PiAoeyBsZXR0ZXIsIG1vdmllcyB9KSk7XG59O1xuXG5jb25zdCBBbGxNb3ZpZXNBbHBoYWJldGljYWxseSA9ICh7IG1vdmllcyB9OiBQcm9wcykgPT4ge1xuICBjb25zdCBncm91cGVkTW92aWVzID0gdXNlTWVtbygoKSA9PiBncm91cE1vdmllcyhtb3ZpZXMpLCBbbW92aWVzXSk7XG4gIGNvbnN0IHsgdCB9ID0gdXNlVHJhbnNsYXRpb24oKTtcbiAgLy8gU3BsaXQgaW50byBMZXR0ZXJzLlxuICBjb25zdCB3cmFwcGVyUmVmOiBSZWZPYmplY3Q8SFRNTEVsZW1lbnQ+ID0gdXNlUmVmKG51bGwpO1xuXG4gIHJldHVybiAoXG4gICAgPFN0eWxlZFdyYXBwZXIgcmVmPXt3cmFwcGVyUmVmfT5cbiAgICAgIHtncm91cGVkTW92aWVzLm1hcCgoeyBsZXR0ZXIsIG1vdmllcyB9KSA9PiAoXG4gICAgICAgIDxNb3ZpZUdyb3VwIGtleT17bGV0dGVyfT5cbiAgICAgICAgICA8TGV0dGVyIGFyaWEtbGFiZWw9e3QoJ2ZpbG1mcm9udHBhZ2UuYWxsTW92aWVHcm91cFRpdGxlTGFiZWwnLCB7IGxldHRlciB9KX0+e2xldHRlcn08L0xldHRlcj5cbiAgICAgICAgICB7bW92aWVzLm1hcCgobW92aWUpID0+IChcbiAgICAgICAgICAgIDxNb3ZpZUl0ZW0ga2V5PXttb3ZpZS5pZH0+XG4gICAgICAgICAgICAgIDxTdHlsZWRTYWZlTGluayB0bz17bW92aWUucGF0aH0+XG4gICAgICAgICAgICAgICAgPE1vdmllSW1hZ2VcbiAgICAgICAgICAgICAgICAgIHNyYz17XG4gICAgICAgICAgICAgICAgICAgIG1vdmllPy5tZXRhSW1hZ2U/LnVybCA/IGAke21vdmllLm1ldGFJbWFnZT8udXJsfT8ke21ha2VTcmNRdWVyeVN0cmluZyhJTUFHRV9XSURUSCAqIDIpfWAgOiB1bmRlZmluZWRcbiAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgICAgIDxNb3ZpZVRleHRXcmFwcGVyPlxuICAgICAgICAgICAgICAgICAgPE1vdmllVGl0bGU+e21vdmllLnRpdGxlfTwvTW92aWVUaXRsZT5cbiAgICAgICAgICAgICAgICAgIDxNb3ZpZURlc2NyaXB0aW9uPnttb3ZpZS5tZXRhRGVzY3JpcHRpb259PC9Nb3ZpZURlc2NyaXB0aW9uPlxuICAgICAgICAgICAgICAgIDwvTW92aWVUZXh0V3JhcHBlcj5cbiAgICAgICAgICAgICAgPC9TdHlsZWRTYWZlTGluaz5cbiAgICAgICAgICAgIDwvTW92aWVJdGVtPlxuICAgICAgICAgICkpfVxuICAgICAgICA8L01vdmllR3JvdXA+XG4gICAgICApKX1cbiAgICA8L1N0eWxlZFdyYXBwZXI+XG4gICk7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBBbGxNb3ZpZXNBbHBoYWJldGljYWxseTtcbiJdfQ== */"));
37
32
  var StyledWrapper = /*#__PURE__*/_styled("section", {
38
- target: "e1ul1xui6",
33
+ target: "e1ul1xui7",
39
34
  label: "StyledWrapper"
40
- })("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":"AAoCoC","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, RefObject, useEffect, useRef, useState } from 'react';\nimport { isIE, browserVersion } from 'react-device-detect';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport throttle from 'lodash/throttle';\nimport { breakpoints, mq, spacing, spacingUnit, colors, fonts, animations } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\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 (let i = 0; i < this.length; i++) {\n        callback.call(thisArg, this[i], i, this);\n      }\n    };\n  }\n};\n\nconst AllMoviesAlphabetically = ({ movies, locale }: Props) => {\n  const isIE11 = isIE && parseInt(browserVersion) < 12;\n  // Split into Letters.\n  let previousLetter = '';\n  const wrapperRef: RefObject<HTMLElement> = 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"]} */"));
41
- var _ref2 = process.env.NODE_ENV === "production" ? {
42
- name: "cc7o7u-MovieItem",
43
- styles: "opacity:1;transform:translateY(0);label:MovieItem;"
44
- } : {
45
- name: "cc7o7u-MovieItem",
46
- styles: "opacity:1;transform:translateY(0);label:MovieItem;",
47
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["AllMoviesAlphabetically.tsx"],"names":[],"mappings":"AA4DO","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, RefObject, useEffect, useRef, useState } from 'react';\nimport { isIE, browserVersion } from 'react-device-detect';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport throttle from 'lodash/throttle';\nimport { breakpoints, mq, spacing, spacingUnit, colors, fonts, animations } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\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 (let i = 0; i < this.length; i++) {\n        callback.call(thisArg, this[i], i, this);\n      }\n    };\n  }\n};\n\nconst AllMoviesAlphabetically = ({ movies, locale }: Props) => {\n  const isIE11 = isIE && parseInt(browserVersion) < 12;\n  // Split into Letters.\n  let previousLetter = '';\n  const wrapperRef: RefObject<HTMLElement> = 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
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__
49
- };
35
+ })("width:652px;max-width:100%;margin:", spacing.large, " auto;padding:0 ", spacing.normal, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkFsbE1vdmllc0FscGhhYmV0aWNhbGx5LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFrQ29DIiwiZmlsZSI6IkFsbE1vdmllc0FscGhhYmV0aWNhbGx5LnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDE5LXByZXNlbnQsIE5ETEEuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgR1BMdjMgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqXG4gKi9cblxuaW1wb3J0IFJlYWN0LCB7IFJlZk9iamVjdCwgdXNlTWVtbywgdXNlUmVmIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgYnJlYWtwb2ludHMsIG1xLCBzcGFjaW5nLCBzcGFjaW5nVW5pdCwgY29sb3JzIH0gZnJvbSAnQG5kbGEvY29yZSc7XG5pbXBvcnQgU2FmZUxpbmsgZnJvbSAnQG5kbGEvc2FmZWxpbmsnO1xuaW1wb3J0IGdyb3VwQnkgZnJvbSAnbG9kYXNoL2dyb3VwQnknO1xuaW1wb3J0IHNvcnRCeSBmcm9tICdsb2Rhc2gvc29ydEJ5JztcbmltcG9ydCB7IHVzZVRyYW5zbGF0aW9uIH0gZnJvbSAncmVhY3QtaTE4bmV4dCc7XG5pbXBvcnQgeyBtYWtlU3JjUXVlcnlTdHJpbmcgfSBmcm9tICcuLi9JbWFnZSc7XG5pbXBvcnQgeyBNb3ZpZVR5cGUgfSBmcm9tICcuL3R5cGVzJztcblxuY29uc3QgSU1BR0VfV0lEVEggPSAxNDM7XG5cbmNvbnN0IExldHRlciA9IHN0eWxlZC5oMmBcbiAgY29sb3I6ICR7Y29sb3JzLndoaXRlfTtcbiAgJHttcS5yYW5nZSh7IGZyb206IGJyZWFrcG9pbnRzLnRhYmxldCB9KX0ge1xuICAgIHRleHQtaW5kZW50OiAke3NwYWNpbmdVbml0ICogMC43NX1weDtcbiAgfVxuICAmOmFmdGVyIHtcbiAgICBjb250ZW50OiAnJztcbiAgICBkaXNwbGF5OiBibG9jaztcbiAgICBoZWlnaHQ6IDFweDtcbiAgICBiYWNrZ3JvdW5kOiAke2NvbG9ycy5icmFuZC5ncmV5RGFya307XG4gICAgbWFyZ2luLXRvcDogJHtzcGFjaW5nLnNtYWxsfTtcbiAgfVxuYDtcblxuY29uc3QgU3R5bGVkV3JhcHBlciA9IHN0eWxlZC5zZWN0aW9uYFxuICB3aWR0aDogNjUycHg7XG4gIG1heC13aWR0aDogMTAwJTtcbiAgbWFyZ2luOiAke3NwYWNpbmcubGFyZ2V9IGF1dG87XG4gIHBhZGRpbmc6IDAgJHtzcGFjaW5nLm5vcm1hbH07XG5gO1xuXG5jb25zdCBNb3ZpZUl0ZW0gPSBzdHlsZWQuZGl2YFxuICBkaXNwbGF5OiBmbGV4O1xuICBnYXA6ICR7c3BhY2luZy5zbWFsbH07XG4gIGNvbG9yOiAke2NvbG9ycy53aGl0ZX07XG5gO1xuXG5jb25zdCBNb3ZpZVRleHRXcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgJHttcS5yYW5nZSh7IGZyb206IGJyZWFrcG9pbnRzLnRhYmxldCB9KX0ge1xuICAgIHBhZGRpbmc6ICR7c3BhY2luZy54c21hbGx9ICR7c3BhY2luZy54c21hbGx9IDAgMDtcbiAgfVxuICBmbGV4OiAxO1xuYDtcblxuY29uc3QgTW92aWVJbWFnZSA9IHN0eWxlZC5pbWdgXG4gIHdpZHRoOiAxMDRweDtcbiAgaGVpZ2h0OiA4MHB4O1xuICAke21xLnJhbmdlKHsgZnJvbTogYnJlYWtwb2ludHMudGFibGV0IH0pfSB7XG4gICAgd2lkdGg6ICR7SU1BR0VfV0lEVEh9cHg7XG4gICAgaGVpZ2h0OiA5MHB4O1xuICB9XG5gO1xuXG5jb25zdCBNb3ZpZVRpdGxlID0gc3R5bGVkLmgzYFxuICBjb2xvcjogJHtjb2xvcnMud2hpdGV9O1xuICBtYXJnaW46IDA7XG5gO1xuXG5jb25zdCBNb3ZpZURlc2NyaXB0aW9uID0gc3R5bGVkLnBgXG4gIGNvbG9yOiAke2NvbG9ycy5icmFuZC5ncmV5TGlnaHRlcn07XG4gIG1hcmdpbjogMDtcbiAgb3ZlcmZsb3c6IGhpZGRlbjtcbiAgdGV4dC1vdmVyZmxvdzogZWxsaXBzaXM7XG4gIGRpc3BsYXk6IC13ZWJraXQtYm94O1xuICAtd2Via2l0LWJveC1vcmllbnQ6IHZlcnRpY2FsO1xuICAtd2Via2l0LWxpbmUtY2xhbXA6IDI7XG5gO1xuXG5jb25zdCBTdHlsZWRTYWZlTGluayA9IHN0eWxlZChTYWZlTGluaylgXG4gIGJveC1zaGFkb3c6IG5vbmU7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGdhcDogJHtzcGFjaW5nLnNtYWxsfTtcbiAgJjpob3ZlcixcbiAgJjpmb2N1cyB7XG4gICAgJHtNb3ZpZVRpdGxlfSB7XG4gICAgICB0ZXh0LWRlY29yYXRpb246IHVuZGVybGluZTtcbiAgICB9XG4gICAgJHtNb3ZpZUltYWdlfSB7XG4gICAgICAmOmFmdGVyIHtcbiAgICAgICAgdHJhbnNpdGlvbjogb3BhY2l0eSAyMDBtcyBlYXNlO1xuICAgICAgICBkaXNwbGF5OiBibG9jaztcbiAgICAgICAgb3BhY2l0eTogMC4zO1xuICAgICAgfVxuICAgIH1cbiAgfVxuYDtcblxuaW50ZXJmYWNlIFByb3BzIHtcbiAgbW92aWVzOiBNb3ZpZVR5cGVbXTtcbn1cblxuY29uc3QgTW92aWVHcm91cCA9IHN0eWxlZC5zZWN0aW9uYFxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICBnYXA6ICR7c3BhY2luZy5ub3JtYWx9O1xuYDtcblxuY29uc3QgZ3JvdXBNb3ZpZXMgPSAobW92aWVzOiBNb3ZpZVR5cGVbXSkgPT4ge1xuICBjb25zdCBzb3J0ZWRNb3ZpZXMgPSBzb3J0QnkobW92aWVzLCAobSkgPT4gbS50aXRsZSk7XG4gIGNvbnN0IGdyb3VwZWQgPSBncm91cEJ5KHNvcnRlZE1vdmllcywgKG1vdmllKSA9PiB7XG4gICAgY29uc3QgZmlyc3RDaGFyID0gbW92aWUudGl0bGVbMF0/LnRvVXBwZXJDYXNlKCk7XG4gICAgY29uc3QgaXNMZXR0ZXIgPSBmaXJzdENoYXI/Lm1hdGNoKC9bQS1aXFxXw4bDmMOFXSsvKTtcbiAgICByZXR1cm4gaXNMZXR0ZXIgPyBmaXJzdENoYXIgOiAnIyc7XG4gIH0pO1xuICByZXR1cm4gT2JqZWN0LmVudHJpZXMoZ3JvdXBlZCkubWFwKChbbGV0dGVyLCBtb3ZpZXNdKSA9PiAoeyBsZXR0ZXIsIG1vdmllcyB9KSk7XG59O1xuXG5jb25zdCBBbGxNb3ZpZXNBbHBoYWJldGljYWxseSA9ICh7IG1vdmllcyB9OiBQcm9wcykgPT4ge1xuICBjb25zdCBncm91cGVkTW92aWVzID0gdXNlTWVtbygoKSA9PiBncm91cE1vdmllcyhtb3ZpZXMpLCBbbW92aWVzXSk7XG4gIGNvbnN0IHsgdCB9ID0gdXNlVHJhbnNsYXRpb24oKTtcbiAgLy8gU3BsaXQgaW50byBMZXR0ZXJzLlxuICBjb25zdCB3cmFwcGVyUmVmOiBSZWZPYmplY3Q8SFRNTEVsZW1lbnQ+ID0gdXNlUmVmKG51bGwpO1xuXG4gIHJldHVybiAoXG4gICAgPFN0eWxlZFdyYXBwZXIgcmVmPXt3cmFwcGVyUmVmfT5cbiAgICAgIHtncm91cGVkTW92aWVzLm1hcCgoeyBsZXR0ZXIsIG1vdmllcyB9KSA9PiAoXG4gICAgICAgIDxNb3ZpZUdyb3VwIGtleT17bGV0dGVyfT5cbiAgICAgICAgICA8TGV0dGVyIGFyaWEtbGFiZWw9e3QoJ2ZpbG1mcm9udHBhZ2UuYWxsTW92aWVHcm91cFRpdGxlTGFiZWwnLCB7IGxldHRlciB9KX0+e2xldHRlcn08L0xldHRlcj5cbiAgICAgICAgICB7bW92aWVzLm1hcCgobW92aWUpID0+IChcbiAgICAgICAgICAgIDxNb3ZpZUl0ZW0ga2V5PXttb3ZpZS5pZH0+XG4gICAgICAgICAgICAgIDxTdHlsZWRTYWZlTGluayB0bz17bW92aWUucGF0aH0+XG4gICAgICAgICAgICAgICAgPE1vdmllSW1hZ2VcbiAgICAgICAgICAgICAgICAgIHNyYz17XG4gICAgICAgICAgICAgICAgICAgIG1vdmllPy5tZXRhSW1hZ2U/LnVybCA/IGAke21vdmllLm1ldGFJbWFnZT8udXJsfT8ke21ha2VTcmNRdWVyeVN0cmluZyhJTUFHRV9XSURUSCAqIDIpfWAgOiB1bmRlZmluZWRcbiAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgICAgIDxNb3ZpZVRleHRXcmFwcGVyPlxuICAgICAgICAgICAgICAgICAgPE1vdmllVGl0bGU+e21vdmllLnRpdGxlfTwvTW92aWVUaXRsZT5cbiAgICAgICAgICAgICAgICAgIDxNb3ZpZURlc2NyaXB0aW9uPnttb3ZpZS5tZXRhRGVzY3JpcHRpb259PC9Nb3ZpZURlc2NyaXB0aW9uPlxuICAgICAgICAgICAgICAgIDwvTW92aWVUZXh0V3JhcHBlcj5cbiAgICAgICAgICAgICAgPC9TdHlsZWRTYWZlTGluaz5cbiAgICAgICAgICAgIDwvTW92aWVJdGVtPlxuICAgICAgICAgICkpfVxuICAgICAgICA8L01vdmllR3JvdXA+XG4gICAgICApKX1cbiAgICA8L1N0eWxlZFdyYXBwZXI+XG4gICk7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBBbGxNb3ZpZXNBbHBoYWJldGljYWxseTtcbiJdfQ== */"));
50
36
  var MovieItem = /*#__PURE__*/_styled("div", {
51
- target: "e1ul1xui5",
37
+ target: "e1ul1xui6",
52
38
  label: "MovieItem"
53
- })("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) {
54
- return props.inView && _ref2;
55
- }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["AllMoviesAlphabetically.tsx"],"names":[],"mappings":"AAiD4C","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, RefObject, useEffect, useRef, useState } from 'react';\nimport { isIE, browserVersion } from 'react-device-detect';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport throttle from 'lodash/throttle';\nimport { breakpoints, mq, spacing, spacingUnit, colors, fonts, animations } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\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 (let i = 0; i < this.length; i++) {\n        callback.call(thisArg, this[i], i, this);\n      }\n    };\n  }\n};\n\nconst AllMoviesAlphabetically = ({ movies, locale }: Props) => {\n  const isIE11 = isIE && parseInt(browserVersion) < 12;\n  // Split into Letters.\n  let previousLetter = '';\n  const wrapperRef: RefObject<HTMLElement> = 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"]} */"));
39
+ })("display:flex;gap:", spacing.small, ";color:", colors.white, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkFsbE1vdmllc0FscGhhYmV0aWNhbGx5LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF5QzRCIiwiZmlsZSI6IkFsbE1vdmllc0FscGhhYmV0aWNhbGx5LnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDE5LXByZXNlbnQsIE5ETEEuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgR1BMdjMgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqXG4gKi9cblxuaW1wb3J0IFJlYWN0LCB7IFJlZk9iamVjdCwgdXNlTWVtbywgdXNlUmVmIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgYnJlYWtwb2ludHMsIG1xLCBzcGFjaW5nLCBzcGFjaW5nVW5pdCwgY29sb3JzIH0gZnJvbSAnQG5kbGEvY29yZSc7XG5pbXBvcnQgU2FmZUxpbmsgZnJvbSAnQG5kbGEvc2FmZWxpbmsnO1xuaW1wb3J0IGdyb3VwQnkgZnJvbSAnbG9kYXNoL2dyb3VwQnknO1xuaW1wb3J0IHNvcnRCeSBmcm9tICdsb2Rhc2gvc29ydEJ5JztcbmltcG9ydCB7IHVzZVRyYW5zbGF0aW9uIH0gZnJvbSAncmVhY3QtaTE4bmV4dCc7XG5pbXBvcnQgeyBtYWtlU3JjUXVlcnlTdHJpbmcgfSBmcm9tICcuLi9JbWFnZSc7XG5pbXBvcnQgeyBNb3ZpZVR5cGUgfSBmcm9tICcuL3R5cGVzJztcblxuY29uc3QgSU1BR0VfV0lEVEggPSAxNDM7XG5cbmNvbnN0IExldHRlciA9IHN0eWxlZC5oMmBcbiAgY29sb3I6ICR7Y29sb3JzLndoaXRlfTtcbiAgJHttcS5yYW5nZSh7IGZyb206IGJyZWFrcG9pbnRzLnRhYmxldCB9KX0ge1xuICAgIHRleHQtaW5kZW50OiAke3NwYWNpbmdVbml0ICogMC43NX1weDtcbiAgfVxuICAmOmFmdGVyIHtcbiAgICBjb250ZW50OiAnJztcbiAgICBkaXNwbGF5OiBibG9jaztcbiAgICBoZWlnaHQ6IDFweDtcbiAgICBiYWNrZ3JvdW5kOiAke2NvbG9ycy5icmFuZC5ncmV5RGFya307XG4gICAgbWFyZ2luLXRvcDogJHtzcGFjaW5nLnNtYWxsfTtcbiAgfVxuYDtcblxuY29uc3QgU3R5bGVkV3JhcHBlciA9IHN0eWxlZC5zZWN0aW9uYFxuICB3aWR0aDogNjUycHg7XG4gIG1heC13aWR0aDogMTAwJTtcbiAgbWFyZ2luOiAke3NwYWNpbmcubGFyZ2V9IGF1dG87XG4gIHBhZGRpbmc6IDAgJHtzcGFjaW5nLm5vcm1hbH07XG5gO1xuXG5jb25zdCBNb3ZpZUl0ZW0gPSBzdHlsZWQuZGl2YFxuICBkaXNwbGF5OiBmbGV4O1xuICBnYXA6ICR7c3BhY2luZy5zbWFsbH07XG4gIGNvbG9yOiAke2NvbG9ycy53aGl0ZX07XG5gO1xuXG5jb25zdCBNb3ZpZVRleHRXcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgJHttcS5yYW5nZSh7IGZyb206IGJyZWFrcG9pbnRzLnRhYmxldCB9KX0ge1xuICAgIHBhZGRpbmc6ICR7c3BhY2luZy54c21hbGx9ICR7c3BhY2luZy54c21hbGx9IDAgMDtcbiAgfVxuICBmbGV4OiAxO1xuYDtcblxuY29uc3QgTW92aWVJbWFnZSA9IHN0eWxlZC5pbWdgXG4gIHdpZHRoOiAxMDRweDtcbiAgaGVpZ2h0OiA4MHB4O1xuICAke21xLnJhbmdlKHsgZnJvbTogYnJlYWtwb2ludHMudGFibGV0IH0pfSB7XG4gICAgd2lkdGg6ICR7SU1BR0VfV0lEVEh9cHg7XG4gICAgaGVpZ2h0OiA5MHB4O1xuICB9XG5gO1xuXG5jb25zdCBNb3ZpZVRpdGxlID0gc3R5bGVkLmgzYFxuICBjb2xvcjogJHtjb2xvcnMud2hpdGV9O1xuICBtYXJnaW46IDA7XG5gO1xuXG5jb25zdCBNb3ZpZURlc2NyaXB0aW9uID0gc3R5bGVkLnBgXG4gIGNvbG9yOiAke2NvbG9ycy5icmFuZC5ncmV5TGlnaHRlcn07XG4gIG1hcmdpbjogMDtcbiAgb3ZlcmZsb3c6IGhpZGRlbjtcbiAgdGV4dC1vdmVyZmxvdzogZWxsaXBzaXM7XG4gIGRpc3BsYXk6IC13ZWJraXQtYm94O1xuICAtd2Via2l0LWJveC1vcmllbnQ6IHZlcnRpY2FsO1xuICAtd2Via2l0LWxpbmUtY2xhbXA6IDI7XG5gO1xuXG5jb25zdCBTdHlsZWRTYWZlTGluayA9IHN0eWxlZChTYWZlTGluaylgXG4gIGJveC1zaGFkb3c6IG5vbmU7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGdhcDogJHtzcGFjaW5nLnNtYWxsfTtcbiAgJjpob3ZlcixcbiAgJjpmb2N1cyB7XG4gICAgJHtNb3ZpZVRpdGxlfSB7XG4gICAgICB0ZXh0LWRlY29yYXRpb246IHVuZGVybGluZTtcbiAgICB9XG4gICAgJHtNb3ZpZUltYWdlfSB7XG4gICAgICAmOmFmdGVyIHtcbiAgICAgICAgdHJhbnNpdGlvbjogb3BhY2l0eSAyMDBtcyBlYXNlO1xuICAgICAgICBkaXNwbGF5OiBibG9jaztcbiAgICAgICAgb3BhY2l0eTogMC4zO1xuICAgICAgfVxuICAgIH1cbiAgfVxuYDtcblxuaW50ZXJmYWNlIFByb3BzIHtcbiAgbW92aWVzOiBNb3ZpZVR5cGVbXTtcbn1cblxuY29uc3QgTW92aWVHcm91cCA9IHN0eWxlZC5zZWN0aW9uYFxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICBnYXA6ICR7c3BhY2luZy5ub3JtYWx9O1xuYDtcblxuY29uc3QgZ3JvdXBNb3ZpZXMgPSAobW92aWVzOiBNb3ZpZVR5cGVbXSkgPT4ge1xuICBjb25zdCBzb3J0ZWRNb3ZpZXMgPSBzb3J0QnkobW92aWVzLCAobSkgPT4gbS50aXRsZSk7XG4gIGNvbnN0IGdyb3VwZWQgPSBncm91cEJ5KHNvcnRlZE1vdmllcywgKG1vdmllKSA9PiB7XG4gICAgY29uc3QgZmlyc3RDaGFyID0gbW92aWUudGl0bGVbMF0/LnRvVXBwZXJDYXNlKCk7XG4gICAgY29uc3QgaXNMZXR0ZXIgPSBmaXJzdENoYXI/Lm1hdGNoKC9bQS1aXFxXw4bDmMOFXSsvKTtcbiAgICByZXR1cm4gaXNMZXR0ZXIgPyBmaXJzdENoYXIgOiAnIyc7XG4gIH0pO1xuICByZXR1cm4gT2JqZWN0LmVudHJpZXMoZ3JvdXBlZCkubWFwKChbbGV0dGVyLCBtb3ZpZXNdKSA9PiAoeyBsZXR0ZXIsIG1vdmllcyB9KSk7XG59O1xuXG5jb25zdCBBbGxNb3ZpZXNBbHBoYWJldGljYWxseSA9ICh7IG1vdmllcyB9OiBQcm9wcykgPT4ge1xuICBjb25zdCBncm91cGVkTW92aWVzID0gdXNlTWVtbygoKSA9PiBncm91cE1vdmllcyhtb3ZpZXMpLCBbbW92aWVzXSk7XG4gIGNvbnN0IHsgdCB9ID0gdXNlVHJhbnNsYXRpb24oKTtcbiAgLy8gU3BsaXQgaW50byBMZXR0ZXJzLlxuICBjb25zdCB3cmFwcGVyUmVmOiBSZWZPYmplY3Q8SFRNTEVsZW1lbnQ+ID0gdXNlUmVmKG51bGwpO1xuXG4gIHJldHVybiAoXG4gICAgPFN0eWxlZFdyYXBwZXIgcmVmPXt3cmFwcGVyUmVmfT5cbiAgICAgIHtncm91cGVkTW92aWVzLm1hcCgoeyBsZXR0ZXIsIG1vdmllcyB9KSA9PiAoXG4gICAgICAgIDxNb3ZpZUdyb3VwIGtleT17bGV0dGVyfT5cbiAgICAgICAgICA8TGV0dGVyIGFyaWEtbGFiZWw9e3QoJ2ZpbG1mcm9udHBhZ2UuYWxsTW92aWVHcm91cFRpdGxlTGFiZWwnLCB7IGxldHRlciB9KX0+e2xldHRlcn08L0xldHRlcj5cbiAgICAgICAgICB7bW92aWVzLm1hcCgobW92aWUpID0+IChcbiAgICAgICAgICAgIDxNb3ZpZUl0ZW0ga2V5PXttb3ZpZS5pZH0+XG4gICAgICAgICAgICAgIDxTdHlsZWRTYWZlTGluayB0bz17bW92aWUucGF0aH0+XG4gICAgICAgICAgICAgICAgPE1vdmllSW1hZ2VcbiAgICAgICAgICAgICAgICAgIHNyYz17XG4gICAgICAgICAgICAgICAgICAgIG1vdmllPy5tZXRhSW1hZ2U/LnVybCA/IGAke21vdmllLm1ldGFJbWFnZT8udXJsfT8ke21ha2VTcmNRdWVyeVN0cmluZyhJTUFHRV9XSURUSCAqIDIpfWAgOiB1bmRlZmluZWRcbiAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgICAgIDxNb3ZpZVRleHRXcmFwcGVyPlxuICAgICAgICAgICAgICAgICAgPE1vdmllVGl0bGU+e21vdmllLnRpdGxlfTwvTW92aWVUaXRsZT5cbiAgICAgICAgICAgICAgICAgIDxNb3ZpZURlc2NyaXB0aW9uPnttb3ZpZS5tZXRhRGVzY3JpcHRpb259PC9Nb3ZpZURlc2NyaXB0aW9uPlxuICAgICAgICAgICAgICAgIDwvTW92aWVUZXh0V3JhcHBlcj5cbiAgICAgICAgICAgICAgPC9TdHlsZWRTYWZlTGluaz5cbiAgICAgICAgICAgIDwvTW92aWVJdGVtPlxuICAgICAgICAgICkpfVxuICAgICAgICA8L01vdmllR3JvdXA+XG4gICAgICApKX1cbiAgICA8L1N0eWxlZFdyYXBwZXI+XG4gICk7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBBbGxNb3ZpZXNBbHBoYWJldGljYWxseTtcbiJdfQ== */"));
56
40
  var MovieTextWrapper = /*#__PURE__*/_styled("div", {
57
- target: "e1ul1xui4",
41
+ target: "e1ul1xui5",
58
42
  label: "MovieTextWrapper"
59
43
  })(mq.range({
60
44
  from: breakpoints.tablet
61
- }), "{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":"AAkEmC","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, RefObject, useEffect, useRef, useState } from 'react';\nimport { isIE, browserVersion } from 'react-device-detect';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport throttle from 'lodash/throttle';\nimport { breakpoints, mq, spacing, spacingUnit, colors, fonts, animations } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\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 (let i = 0; i < this.length; i++) {\n        callback.call(thisArg, this[i], i, this);\n      }\n    };\n  }\n};\n\nconst AllMoviesAlphabetically = ({ movies, locale }: Props) => {\n  const isIE11 = isIE && parseInt(browserVersion) < 12;\n  // Split into Letters.\n  let previousLetter = '';\n  const wrapperRef: RefObject<HTMLElement> = 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"]} */"));
62
- var MovieImage = /*#__PURE__*/_styled("div", {
63
- target: "e1ul1xui3",
45
+ }), "{padding:", spacing.xsmall, " ", spacing.xsmall, " 0 0;}flex:1;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkFsbE1vdmllc0FscGhhYmV0aWNhbGx5LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUErQ21DIiwiZmlsZSI6IkFsbE1vdmllc0FscGhhYmV0aWNhbGx5LnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDE5LXByZXNlbnQsIE5ETEEuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgR1BMdjMgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqXG4gKi9cblxuaW1wb3J0IFJlYWN0LCB7IFJlZk9iamVjdCwgdXNlTWVtbywgdXNlUmVmIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgYnJlYWtwb2ludHMsIG1xLCBzcGFjaW5nLCBzcGFjaW5nVW5pdCwgY29sb3JzIH0gZnJvbSAnQG5kbGEvY29yZSc7XG5pbXBvcnQgU2FmZUxpbmsgZnJvbSAnQG5kbGEvc2FmZWxpbmsnO1xuaW1wb3J0IGdyb3VwQnkgZnJvbSAnbG9kYXNoL2dyb3VwQnknO1xuaW1wb3J0IHNvcnRCeSBmcm9tICdsb2Rhc2gvc29ydEJ5JztcbmltcG9ydCB7IHVzZVRyYW5zbGF0aW9uIH0gZnJvbSAncmVhY3QtaTE4bmV4dCc7XG5pbXBvcnQgeyBtYWtlU3JjUXVlcnlTdHJpbmcgfSBmcm9tICcuLi9JbWFnZSc7XG5pbXBvcnQgeyBNb3ZpZVR5cGUgfSBmcm9tICcuL3R5cGVzJztcblxuY29uc3QgSU1BR0VfV0lEVEggPSAxNDM7XG5cbmNvbnN0IExldHRlciA9IHN0eWxlZC5oMmBcbiAgY29sb3I6ICR7Y29sb3JzLndoaXRlfTtcbiAgJHttcS5yYW5nZSh7IGZyb206IGJyZWFrcG9pbnRzLnRhYmxldCB9KX0ge1xuICAgIHRleHQtaW5kZW50OiAke3NwYWNpbmdVbml0ICogMC43NX1weDtcbiAgfVxuICAmOmFmdGVyIHtcbiAgICBjb250ZW50OiAnJztcbiAgICBkaXNwbGF5OiBibG9jaztcbiAgICBoZWlnaHQ6IDFweDtcbiAgICBiYWNrZ3JvdW5kOiAke2NvbG9ycy5icmFuZC5ncmV5RGFya307XG4gICAgbWFyZ2luLXRvcDogJHtzcGFjaW5nLnNtYWxsfTtcbiAgfVxuYDtcblxuY29uc3QgU3R5bGVkV3JhcHBlciA9IHN0eWxlZC5zZWN0aW9uYFxuICB3aWR0aDogNjUycHg7XG4gIG1heC13aWR0aDogMTAwJTtcbiAgbWFyZ2luOiAke3NwYWNpbmcubGFyZ2V9IGF1dG87XG4gIHBhZGRpbmc6IDAgJHtzcGFjaW5nLm5vcm1hbH07XG5gO1xuXG5jb25zdCBNb3ZpZUl0ZW0gPSBzdHlsZWQuZGl2YFxuICBkaXNwbGF5OiBmbGV4O1xuICBnYXA6ICR7c3BhY2luZy5zbWFsbH07XG4gIGNvbG9yOiAke2NvbG9ycy53aGl0ZX07XG5gO1xuXG5jb25zdCBNb3ZpZVRleHRXcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgJHttcS5yYW5nZSh7IGZyb206IGJyZWFrcG9pbnRzLnRhYmxldCB9KX0ge1xuICAgIHBhZGRpbmc6ICR7c3BhY2luZy54c21hbGx9ICR7c3BhY2luZy54c21hbGx9IDAgMDtcbiAgfVxuICBmbGV4OiAxO1xuYDtcblxuY29uc3QgTW92aWVJbWFnZSA9IHN0eWxlZC5pbWdgXG4gIHdpZHRoOiAxMDRweDtcbiAgaGVpZ2h0OiA4MHB4O1xuICAke21xLnJhbmdlKHsgZnJvbTogYnJlYWtwb2ludHMudGFibGV0IH0pfSB7XG4gICAgd2lkdGg6ICR7SU1BR0VfV0lEVEh9cHg7XG4gICAgaGVpZ2h0OiA5MHB4O1xuICB9XG5gO1xuXG5jb25zdCBNb3ZpZVRpdGxlID0gc3R5bGVkLmgzYFxuICBjb2xvcjogJHtjb2xvcnMud2hpdGV9O1xuICBtYXJnaW46IDA7XG5gO1xuXG5jb25zdCBNb3ZpZURlc2NyaXB0aW9uID0gc3R5bGVkLnBgXG4gIGNvbG9yOiAke2NvbG9ycy5icmFuZC5ncmV5TGlnaHRlcn07XG4gIG1hcmdpbjogMDtcbiAgb3ZlcmZsb3c6IGhpZGRlbjtcbiAgdGV4dC1vdmVyZmxvdzogZWxsaXBzaXM7XG4gIGRpc3BsYXk6IC13ZWJraXQtYm94O1xuICAtd2Via2l0LWJveC1vcmllbnQ6IHZlcnRpY2FsO1xuICAtd2Via2l0LWxpbmUtY2xhbXA6IDI7XG5gO1xuXG5jb25zdCBTdHlsZWRTYWZlTGluayA9IHN0eWxlZChTYWZlTGluaylgXG4gIGJveC1zaGFkb3c6IG5vbmU7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGdhcDogJHtzcGFjaW5nLnNtYWxsfTtcbiAgJjpob3ZlcixcbiAgJjpmb2N1cyB7XG4gICAgJHtNb3ZpZVRpdGxlfSB7XG4gICAgICB0ZXh0LWRlY29yYXRpb246IHVuZGVybGluZTtcbiAgICB9XG4gICAgJHtNb3ZpZUltYWdlfSB7XG4gICAgICAmOmFmdGVyIHtcbiAgICAgICAgdHJhbnNpdGlvbjogb3BhY2l0eSAyMDBtcyBlYXNlO1xuICAgICAgICBkaXNwbGF5OiBibG9jaztcbiAgICAgICAgb3BhY2l0eTogMC4zO1xuICAgICAgfVxuICAgIH1cbiAgfVxuYDtcblxuaW50ZXJmYWNlIFByb3BzIHtcbiAgbW92aWVzOiBNb3ZpZVR5cGVbXTtcbn1cblxuY29uc3QgTW92aWVHcm91cCA9IHN0eWxlZC5zZWN0aW9uYFxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICBnYXA6ICR7c3BhY2luZy5ub3JtYWx9O1xuYDtcblxuY29uc3QgZ3JvdXBNb3ZpZXMgPSAobW92aWVzOiBNb3ZpZVR5cGVbXSkgPT4ge1xuICBjb25zdCBzb3J0ZWRNb3ZpZXMgPSBzb3J0QnkobW92aWVzLCAobSkgPT4gbS50aXRsZSk7XG4gIGNvbnN0IGdyb3VwZWQgPSBncm91cEJ5KHNvcnRlZE1vdmllcywgKG1vdmllKSA9PiB7XG4gICAgY29uc3QgZmlyc3RDaGFyID0gbW92aWUudGl0bGVbMF0/LnRvVXBwZXJDYXNlKCk7XG4gICAgY29uc3QgaXNMZXR0ZXIgPSBmaXJzdENoYXI/Lm1hdGNoKC9bQS1aXFxXw4bDmMOFXSsvKTtcbiAgICByZXR1cm4gaXNMZXR0ZXIgPyBmaXJzdENoYXIgOiAnIyc7XG4gIH0pO1xuICByZXR1cm4gT2JqZWN0LmVudHJpZXMoZ3JvdXBlZCkubWFwKChbbGV0dGVyLCBtb3ZpZXNdKSA9PiAoeyBsZXR0ZXIsIG1vdmllcyB9KSk7XG59O1xuXG5jb25zdCBBbGxNb3ZpZXNBbHBoYWJldGljYWxseSA9ICh7IG1vdmllcyB9OiBQcm9wcykgPT4ge1xuICBjb25zdCBncm91cGVkTW92aWVzID0gdXNlTWVtbygoKSA9PiBncm91cE1vdmllcyhtb3ZpZXMpLCBbbW92aWVzXSk7XG4gIGNvbnN0IHsgdCB9ID0gdXNlVHJhbnNsYXRpb24oKTtcbiAgLy8gU3BsaXQgaW50byBMZXR0ZXJzLlxuICBjb25zdCB3cmFwcGVyUmVmOiBSZWZPYmplY3Q8SFRNTEVsZW1lbnQ+ID0gdXNlUmVmKG51bGwpO1xuXG4gIHJldHVybiAoXG4gICAgPFN0eWxlZFdyYXBwZXIgcmVmPXt3cmFwcGVyUmVmfT5cbiAgICAgIHtncm91cGVkTW92aWVzLm1hcCgoeyBsZXR0ZXIsIG1vdmllcyB9KSA9PiAoXG4gICAgICAgIDxNb3ZpZUdyb3VwIGtleT17bGV0dGVyfT5cbiAgICAgICAgICA8TGV0dGVyIGFyaWEtbGFiZWw9e3QoJ2ZpbG1mcm9udHBhZ2UuYWxsTW92aWVHcm91cFRpdGxlTGFiZWwnLCB7IGxldHRlciB9KX0+e2xldHRlcn08L0xldHRlcj5cbiAgICAgICAgICB7bW92aWVzLm1hcCgobW92aWUpID0+IChcbiAgICAgICAgICAgIDxNb3ZpZUl0ZW0ga2V5PXttb3ZpZS5pZH0+XG4gICAgICAgICAgICAgIDxTdHlsZWRTYWZlTGluayB0bz17bW92aWUucGF0aH0+XG4gICAgICAgICAgICAgICAgPE1vdmllSW1hZ2VcbiAgICAgICAgICAgICAgICAgIHNyYz17XG4gICAgICAgICAgICAgICAgICAgIG1vdmllPy5tZXRhSW1hZ2U/LnVybCA/IGAke21vdmllLm1ldGFJbWFnZT8udXJsfT8ke21ha2VTcmNRdWVyeVN0cmluZyhJTUFHRV9XSURUSCAqIDIpfWAgOiB1bmRlZmluZWRcbiAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgICAgIDxNb3ZpZVRleHRXcmFwcGVyPlxuICAgICAgICAgICAgICAgICAgPE1vdmllVGl0bGU+e21vdmllLnRpdGxlfTwvTW92aWVUaXRsZT5cbiAgICAgICAgICAgICAgICAgIDxNb3ZpZURlc2NyaXB0aW9uPnttb3ZpZS5tZXRhRGVzY3JpcHRpb259PC9Nb3ZpZURlc2NyaXB0aW9uPlxuICAgICAgICAgICAgICAgIDwvTW92aWVUZXh0V3JhcHBlcj5cbiAgICAgICAgICAgICAgPC9TdHlsZWRTYWZlTGluaz5cbiAgICAgICAgICAgIDwvTW92aWVJdGVtPlxuICAgICAgICAgICkpfVxuICAgICAgICA8L01vdmllR3JvdXA+XG4gICAgICApKX1cbiAgICA8L1N0eWxlZFdyYXBwZXI+XG4gICk7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBBbGxNb3ZpZXNBbHBoYWJldGljYWxseTtcbiJdfQ== */"));
46
+ var MovieImage = /*#__PURE__*/_styled("img", {
47
+ target: "e1ul1xui4",
64
48
  label: "MovieImage"
65
- })("width:104px;height:80px;background-color:", colors.ndlaFilm.filmColorLight, ";", function (props) {
66
- 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":"AAmFO","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, RefObject, useEffect, useRef, useState } from 'react';\nimport { isIE, browserVersion } from 'react-device-detect';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport throttle from 'lodash/throttle';\nimport { breakpoints, mq, spacing, spacingUnit, colors, fonts, animations } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\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 (let i = 0; i < this.length; i++) {\n        callback.call(thisArg, this[i], i, this);\n      }\n    };\n  }\n};\n\nconst AllMoviesAlphabetically = ({ movies, locale }: Props) => {\n  const isIE11 = isIE && parseInt(browserVersion) < 12;\n  // Split into Letters.\n  let previousLetter = '';\n  const wrapperRef: RefObject<HTMLElement> = 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"]} */"));
67
- }, " background-size:cover;background-position:center center;margin:0 ", spacingUnit * 0.75, "px 0 0;", mq.range({
49
+ })("width:104px;height:80px;", mq.range({
68
50
  from: breakpoints.tablet
69
- }), "{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":"AA6E6C","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, RefObject, useEffect, useRef, useState } from 'react';\nimport { isIE, browserVersion } from 'react-device-detect';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport throttle from 'lodash/throttle';\nimport { breakpoints, mq, spacing, spacingUnit, colors, fonts, animations } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\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 (let i = 0; i < this.length; i++) {\n        callback.call(thisArg, this[i], i, this);\n      }\n    };\n  }\n};\n\nconst AllMoviesAlphabetically = ({ movies, locale }: Props) => {\n  const isIE11 = isIE && parseInt(browserVersion) < 12;\n  // Split into Letters.\n  let previousLetter = '';\n  const wrapperRef: RefObject<HTMLElement> = 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"]} */"));
51
+ }), "{width:", IMAGE_WIDTH, "px;height:90px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkFsbE1vdmllc0FscGhhYmV0aWNhbGx5LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFzRDZCIiwiZmlsZSI6IkFsbE1vdmllc0FscGhhYmV0aWNhbGx5LnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDE5LXByZXNlbnQsIE5ETEEuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgR1BMdjMgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqXG4gKi9cblxuaW1wb3J0IFJlYWN0LCB7IFJlZk9iamVjdCwgdXNlTWVtbywgdXNlUmVmIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgYnJlYWtwb2ludHMsIG1xLCBzcGFjaW5nLCBzcGFjaW5nVW5pdCwgY29sb3JzIH0gZnJvbSAnQG5kbGEvY29yZSc7XG5pbXBvcnQgU2FmZUxpbmsgZnJvbSAnQG5kbGEvc2FmZWxpbmsnO1xuaW1wb3J0IGdyb3VwQnkgZnJvbSAnbG9kYXNoL2dyb3VwQnknO1xuaW1wb3J0IHNvcnRCeSBmcm9tICdsb2Rhc2gvc29ydEJ5JztcbmltcG9ydCB7IHVzZVRyYW5zbGF0aW9uIH0gZnJvbSAncmVhY3QtaTE4bmV4dCc7XG5pbXBvcnQgeyBtYWtlU3JjUXVlcnlTdHJpbmcgfSBmcm9tICcuLi9JbWFnZSc7XG5pbXBvcnQgeyBNb3ZpZVR5cGUgfSBmcm9tICcuL3R5cGVzJztcblxuY29uc3QgSU1BR0VfV0lEVEggPSAxNDM7XG5cbmNvbnN0IExldHRlciA9IHN0eWxlZC5oMmBcbiAgY29sb3I6ICR7Y29sb3JzLndoaXRlfTtcbiAgJHttcS5yYW5nZSh7IGZyb206IGJyZWFrcG9pbnRzLnRhYmxldCB9KX0ge1xuICAgIHRleHQtaW5kZW50OiAke3NwYWNpbmdVbml0ICogMC43NX1weDtcbiAgfVxuICAmOmFmdGVyIHtcbiAgICBjb250ZW50OiAnJztcbiAgICBkaXNwbGF5OiBibG9jaztcbiAgICBoZWlnaHQ6IDFweDtcbiAgICBiYWNrZ3JvdW5kOiAke2NvbG9ycy5icmFuZC5ncmV5RGFya307XG4gICAgbWFyZ2luLXRvcDogJHtzcGFjaW5nLnNtYWxsfTtcbiAgfVxuYDtcblxuY29uc3QgU3R5bGVkV3JhcHBlciA9IHN0eWxlZC5zZWN0aW9uYFxuICB3aWR0aDogNjUycHg7XG4gIG1heC13aWR0aDogMTAwJTtcbiAgbWFyZ2luOiAke3NwYWNpbmcubGFyZ2V9IGF1dG87XG4gIHBhZGRpbmc6IDAgJHtzcGFjaW5nLm5vcm1hbH07XG5gO1xuXG5jb25zdCBNb3ZpZUl0ZW0gPSBzdHlsZWQuZGl2YFxuICBkaXNwbGF5OiBmbGV4O1xuICBnYXA6ICR7c3BhY2luZy5zbWFsbH07XG4gIGNvbG9yOiAke2NvbG9ycy53aGl0ZX07XG5gO1xuXG5jb25zdCBNb3ZpZVRleHRXcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgJHttcS5yYW5nZSh7IGZyb206IGJyZWFrcG9pbnRzLnRhYmxldCB9KX0ge1xuICAgIHBhZGRpbmc6ICR7c3BhY2luZy54c21hbGx9ICR7c3BhY2luZy54c21hbGx9IDAgMDtcbiAgfVxuICBmbGV4OiAxO1xuYDtcblxuY29uc3QgTW92aWVJbWFnZSA9IHN0eWxlZC5pbWdgXG4gIHdpZHRoOiAxMDRweDtcbiAgaGVpZ2h0OiA4MHB4O1xuICAke21xLnJhbmdlKHsgZnJvbTogYnJlYWtwb2ludHMudGFibGV0IH0pfSB7XG4gICAgd2lkdGg6ICR7SU1BR0VfV0lEVEh9cHg7XG4gICAgaGVpZ2h0OiA5MHB4O1xuICB9XG5gO1xuXG5jb25zdCBNb3ZpZVRpdGxlID0gc3R5bGVkLmgzYFxuICBjb2xvcjogJHtjb2xvcnMud2hpdGV9O1xuICBtYXJnaW46IDA7XG5gO1xuXG5jb25zdCBNb3ZpZURlc2NyaXB0aW9uID0gc3R5bGVkLnBgXG4gIGNvbG9yOiAke2NvbG9ycy5icmFuZC5ncmV5TGlnaHRlcn07XG4gIG1hcmdpbjogMDtcbiAgb3ZlcmZsb3c6IGhpZGRlbjtcbiAgdGV4dC1vdmVyZmxvdzogZWxsaXBzaXM7XG4gIGRpc3BsYXk6IC13ZWJraXQtYm94O1xuICAtd2Via2l0LWJveC1vcmllbnQ6IHZlcnRpY2FsO1xuICAtd2Via2l0LWxpbmUtY2xhbXA6IDI7XG5gO1xuXG5jb25zdCBTdHlsZWRTYWZlTGluayA9IHN0eWxlZChTYWZlTGluaylgXG4gIGJveC1zaGFkb3c6IG5vbmU7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGdhcDogJHtzcGFjaW5nLnNtYWxsfTtcbiAgJjpob3ZlcixcbiAgJjpmb2N1cyB7XG4gICAgJHtNb3ZpZVRpdGxlfSB7XG4gICAgICB0ZXh0LWRlY29yYXRpb246IHVuZGVybGluZTtcbiAgICB9XG4gICAgJHtNb3ZpZUltYWdlfSB7XG4gICAgICAmOmFmdGVyIHtcbiAgICAgICAgdHJhbnNpdGlvbjogb3BhY2l0eSAyMDBtcyBlYXNlO1xuICAgICAgICBkaXNwbGF5OiBibG9jaztcbiAgICAgICAgb3BhY2l0eTogMC4zO1xuICAgICAgfVxuICAgIH1cbiAgfVxuYDtcblxuaW50ZXJmYWNlIFByb3BzIHtcbiAgbW92aWVzOiBNb3ZpZVR5cGVbXTtcbn1cblxuY29uc3QgTW92aWVHcm91cCA9IHN0eWxlZC5zZWN0aW9uYFxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICBnYXA6ICR7c3BhY2luZy5ub3JtYWx9O1xuYDtcblxuY29uc3QgZ3JvdXBNb3ZpZXMgPSAobW92aWVzOiBNb3ZpZVR5cGVbXSkgPT4ge1xuICBjb25zdCBzb3J0ZWRNb3ZpZXMgPSBzb3J0QnkobW92aWVzLCAobSkgPT4gbS50aXRsZSk7XG4gIGNvbnN0IGdyb3VwZWQgPSBncm91cEJ5KHNvcnRlZE1vdmllcywgKG1vdmllKSA9PiB7XG4gICAgY29uc3QgZmlyc3RDaGFyID0gbW92aWUudGl0bGVbMF0/LnRvVXBwZXJDYXNlKCk7XG4gICAgY29uc3QgaXNMZXR0ZXIgPSBmaXJzdENoYXI/Lm1hdGNoKC9bQS1aXFxXw4bDmMOFXSsvKTtcbiAgICByZXR1cm4gaXNMZXR0ZXIgPyBmaXJzdENoYXIgOiAnIyc7XG4gIH0pO1xuICByZXR1cm4gT2JqZWN0LmVudHJpZXMoZ3JvdXBlZCkubWFwKChbbGV0dGVyLCBtb3ZpZXNdKSA9PiAoeyBsZXR0ZXIsIG1vdmllcyB9KSk7XG59O1xuXG5jb25zdCBBbGxNb3ZpZXNBbHBoYWJldGljYWxseSA9ICh7IG1vdmllcyB9OiBQcm9wcykgPT4ge1xuICBjb25zdCBncm91cGVkTW92aWVzID0gdXNlTWVtbygoKSA9PiBncm91cE1vdmllcyhtb3ZpZXMpLCBbbW92aWVzXSk7XG4gIGNvbnN0IHsgdCB9ID0gdXNlVHJhbnNsYXRpb24oKTtcbiAgLy8gU3BsaXQgaW50byBMZXR0ZXJzLlxuICBjb25zdCB3cmFwcGVyUmVmOiBSZWZPYmplY3Q8SFRNTEVsZW1lbnQ+ID0gdXNlUmVmKG51bGwpO1xuXG4gIHJldHVybiAoXG4gICAgPFN0eWxlZFdyYXBwZXIgcmVmPXt3cmFwcGVyUmVmfT5cbiAgICAgIHtncm91cGVkTW92aWVzLm1hcCgoeyBsZXR0ZXIsIG1vdmllcyB9KSA9PiAoXG4gICAgICAgIDxNb3ZpZUdyb3VwIGtleT17bGV0dGVyfT5cbiAgICAgICAgICA8TGV0dGVyIGFyaWEtbGFiZWw9e3QoJ2ZpbG1mcm9udHBhZ2UuYWxsTW92aWVHcm91cFRpdGxlTGFiZWwnLCB7IGxldHRlciB9KX0+e2xldHRlcn08L0xldHRlcj5cbiAgICAgICAgICB7bW92aWVzLm1hcCgobW92aWUpID0+IChcbiAgICAgICAgICAgIDxNb3ZpZUl0ZW0ga2V5PXttb3ZpZS5pZH0+XG4gICAgICAgICAgICAgIDxTdHlsZWRTYWZlTGluayB0bz17bW92aWUucGF0aH0+XG4gICAgICAgICAgICAgICAgPE1vdmllSW1hZ2VcbiAgICAgICAgICAgICAgICAgIHNyYz17XG4gICAgICAgICAgICAgICAgICAgIG1vdmllPy5tZXRhSW1hZ2U/LnVybCA/IGAke21vdmllLm1ldGFJbWFnZT8udXJsfT8ke21ha2VTcmNRdWVyeVN0cmluZyhJTUFHRV9XSURUSCAqIDIpfWAgOiB1bmRlZmluZWRcbiAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgICAgIDxNb3ZpZVRleHRXcmFwcGVyPlxuICAgICAgICAgICAgICAgICAgPE1vdmllVGl0bGU+e21vdmllLnRpdGxlfTwvTW92aWVUaXRsZT5cbiAgICAgICAgICAgICAgICAgIDxNb3ZpZURlc2NyaXB0aW9uPnttb3ZpZS5tZXRhRGVzY3JpcHRpb259PC9Nb3ZpZURlc2NyaXB0aW9uPlxuICAgICAgICAgICAgICAgIDwvTW92aWVUZXh0V3JhcHBlcj5cbiAgICAgICAgICAgICAgPC9TdHlsZWRTYWZlTGluaz5cbiAgICAgICAgICAgIDwvTW92aWVJdGVtPlxuICAgICAgICAgICkpfVxuICAgICAgICA8L01vdmllR3JvdXA+XG4gICAgICApKX1cbiAgICA8L1N0eWxlZFdyYXBwZXI+XG4gICk7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBBbGxNb3ZpZXNBbHBoYWJldGljYWxseTtcbiJdfQ== */"));
70
52
  var MovieTitle = /*#__PURE__*/_styled("h3", {
71
- target: "e1ul1xui2",
53
+ target: "e1ul1xui3",
72
54
  label: "MovieTitle"
73
- })("color:#fff;margin:0 0 2px;", fonts.sizes(18, 1.3), ";", mq.range({
74
- from: breakpoints.tablet
75
- }), "{", 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":"AA4G4B","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, RefObject, useEffect, useRef, useState } from 'react';\nimport { isIE, browserVersion } from 'react-device-detect';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport throttle from 'lodash/throttle';\nimport { breakpoints, mq, spacing, spacingUnit, colors, fonts, animations } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\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 (let i = 0; i < this.length; i++) {\n        callback.call(thisArg, this[i], i, this);\n      }\n    };\n  }\n};\n\nconst AllMoviesAlphabetically = ({ movies, locale }: Props) => {\n  const isIE11 = isIE && parseInt(browserVersion) < 12;\n  // Split into Letters.\n  let previousLetter = '';\n  const wrapperRef: RefObject<HTMLElement> = 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"]} */"));
55
+ })("color:", colors.white, ";margin:0;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkFsbE1vdmllc0FscGhhYmV0aWNhbGx5LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUErRDRCIiwiZmlsZSI6IkFsbE1vdmllc0FscGhhYmV0aWNhbGx5LnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDE5LXByZXNlbnQsIE5ETEEuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgR1BMdjMgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqXG4gKi9cblxuaW1wb3J0IFJlYWN0LCB7IFJlZk9iamVjdCwgdXNlTWVtbywgdXNlUmVmIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgYnJlYWtwb2ludHMsIG1xLCBzcGFjaW5nLCBzcGFjaW5nVW5pdCwgY29sb3JzIH0gZnJvbSAnQG5kbGEvY29yZSc7XG5pbXBvcnQgU2FmZUxpbmsgZnJvbSAnQG5kbGEvc2FmZWxpbmsnO1xuaW1wb3J0IGdyb3VwQnkgZnJvbSAnbG9kYXNoL2dyb3VwQnknO1xuaW1wb3J0IHNvcnRCeSBmcm9tICdsb2Rhc2gvc29ydEJ5JztcbmltcG9ydCB7IHVzZVRyYW5zbGF0aW9uIH0gZnJvbSAncmVhY3QtaTE4bmV4dCc7XG5pbXBvcnQgeyBtYWtlU3JjUXVlcnlTdHJpbmcgfSBmcm9tICcuLi9JbWFnZSc7XG5pbXBvcnQgeyBNb3ZpZVR5cGUgfSBmcm9tICcuL3R5cGVzJztcblxuY29uc3QgSU1BR0VfV0lEVEggPSAxNDM7XG5cbmNvbnN0IExldHRlciA9IHN0eWxlZC5oMmBcbiAgY29sb3I6ICR7Y29sb3JzLndoaXRlfTtcbiAgJHttcS5yYW5nZSh7IGZyb206IGJyZWFrcG9pbnRzLnRhYmxldCB9KX0ge1xuICAgIHRleHQtaW5kZW50OiAke3NwYWNpbmdVbml0ICogMC43NX1weDtcbiAgfVxuICAmOmFmdGVyIHtcbiAgICBjb250ZW50OiAnJztcbiAgICBkaXNwbGF5OiBibG9jaztcbiAgICBoZWlnaHQ6IDFweDtcbiAgICBiYWNrZ3JvdW5kOiAke2NvbG9ycy5icmFuZC5ncmV5RGFya307XG4gICAgbWFyZ2luLXRvcDogJHtzcGFjaW5nLnNtYWxsfTtcbiAgfVxuYDtcblxuY29uc3QgU3R5bGVkV3JhcHBlciA9IHN0eWxlZC5zZWN0aW9uYFxuICB3aWR0aDogNjUycHg7XG4gIG1heC13aWR0aDogMTAwJTtcbiAgbWFyZ2luOiAke3NwYWNpbmcubGFyZ2V9IGF1dG87XG4gIHBhZGRpbmc6IDAgJHtzcGFjaW5nLm5vcm1hbH07XG5gO1xuXG5jb25zdCBNb3ZpZUl0ZW0gPSBzdHlsZWQuZGl2YFxuICBkaXNwbGF5OiBmbGV4O1xuICBnYXA6ICR7c3BhY2luZy5zbWFsbH07XG4gIGNvbG9yOiAke2NvbG9ycy53aGl0ZX07XG5gO1xuXG5jb25zdCBNb3ZpZVRleHRXcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgJHttcS5yYW5nZSh7IGZyb206IGJyZWFrcG9pbnRzLnRhYmxldCB9KX0ge1xuICAgIHBhZGRpbmc6ICR7c3BhY2luZy54c21hbGx9ICR7c3BhY2luZy54c21hbGx9IDAgMDtcbiAgfVxuICBmbGV4OiAxO1xuYDtcblxuY29uc3QgTW92aWVJbWFnZSA9IHN0eWxlZC5pbWdgXG4gIHdpZHRoOiAxMDRweDtcbiAgaGVpZ2h0OiA4MHB4O1xuICAke21xLnJhbmdlKHsgZnJvbTogYnJlYWtwb2ludHMudGFibGV0IH0pfSB7XG4gICAgd2lkdGg6ICR7SU1BR0VfV0lEVEh9cHg7XG4gICAgaGVpZ2h0OiA5MHB4O1xuICB9XG5gO1xuXG5jb25zdCBNb3ZpZVRpdGxlID0gc3R5bGVkLmgzYFxuICBjb2xvcjogJHtjb2xvcnMud2hpdGV9O1xuICBtYXJnaW46IDA7XG5gO1xuXG5jb25zdCBNb3ZpZURlc2NyaXB0aW9uID0gc3R5bGVkLnBgXG4gIGNvbG9yOiAke2NvbG9ycy5icmFuZC5ncmV5TGlnaHRlcn07XG4gIG1hcmdpbjogMDtcbiAgb3ZlcmZsb3c6IGhpZGRlbjtcbiAgdGV4dC1vdmVyZmxvdzogZWxsaXBzaXM7XG4gIGRpc3BsYXk6IC13ZWJraXQtYm94O1xuICAtd2Via2l0LWJveC1vcmllbnQ6IHZlcnRpY2FsO1xuICAtd2Via2l0LWxpbmUtY2xhbXA6IDI7XG5gO1xuXG5jb25zdCBTdHlsZWRTYWZlTGluayA9IHN0eWxlZChTYWZlTGluaylgXG4gIGJveC1zaGFkb3c6IG5vbmU7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGdhcDogJHtzcGFjaW5nLnNtYWxsfTtcbiAgJjpob3ZlcixcbiAgJjpmb2N1cyB7XG4gICAgJHtNb3ZpZVRpdGxlfSB7XG4gICAgICB0ZXh0LWRlY29yYXRpb246IHVuZGVybGluZTtcbiAgICB9XG4gICAgJHtNb3ZpZUltYWdlfSB7XG4gICAgICAmOmFmdGVyIHtcbiAgICAgICAgdHJhbnNpdGlvbjogb3BhY2l0eSAyMDBtcyBlYXNlO1xuICAgICAgICBkaXNwbGF5OiBibG9jaztcbiAgICAgICAgb3BhY2l0eTogMC4zO1xuICAgICAgfVxuICAgIH1cbiAgfVxuYDtcblxuaW50ZXJmYWNlIFByb3BzIHtcbiAgbW92aWVzOiBNb3ZpZVR5cGVbXTtcbn1cblxuY29uc3QgTW92aWVHcm91cCA9IHN0eWxlZC5zZWN0aW9uYFxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICBnYXA6ICR7c3BhY2luZy5ub3JtYWx9O1xuYDtcblxuY29uc3QgZ3JvdXBNb3ZpZXMgPSAobW92aWVzOiBNb3ZpZVR5cGVbXSkgPT4ge1xuICBjb25zdCBzb3J0ZWRNb3ZpZXMgPSBzb3J0QnkobW92aWVzLCAobSkgPT4gbS50aXRsZSk7XG4gIGNvbnN0IGdyb3VwZWQgPSBncm91cEJ5KHNvcnRlZE1vdmllcywgKG1vdmllKSA9PiB7XG4gICAgY29uc3QgZmlyc3RDaGFyID0gbW92aWUudGl0bGVbMF0/LnRvVXBwZXJDYXNlKCk7XG4gICAgY29uc3QgaXNMZXR0ZXIgPSBmaXJzdENoYXI/Lm1hdGNoKC9bQS1aXFxXw4bDmMOFXSsvKTtcbiAgICByZXR1cm4gaXNMZXR0ZXIgPyBmaXJzdENoYXIgOiAnIyc7XG4gIH0pO1xuICByZXR1cm4gT2JqZWN0LmVudHJpZXMoZ3JvdXBlZCkubWFwKChbbGV0dGVyLCBtb3ZpZXNdKSA9PiAoeyBsZXR0ZXIsIG1vdmllcyB9KSk7XG59O1xuXG5jb25zdCBBbGxNb3ZpZXNBbHBoYWJldGljYWxseSA9ICh7IG1vdmllcyB9OiBQcm9wcykgPT4ge1xuICBjb25zdCBncm91cGVkTW92aWVzID0gdXNlTWVtbygoKSA9PiBncm91cE1vdmllcyhtb3ZpZXMpLCBbbW92aWVzXSk7XG4gIGNvbnN0IHsgdCB9ID0gdXNlVHJhbnNsYXRpb24oKTtcbiAgLy8gU3BsaXQgaW50byBMZXR0ZXJzLlxuICBjb25zdCB3cmFwcGVyUmVmOiBSZWZPYmplY3Q8SFRNTEVsZW1lbnQ+ID0gdXNlUmVmKG51bGwpO1xuXG4gIHJldHVybiAoXG4gICAgPFN0eWxlZFdyYXBwZXIgcmVmPXt3cmFwcGVyUmVmfT5cbiAgICAgIHtncm91cGVkTW92aWVzLm1hcCgoeyBsZXR0ZXIsIG1vdmllcyB9KSA9PiAoXG4gICAgICAgIDxNb3ZpZUdyb3VwIGtleT17bGV0dGVyfT5cbiAgICAgICAgICA8TGV0dGVyIGFyaWEtbGFiZWw9e3QoJ2ZpbG1mcm9udHBhZ2UuYWxsTW92aWVHcm91cFRpdGxlTGFiZWwnLCB7IGxldHRlciB9KX0+e2xldHRlcn08L0xldHRlcj5cbiAgICAgICAgICB7bW92aWVzLm1hcCgobW92aWUpID0+IChcbiAgICAgICAgICAgIDxNb3ZpZUl0ZW0ga2V5PXttb3ZpZS5pZH0+XG4gICAgICAgICAgICAgIDxTdHlsZWRTYWZlTGluayB0bz17bW92aWUucGF0aH0+XG4gICAgICAgICAgICAgICAgPE1vdmllSW1hZ2VcbiAgICAgICAgICAgICAgICAgIHNyYz17XG4gICAgICAgICAgICAgICAgICAgIG1vdmllPy5tZXRhSW1hZ2U/LnVybCA/IGAke21vdmllLm1ldGFJbWFnZT8udXJsfT8ke21ha2VTcmNRdWVyeVN0cmluZyhJTUFHRV9XSURUSCAqIDIpfWAgOiB1bmRlZmluZWRcbiAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgICAgIDxNb3ZpZVRleHRXcmFwcGVyPlxuICAgICAgICAgICAgICAgICAgPE1vdmllVGl0bGU+e21vdmllLnRpdGxlfTwvTW92aWVUaXRsZT5cbiAgICAgICAgICAgICAgICAgIDxNb3ZpZURlc2NyaXB0aW9uPnttb3ZpZS5tZXRhRGVzY3JpcHRpb259PC9Nb3ZpZURlc2NyaXB0aW9uPlxuICAgICAgICAgICAgICAgIDwvTW92aWVUZXh0V3JhcHBlcj5cbiAgICAgICAgICAgICAgPC9TdHlsZWRTYWZlTGluaz5cbiAgICAgICAgICAgIDwvTW92aWVJdGVtPlxuICAgICAgICAgICkpfVxuICAgICAgICA8L01vdmllR3JvdXA+XG4gICAgICApKX1cbiAgICA8L1N0eWxlZFdyYXBwZXI+XG4gICk7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBBbGxNb3ZpZXNBbHBoYWJldGljYWxseTtcbiJdfQ== */"));
76
56
  var MovieDescription = /*#__PURE__*/_styled("p", {
77
- target: "e1ul1xui1",
57
+ target: "e1ul1xui2",
78
58
  label: "MovieDescription"
79
- })("color:", colors.brand.greyLighter, ";margin:0;", fonts.sizes(14, 1.5), ";", mq.range({
80
- from: breakpoints.tablet
81
- }), "{", 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":"AAqHiC","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, RefObject, useEffect, useRef, useState } from 'react';\nimport { isIE, browserVersion } from 'react-device-detect';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport throttle from 'lodash/throttle';\nimport { breakpoints, mq, spacing, spacingUnit, colors, fonts, animations } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\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 (let i = 0; i < this.length; i++) {\n        callback.call(thisArg, this[i], i, this);\n      }\n    };\n  }\n};\n\nconst AllMoviesAlphabetically = ({ movies, locale }: Props) => {\n  const isIE11 = isIE && parseInt(browserVersion) < 12;\n  // Split into Letters.\n  let previousLetter = '';\n  const wrapperRef: RefObject<HTMLElement> = 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
- var _ref = process.env.NODE_ENV === "production" ? {
83
- name: "1ogu8uf-StyledSafeLink",
84
- styles: "flex:1;label:StyledSafeLink;"
85
- } : {
86
- name: "1ogu8uf-StyledSafeLink",
87
- styles: "flex:1;label:StyledSafeLink;",
88
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["AllMoviesAlphabetically.tsx"],"names":[],"mappings":"AA4IO","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, RefObject, useEffect, useRef, useState } from 'react';\nimport { isIE, browserVersion } from 'react-device-detect';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport throttle from 'lodash/throttle';\nimport { breakpoints, mq, spacing, spacingUnit, colors, fonts, animations } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\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 (let i = 0; i < this.length; i++) {\n        callback.call(thisArg, this[i], i, this);\n      }\n    };\n  }\n};\n\nconst AllMoviesAlphabetically = ({ movies, locale }: Props) => {\n  const isIE11 = isIE && parseInt(browserVersion) < 12;\n  // Split into Letters.\n  let previousLetter = '';\n  const wrapperRef: RefObject<HTMLElement> = 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"]} */",
89
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__
90
- };
59
+ })("color:", colors.brand.greyLighter, ";margin:0;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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkFsbE1vdmllc0FscGhhYmV0aWNhbGx5LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFvRWlDIiwiZmlsZSI6IkFsbE1vdmllc0FscGhhYmV0aWNhbGx5LnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDE5LXByZXNlbnQsIE5ETEEuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgR1BMdjMgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqXG4gKi9cblxuaW1wb3J0IFJlYWN0LCB7IFJlZk9iamVjdCwgdXNlTWVtbywgdXNlUmVmIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgYnJlYWtwb2ludHMsIG1xLCBzcGFjaW5nLCBzcGFjaW5nVW5pdCwgY29sb3JzIH0gZnJvbSAnQG5kbGEvY29yZSc7XG5pbXBvcnQgU2FmZUxpbmsgZnJvbSAnQG5kbGEvc2FmZWxpbmsnO1xuaW1wb3J0IGdyb3VwQnkgZnJvbSAnbG9kYXNoL2dyb3VwQnknO1xuaW1wb3J0IHNvcnRCeSBmcm9tICdsb2Rhc2gvc29ydEJ5JztcbmltcG9ydCB7IHVzZVRyYW5zbGF0aW9uIH0gZnJvbSAncmVhY3QtaTE4bmV4dCc7XG5pbXBvcnQgeyBtYWtlU3JjUXVlcnlTdHJpbmcgfSBmcm9tICcuLi9JbWFnZSc7XG5pbXBvcnQgeyBNb3ZpZVR5cGUgfSBmcm9tICcuL3R5cGVzJztcblxuY29uc3QgSU1BR0VfV0lEVEggPSAxNDM7XG5cbmNvbnN0IExldHRlciA9IHN0eWxlZC5oMmBcbiAgY29sb3I6ICR7Y29sb3JzLndoaXRlfTtcbiAgJHttcS5yYW5nZSh7IGZyb206IGJyZWFrcG9pbnRzLnRhYmxldCB9KX0ge1xuICAgIHRleHQtaW5kZW50OiAke3NwYWNpbmdVbml0ICogMC43NX1weDtcbiAgfVxuICAmOmFmdGVyIHtcbiAgICBjb250ZW50OiAnJztcbiAgICBkaXNwbGF5OiBibG9jaztcbiAgICBoZWlnaHQ6IDFweDtcbiAgICBiYWNrZ3JvdW5kOiAke2NvbG9ycy5icmFuZC5ncmV5RGFya307XG4gICAgbWFyZ2luLXRvcDogJHtzcGFjaW5nLnNtYWxsfTtcbiAgfVxuYDtcblxuY29uc3QgU3R5bGVkV3JhcHBlciA9IHN0eWxlZC5zZWN0aW9uYFxuICB3aWR0aDogNjUycHg7XG4gIG1heC13aWR0aDogMTAwJTtcbiAgbWFyZ2luOiAke3NwYWNpbmcubGFyZ2V9IGF1dG87XG4gIHBhZGRpbmc6IDAgJHtzcGFjaW5nLm5vcm1hbH07XG5gO1xuXG5jb25zdCBNb3ZpZUl0ZW0gPSBzdHlsZWQuZGl2YFxuICBkaXNwbGF5OiBmbGV4O1xuICBnYXA6ICR7c3BhY2luZy5zbWFsbH07XG4gIGNvbG9yOiAke2NvbG9ycy53aGl0ZX07XG5gO1xuXG5jb25zdCBNb3ZpZVRleHRXcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgJHttcS5yYW5nZSh7IGZyb206IGJyZWFrcG9pbnRzLnRhYmxldCB9KX0ge1xuICAgIHBhZGRpbmc6ICR7c3BhY2luZy54c21hbGx9ICR7c3BhY2luZy54c21hbGx9IDAgMDtcbiAgfVxuICBmbGV4OiAxO1xuYDtcblxuY29uc3QgTW92aWVJbWFnZSA9IHN0eWxlZC5pbWdgXG4gIHdpZHRoOiAxMDRweDtcbiAgaGVpZ2h0OiA4MHB4O1xuICAke21xLnJhbmdlKHsgZnJvbTogYnJlYWtwb2ludHMudGFibGV0IH0pfSB7XG4gICAgd2lkdGg6ICR7SU1BR0VfV0lEVEh9cHg7XG4gICAgaGVpZ2h0OiA5MHB4O1xuICB9XG5gO1xuXG5jb25zdCBNb3ZpZVRpdGxlID0gc3R5bGVkLmgzYFxuICBjb2xvcjogJHtjb2xvcnMud2hpdGV9O1xuICBtYXJnaW46IDA7XG5gO1xuXG5jb25zdCBNb3ZpZURlc2NyaXB0aW9uID0gc3R5bGVkLnBgXG4gIGNvbG9yOiAke2NvbG9ycy5icmFuZC5ncmV5TGlnaHRlcn07XG4gIG1hcmdpbjogMDtcbiAgb3ZlcmZsb3c6IGhpZGRlbjtcbiAgdGV4dC1vdmVyZmxvdzogZWxsaXBzaXM7XG4gIGRpc3BsYXk6IC13ZWJraXQtYm94O1xuICAtd2Via2l0LWJveC1vcmllbnQ6IHZlcnRpY2FsO1xuICAtd2Via2l0LWxpbmUtY2xhbXA6IDI7XG5gO1xuXG5jb25zdCBTdHlsZWRTYWZlTGluayA9IHN0eWxlZChTYWZlTGluaylgXG4gIGJveC1zaGFkb3c6IG5vbmU7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGdhcDogJHtzcGFjaW5nLnNtYWxsfTtcbiAgJjpob3ZlcixcbiAgJjpmb2N1cyB7XG4gICAgJHtNb3ZpZVRpdGxlfSB7XG4gICAgICB0ZXh0LWRlY29yYXRpb246IHVuZGVybGluZTtcbiAgICB9XG4gICAgJHtNb3ZpZUltYWdlfSB7XG4gICAgICAmOmFmdGVyIHtcbiAgICAgICAgdHJhbnNpdGlvbjogb3BhY2l0eSAyMDBtcyBlYXNlO1xuICAgICAgICBkaXNwbGF5OiBibG9jaztcbiAgICAgICAgb3BhY2l0eTogMC4zO1xuICAgICAgfVxuICAgIH1cbiAgfVxuYDtcblxuaW50ZXJmYWNlIFByb3BzIHtcbiAgbW92aWVzOiBNb3ZpZVR5cGVbXTtcbn1cblxuY29uc3QgTW92aWVHcm91cCA9IHN0eWxlZC5zZWN0aW9uYFxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICBnYXA6ICR7c3BhY2luZy5ub3JtYWx9O1xuYDtcblxuY29uc3QgZ3JvdXBNb3ZpZXMgPSAobW92aWVzOiBNb3ZpZVR5cGVbXSkgPT4ge1xuICBjb25zdCBzb3J0ZWRNb3ZpZXMgPSBzb3J0QnkobW92aWVzLCAobSkgPT4gbS50aXRsZSk7XG4gIGNvbnN0IGdyb3VwZWQgPSBncm91cEJ5KHNvcnRlZE1vdmllcywgKG1vdmllKSA9PiB7XG4gICAgY29uc3QgZmlyc3RDaGFyID0gbW92aWUudGl0bGVbMF0/LnRvVXBwZXJDYXNlKCk7XG4gICAgY29uc3QgaXNMZXR0ZXIgPSBmaXJzdENoYXI/Lm1hdGNoKC9bQS1aXFxXw4bDmMOFXSsvKTtcbiAgICByZXR1cm4gaXNMZXR0ZXIgPyBmaXJzdENoYXIgOiAnIyc7XG4gIH0pO1xuICByZXR1cm4gT2JqZWN0LmVudHJpZXMoZ3JvdXBlZCkubWFwKChbbGV0dGVyLCBtb3ZpZXNdKSA9PiAoeyBsZXR0ZXIsIG1vdmllcyB9KSk7XG59O1xuXG5jb25zdCBBbGxNb3ZpZXNBbHBoYWJldGljYWxseSA9ICh7IG1vdmllcyB9OiBQcm9wcykgPT4ge1xuICBjb25zdCBncm91cGVkTW92aWVzID0gdXNlTWVtbygoKSA9PiBncm91cE1vdmllcyhtb3ZpZXMpLCBbbW92aWVzXSk7XG4gIGNvbnN0IHsgdCB9ID0gdXNlVHJhbnNsYXRpb24oKTtcbiAgLy8gU3BsaXQgaW50byBMZXR0ZXJzLlxuICBjb25zdCB3cmFwcGVyUmVmOiBSZWZPYmplY3Q8SFRNTEVsZW1lbnQ+ID0gdXNlUmVmKG51bGwpO1xuXG4gIHJldHVybiAoXG4gICAgPFN0eWxlZFdyYXBwZXIgcmVmPXt3cmFwcGVyUmVmfT5cbiAgICAgIHtncm91cGVkTW92aWVzLm1hcCgoeyBsZXR0ZXIsIG1vdmllcyB9KSA9PiAoXG4gICAgICAgIDxNb3ZpZUdyb3VwIGtleT17bGV0dGVyfT5cbiAgICAgICAgICA8TGV0dGVyIGFyaWEtbGFiZWw9e3QoJ2ZpbG1mcm9udHBhZ2UuYWxsTW92aWVHcm91cFRpdGxlTGFiZWwnLCB7IGxldHRlciB9KX0+e2xldHRlcn08L0xldHRlcj5cbiAgICAgICAgICB7bW92aWVzLm1hcCgobW92aWUpID0+IChcbiAgICAgICAgICAgIDxNb3ZpZUl0ZW0ga2V5PXttb3ZpZS5pZH0+XG4gICAgICAgICAgICAgIDxTdHlsZWRTYWZlTGluayB0bz17bW92aWUucGF0aH0+XG4gICAgICAgICAgICAgICAgPE1vdmllSW1hZ2VcbiAgICAgICAgICAgICAgICAgIHNyYz17XG4gICAgICAgICAgICAgICAgICAgIG1vdmllPy5tZXRhSW1hZ2U/LnVybCA/IGAke21vdmllLm1ldGFJbWFnZT8udXJsfT8ke21ha2VTcmNRdWVyeVN0cmluZyhJTUFHRV9XSURUSCAqIDIpfWAgOiB1bmRlZmluZWRcbiAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgICAgIDxNb3ZpZVRleHRXcmFwcGVyPlxuICAgICAgICAgICAgICAgICAgPE1vdmllVGl0bGU+e21vdmllLnRpdGxlfTwvTW92aWVUaXRsZT5cbiAgICAgICAgICAgICAgICAgIDxNb3ZpZURlc2NyaXB0aW9uPnttb3ZpZS5tZXRhRGVzY3JpcHRpb259PC9Nb3ZpZURlc2NyaXB0aW9uPlxuICAgICAgICAgICAgICAgIDwvTW92aWVUZXh0V3JhcHBlcj5cbiAgICAgICAgICAgICAgPC9TdHlsZWRTYWZlTGluaz5cbiAgICAgICAgICAgIDwvTW92aWVJdGVtPlxuICAgICAgICAgICkpfVxuICAgICAgICA8L01vdmllR3JvdXA+XG4gICAgICApKX1cbiAgICA8L1N0eWxlZFdyYXBwZXI+XG4gICk7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBBbGxNb3ZpZXNBbHBoYWJldGljYWxseTtcbiJdfQ== */"));
91
60
  var StyledSafeLink = /*#__PURE__*/_styled(SafeLink, {
92
- target: "e1ul1xui0",
61
+ target: "e1ul1xui1",
93
62
  label: "StyledSafeLink"
94
- })("box-shadow:none;display:flex;", function (props) {
95
- return props.isIE11 && _ref;
96
- }, " &: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":"AAuIkD","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, RefObject, useEffect, useRef, useState } from 'react';\nimport { isIE, browserVersion } from 'react-device-detect';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport throttle from 'lodash/throttle';\nimport { breakpoints, mq, spacing, spacingUnit, colors, fonts, animations } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\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 (let i = 0; i < this.length; i++) {\n        callback.call(thisArg, this[i], i, this);\n      }\n    };\n  }\n};\n\nconst AllMoviesAlphabetically = ({ movies, locale }: Props) => {\n  const isIE11 = isIE && parseInt(browserVersion) < 12;\n  // Split into Letters.\n  let previousLetter = '';\n  const wrapperRef: RefObject<HTMLElement> = 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"]} */"));
97
- var hasForEachPolyfill = function hasForEachPolyfill() {
98
- // Polyfill for ie11
99
- if ('NodeList' in window && !NodeList.prototype.forEach) {
100
- NodeList.prototype.forEach = function (callback, thisArg) {
101
- thisArg = thisArg || window;
102
- for (var i = 0; i < this.length; i++) {
103
- callback.call(thisArg, this[i], i, this);
104
- }
63
+ })("box-shadow:none;display:flex;gap:", spacing.small, ";&: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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkFsbE1vdmllc0FscGhhYmV0aWNhbGx5LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE4RXVDIiwiZmlsZSI6IkFsbE1vdmllc0FscGhhYmV0aWNhbGx5LnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDE5LXByZXNlbnQsIE5ETEEuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgR1BMdjMgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqXG4gKi9cblxuaW1wb3J0IFJlYWN0LCB7IFJlZk9iamVjdCwgdXNlTWVtbywgdXNlUmVmIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgYnJlYWtwb2ludHMsIG1xLCBzcGFjaW5nLCBzcGFjaW5nVW5pdCwgY29sb3JzIH0gZnJvbSAnQG5kbGEvY29yZSc7XG5pbXBvcnQgU2FmZUxpbmsgZnJvbSAnQG5kbGEvc2FmZWxpbmsnO1xuaW1wb3J0IGdyb3VwQnkgZnJvbSAnbG9kYXNoL2dyb3VwQnknO1xuaW1wb3J0IHNvcnRCeSBmcm9tICdsb2Rhc2gvc29ydEJ5JztcbmltcG9ydCB7IHVzZVRyYW5zbGF0aW9uIH0gZnJvbSAncmVhY3QtaTE4bmV4dCc7XG5pbXBvcnQgeyBtYWtlU3JjUXVlcnlTdHJpbmcgfSBmcm9tICcuLi9JbWFnZSc7XG5pbXBvcnQgeyBNb3ZpZVR5cGUgfSBmcm9tICcuL3R5cGVzJztcblxuY29uc3QgSU1BR0VfV0lEVEggPSAxNDM7XG5cbmNvbnN0IExldHRlciA9IHN0eWxlZC5oMmBcbiAgY29sb3I6ICR7Y29sb3JzLndoaXRlfTtcbiAgJHttcS5yYW5nZSh7IGZyb206IGJyZWFrcG9pbnRzLnRhYmxldCB9KX0ge1xuICAgIHRleHQtaW5kZW50OiAke3NwYWNpbmdVbml0ICogMC43NX1weDtcbiAgfVxuICAmOmFmdGVyIHtcbiAgICBjb250ZW50OiAnJztcbiAgICBkaXNwbGF5OiBibG9jaztcbiAgICBoZWlnaHQ6IDFweDtcbiAgICBiYWNrZ3JvdW5kOiAke2NvbG9ycy5icmFuZC5ncmV5RGFya307XG4gICAgbWFyZ2luLXRvcDogJHtzcGFjaW5nLnNtYWxsfTtcbiAgfVxuYDtcblxuY29uc3QgU3R5bGVkV3JhcHBlciA9IHN0eWxlZC5zZWN0aW9uYFxuICB3aWR0aDogNjUycHg7XG4gIG1heC13aWR0aDogMTAwJTtcbiAgbWFyZ2luOiAke3NwYWNpbmcubGFyZ2V9IGF1dG87XG4gIHBhZGRpbmc6IDAgJHtzcGFjaW5nLm5vcm1hbH07XG5gO1xuXG5jb25zdCBNb3ZpZUl0ZW0gPSBzdHlsZWQuZGl2YFxuICBkaXNwbGF5OiBmbGV4O1xuICBnYXA6ICR7c3BhY2luZy5zbWFsbH07XG4gIGNvbG9yOiAke2NvbG9ycy53aGl0ZX07XG5gO1xuXG5jb25zdCBNb3ZpZVRleHRXcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgJHttcS5yYW5nZSh7IGZyb206IGJyZWFrcG9pbnRzLnRhYmxldCB9KX0ge1xuICAgIHBhZGRpbmc6ICR7c3BhY2luZy54c21hbGx9ICR7c3BhY2luZy54c21hbGx9IDAgMDtcbiAgfVxuICBmbGV4OiAxO1xuYDtcblxuY29uc3QgTW92aWVJbWFnZSA9IHN0eWxlZC5pbWdgXG4gIHdpZHRoOiAxMDRweDtcbiAgaGVpZ2h0OiA4MHB4O1xuICAke21xLnJhbmdlKHsgZnJvbTogYnJlYWtwb2ludHMudGFibGV0IH0pfSB7XG4gICAgd2lkdGg6ICR7SU1BR0VfV0lEVEh9cHg7XG4gICAgaGVpZ2h0OiA5MHB4O1xuICB9XG5gO1xuXG5jb25zdCBNb3ZpZVRpdGxlID0gc3R5bGVkLmgzYFxuICBjb2xvcjogJHtjb2xvcnMud2hpdGV9O1xuICBtYXJnaW46IDA7XG5gO1xuXG5jb25zdCBNb3ZpZURlc2NyaXB0aW9uID0gc3R5bGVkLnBgXG4gIGNvbG9yOiAke2NvbG9ycy5icmFuZC5ncmV5TGlnaHRlcn07XG4gIG1hcmdpbjogMDtcbiAgb3ZlcmZsb3c6IGhpZGRlbjtcbiAgdGV4dC1vdmVyZmxvdzogZWxsaXBzaXM7XG4gIGRpc3BsYXk6IC13ZWJraXQtYm94O1xuICAtd2Via2l0LWJveC1vcmllbnQ6IHZlcnRpY2FsO1xuICAtd2Via2l0LWxpbmUtY2xhbXA6IDI7XG5gO1xuXG5jb25zdCBTdHlsZWRTYWZlTGluayA9IHN0eWxlZChTYWZlTGluaylgXG4gIGJveC1zaGFkb3c6IG5vbmU7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGdhcDogJHtzcGFjaW5nLnNtYWxsfTtcbiAgJjpob3ZlcixcbiAgJjpmb2N1cyB7XG4gICAgJHtNb3ZpZVRpdGxlfSB7XG4gICAgICB0ZXh0LWRlY29yYXRpb246IHVuZGVybGluZTtcbiAgICB9XG4gICAgJHtNb3ZpZUltYWdlfSB7XG4gICAgICAmOmFmdGVyIHtcbiAgICAgICAgdHJhbnNpdGlvbjogb3BhY2l0eSAyMDBtcyBlYXNlO1xuICAgICAgICBkaXNwbGF5OiBibG9jaztcbiAgICAgICAgb3BhY2l0eTogMC4zO1xuICAgICAgfVxuICAgIH1cbiAgfVxuYDtcblxuaW50ZXJmYWNlIFByb3BzIHtcbiAgbW92aWVzOiBNb3ZpZVR5cGVbXTtcbn1cblxuY29uc3QgTW92aWVHcm91cCA9IHN0eWxlZC5zZWN0aW9uYFxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICBnYXA6ICR7c3BhY2luZy5ub3JtYWx9O1xuYDtcblxuY29uc3QgZ3JvdXBNb3ZpZXMgPSAobW92aWVzOiBNb3ZpZVR5cGVbXSkgPT4ge1xuICBjb25zdCBzb3J0ZWRNb3ZpZXMgPSBzb3J0QnkobW92aWVzLCAobSkgPT4gbS50aXRsZSk7XG4gIGNvbnN0IGdyb3VwZWQgPSBncm91cEJ5KHNvcnRlZE1vdmllcywgKG1vdmllKSA9PiB7XG4gICAgY29uc3QgZmlyc3RDaGFyID0gbW92aWUudGl0bGVbMF0/LnRvVXBwZXJDYXNlKCk7XG4gICAgY29uc3QgaXNMZXR0ZXIgPSBmaXJzdENoYXI/Lm1hdGNoKC9bQS1aXFxXw4bDmMOFXSsvKTtcbiAgICByZXR1cm4gaXNMZXR0ZXIgPyBmaXJzdENoYXIgOiAnIyc7XG4gIH0pO1xuICByZXR1cm4gT2JqZWN0LmVudHJpZXMoZ3JvdXBlZCkubWFwKChbbGV0dGVyLCBtb3ZpZXNdKSA9PiAoeyBsZXR0ZXIsIG1vdmllcyB9KSk7XG59O1xuXG5jb25zdCBBbGxNb3ZpZXNBbHBoYWJldGljYWxseSA9ICh7IG1vdmllcyB9OiBQcm9wcykgPT4ge1xuICBjb25zdCBncm91cGVkTW92aWVzID0gdXNlTWVtbygoKSA9PiBncm91cE1vdmllcyhtb3ZpZXMpLCBbbW92aWVzXSk7XG4gIGNvbnN0IHsgdCB9ID0gdXNlVHJhbnNsYXRpb24oKTtcbiAgLy8gU3BsaXQgaW50byBMZXR0ZXJzLlxuICBjb25zdCB3cmFwcGVyUmVmOiBSZWZPYmplY3Q8SFRNTEVsZW1lbnQ+ID0gdXNlUmVmKG51bGwpO1xuXG4gIHJldHVybiAoXG4gICAgPFN0eWxlZFdyYXBwZXIgcmVmPXt3cmFwcGVyUmVmfT5cbiAgICAgIHtncm91cGVkTW92aWVzLm1hcCgoeyBsZXR0ZXIsIG1vdmllcyB9KSA9PiAoXG4gICAgICAgIDxNb3ZpZUdyb3VwIGtleT17bGV0dGVyfT5cbiAgICAgICAgICA8TGV0dGVyIGFyaWEtbGFiZWw9e3QoJ2ZpbG1mcm9udHBhZ2UuYWxsTW92aWVHcm91cFRpdGxlTGFiZWwnLCB7IGxldHRlciB9KX0+e2xldHRlcn08L0xldHRlcj5cbiAgICAgICAgICB7bW92aWVzLm1hcCgobW92aWUpID0+IChcbiAgICAgICAgICAgIDxNb3ZpZUl0ZW0ga2V5PXttb3ZpZS5pZH0+XG4gICAgICAgICAgICAgIDxTdHlsZWRTYWZlTGluayB0bz17bW92aWUucGF0aH0+XG4gICAgICAgICAgICAgICAgPE1vdmllSW1hZ2VcbiAgICAgICAgICAgICAgICAgIHNyYz17XG4gICAgICAgICAgICAgICAgICAgIG1vdmllPy5tZXRhSW1hZ2U/LnVybCA/IGAke21vdmllLm1ldGFJbWFnZT8udXJsfT8ke21ha2VTcmNRdWVyeVN0cmluZyhJTUFHRV9XSURUSCAqIDIpfWAgOiB1bmRlZmluZWRcbiAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgICAgIDxNb3ZpZVRleHRXcmFwcGVyPlxuICAgICAgICAgICAgICAgICAgPE1vdmllVGl0bGU+e21vdmllLnRpdGxlfTwvTW92aWVUaXRsZT5cbiAgICAgICAgICAgICAgICAgIDxNb3ZpZURlc2NyaXB0aW9uPnttb3ZpZS5tZXRhRGVzY3JpcHRpb259PC9Nb3ZpZURlc2NyaXB0aW9uPlxuICAgICAgICAgICAgICAgIDwvTW92aWVUZXh0V3JhcHBlcj5cbiAgICAgICAgICAgICAgPC9TdHlsZWRTYWZlTGluaz5cbiAgICAgICAgICAgIDwvTW92aWVJdGVtPlxuICAgICAgICAgICkpfVxuICAgICAgICA8L01vdmllR3JvdXA+XG4gICAgICApKX1cbiAgICA8L1N0eWxlZFdyYXBwZXI+XG4gICk7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBBbGxNb3ZpZXNBbHBoYWJldGljYWxseTtcbiJdfQ== */"));
64
+ var MovieGroup = /*#__PURE__*/_styled("section", {
65
+ target: "e1ul1xui0",
66
+ label: "MovieGroup"
67
+ })("display:flex;flex-direction:column;gap:", spacing.normal, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkFsbE1vdmllc0FscGhhYmV0aWNhbGx5LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFxR2lDIiwiZmlsZSI6IkFsbE1vdmllc0FscGhhYmV0aWNhbGx5LnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDE5LXByZXNlbnQsIE5ETEEuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgR1BMdjMgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqXG4gKi9cblxuaW1wb3J0IFJlYWN0LCB7IFJlZk9iamVjdCwgdXNlTWVtbywgdXNlUmVmIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgYnJlYWtwb2ludHMsIG1xLCBzcGFjaW5nLCBzcGFjaW5nVW5pdCwgY29sb3JzIH0gZnJvbSAnQG5kbGEvY29yZSc7XG5pbXBvcnQgU2FmZUxpbmsgZnJvbSAnQG5kbGEvc2FmZWxpbmsnO1xuaW1wb3J0IGdyb3VwQnkgZnJvbSAnbG9kYXNoL2dyb3VwQnknO1xuaW1wb3J0IHNvcnRCeSBmcm9tICdsb2Rhc2gvc29ydEJ5JztcbmltcG9ydCB7IHVzZVRyYW5zbGF0aW9uIH0gZnJvbSAncmVhY3QtaTE4bmV4dCc7XG5pbXBvcnQgeyBtYWtlU3JjUXVlcnlTdHJpbmcgfSBmcm9tICcuLi9JbWFnZSc7XG5pbXBvcnQgeyBNb3ZpZVR5cGUgfSBmcm9tICcuL3R5cGVzJztcblxuY29uc3QgSU1BR0VfV0lEVEggPSAxNDM7XG5cbmNvbnN0IExldHRlciA9IHN0eWxlZC5oMmBcbiAgY29sb3I6ICR7Y29sb3JzLndoaXRlfTtcbiAgJHttcS5yYW5nZSh7IGZyb206IGJyZWFrcG9pbnRzLnRhYmxldCB9KX0ge1xuICAgIHRleHQtaW5kZW50OiAke3NwYWNpbmdVbml0ICogMC43NX1weDtcbiAgfVxuICAmOmFmdGVyIHtcbiAgICBjb250ZW50OiAnJztcbiAgICBkaXNwbGF5OiBibG9jaztcbiAgICBoZWlnaHQ6IDFweDtcbiAgICBiYWNrZ3JvdW5kOiAke2NvbG9ycy5icmFuZC5ncmV5RGFya307XG4gICAgbWFyZ2luLXRvcDogJHtzcGFjaW5nLnNtYWxsfTtcbiAgfVxuYDtcblxuY29uc3QgU3R5bGVkV3JhcHBlciA9IHN0eWxlZC5zZWN0aW9uYFxuICB3aWR0aDogNjUycHg7XG4gIG1heC13aWR0aDogMTAwJTtcbiAgbWFyZ2luOiAke3NwYWNpbmcubGFyZ2V9IGF1dG87XG4gIHBhZGRpbmc6IDAgJHtzcGFjaW5nLm5vcm1hbH07XG5gO1xuXG5jb25zdCBNb3ZpZUl0ZW0gPSBzdHlsZWQuZGl2YFxuICBkaXNwbGF5OiBmbGV4O1xuICBnYXA6ICR7c3BhY2luZy5zbWFsbH07XG4gIGNvbG9yOiAke2NvbG9ycy53aGl0ZX07XG5gO1xuXG5jb25zdCBNb3ZpZVRleHRXcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgJHttcS5yYW5nZSh7IGZyb206IGJyZWFrcG9pbnRzLnRhYmxldCB9KX0ge1xuICAgIHBhZGRpbmc6ICR7c3BhY2luZy54c21hbGx9ICR7c3BhY2luZy54c21hbGx9IDAgMDtcbiAgfVxuICBmbGV4OiAxO1xuYDtcblxuY29uc3QgTW92aWVJbWFnZSA9IHN0eWxlZC5pbWdgXG4gIHdpZHRoOiAxMDRweDtcbiAgaGVpZ2h0OiA4MHB4O1xuICAke21xLnJhbmdlKHsgZnJvbTogYnJlYWtwb2ludHMudGFibGV0IH0pfSB7XG4gICAgd2lkdGg6ICR7SU1BR0VfV0lEVEh9cHg7XG4gICAgaGVpZ2h0OiA5MHB4O1xuICB9XG5gO1xuXG5jb25zdCBNb3ZpZVRpdGxlID0gc3R5bGVkLmgzYFxuICBjb2xvcjogJHtjb2xvcnMud2hpdGV9O1xuICBtYXJnaW46IDA7XG5gO1xuXG5jb25zdCBNb3ZpZURlc2NyaXB0aW9uID0gc3R5bGVkLnBgXG4gIGNvbG9yOiAke2NvbG9ycy5icmFuZC5ncmV5TGlnaHRlcn07XG4gIG1hcmdpbjogMDtcbiAgb3ZlcmZsb3c6IGhpZGRlbjtcbiAgdGV4dC1vdmVyZmxvdzogZWxsaXBzaXM7XG4gIGRpc3BsYXk6IC13ZWJraXQtYm94O1xuICAtd2Via2l0LWJveC1vcmllbnQ6IHZlcnRpY2FsO1xuICAtd2Via2l0LWxpbmUtY2xhbXA6IDI7XG5gO1xuXG5jb25zdCBTdHlsZWRTYWZlTGluayA9IHN0eWxlZChTYWZlTGluaylgXG4gIGJveC1zaGFkb3c6IG5vbmU7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGdhcDogJHtzcGFjaW5nLnNtYWxsfTtcbiAgJjpob3ZlcixcbiAgJjpmb2N1cyB7XG4gICAgJHtNb3ZpZVRpdGxlfSB7XG4gICAgICB0ZXh0LWRlY29yYXRpb246IHVuZGVybGluZTtcbiAgICB9XG4gICAgJHtNb3ZpZUltYWdlfSB7XG4gICAgICAmOmFmdGVyIHtcbiAgICAgICAgdHJhbnNpdGlvbjogb3BhY2l0eSAyMDBtcyBlYXNlO1xuICAgICAgICBkaXNwbGF5OiBibG9jaztcbiAgICAgICAgb3BhY2l0eTogMC4zO1xuICAgICAgfVxuICAgIH1cbiAgfVxuYDtcblxuaW50ZXJmYWNlIFByb3BzIHtcbiAgbW92aWVzOiBNb3ZpZVR5cGVbXTtcbn1cblxuY29uc3QgTW92aWVHcm91cCA9IHN0eWxlZC5zZWN0aW9uYFxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICBnYXA6ICR7c3BhY2luZy5ub3JtYWx9O1xuYDtcblxuY29uc3QgZ3JvdXBNb3ZpZXMgPSAobW92aWVzOiBNb3ZpZVR5cGVbXSkgPT4ge1xuICBjb25zdCBzb3J0ZWRNb3ZpZXMgPSBzb3J0QnkobW92aWVzLCAobSkgPT4gbS50aXRsZSk7XG4gIGNvbnN0IGdyb3VwZWQgPSBncm91cEJ5KHNvcnRlZE1vdmllcywgKG1vdmllKSA9PiB7XG4gICAgY29uc3QgZmlyc3RDaGFyID0gbW92aWUudGl0bGVbMF0/LnRvVXBwZXJDYXNlKCk7XG4gICAgY29uc3QgaXNMZXR0ZXIgPSBmaXJzdENoYXI/Lm1hdGNoKC9bQS1aXFxXw4bDmMOFXSsvKTtcbiAgICByZXR1cm4gaXNMZXR0ZXIgPyBmaXJzdENoYXIgOiAnIyc7XG4gIH0pO1xuICByZXR1cm4gT2JqZWN0LmVudHJpZXMoZ3JvdXBlZCkubWFwKChbbGV0dGVyLCBtb3ZpZXNdKSA9PiAoeyBsZXR0ZXIsIG1vdmllcyB9KSk7XG59O1xuXG5jb25zdCBBbGxNb3ZpZXNBbHBoYWJldGljYWxseSA9ICh7IG1vdmllcyB9OiBQcm9wcykgPT4ge1xuICBjb25zdCBncm91cGVkTW92aWVzID0gdXNlTWVtbygoKSA9PiBncm91cE1vdmllcyhtb3ZpZXMpLCBbbW92aWVzXSk7XG4gIGNvbnN0IHsgdCB9ID0gdXNlVHJhbnNsYXRpb24oKTtcbiAgLy8gU3BsaXQgaW50byBMZXR0ZXJzLlxuICBjb25zdCB3cmFwcGVyUmVmOiBSZWZPYmplY3Q8SFRNTEVsZW1lbnQ+ID0gdXNlUmVmKG51bGwpO1xuXG4gIHJldHVybiAoXG4gICAgPFN0eWxlZFdyYXBwZXIgcmVmPXt3cmFwcGVyUmVmfT5cbiAgICAgIHtncm91cGVkTW92aWVzLm1hcCgoeyBsZXR0ZXIsIG1vdmllcyB9KSA9PiAoXG4gICAgICAgIDxNb3ZpZUdyb3VwIGtleT17bGV0dGVyfT5cbiAgICAgICAgICA8TGV0dGVyIGFyaWEtbGFiZWw9e3QoJ2ZpbG1mcm9udHBhZ2UuYWxsTW92aWVHcm91cFRpdGxlTGFiZWwnLCB7IGxldHRlciB9KX0+e2xldHRlcn08L0xldHRlcj5cbiAgICAgICAgICB7bW92aWVzLm1hcCgobW92aWUpID0+IChcbiAgICAgICAgICAgIDxNb3ZpZUl0ZW0ga2V5PXttb3ZpZS5pZH0+XG4gICAgICAgICAgICAgIDxTdHlsZWRTYWZlTGluayB0bz17bW92aWUucGF0aH0+XG4gICAgICAgICAgICAgICAgPE1vdmllSW1hZ2VcbiAgICAgICAgICAgICAgICAgIHNyYz17XG4gICAgICAgICAgICAgICAgICAgIG1vdmllPy5tZXRhSW1hZ2U/LnVybCA/IGAke21vdmllLm1ldGFJbWFnZT8udXJsfT8ke21ha2VTcmNRdWVyeVN0cmluZyhJTUFHRV9XSURUSCAqIDIpfWAgOiB1bmRlZmluZWRcbiAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgICAgIDxNb3ZpZVRleHRXcmFwcGVyPlxuICAgICAgICAgICAgICAgICAgPE1vdmllVGl0bGU+e21vdmllLnRpdGxlfTwvTW92aWVUaXRsZT5cbiAgICAgICAgICAgICAgICAgIDxNb3ZpZURlc2NyaXB0aW9uPnttb3ZpZS5tZXRhRGVzY3JpcHRpb259PC9Nb3ZpZURlc2NyaXB0aW9uPlxuICAgICAgICAgICAgICAgIDwvTW92aWVUZXh0V3JhcHBlcj5cbiAgICAgICAgICAgICAgPC9TdHlsZWRTYWZlTGluaz5cbiAgICAgICAgICAgIDwvTW92aWVJdGVtPlxuICAgICAgICAgICkpfVxuICAgICAgICA8L01vdmllR3JvdXA+XG4gICAgICApKX1cbiAgICA8L1N0eWxlZFdyYXBwZXI+XG4gICk7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBBbGxNb3ZpZXNBbHBoYWJldGljYWxseTtcbiJdfQ== */"));
68
+ var groupMovies = function groupMovies(movies) {
69
+ var sortedMovies = sortBy(movies, function (m) {
70
+ return m.title;
71
+ });
72
+ var grouped = groupBy(sortedMovies, function (movie) {
73
+ var _movie$title$;
74
+ var firstChar = (_movie$title$ = movie.title[0]) === null || _movie$title$ === void 0 ? void 0 : _movie$title$.toUpperCase();
75
+ var isLetter = firstChar === null || firstChar === void 0 ? void 0 : firstChar.match(/[A-Z\WÆØÅ]+/);
76
+ return isLetter ? firstChar : '#';
77
+ });
78
+ return Object.entries(grouped).map(function (_ref) {
79
+ var _ref2 = _slicedToArray(_ref, 2),
80
+ letter = _ref2[0],
81
+ movies = _ref2[1];
82
+ return {
83
+ letter: letter,
84
+ movies: movies
105
85
  };
106
- }
86
+ });
107
87
  };
108
88
  var AllMoviesAlphabetically = function AllMoviesAlphabetically(_ref3) {
109
- var movies = _ref3.movies,
110
- locale = _ref3.locale;
111
- var isIE11 = isIE && parseInt(browserVersion) < 12;
89
+ var movies = _ref3.movies;
90
+ var groupedMovies = useMemo(function () {
91
+ return groupMovies(movies);
92
+ }, [movies]);
93
+ var _useTranslation = useTranslation(),
94
+ t = _useTranslation.t;
112
95
  // Split into Letters.
113
- var previousLetter = '';
114
96
  var wrapperRef = useRef(null);
115
- var _useState = useState({}),
116
- _useState2 = _slicedToArray(_useState, 2),
117
- visibleImages = _useState2[0],
118
- setVisibleImages = _useState2[1];
119
- var scrollEvent = function scrollEvent() {
120
- hasForEachPolyfill();
121
- var updates = {};
122
- var allChildren = wrapperRef.current && wrapperRef.current.querySelectorAll('[role=img]');
123
- var windowInnerHeight = window.innerHeight;
124
- if (allChildren) {
125
- var started = false;
126
- var ended = false;
127
- allChildren.forEach(function (el, index) {
128
- if (!ended) {
129
- var rect = el.getBoundingClientRect();
130
- if (!started) {
131
- if (rect.top > -20) {
132
- updates[index] = true;
133
- started = true;
134
- }
135
- } else {
136
- updates[index] = true;
137
- if (rect.top > windowInnerHeight + 20) {
138
- ended = true;
139
- }
140
- }
141
- }
142
- });
143
- }
144
- setVisibleImages(function (visibleImages) {
145
- return _objectSpread(_objectSpread({}, visibleImages), updates);
146
- });
147
- };
148
- useEffect(function () {
149
- var throttledScrollEvent = throttle(function () {
150
- scrollEvent();
151
- }, 100);
152
- window.addEventListener('scroll', throttledScrollEvent);
153
- scrollEvent();
154
- return function () {
155
- window.removeEventListener('scroll', throttledScrollEvent);
156
- };
157
- }, []);
158
- useEffect(function () {
159
- scrollEvent();
160
- }, [movies]);
161
97
  return _jsx(StyledWrapper, {
162
98
  ref: wrapperRef,
163
- children: movies.map(function (movie, index) {
164
- var currentLetter = movie.title.substr(0, 1);
165
- var isNewLetter = currentLetter.localeCompare(previousLetter, locale) === 1 && isLetter(movie.title);
166
- previousLetter = currentLetter;
167
- var inView = visibleImages ? visibleImages[index] : null;
168
- return _jsxs(Fragment, {
169
- children: [isNewLetter && _jsx(StyledNewLetter, {
170
- children: movie.title.substr(0, 1)
171
- }), _jsx(MovieItem, {
172
- inView: inView,
173
- children: _jsxs(StyledSafeLink, {
174
- isIE11: isIE11,
175
- to: movie.path,
176
- children: [_jsx(MovieImage, {
177
- role: "img",
178
- backgroundImage: inView && movie.metaImage && movie.metaImage.url ? "".concat(movie.metaImage.url, "?").concat(makeSrcQueryString(IMAGE_WIDTH * 2)) : null,
179
- "aria-label": movie.metaImage && movie.metaImage.alt,
180
- title: movie.title
181
- }), _jsxs(MovieTextWrapper, {
182
- children: [_jsx(MovieTitle, {
183
- children: movie.title
184
- }), _jsx(MovieDescription, {
185
- children: movie.metaDescription
99
+ children: groupedMovies.map(function (_ref4) {
100
+ var letter = _ref4.letter,
101
+ movies = _ref4.movies;
102
+ return _jsxs(MovieGroup, {
103
+ children: [_jsx(Letter, {
104
+ "aria-label": t('filmfrontpage.allMovieGroupTitleLabel', {
105
+ letter: letter
106
+ }),
107
+ children: letter
108
+ }), movies.map(function (movie) {
109
+ var _movie$metaImage, _movie$metaImage2;
110
+ return _jsx(MovieItem, {
111
+ children: _jsxs(StyledSafeLink, {
112
+ to: movie.path,
113
+ children: [_jsx(MovieImage, {
114
+ src: movie !== null && movie !== void 0 && (_movie$metaImage = movie.metaImage) !== null && _movie$metaImage !== void 0 && _movie$metaImage.url ? "".concat((_movie$metaImage2 = movie.metaImage) === null || _movie$metaImage2 === void 0 ? void 0 : _movie$metaImage2.url, "?").concat(makeSrcQueryString(IMAGE_WIDTH * 2)) : undefined
115
+ }), _jsxs(MovieTextWrapper, {
116
+ children: [_jsx(MovieTitle, {
117
+ children: movie.title
118
+ }), _jsx(MovieDescription, {
119
+ children: movie.metaDescription
120
+ })]
186
121
  })]
187
- })]
188
- })
122
+ })
123
+ }, movie.id);
189
124
  })]
190
- }, movie.id);
125
+ }, letter);
191
126
  })
192
127
  });
193
128
  };