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