@ndla/ui 34.0.0 → 34.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (94) hide show
  1. package/es/Figure/Figure.js +3 -2
  2. package/es/FileList/File.js +6 -6
  3. package/es/LanguageSelector/LanguageSelector.js +67 -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/ResourceGroup/ResourceList.js +4 -3
  14. package/es/Search/ActiveFilterContent.js +6 -5
  15. package/es/Search/ContentTypeResult.js +6 -3
  16. package/es/SearchTypeResult/ActiveFilterContent.js +9 -10
  17. package/es/Topic/Topic.js +171 -213
  18. package/es/all.css +1 -1
  19. package/es/locale/messages-en.js +3 -1
  20. package/es/locale/messages-nb.js +3 -1
  21. package/es/locale/messages-nn.js +7 -5
  22. package/es/locale/messages-se.js +2 -0
  23. package/es/locale/messages-sma.js +3 -1
  24. package/lib/Figure/Figure.d.ts +2 -1
  25. package/lib/Figure/Figure.js +3 -2
  26. package/lib/FileList/File.js +6 -6
  27. package/lib/LanguageSelector/LanguageSelector.d.ts +6 -15
  28. package/lib/LanguageSelector/LanguageSelector.js +64 -99
  29. package/lib/NDLAFilm/AboutNdlaFilm.js +11 -14
  30. package/lib/NDLAFilm/AllMoviesAlphabetically.d.ts +1 -2
  31. package/lib/NDLAFilm/AllMoviesAlphabetically.js +77 -142
  32. package/lib/NDLAFilm/FilmContentCard.d.ts +7 -0
  33. package/lib/NDLAFilm/FilmContentCard.js +41 -26
  34. package/lib/NDLAFilm/FilmContentCardTags.d.ts +2 -1
  35. package/lib/NDLAFilm/FilmContentCardTags.js +5 -3
  36. package/lib/NDLAFilm/FilmMovieList.js +12 -7
  37. package/lib/NDLAFilm/FilmMovieSearch.js +5 -4
  38. package/lib/NDLAFilm/FilmSlideshow.js +44 -20
  39. package/lib/NDLAFilm/filmStyles.js +2 -2
  40. package/lib/Resource/resourceComponents.d.ts +1 -1
  41. package/lib/ResourceGroup/ResourceItem.d.ts +2 -2
  42. package/lib/ResourceGroup/ResourceItem.js +72 -48
  43. package/lib/ResourceGroup/ResourceList.js +4 -3
  44. package/lib/Search/ActiveFilterContent.d.ts +1 -1
  45. package/lib/Search/ActiveFilterContent.js +9 -5
  46. package/lib/Search/ContentTypeResult.js +6 -3
  47. package/lib/SearchTypeResult/ActiveFilterContent.d.ts +1 -1
  48. package/lib/SearchTypeResult/ActiveFilterContent.js +12 -10
  49. package/lib/Topic/Topic.js +170 -215
  50. package/lib/all.css +1 -1
  51. package/lib/locale/messages-en.d.ts +2 -0
  52. package/lib/locale/messages-en.js +3 -1
  53. package/lib/locale/messages-nb.d.ts +2 -0
  54. package/lib/locale/messages-nb.js +3 -1
  55. package/lib/locale/messages-nn.d.ts +4 -2
  56. package/lib/locale/messages-nn.js +7 -5
  57. package/lib/locale/messages-se.d.ts +2 -0
  58. package/lib/locale/messages-se.js +2 -0
  59. package/lib/locale/messages-sma.d.ts +2 -0
  60. package/lib/locale/messages-sma.js +3 -1
  61. package/package.json +15 -14
  62. package/src/Figure/Figure.tsx +6 -2
  63. package/src/FileList/File.tsx +4 -4
  64. package/src/LanguageSelector/LanguageSelector.stories.tsx +48 -0
  65. package/src/LanguageSelector/LanguageSelector.tsx +70 -149
  66. package/src/NDLAFilm/AboutNdlaFilm.tsx +11 -14
  67. package/src/NDLAFilm/AllMoviesAlphabetically.tsx +44 -160
  68. package/src/NDLAFilm/FilmContentCard.tsx +40 -21
  69. package/src/NDLAFilm/FilmContentCardTags.tsx +3 -2
  70. package/src/NDLAFilm/FilmMovieList.tsx +14 -7
  71. package/src/NDLAFilm/FilmMovieSearch.tsx +2 -2
  72. package/src/NDLAFilm/FilmSlideshow.tsx +49 -40
  73. package/src/NDLAFilm/filmStyles.ts +1 -1
  74. package/src/ResourceGroup/ResourceItem.tsx +79 -94
  75. package/src/ResourceGroup/ResourceList.tsx +2 -0
  76. package/src/Search/ActiveFilterContent.tsx +4 -3
  77. package/src/Search/ContentTypeResult.tsx +3 -1
  78. package/src/SearchTypeResult/ActiveFilterContent.tsx +7 -8
  79. package/src/Topic/Topic.tsx +166 -193
  80. package/src/locale/messages-en.ts +3 -1
  81. package/src/locale/messages-nb.ts +3 -1
  82. package/src/locale/messages-nn.ts +5 -4
  83. package/src/locale/messages-se.ts +2 -0
  84. package/src/locale/messages-sma.ts +3 -1
  85. package/src/main.scss +0 -1
  86. package/es/LanguageSelector/LanguageSelectorContent.js +0 -61
  87. package/es/Subject/SubjectCarousel.js +0 -133
  88. package/lib/LanguageSelector/LanguageSelectorContent.d.ts +0 -15
  89. package/lib/LanguageSelector/LanguageSelectorContent.js +0 -68
  90. package/lib/Subject/SubjectCarousel.d.ts +0 -18
  91. package/lib/Subject/SubjectCarousel.js +0 -138
  92. package/src/LanguageSelector/LanguageSelectorContent.tsx +0 -80
  93. package/src/NDLAFilm/component.film-movielist.scss +0 -105
  94. package/src/Subject/SubjectCarousel.tsx +0 -162
@@ -7,188 +7,123 @@ Object.defineProperty(exports, "__esModule", {
7
7
  exports["default"] = void 0;
8
8
  var _base = _interopRequireDefault(require("@emotion/styled/base"));
9
9
  var _react = _interopRequireWildcard(require("react"));
10
- var _reactDeviceDetect = require("react-device-detect");
11
- var _react2 = require("@emotion/react");
12
- var _throttle = _interopRequireDefault(require("lodash/throttle"));
13
10
  var _core = require("@ndla/core");
14
11
  var _safelink = _interopRequireDefault(require("@ndla/safelink"));
12
+ var _groupBy = _interopRequireDefault(require("lodash/groupBy"));
13
+ var _sortBy = _interopRequireDefault(require("lodash/sortBy"));
14
+ var _reactI18next = require("react-i18next");
15
15
  var _Image = require("../Image");
16
- var _isLetter = require("./isLetter");
17
16
  var _jsxRuntime = require("@emotion/react/jsx-runtime");
18
17
  function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
19
18
  function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
20
19
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
21
- 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; }
22
- 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; }
23
- 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; }
24
20
  function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
25
21
  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."); }
26
22
  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); }
27
23
  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; }
28
24
  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; }
29
25
  function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
30
- 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)."; }
31
26
  var IMAGE_WIDTH = 143;
32
- var StyledNewLetter = /*#__PURE__*/(0, _base["default"])("h2", {
33
- target: "e1ul1xui7",
34
- label: "StyledNewLetter"
35
- })("color:#fff;margin:", _core.spacing.large, " 0 ", _core.spacingUnit * 0.75, "px;", _core.fonts.sizes(26, 1.1), ";", _core.mq.range({
27
+ var Letter = /*#__PURE__*/(0, _base["default"])("h2", {
28
+ target: "e1ul1xui8",
29
+ label: "Letter"
30
+ })("color:", _core.colors.white, ";", _core.mq.range({
36
31
  from: _core.breakpoints.tablet
37
- }), "{text-indent:", _core.spacingUnit * 0.75, "px;}&:after{content:'';display:block;height:1px;background:", _core.colors.brand.greyDark, ";margin-top:", _core.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"]} */"));
32
+ }), "{text-indent:", _core.spacingUnit * 0.75, "px;}&:after{content:'';display:block;height:1px;background:", _core.colors.brand.greyDark, ";margin-top:", _core.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== */"));
38
33
  var StyledWrapper = /*#__PURE__*/(0, _base["default"])("section", {
39
- target: "e1ul1xui6",
34
+ target: "e1ul1xui7",
40
35
  label: "StyledWrapper"
41
- })("width:652px;max-width:100%;margin:", _core.spacing.large, " auto;padding:0 ", _core.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"]} */"));
42
- var _ref2 = process.env.NODE_ENV === "production" ? {
43
- name: "cc7o7u-MovieItem",
44
- styles: "opacity:1;transform:translateY(0);label:MovieItem;"
45
- } : {
46
- name: "cc7o7u-MovieItem",
47
- styles: "opacity:1;transform:translateY(0);label:MovieItem;",
48
- 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"]} */",
49
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__
50
- };
36
+ })("width:652px;max-width:100%;margin:", _core.spacing.large, " auto;padding:0 ", _core.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== */"));
51
37
  var MovieItem = /*#__PURE__*/(0, _base["default"])("div", {
52
- target: "e1ul1xui5",
38
+ target: "e1ul1xui6",
53
39
  label: "MovieItem"
54
- })("margin:0 0 ", _core.spacingUnit * 0.75, "px;display:inline-flex;&:last-child{margin-bottom:", _core.spacing.large, ";}opacity:0;transform:translateY(", _core.spacing.xsmall, ");transition:all ", _core.animations.durations.slow, " ease;", function (props) {
55
- return props.inView && _ref2;
56
- }, ";" + (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"]} */"));
40
+ })("display:flex;gap:", _core.spacing.small, ";color:", _core.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== */"));
57
41
  var MovieTextWrapper = /*#__PURE__*/(0, _base["default"])("div", {
58
- target: "e1ul1xui4",
42
+ target: "e1ul1xui5",
59
43
  label: "MovieTextWrapper"
60
44
  })(_core.mq.range({
61
45
  from: _core.breakpoints.tablet
62
- }), "{padding:", _core.spacing.xsmall, " ", _core.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"]} */"));
63
- var MovieImage = /*#__PURE__*/(0, _base["default"])("div", {
64
- target: "e1ul1xui3",
46
+ }), "{padding:", _core.spacing.xsmall, " ", _core.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== */"));
47
+ var MovieImage = /*#__PURE__*/(0, _base["default"])("img", {
48
+ target: "e1ul1xui4",
65
49
  label: "MovieImage"
66
- })("width:104px;height:80px;background-color:", _core.colors.ndlaFilm.filmColorLight, ";", function (props) {
67
- return props.backgroundImage !== null && /*#__PURE__*/(0, _react2.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"]} */"));
68
- }, " background-size:cover;background-position:center center;margin:0 ", _core.spacingUnit * 0.75, "px 0 0;", _core.mq.range({
50
+ })("width:104px;height:80px;", _core.mq.range({
69
51
  from: _core.breakpoints.tablet
70
- }), "{margin-left:", _core.spacingUnit * 0.75, "px;width:", IMAGE_WIDTH, "px;height:90px;}position:relative;&:after{content:'';position:absolute;z-index:1;background:", _core.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"]} */"));
52
+ }), "{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== */"));
71
53
  var MovieTitle = /*#__PURE__*/(0, _base["default"])("h3", {
72
- target: "e1ul1xui2",
54
+ target: "e1ul1xui3",
73
55
  label: "MovieTitle"
74
- })("color:#fff;margin:0 0 2px;", _core.fonts.sizes(18, 1.3), ";", _core.mq.range({
75
- from: _core.breakpoints.tablet
76
- }), "{", _core.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"]} */"));
56
+ })("color:", _core.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== */"));
77
57
  var MovieDescription = /*#__PURE__*/(0, _base["default"])("p", {
78
- target: "e1ul1xui1",
58
+ target: "e1ul1xui2",
79
59
  label: "MovieDescription"
80
- })("color:", _core.colors.brand.greyLighter, ";margin:0;", _core.fonts.sizes(14, 1.5), ";", _core.mq.range({
81
- from: _core.breakpoints.tablet
82
- }), "{", _core.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"]} */"));
83
- var _ref = process.env.NODE_ENV === "production" ? {
84
- name: "1ogu8uf-StyledSafeLink",
85
- styles: "flex:1;label:StyledSafeLink;"
86
- } : {
87
- name: "1ogu8uf-StyledSafeLink",
88
- styles: "flex:1;label:StyledSafeLink;",
89
- 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"]} */",
90
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__
91
- };
60
+ })("color:", _core.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== */"));
92
61
  var StyledSafeLink = /*#__PURE__*/(0, _base["default"])(_safelink["default"], {
93
- target: "e1ul1xui0",
62
+ target: "e1ul1xui1",
94
63
  label: "StyledSafeLink"
95
- })("box-shadow:none;display:flex;", function (props) {
96
- return props.isIE11 && _ref;
97
- }, " &: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"]} */"));
98
- var hasForEachPolyfill = function hasForEachPolyfill() {
99
- // Polyfill for ie11
100
- if ('NodeList' in window && !NodeList.prototype.forEach) {
101
- NodeList.prototype.forEach = function (callback, thisArg) {
102
- thisArg = thisArg || window;
103
- for (var i = 0; i < this.length; i++) {
104
- callback.call(thisArg, this[i], i, this);
105
- }
64
+ })("box-shadow:none;display:flex;gap:", _core.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== */"));
65
+ var MovieGroup = /*#__PURE__*/(0, _base["default"])("section", {
66
+ target: "e1ul1xui0",
67
+ label: "MovieGroup"
68
+ })("display:flex;flex-direction:column;gap:", _core.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== */"));
69
+ var groupMovies = function groupMovies(movies) {
70
+ var sortedMovies = (0, _sortBy["default"])(movies, function (m) {
71
+ return m.title;
72
+ });
73
+ var grouped = (0, _groupBy["default"])(sortedMovies, function (movie) {
74
+ var _movie$title$;
75
+ var firstChar = (_movie$title$ = movie.title[0]) === null || _movie$title$ === void 0 ? void 0 : _movie$title$.toUpperCase();
76
+ var isLetter = firstChar === null || firstChar === void 0 ? void 0 : firstChar.match(/[A-Z\WÆØÅ]+/);
77
+ return isLetter ? firstChar : '#';
78
+ });
79
+ return Object.entries(grouped).map(function (_ref) {
80
+ var _ref2 = _slicedToArray(_ref, 2),
81
+ letter = _ref2[0],
82
+ movies = _ref2[1];
83
+ return {
84
+ letter: letter,
85
+ movies: movies
106
86
  };
107
- }
87
+ });
108
88
  };
109
89
  var AllMoviesAlphabetically = function AllMoviesAlphabetically(_ref3) {
110
- var movies = _ref3.movies,
111
- locale = _ref3.locale;
112
- var isIE11 = _reactDeviceDetect.isIE && parseInt(_reactDeviceDetect.browserVersion) < 12;
90
+ var movies = _ref3.movies;
91
+ var groupedMovies = (0, _react.useMemo)(function () {
92
+ return groupMovies(movies);
93
+ }, [movies]);
94
+ var _useTranslation = (0, _reactI18next.useTranslation)(),
95
+ t = _useTranslation.t;
113
96
  // Split into Letters.
114
- var previousLetter = '';
115
97
  var wrapperRef = (0, _react.useRef)(null);
116
- var _useState = (0, _react.useState)({}),
117
- _useState2 = _slicedToArray(_useState, 2),
118
- visibleImages = _useState2[0],
119
- setVisibleImages = _useState2[1];
120
- var scrollEvent = function scrollEvent() {
121
- hasForEachPolyfill();
122
- var updates = {};
123
- var allChildren = wrapperRef.current && wrapperRef.current.querySelectorAll('[role=img]');
124
- var windowInnerHeight = window.innerHeight;
125
- if (allChildren) {
126
- var started = false;
127
- var ended = false;
128
- allChildren.forEach(function (el, index) {
129
- if (!ended) {
130
- var rect = el.getBoundingClientRect();
131
- if (!started) {
132
- if (rect.top > -20) {
133
- updates[index] = true;
134
- started = true;
135
- }
136
- } else {
137
- updates[index] = true;
138
- if (rect.top > windowInnerHeight + 20) {
139
- ended = true;
140
- }
141
- }
142
- }
143
- });
144
- }
145
- setVisibleImages(function (visibleImages) {
146
- return _objectSpread(_objectSpread({}, visibleImages), updates);
147
- });
148
- };
149
- (0, _react.useEffect)(function () {
150
- var throttledScrollEvent = (0, _throttle["default"])(function () {
151
- scrollEvent();
152
- }, 100);
153
- window.addEventListener('scroll', throttledScrollEvent);
154
- scrollEvent();
155
- return function () {
156
- window.removeEventListener('scroll', throttledScrollEvent);
157
- };
158
- }, []);
159
- (0, _react.useEffect)(function () {
160
- scrollEvent();
161
- }, [movies]);
162
98
  return (0, _jsxRuntime.jsx)(StyledWrapper, {
163
99
  ref: wrapperRef,
164
- children: movies.map(function (movie, index) {
165
- var currentLetter = movie.title.substr(0, 1);
166
- var isNewLetter = currentLetter.localeCompare(previousLetter, locale) === 1 && (0, _isLetter.isLetter)(movie.title);
167
- previousLetter = currentLetter;
168
- var inView = visibleImages ? visibleImages[index] : null;
169
- return (0, _jsxRuntime.jsxs)(_react.Fragment, {
170
- children: [isNewLetter && (0, _jsxRuntime.jsx)(StyledNewLetter, {
171
- children: movie.title.substr(0, 1)
172
- }), (0, _jsxRuntime.jsx)(MovieItem, {
173
- inView: inView,
174
- children: (0, _jsxRuntime.jsxs)(StyledSafeLink, {
175
- isIE11: isIE11,
176
- to: movie.path,
177
- children: [(0, _jsxRuntime.jsx)(MovieImage, {
178
- role: "img",
179
- backgroundImage: inView && movie.metaImage && movie.metaImage.url ? "".concat(movie.metaImage.url, "?").concat((0, _Image.makeSrcQueryString)(IMAGE_WIDTH * 2)) : null,
180
- "aria-label": movie.metaImage && movie.metaImage.alt,
181
- title: movie.title
182
- }), (0, _jsxRuntime.jsxs)(MovieTextWrapper, {
183
- children: [(0, _jsxRuntime.jsx)(MovieTitle, {
184
- children: movie.title
185
- }), (0, _jsxRuntime.jsx)(MovieDescription, {
186
- children: movie.metaDescription
100
+ children: groupedMovies.map(function (_ref4) {
101
+ var letter = _ref4.letter,
102
+ movies = _ref4.movies;
103
+ return (0, _jsxRuntime.jsxs)(MovieGroup, {
104
+ children: [(0, _jsxRuntime.jsx)(Letter, {
105
+ "aria-label": t('filmfrontpage.allMovieGroupTitleLabel', {
106
+ letter: letter
107
+ }),
108
+ children: letter
109
+ }), movies.map(function (movie) {
110
+ var _movie$metaImage, _movie$metaImage2;
111
+ return (0, _jsxRuntime.jsx)(MovieItem, {
112
+ children: (0, _jsxRuntime.jsxs)(StyledSafeLink, {
113
+ to: movie.path,
114
+ children: [(0, _jsxRuntime.jsx)(MovieImage, {
115
+ 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((0, _Image.makeSrcQueryString)(IMAGE_WIDTH * 2)) : undefined
116
+ }), (0, _jsxRuntime.jsxs)(MovieTextWrapper, {
117
+ children: [(0, _jsxRuntime.jsx)(MovieTitle, {
118
+ children: movie.title
119
+ }), (0, _jsxRuntime.jsx)(MovieDescription, {
120
+ children: movie.metaDescription
121
+ })]
187
122
  })]
188
- })]
189
- })
123
+ })
124
+ }, movie.id);
190
125
  })]
191
- }, movie.id);
126
+ }, letter);
192
127
  })
193
128
  });
194
129
  };