@ndla/ui 15.2.0 → 16.1.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (58) hide show
  1. package/es/Article/ArticleContent.js +2 -0
  2. package/es/FileList/File.js +7 -12
  3. package/es/Filter/FilterButtons.js +13 -13
  4. package/es/NDLAFilm/CategorySelect.js +51 -25
  5. package/es/NDLAFilm/FilmMovieList.js +14 -10
  6. package/es/NDLAFilm/FilmMovieSearch.js +23 -10
  7. package/es/NDLAFilm/FilmSlideshow.js +117 -19
  8. package/es/NDLAFilm/MovieGrid.js +23 -14
  9. package/es/NDLAFilm/NavigationArrow.js +33 -7
  10. package/es/NDLAFilm/SlideshowIndicator.js +27 -11
  11. package/es/NDLAFilm/filmStyles.js +23 -0
  12. package/es/RadioButtonGroup/RadioButtonGroup.js +28 -9
  13. package/es/Resource/resourceComponents.js +17 -9
  14. package/es/TreeStructure/TreeStructure.js +6 -9
  15. package/es/all.css +1 -1
  16. package/lib/Article/ArticleContent.js +3 -0
  17. package/lib/FileList/File.js +10 -14
  18. package/lib/Filter/FilterButtons.js +13 -13
  19. package/lib/Frontpage/FrontpageMultidisciplinarySubject.d.ts +5 -5
  20. package/lib/Frontpage/illustrations/FrontpageIllustrations.d.ts +2 -2
  21. package/lib/MultidisciplinarySubject/Illustrations.d.ts +7 -7
  22. package/lib/NDLAFilm/CategorySelect.js +52 -30
  23. package/lib/NDLAFilm/FilmMovieList.js +17 -13
  24. package/lib/NDLAFilm/FilmMovieSearch.js +29 -17
  25. package/lib/NDLAFilm/FilmSlideshow.js +113 -24
  26. package/lib/NDLAFilm/MovieGrid.js +26 -16
  27. package/lib/NDLAFilm/NavigationArrow.d.ts +5 -1
  28. package/lib/NDLAFilm/NavigationArrow.js +34 -10
  29. package/lib/NDLAFilm/SlideshowIndicator.js +34 -13
  30. package/lib/NDLAFilm/filmStyles.d.ts +8 -0
  31. package/lib/NDLAFilm/filmStyles.js +38 -0
  32. package/lib/RadioButtonGroup/RadioButtonGroup.js +28 -13
  33. package/lib/Resource/resourceComponents.d.ts +2 -2
  34. package/lib/Resource/resourceComponents.js +17 -9
  35. package/lib/Search/ContentTypeResultStyles.d.ts +3 -3
  36. package/lib/SearchTypeResult/ActiveFilterContent.d.ts +1 -1
  37. package/lib/TreeStructure/TreeStructure.js +6 -9
  38. package/lib/all.css +1 -1
  39. package/package.json +7 -7
  40. package/src/Article/ArticleContent.tsx +2 -0
  41. package/src/FileList/File.tsx +8 -11
  42. package/src/Filter/FilterButtons.tsx +3 -4
  43. package/src/NDLAFilm/CategorySelect.tsx +110 -23
  44. package/src/NDLAFilm/FilmMovieList.tsx +13 -11
  45. package/src/NDLAFilm/FilmMovieSearch.tsx +45 -14
  46. package/src/NDLAFilm/FilmSlideshow.tsx +186 -25
  47. package/src/NDLAFilm/MovieGrid.tsx +33 -25
  48. package/src/NDLAFilm/NavigationArrow.tsx +76 -10
  49. package/src/NDLAFilm/SlideshowIndicator.tsx +53 -11
  50. package/src/NDLAFilm/component.film-movielist.scss +0 -46
  51. package/src/NDLAFilm/filmStyles.ts +33 -0
  52. package/src/RadioButtonGroup/RadioButtonGroup.tsx +82 -11
  53. package/src/Resource/resourceComponents.tsx +1 -3
  54. package/src/TreeStructure/TreeStructure.tsx +5 -11
  55. package/src/main.scss +0 -3
  56. package/src/NDLAFilm/component.film-moviesearch.scss +0 -127
  57. package/src/NDLAFilm/component.film-slideshow.scss +0 -258
  58. package/src/RadioButtonGroup/component.radio-button-group.scss +0 -67
@@ -7,11 +7,15 @@ Object.defineProperty(exports, "__esModule", {
7
7
  });
8
8
  exports["default"] = void 0;
9
9
 
10
+ var _styledBase = _interopRequireDefault(require("@emotion/styled-base"));
11
+
10
12
  var _react = _interopRequireWildcard(require("react"));
11
13
 
12
14
  var _reactSwipeable = require("react-swipeable");
13
15
 
14
- var _reactBemHelper = _interopRequireDefault(require("react-bem-helper"));
16
+ var _core = require("@emotion/core");
17
+
18
+ var _core2 = require("@ndla/core");
15
19
 
16
20
  var _safelink = _interopRequireDefault(require("@ndla/safelink"));
17
21
 
@@ -19,18 +23,16 @@ var _Layout = require("../Layout");
19
23
 
20
24
  var _Spinner = _interopRequireDefault(require("../Spinner"));
21
25
 
22
- var _NavigationArrow = _interopRequireDefault(require("./NavigationArrow"));
26
+ var _NavigationArrow = _interopRequireWildcard(require("./NavigationArrow"));
23
27
 
24
28
  var _SlideshowIndicator = _interopRequireDefault(require("./SlideshowIndicator"));
25
29
 
26
- var _core = require("@emotion/core");
27
-
28
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
29
-
30
30
  function _getRequireWildcardCache() { if (typeof WeakMap !== "function") return null; var cache = new WeakMap(); _getRequireWildcardCache = function _getRequireWildcardCache() { return cache; }; return cache; }
31
31
 
32
32
  function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
33
33
 
34
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
35
+
34
36
  function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
35
37
 
36
38
  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."); }
@@ -43,24 +45,111 @@ function _iterableToArrayLimit(arr, i) { if (typeof Symbol === "undefined" || !(
43
45
 
44
46
  function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
45
47
 
46
- function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
47
-
48
- var classes = new _reactBemHelper["default"]({
49
- name: 'film-slideshow',
50
- prefix: 'c-'
48
+ 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)."; }
49
+
50
+ var SlideLinkWrapper = (0, _styledBase["default"])("div", {
51
+ target: "essc37o0",
52
+ label: "SlideLinkWrapper"
53
+ })("margin:0 auto;display:flex;justify-content:flex-start;align-items:flex-end;position:absolute;z-index:2;height:100vw;width:100%;", _core2.mq.range({
54
+ from: _core2.breakpoints.mobileWide
55
+ }), "{height:100vw;}", _core2.mq.range({
56
+ from: _core2.breakpoints.tablet
57
+ }), "{height:75vw;}", _core2.mq.range({
58
+ from: _core2.breakpoints.desktop
59
+ }), "{height:55vw;}", _core2.mq.range({
60
+ from: _core2.breakpoints.wide
61
+ }), "{height:40vw;}", _core2.mq.range({
62
+ from: _core2.breakpoints.ultraWide
63
+ }), "{height:36vw;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FilmSlideshow.tsx"],"names":[],"mappings":"AA2BmC","file":"FilmSlideshow.tsx","sourcesContent":["/**\n * Copyright (c) 2016-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { useCallback, useEffect, useRef, useState } from 'react';\nimport { SwipeEventData, useSwipeable } from 'react-swipeable';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/core';\nimport { breakpoints, mq, spacing, spacingUnit, fonts, colors } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\nimport { OneColumn } from '../Layout';\nimport Spinner from '../Spinner';\nimport NavigationArrow, { StyledNavigationArrow } from './NavigationArrow';\nimport SlideshowIndicator from './SlideshowIndicator';\nimport { MovieType } from './types';\n\ninterface Props {\n  autoSlide?: boolean;\n  randomStart?: boolean;\n  slideshow: MovieType[];\n  slideInterval?: number;\n}\n\nconst SlideLinkWrapper = styled.div`\n  margin: 0 auto;\n  display: flex;\n  justify-content: flex-start;\n  align-items: flex-end;\n  position: absolute;\n  z-index: 2;\n  height: 100vw;\n  width: 100%;\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    height: 100vw;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 75vw;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    height: 55vw;\n  }\n  ${mq.range({ from: breakpoints.wide })} {\n    height: 40vw;\n  }\n  ${mq.range({ from: breakpoints.ultraWide })} {\n    height: 36vw;\n  }\n`;\n\nconst itemWrapperCSS = css`\n  display: flex;\n  box-shadow: none;\n`;\n\ninterface SlideshowItemProps {\n  fadeOver?: boolean;\n}\n\nconst SlideshowItem = styled.div<SlideshowItemProps>`\n  width: 100vw;\n  height: 100vw;\n  /* aspect ratios */\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    height: 100vw;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 75vw;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    height: 55vw;\n  }\n  ${mq.range({ from: breakpoints.wide })} {\n    height: 40vw;\n  }\n  ${mq.range({ from: breakpoints.ultraWide })} {\n    height: 36vw;\n  }\n  background-color: '#222';\n  background-size: cover;\n  background-position-x: center;\n  background-position-y: center;\n  border: 0;\n  position: ${(props) => (props.fadeOver ? 'absolute' : 'relative')};\n  animation: ${(props) => props.fadeOver && 'fadeIn 400ms ease'};\n  z-index: ${(props) => props.fadeOver && 1};\n  &:before {\n    content: '';\n    opacity: 0.4;\n    background: #091a2a;\n    top: 0;\n    left: 0;\n    bottom: 0;\n    right: 0;\n    position: absolute;\n    z-index: 1;\n  }\n`;\n\ninterface SlideshowLinkProps {\n  out?: boolean;\n}\n\nconst SlideshowLink = styled(SafeLink)<SlideshowLinkProps>`\n  display: flex;\n  box-shadow: none;\n  transition: all 400ms ease;\n  opacity: ${(props) => props.out && 0};\n  animation: ${(props) => !props.out && 'fadeInBottomFixed 600ms ease'};\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    padding-bottom: ${spacing.medium};\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-bottom: ${spacing.large};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-bottom: ${spacingUnit * 3}px;\n  }\n  &:hover {\n    h1 {\n      text-decoration: underline;\n    }\n  }\n`;\n\nconst SlideshowWrapper = styled.section`\n  &:hover {\n    ${StyledNavigationArrow} {\n      opacity: 1;\n      transform: translate(0, 0);\n    }\n  }\n`;\n\nconst SlideshowInfo = styled.div`\n  border: 0;\n  background: none;\n  background-color: rgba(3, 23, 43, 0.7);\n  border-radius: 4px;\n  padding: ${spacing.medium} ${spacing.medium} ${spacing.medium} ${spacing.normal};\n  margin: 0 -20px;\n  width: 100vw;\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    margin: 0;\n    width: 100%;\n    padding: ${spacing.medium} ${spacingUnit * 2}px ${spacing.medium} ${spacing.normal};\n  }\n  h1 {\n    ${fonts.sizes('22px', '30px')};\n    color: ${colors.white};\n    text-shadow: 0 2px 4px rgba(0, 0, 0, 0.25);\n    margin: 0;\n    font-weight: ${fonts.weight.semibold};\n    ${mq.range({ from: breakpoints.mobileWide })} {\n      margin: 0 0 ${spacing.small};\n      ${fonts.sizes('26px', '30px')};\n    }\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes('40px', '44px')};\n    }\n    ${mq.range({ from: breakpoints.desktop })} {\n      ${fonts.sizes('48px', '54px')};\n    }\n  }\n\n  p {\n    color: ${colors.white};\n    display: inline-block;\n    margin: 0;\n    padding: 0;\n    border-radius: 4px;\n    ${fonts.sizes('12px', '18px')};\n    ${mq.range({ from: breakpoints.mobileWide })} {\n      ${fonts.sizes('15px', '20px')};\n    }\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes('18px', '24px')};\n    }\n    ${mq.range({ from: breakpoints.wide })} {\n      ${fonts.sizes('20px', '32px')};\n    }\n  }\n`;\n\nconst EmptySlideshow = styled.div`\n  background: rgba(255, 255, 255, 0.08);\n  margin-bottom: $spacing--large * 4;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  height: 40vw;\n`;\n\nconst defaultTransitionSwipeEnd = 'transform 600ms cubic-bezier(0, 0.76, 0.09, 1)';\nconst defaultTransitionText = 'opacity 600ms ease';\n\nconst renderSlideItem = (slide: MovieType) => (\n  <SlideshowItem\n    key={slide.id}\n    role=\"img\"\n    aria-label={(slide.metaImage && slide.metaImage.alt) || ''}\n    style={{\n      backgroundImage: `url(${(slide.metaImage && slide.metaImage.url) || ''})`,\n    }}\n  />\n);\n\nconst FilmSlideshow = ({ autoSlide = false, slideshow = [], slideInterval = 5000 }: Props) => {\n  const [swipeDistance, setSwipeDistance] = useState(0);\n  const [slideIndex, setSlideIndex] = useState(0);\n  const [slideIndexTarget, setSlideIndexTarget] = useState(0);\n  const [animationComplete, setAnimationComplete] = useState(true);\n  const slideRef = useRef<HTMLDivElement>(null);\n  const slideText = useRef<HTMLDivElement>(null);\n  let timer = useRef<ReturnType<typeof setTimeout> | null>(null);\n\n  const gotoSlide = useCallback((indexTarget: number, useAnimation = false) => {\n    setSwipeDistance(0);\n    if (timer.current) {\n      clearTimeout(timer.current);\n    }\n    setSlideIndexTarget(indexTarget);\n    setAnimationComplete(!useAnimation);\n  }, []);\n\n  const onChangedSlide = () => {\n    if (!animationComplete) {\n      if (slideRef.current) {\n        slideRef.current.style.transition = 'none';\n        slideRef.current.style.transform = `translateX(${slideIndexTarget * 100}vw))`;\n      }\n\n      setAnimationComplete(true);\n      setSlideIndex(slideIndexTarget);\n    } else if (slideIndexTarget === -1) {\n      if (slideRef.current) {\n        // Go to last slide for continuous loop\n        slideRef.current.style.transition = 'none';\n        slideRef.current.style.transform = `translateX(${slideshow.length * 100}vw))`;\n      }\n\n      setSlideIndex(slideshow.length - 1);\n      setSlideIndexTarget(slideshow.length - 1);\n      setAnimationComplete(true);\n    } else if (slideIndexTarget === slideshow.length) {\n      if (slideRef.current) {\n        // Go to first slide for continuous loop\n        slideRef.current.style.transition = 'none';\n        slideRef.current.style.transform = `translateX(100vw))`;\n      }\n      setSlideIndex(0);\n      setSlideIndexTarget(0);\n      setAnimationComplete(true);\n    } else {\n      setAnimationComplete(true);\n      setSlideIndex(slideIndexTarget);\n    }\n  };\n\n  const onSwipeEnd = () => {\n    let slide;\n    if (swipeDistance > 40) {\n      slide = -1;\n    } else if (swipeDistance < -40) {\n      slide = 1;\n    } else {\n      slide = 0;\n    }\n    if (slideRef.current && slideText.current) {\n      slideRef.current.style.transition = defaultTransitionSwipeEnd;\n      slideText.current.style.transition = defaultTransitionText;\n      slideText.current.style.opacity = '1';\n    }\n    setSwipeDistance(0);\n\n    initTimer();\n\n    if (slide !== 0) {\n      setSlideIndex(slideIndex + slide);\n      setSlideIndexTarget(slideIndex + slide);\n    } else {\n      // Reset transfrom\n      if (slideRef.current) {\n        slideRef.current.style.transform = getSlidePosition(slideIndex + slide);\n      }\n    }\n  };\n\n  const onSwipe = (eventData: SwipeEventData) => {\n    if (eventData.dir === 'Up' || eventData.dir === 'Down') {\n      return;\n    }\n    if (timer.current) {\n      clearTimeout(timer.current);\n    }\n    setSwipeDistance(eventData.deltaX);\n    if (slideRef && slideRef.current) {\n      slideRef.current.style.transition = 'none';\n      slideRef.current.style.transform = getSlidePosition(slideIndexTarget);\n    }\n    const opacityText = 1 - Math.min(100, Math.abs(swipeDistance)) / 100;\n    if (slideText && slideText.current) {\n      slideText.current.style.transition = 'none';\n      slideText.current.style.opacity = opacityText.toString();\n    }\n  };\n\n  const onTransitionEnd = () => {\n    const slideshowLength = slideshow.length;\n    if (slideIndex === -1) {\n      if (slideRef.current) {\n        slideRef.current.style.transition = 'none';\n        slideRef.current.style.transform = getSlidePosition(slideshowLength - 1);\n      }\n      setSlideIndex(slideshowLength - 1);\n      setSlideIndexTarget(slideshowLength - 1);\n    } else if (slideIndex >= slideshowLength) {\n      if (slideRef.current) {\n        slideRef.current.style.transition = 'none';\n        slideRef.current.style.transform = getSlidePosition(0);\n      }\n      setSlideIndex(0);\n      setSlideIndexTarget(0);\n    }\n  };\n\n  const getSlidePosition = (target: number) => {\n    if (swipeDistance !== 0) {\n      return `translateX(calc(${swipeDistance}px -\n        ${(target + 1) * 100}vw))`;\n    }\n    return `translateX(-${(target + 1) * 100}vw)`;\n  };\n\n  const initTimer = useCallback(() => {\n    if (autoSlide) {\n      timer.current = setTimeout(() => {\n        gotoSlide(slideIndex + 1);\n      }, slideInterval);\n    }\n  }, [autoSlide, gotoSlide, slideInterval, slideIndex]);\n\n  useEffect(() => {\n    initTimer();\n  }, [initTimer]);\n\n  const handlers = useSwipeable({\n    onSwiped: onSwipeEnd,\n    onSwiping: onSwipe,\n  });\n\n  if (slideshow.length === 0) {\n    return (\n      <div>\n        <EmptySlideshow>\n          <Spinner inverted />\n        </EmptySlideshow>\n      </div>\n    );\n  }\n\n  const slideshowWidth = `${(slideshow.length + 2) * 100}vw`;\n  let activeSlide = slideIndex;\n  if (activeSlide < 0) {\n    activeSlide = slideshow.length - 1;\n  } else if (activeSlide >= slideshow.length) {\n    activeSlide = 0;\n  }\n\n  const backgroundImage = slideshow[activeSlide].metaImage;\n\n  return (\n    <SlideshowWrapper {...handlers}>\n      <>\n        <SlideLinkWrapper>\n          <OneColumn>\n            <SlideshowLink to={slideshow[activeSlide].path} out={!animationComplete}>\n              <SlideshowInfo ref={slideText}>\n                <h1>{slideshow[activeSlide].title}</h1>\n                <p>{slideshow[activeSlide].metaDescription}</p>\n              </SlideshowInfo>\n            </SlideshowLink>\n          </OneColumn>\n        </SlideLinkWrapper>\n        <NavigationArrow\n          slideIndexTarget={slideIndexTarget > 0 ? slideIndexTarget - 1 : slideshow.length - 1}\n          gotoSlide={gotoSlide}\n        />\n        <NavigationArrow\n          slideIndexTarget={slideIndexTarget < slideshow.length - 1 ? slideIndexTarget + 1 : 0}\n          gotoSlide={gotoSlide}\n          rightArrow\n        />\n        {!animationComplete && (\n          <SlideshowItem\n            fadeOver\n            role=\"img\"\n            onAnimationEnd={onChangedSlide}\n            style={{\n              backgroundImage: `url(${(backgroundImage && backgroundImage.url) || ''})`,\n            }}\n          />\n        )}\n        <div\n          ref={slideRef}\n          css={itemWrapperCSS}\n          onTransitionEnd={onTransitionEnd}\n          style={{\n            width: slideshowWidth,\n            transform: getSlidePosition(slideIndex),\n          }}>\n          {renderSlideItem(slideshow[slideshow.length - 1])}\n          {slideshow.map(renderSlideItem)}\n          {renderSlideItem(slideshow[0])}\n        </div>\n        <SlideshowIndicator slideshow={slideshow} activeSlide={activeSlide} gotoSlide={gotoSlide} />\n      </>\n    </SlideshowWrapper>\n  );\n};\n\nexport default FilmSlideshow;\n"]} */"));
64
+ var itemWrapperCSS = process.env.NODE_ENV === "production" ? {
65
+ name: "m1vhg0-itemWrapperCSS",
66
+ styles: "display:flex;box-shadow:none;;label:itemWrapperCSS;"
67
+ } : {
68
+ name: "m1vhg0-itemWrapperCSS",
69
+ styles: "display:flex;box-shadow:none;;label:itemWrapperCSS;",
70
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FilmSlideshow.tsx"],"names":[],"mappings":"AAqD0B","file":"FilmSlideshow.tsx","sourcesContent":["/**\n * Copyright (c) 2016-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { useCallback, useEffect, useRef, useState } from 'react';\nimport { SwipeEventData, useSwipeable } from 'react-swipeable';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/core';\nimport { breakpoints, mq, spacing, spacingUnit, fonts, colors } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\nimport { OneColumn } from '../Layout';\nimport Spinner from '../Spinner';\nimport NavigationArrow, { StyledNavigationArrow } from './NavigationArrow';\nimport SlideshowIndicator from './SlideshowIndicator';\nimport { MovieType } from './types';\n\ninterface Props {\n  autoSlide?: boolean;\n  randomStart?: boolean;\n  slideshow: MovieType[];\n  slideInterval?: number;\n}\n\nconst SlideLinkWrapper = styled.div`\n  margin: 0 auto;\n  display: flex;\n  justify-content: flex-start;\n  align-items: flex-end;\n  position: absolute;\n  z-index: 2;\n  height: 100vw;\n  width: 100%;\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    height: 100vw;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 75vw;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    height: 55vw;\n  }\n  ${mq.range({ from: breakpoints.wide })} {\n    height: 40vw;\n  }\n  ${mq.range({ from: breakpoints.ultraWide })} {\n    height: 36vw;\n  }\n`;\n\nconst itemWrapperCSS = css`\n  display: flex;\n  box-shadow: none;\n`;\n\ninterface SlideshowItemProps {\n  fadeOver?: boolean;\n}\n\nconst SlideshowItem = styled.div<SlideshowItemProps>`\n  width: 100vw;\n  height: 100vw;\n  /* aspect ratios */\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    height: 100vw;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 75vw;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    height: 55vw;\n  }\n  ${mq.range({ from: breakpoints.wide })} {\n    height: 40vw;\n  }\n  ${mq.range({ from: breakpoints.ultraWide })} {\n    height: 36vw;\n  }\n  background-color: '#222';\n  background-size: cover;\n  background-position-x: center;\n  background-position-y: center;\n  border: 0;\n  position: ${(props) => (props.fadeOver ? 'absolute' : 'relative')};\n  animation: ${(props) => props.fadeOver && 'fadeIn 400ms ease'};\n  z-index: ${(props) => props.fadeOver && 1};\n  &:before {\n    content: '';\n    opacity: 0.4;\n    background: #091a2a;\n    top: 0;\n    left: 0;\n    bottom: 0;\n    right: 0;\n    position: absolute;\n    z-index: 1;\n  }\n`;\n\ninterface SlideshowLinkProps {\n  out?: boolean;\n}\n\nconst SlideshowLink = styled(SafeLink)<SlideshowLinkProps>`\n  display: flex;\n  box-shadow: none;\n  transition: all 400ms ease;\n  opacity: ${(props) => props.out && 0};\n  animation: ${(props) => !props.out && 'fadeInBottomFixed 600ms ease'};\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    padding-bottom: ${spacing.medium};\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-bottom: ${spacing.large};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-bottom: ${spacingUnit * 3}px;\n  }\n  &:hover {\n    h1 {\n      text-decoration: underline;\n    }\n  }\n`;\n\nconst SlideshowWrapper = styled.section`\n  &:hover {\n    ${StyledNavigationArrow} {\n      opacity: 1;\n      transform: translate(0, 0);\n    }\n  }\n`;\n\nconst SlideshowInfo = styled.div`\n  border: 0;\n  background: none;\n  background-color: rgba(3, 23, 43, 0.7);\n  border-radius: 4px;\n  padding: ${spacing.medium} ${spacing.medium} ${spacing.medium} ${spacing.normal};\n  margin: 0 -20px;\n  width: 100vw;\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    margin: 0;\n    width: 100%;\n    padding: ${spacing.medium} ${spacingUnit * 2}px ${spacing.medium} ${spacing.normal};\n  }\n  h1 {\n    ${fonts.sizes('22px', '30px')};\n    color: ${colors.white};\n    text-shadow: 0 2px 4px rgba(0, 0, 0, 0.25);\n    margin: 0;\n    font-weight: ${fonts.weight.semibold};\n    ${mq.range({ from: breakpoints.mobileWide })} {\n      margin: 0 0 ${spacing.small};\n      ${fonts.sizes('26px', '30px')};\n    }\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes('40px', '44px')};\n    }\n    ${mq.range({ from: breakpoints.desktop })} {\n      ${fonts.sizes('48px', '54px')};\n    }\n  }\n\n  p {\n    color: ${colors.white};\n    display: inline-block;\n    margin: 0;\n    padding: 0;\n    border-radius: 4px;\n    ${fonts.sizes('12px', '18px')};\n    ${mq.range({ from: breakpoints.mobileWide })} {\n      ${fonts.sizes('15px', '20px')};\n    }\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes('18px', '24px')};\n    }\n    ${mq.range({ from: breakpoints.wide })} {\n      ${fonts.sizes('20px', '32px')};\n    }\n  }\n`;\n\nconst EmptySlideshow = styled.div`\n  background: rgba(255, 255, 255, 0.08);\n  margin-bottom: $spacing--large * 4;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  height: 40vw;\n`;\n\nconst defaultTransitionSwipeEnd = 'transform 600ms cubic-bezier(0, 0.76, 0.09, 1)';\nconst defaultTransitionText = 'opacity 600ms ease';\n\nconst renderSlideItem = (slide: MovieType) => (\n  <SlideshowItem\n    key={slide.id}\n    role=\"img\"\n    aria-label={(slide.metaImage && slide.metaImage.alt) || ''}\n    style={{\n      backgroundImage: `url(${(slide.metaImage && slide.metaImage.url) || ''})`,\n    }}\n  />\n);\n\nconst FilmSlideshow = ({ autoSlide = false, slideshow = [], slideInterval = 5000 }: Props) => {\n  const [swipeDistance, setSwipeDistance] = useState(0);\n  const [slideIndex, setSlideIndex] = useState(0);\n  const [slideIndexTarget, setSlideIndexTarget] = useState(0);\n  const [animationComplete, setAnimationComplete] = useState(true);\n  const slideRef = useRef<HTMLDivElement>(null);\n  const slideText = useRef<HTMLDivElement>(null);\n  let timer = useRef<ReturnType<typeof setTimeout> | null>(null);\n\n  const gotoSlide = useCallback((indexTarget: number, useAnimation = false) => {\n    setSwipeDistance(0);\n    if (timer.current) {\n      clearTimeout(timer.current);\n    }\n    setSlideIndexTarget(indexTarget);\n    setAnimationComplete(!useAnimation);\n  }, []);\n\n  const onChangedSlide = () => {\n    if (!animationComplete) {\n      if (slideRef.current) {\n        slideRef.current.style.transition = 'none';\n        slideRef.current.style.transform = `translateX(${slideIndexTarget * 100}vw))`;\n      }\n\n      setAnimationComplete(true);\n      setSlideIndex(slideIndexTarget);\n    } else if (slideIndexTarget === -1) {\n      if (slideRef.current) {\n        // Go to last slide for continuous loop\n        slideRef.current.style.transition = 'none';\n        slideRef.current.style.transform = `translateX(${slideshow.length * 100}vw))`;\n      }\n\n      setSlideIndex(slideshow.length - 1);\n      setSlideIndexTarget(slideshow.length - 1);\n      setAnimationComplete(true);\n    } else if (slideIndexTarget === slideshow.length) {\n      if (slideRef.current) {\n        // Go to first slide for continuous loop\n        slideRef.current.style.transition = 'none';\n        slideRef.current.style.transform = `translateX(100vw))`;\n      }\n      setSlideIndex(0);\n      setSlideIndexTarget(0);\n      setAnimationComplete(true);\n    } else {\n      setAnimationComplete(true);\n      setSlideIndex(slideIndexTarget);\n    }\n  };\n\n  const onSwipeEnd = () => {\n    let slide;\n    if (swipeDistance > 40) {\n      slide = -1;\n    } else if (swipeDistance < -40) {\n      slide = 1;\n    } else {\n      slide = 0;\n    }\n    if (slideRef.current && slideText.current) {\n      slideRef.current.style.transition = defaultTransitionSwipeEnd;\n      slideText.current.style.transition = defaultTransitionText;\n      slideText.current.style.opacity = '1';\n    }\n    setSwipeDistance(0);\n\n    initTimer();\n\n    if (slide !== 0) {\n      setSlideIndex(slideIndex + slide);\n      setSlideIndexTarget(slideIndex + slide);\n    } else {\n      // Reset transfrom\n      if (slideRef.current) {\n        slideRef.current.style.transform = getSlidePosition(slideIndex + slide);\n      }\n    }\n  };\n\n  const onSwipe = (eventData: SwipeEventData) => {\n    if (eventData.dir === 'Up' || eventData.dir === 'Down') {\n      return;\n    }\n    if (timer.current) {\n      clearTimeout(timer.current);\n    }\n    setSwipeDistance(eventData.deltaX);\n    if (slideRef && slideRef.current) {\n      slideRef.current.style.transition = 'none';\n      slideRef.current.style.transform = getSlidePosition(slideIndexTarget);\n    }\n    const opacityText = 1 - Math.min(100, Math.abs(swipeDistance)) / 100;\n    if (slideText && slideText.current) {\n      slideText.current.style.transition = 'none';\n      slideText.current.style.opacity = opacityText.toString();\n    }\n  };\n\n  const onTransitionEnd = () => {\n    const slideshowLength = slideshow.length;\n    if (slideIndex === -1) {\n      if (slideRef.current) {\n        slideRef.current.style.transition = 'none';\n        slideRef.current.style.transform = getSlidePosition(slideshowLength - 1);\n      }\n      setSlideIndex(slideshowLength - 1);\n      setSlideIndexTarget(slideshowLength - 1);\n    } else if (slideIndex >= slideshowLength) {\n      if (slideRef.current) {\n        slideRef.current.style.transition = 'none';\n        slideRef.current.style.transform = getSlidePosition(0);\n      }\n      setSlideIndex(0);\n      setSlideIndexTarget(0);\n    }\n  };\n\n  const getSlidePosition = (target: number) => {\n    if (swipeDistance !== 0) {\n      return `translateX(calc(${swipeDistance}px -\n        ${(target + 1) * 100}vw))`;\n    }\n    return `translateX(-${(target + 1) * 100}vw)`;\n  };\n\n  const initTimer = useCallback(() => {\n    if (autoSlide) {\n      timer.current = setTimeout(() => {\n        gotoSlide(slideIndex + 1);\n      }, slideInterval);\n    }\n  }, [autoSlide, gotoSlide, slideInterval, slideIndex]);\n\n  useEffect(() => {\n    initTimer();\n  }, [initTimer]);\n\n  const handlers = useSwipeable({\n    onSwiped: onSwipeEnd,\n    onSwiping: onSwipe,\n  });\n\n  if (slideshow.length === 0) {\n    return (\n      <div>\n        <EmptySlideshow>\n          <Spinner inverted />\n        </EmptySlideshow>\n      </div>\n    );\n  }\n\n  const slideshowWidth = `${(slideshow.length + 2) * 100}vw`;\n  let activeSlide = slideIndex;\n  if (activeSlide < 0) {\n    activeSlide = slideshow.length - 1;\n  } else if (activeSlide >= slideshow.length) {\n    activeSlide = 0;\n  }\n\n  const backgroundImage = slideshow[activeSlide].metaImage;\n\n  return (\n    <SlideshowWrapper {...handlers}>\n      <>\n        <SlideLinkWrapper>\n          <OneColumn>\n            <SlideshowLink to={slideshow[activeSlide].path} out={!animationComplete}>\n              <SlideshowInfo ref={slideText}>\n                <h1>{slideshow[activeSlide].title}</h1>\n                <p>{slideshow[activeSlide].metaDescription}</p>\n              </SlideshowInfo>\n            </SlideshowLink>\n          </OneColumn>\n        </SlideLinkWrapper>\n        <NavigationArrow\n          slideIndexTarget={slideIndexTarget > 0 ? slideIndexTarget - 1 : slideshow.length - 1}\n          gotoSlide={gotoSlide}\n        />\n        <NavigationArrow\n          slideIndexTarget={slideIndexTarget < slideshow.length - 1 ? slideIndexTarget + 1 : 0}\n          gotoSlide={gotoSlide}\n          rightArrow\n        />\n        {!animationComplete && (\n          <SlideshowItem\n            fadeOver\n            role=\"img\"\n            onAnimationEnd={onChangedSlide}\n            style={{\n              backgroundImage: `url(${(backgroundImage && backgroundImage.url) || ''})`,\n            }}\n          />\n        )}\n        <div\n          ref={slideRef}\n          css={itemWrapperCSS}\n          onTransitionEnd={onTransitionEnd}\n          style={{\n            width: slideshowWidth,\n            transform: getSlidePosition(slideIndex),\n          }}>\n          {renderSlideItem(slideshow[slideshow.length - 1])}\n          {slideshow.map(renderSlideItem)}\n          {renderSlideItem(slideshow[0])}\n        </div>\n        <SlideshowIndicator slideshow={slideshow} activeSlide={activeSlide} gotoSlide={gotoSlide} />\n      </>\n    </SlideshowWrapper>\n  );\n};\n\nexport default FilmSlideshow;\n"]} */",
71
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
72
+ };
73
+ var SlideshowItem = (0, _styledBase["default"])("div", {
74
+ target: "essc37o1",
75
+ label: "SlideshowItem"
76
+ })("width:100vw;height:100vw;", _core2.mq.range({
77
+ from: _core2.breakpoints.mobileWide
78
+ }), "{height:100vw;}", _core2.mq.range({
79
+ from: _core2.breakpoints.tablet
80
+ }), "{height:75vw;}", _core2.mq.range({
81
+ from: _core2.breakpoints.desktop
82
+ }), "{height:55vw;}", _core2.mq.range({
83
+ from: _core2.breakpoints.wide
84
+ }), "{height:40vw;}", _core2.mq.range({
85
+ from: _core2.breakpoints.ultraWide
86
+ }), "{height:36vw;}background-color:'#222';background-size:cover;background-position-x:center;background-position-y:center;border:0;position:", function (props) {
87
+ return props.fadeOver ? 'absolute' : 'relative';
88
+ }, ";animation:", function (props) {
89
+ return props.fadeOver && 'fadeIn 400ms ease';
90
+ }, ";z-index:", function (props) {
91
+ return props.fadeOver && 1;
92
+ }, ";&:before{content:'';opacity:0.4;background:#091a2a;top:0;left:0;bottom:0;right:0;position:absolute;z-index:1;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FilmSlideshow.tsx"],"names":[],"mappings":"AA8DoD","file":"FilmSlideshow.tsx","sourcesContent":["/**\n * Copyright (c) 2016-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { useCallback, useEffect, useRef, useState } from 'react';\nimport { SwipeEventData, useSwipeable } from 'react-swipeable';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/core';\nimport { breakpoints, mq, spacing, spacingUnit, fonts, colors } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\nimport { OneColumn } from '../Layout';\nimport Spinner from '../Spinner';\nimport NavigationArrow, { StyledNavigationArrow } from './NavigationArrow';\nimport SlideshowIndicator from './SlideshowIndicator';\nimport { MovieType } from './types';\n\ninterface Props {\n  autoSlide?: boolean;\n  randomStart?: boolean;\n  slideshow: MovieType[];\n  slideInterval?: number;\n}\n\nconst SlideLinkWrapper = styled.div`\n  margin: 0 auto;\n  display: flex;\n  justify-content: flex-start;\n  align-items: flex-end;\n  position: absolute;\n  z-index: 2;\n  height: 100vw;\n  width: 100%;\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    height: 100vw;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 75vw;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    height: 55vw;\n  }\n  ${mq.range({ from: breakpoints.wide })} {\n    height: 40vw;\n  }\n  ${mq.range({ from: breakpoints.ultraWide })} {\n    height: 36vw;\n  }\n`;\n\nconst itemWrapperCSS = css`\n  display: flex;\n  box-shadow: none;\n`;\n\ninterface SlideshowItemProps {\n  fadeOver?: boolean;\n}\n\nconst SlideshowItem = styled.div<SlideshowItemProps>`\n  width: 100vw;\n  height: 100vw;\n  /* aspect ratios */\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    height: 100vw;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 75vw;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    height: 55vw;\n  }\n  ${mq.range({ from: breakpoints.wide })} {\n    height: 40vw;\n  }\n  ${mq.range({ from: breakpoints.ultraWide })} {\n    height: 36vw;\n  }\n  background-color: '#222';\n  background-size: cover;\n  background-position-x: center;\n  background-position-y: center;\n  border: 0;\n  position: ${(props) => (props.fadeOver ? 'absolute' : 'relative')};\n  animation: ${(props) => props.fadeOver && 'fadeIn 400ms ease'};\n  z-index: ${(props) => props.fadeOver && 1};\n  &:before {\n    content: '';\n    opacity: 0.4;\n    background: #091a2a;\n    top: 0;\n    left: 0;\n    bottom: 0;\n    right: 0;\n    position: absolute;\n    z-index: 1;\n  }\n`;\n\ninterface SlideshowLinkProps {\n  out?: boolean;\n}\n\nconst SlideshowLink = styled(SafeLink)<SlideshowLinkProps>`\n  display: flex;\n  box-shadow: none;\n  transition: all 400ms ease;\n  opacity: ${(props) => props.out && 0};\n  animation: ${(props) => !props.out && 'fadeInBottomFixed 600ms ease'};\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    padding-bottom: ${spacing.medium};\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-bottom: ${spacing.large};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-bottom: ${spacingUnit * 3}px;\n  }\n  &:hover {\n    h1 {\n      text-decoration: underline;\n    }\n  }\n`;\n\nconst SlideshowWrapper = styled.section`\n  &:hover {\n    ${StyledNavigationArrow} {\n      opacity: 1;\n      transform: translate(0, 0);\n    }\n  }\n`;\n\nconst SlideshowInfo = styled.div`\n  border: 0;\n  background: none;\n  background-color: rgba(3, 23, 43, 0.7);\n  border-radius: 4px;\n  padding: ${spacing.medium} ${spacing.medium} ${spacing.medium} ${spacing.normal};\n  margin: 0 -20px;\n  width: 100vw;\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    margin: 0;\n    width: 100%;\n    padding: ${spacing.medium} ${spacingUnit * 2}px ${spacing.medium} ${spacing.normal};\n  }\n  h1 {\n    ${fonts.sizes('22px', '30px')};\n    color: ${colors.white};\n    text-shadow: 0 2px 4px rgba(0, 0, 0, 0.25);\n    margin: 0;\n    font-weight: ${fonts.weight.semibold};\n    ${mq.range({ from: breakpoints.mobileWide })} {\n      margin: 0 0 ${spacing.small};\n      ${fonts.sizes('26px', '30px')};\n    }\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes('40px', '44px')};\n    }\n    ${mq.range({ from: breakpoints.desktop })} {\n      ${fonts.sizes('48px', '54px')};\n    }\n  }\n\n  p {\n    color: ${colors.white};\n    display: inline-block;\n    margin: 0;\n    padding: 0;\n    border-radius: 4px;\n    ${fonts.sizes('12px', '18px')};\n    ${mq.range({ from: breakpoints.mobileWide })} {\n      ${fonts.sizes('15px', '20px')};\n    }\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes('18px', '24px')};\n    }\n    ${mq.range({ from: breakpoints.wide })} {\n      ${fonts.sizes('20px', '32px')};\n    }\n  }\n`;\n\nconst EmptySlideshow = styled.div`\n  background: rgba(255, 255, 255, 0.08);\n  margin-bottom: $spacing--large * 4;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  height: 40vw;\n`;\n\nconst defaultTransitionSwipeEnd = 'transform 600ms cubic-bezier(0, 0.76, 0.09, 1)';\nconst defaultTransitionText = 'opacity 600ms ease';\n\nconst renderSlideItem = (slide: MovieType) => (\n  <SlideshowItem\n    key={slide.id}\n    role=\"img\"\n    aria-label={(slide.metaImage && slide.metaImage.alt) || ''}\n    style={{\n      backgroundImage: `url(${(slide.metaImage && slide.metaImage.url) || ''})`,\n    }}\n  />\n);\n\nconst FilmSlideshow = ({ autoSlide = false, slideshow = [], slideInterval = 5000 }: Props) => {\n  const [swipeDistance, setSwipeDistance] = useState(0);\n  const [slideIndex, setSlideIndex] = useState(0);\n  const [slideIndexTarget, setSlideIndexTarget] = useState(0);\n  const [animationComplete, setAnimationComplete] = useState(true);\n  const slideRef = useRef<HTMLDivElement>(null);\n  const slideText = useRef<HTMLDivElement>(null);\n  let timer = useRef<ReturnType<typeof setTimeout> | null>(null);\n\n  const gotoSlide = useCallback((indexTarget: number, useAnimation = false) => {\n    setSwipeDistance(0);\n    if (timer.current) {\n      clearTimeout(timer.current);\n    }\n    setSlideIndexTarget(indexTarget);\n    setAnimationComplete(!useAnimation);\n  }, []);\n\n  const onChangedSlide = () => {\n    if (!animationComplete) {\n      if (slideRef.current) {\n        slideRef.current.style.transition = 'none';\n        slideRef.current.style.transform = `translateX(${slideIndexTarget * 100}vw))`;\n      }\n\n      setAnimationComplete(true);\n      setSlideIndex(slideIndexTarget);\n    } else if (slideIndexTarget === -1) {\n      if (slideRef.current) {\n        // Go to last slide for continuous loop\n        slideRef.current.style.transition = 'none';\n        slideRef.current.style.transform = `translateX(${slideshow.length * 100}vw))`;\n      }\n\n      setSlideIndex(slideshow.length - 1);\n      setSlideIndexTarget(slideshow.length - 1);\n      setAnimationComplete(true);\n    } else if (slideIndexTarget === slideshow.length) {\n      if (slideRef.current) {\n        // Go to first slide for continuous loop\n        slideRef.current.style.transition = 'none';\n        slideRef.current.style.transform = `translateX(100vw))`;\n      }\n      setSlideIndex(0);\n      setSlideIndexTarget(0);\n      setAnimationComplete(true);\n    } else {\n      setAnimationComplete(true);\n      setSlideIndex(slideIndexTarget);\n    }\n  };\n\n  const onSwipeEnd = () => {\n    let slide;\n    if (swipeDistance > 40) {\n      slide = -1;\n    } else if (swipeDistance < -40) {\n      slide = 1;\n    } else {\n      slide = 0;\n    }\n    if (slideRef.current && slideText.current) {\n      slideRef.current.style.transition = defaultTransitionSwipeEnd;\n      slideText.current.style.transition = defaultTransitionText;\n      slideText.current.style.opacity = '1';\n    }\n    setSwipeDistance(0);\n\n    initTimer();\n\n    if (slide !== 0) {\n      setSlideIndex(slideIndex + slide);\n      setSlideIndexTarget(slideIndex + slide);\n    } else {\n      // Reset transfrom\n      if (slideRef.current) {\n        slideRef.current.style.transform = getSlidePosition(slideIndex + slide);\n      }\n    }\n  };\n\n  const onSwipe = (eventData: SwipeEventData) => {\n    if (eventData.dir === 'Up' || eventData.dir === 'Down') {\n      return;\n    }\n    if (timer.current) {\n      clearTimeout(timer.current);\n    }\n    setSwipeDistance(eventData.deltaX);\n    if (slideRef && slideRef.current) {\n      slideRef.current.style.transition = 'none';\n      slideRef.current.style.transform = getSlidePosition(slideIndexTarget);\n    }\n    const opacityText = 1 - Math.min(100, Math.abs(swipeDistance)) / 100;\n    if (slideText && slideText.current) {\n      slideText.current.style.transition = 'none';\n      slideText.current.style.opacity = opacityText.toString();\n    }\n  };\n\n  const onTransitionEnd = () => {\n    const slideshowLength = slideshow.length;\n    if (slideIndex === -1) {\n      if (slideRef.current) {\n        slideRef.current.style.transition = 'none';\n        slideRef.current.style.transform = getSlidePosition(slideshowLength - 1);\n      }\n      setSlideIndex(slideshowLength - 1);\n      setSlideIndexTarget(slideshowLength - 1);\n    } else if (slideIndex >= slideshowLength) {\n      if (slideRef.current) {\n        slideRef.current.style.transition = 'none';\n        slideRef.current.style.transform = getSlidePosition(0);\n      }\n      setSlideIndex(0);\n      setSlideIndexTarget(0);\n    }\n  };\n\n  const getSlidePosition = (target: number) => {\n    if (swipeDistance !== 0) {\n      return `translateX(calc(${swipeDistance}px -\n        ${(target + 1) * 100}vw))`;\n    }\n    return `translateX(-${(target + 1) * 100}vw)`;\n  };\n\n  const initTimer = useCallback(() => {\n    if (autoSlide) {\n      timer.current = setTimeout(() => {\n        gotoSlide(slideIndex + 1);\n      }, slideInterval);\n    }\n  }, [autoSlide, gotoSlide, slideInterval, slideIndex]);\n\n  useEffect(() => {\n    initTimer();\n  }, [initTimer]);\n\n  const handlers = useSwipeable({\n    onSwiped: onSwipeEnd,\n    onSwiping: onSwipe,\n  });\n\n  if (slideshow.length === 0) {\n    return (\n      <div>\n        <EmptySlideshow>\n          <Spinner inverted />\n        </EmptySlideshow>\n      </div>\n    );\n  }\n\n  const slideshowWidth = `${(slideshow.length + 2) * 100}vw`;\n  let activeSlide = slideIndex;\n  if (activeSlide < 0) {\n    activeSlide = slideshow.length - 1;\n  } else if (activeSlide >= slideshow.length) {\n    activeSlide = 0;\n  }\n\n  const backgroundImage = slideshow[activeSlide].metaImage;\n\n  return (\n    <SlideshowWrapper {...handlers}>\n      <>\n        <SlideLinkWrapper>\n          <OneColumn>\n            <SlideshowLink to={slideshow[activeSlide].path} out={!animationComplete}>\n              <SlideshowInfo ref={slideText}>\n                <h1>{slideshow[activeSlide].title}</h1>\n                <p>{slideshow[activeSlide].metaDescription}</p>\n              </SlideshowInfo>\n            </SlideshowLink>\n          </OneColumn>\n        </SlideLinkWrapper>\n        <NavigationArrow\n          slideIndexTarget={slideIndexTarget > 0 ? slideIndexTarget - 1 : slideshow.length - 1}\n          gotoSlide={gotoSlide}\n        />\n        <NavigationArrow\n          slideIndexTarget={slideIndexTarget < slideshow.length - 1 ? slideIndexTarget + 1 : 0}\n          gotoSlide={gotoSlide}\n          rightArrow\n        />\n        {!animationComplete && (\n          <SlideshowItem\n            fadeOver\n            role=\"img\"\n            onAnimationEnd={onChangedSlide}\n            style={{\n              backgroundImage: `url(${(backgroundImage && backgroundImage.url) || ''})`,\n            }}\n          />\n        )}\n        <div\n          ref={slideRef}\n          css={itemWrapperCSS}\n          onTransitionEnd={onTransitionEnd}\n          style={{\n            width: slideshowWidth,\n            transform: getSlidePosition(slideIndex),\n          }}>\n          {renderSlideItem(slideshow[slideshow.length - 1])}\n          {slideshow.map(renderSlideItem)}\n          {renderSlideItem(slideshow[0])}\n        </div>\n        <SlideshowIndicator slideshow={slideshow} activeSlide={activeSlide} gotoSlide={gotoSlide} />\n      </>\n    </SlideshowWrapper>\n  );\n};\n\nexport default FilmSlideshow;\n"]} */"));
93
+ var SlideshowLink = ( /*#__PURE__*/0, _styledBase["default"])(_safelink["default"], {
94
+ target: "essc37o2",
95
+ label: "SlideshowLink"
96
+ })("display:flex;box-shadow:none;transition:all 400ms ease;opacity:", function (props) {
97
+ return props.out && 0;
98
+ }, ";animation:", function (props) {
99
+ return !props.out && 'fadeInBottomFixed 600ms ease';
100
+ }, ";", _core2.mq.range({
101
+ from: _core2.breakpoints.mobileWide
102
+ }), "{padding-bottom:", _core2.spacing.medium, ";}", _core2.mq.range({
103
+ from: _core2.breakpoints.tablet
104
+ }), "{padding-bottom:", _core2.spacing.large, ";}", _core2.mq.range({
105
+ from: _core2.breakpoints.desktop
106
+ }), "{padding-bottom:", _core2.spacingUnit * 3, "px;}&:hover{h1{text-decoration:underline;}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FilmSlideshow.tsx"],"names":[],"mappings":"AA0G0D","file":"FilmSlideshow.tsx","sourcesContent":["/**\n * Copyright (c) 2016-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { useCallback, useEffect, useRef, useState } from 'react';\nimport { SwipeEventData, useSwipeable } from 'react-swipeable';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/core';\nimport { breakpoints, mq, spacing, spacingUnit, fonts, colors } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\nimport { OneColumn } from '../Layout';\nimport Spinner from '../Spinner';\nimport NavigationArrow, { StyledNavigationArrow } from './NavigationArrow';\nimport SlideshowIndicator from './SlideshowIndicator';\nimport { MovieType } from './types';\n\ninterface Props {\n  autoSlide?: boolean;\n  randomStart?: boolean;\n  slideshow: MovieType[];\n  slideInterval?: number;\n}\n\nconst SlideLinkWrapper = styled.div`\n  margin: 0 auto;\n  display: flex;\n  justify-content: flex-start;\n  align-items: flex-end;\n  position: absolute;\n  z-index: 2;\n  height: 100vw;\n  width: 100%;\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    height: 100vw;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 75vw;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    height: 55vw;\n  }\n  ${mq.range({ from: breakpoints.wide })} {\n    height: 40vw;\n  }\n  ${mq.range({ from: breakpoints.ultraWide })} {\n    height: 36vw;\n  }\n`;\n\nconst itemWrapperCSS = css`\n  display: flex;\n  box-shadow: none;\n`;\n\ninterface SlideshowItemProps {\n  fadeOver?: boolean;\n}\n\nconst SlideshowItem = styled.div<SlideshowItemProps>`\n  width: 100vw;\n  height: 100vw;\n  /* aspect ratios */\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    height: 100vw;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 75vw;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    height: 55vw;\n  }\n  ${mq.range({ from: breakpoints.wide })} {\n    height: 40vw;\n  }\n  ${mq.range({ from: breakpoints.ultraWide })} {\n    height: 36vw;\n  }\n  background-color: '#222';\n  background-size: cover;\n  background-position-x: center;\n  background-position-y: center;\n  border: 0;\n  position: ${(props) => (props.fadeOver ? 'absolute' : 'relative')};\n  animation: ${(props) => props.fadeOver && 'fadeIn 400ms ease'};\n  z-index: ${(props) => props.fadeOver && 1};\n  &:before {\n    content: '';\n    opacity: 0.4;\n    background: #091a2a;\n    top: 0;\n    left: 0;\n    bottom: 0;\n    right: 0;\n    position: absolute;\n    z-index: 1;\n  }\n`;\n\ninterface SlideshowLinkProps {\n  out?: boolean;\n}\n\nconst SlideshowLink = styled(SafeLink)<SlideshowLinkProps>`\n  display: flex;\n  box-shadow: none;\n  transition: all 400ms ease;\n  opacity: ${(props) => props.out && 0};\n  animation: ${(props) => !props.out && 'fadeInBottomFixed 600ms ease'};\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    padding-bottom: ${spacing.medium};\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-bottom: ${spacing.large};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-bottom: ${spacingUnit * 3}px;\n  }\n  &:hover {\n    h1 {\n      text-decoration: underline;\n    }\n  }\n`;\n\nconst SlideshowWrapper = styled.section`\n  &:hover {\n    ${StyledNavigationArrow} {\n      opacity: 1;\n      transform: translate(0, 0);\n    }\n  }\n`;\n\nconst SlideshowInfo = styled.div`\n  border: 0;\n  background: none;\n  background-color: rgba(3, 23, 43, 0.7);\n  border-radius: 4px;\n  padding: ${spacing.medium} ${spacing.medium} ${spacing.medium} ${spacing.normal};\n  margin: 0 -20px;\n  width: 100vw;\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    margin: 0;\n    width: 100%;\n    padding: ${spacing.medium} ${spacingUnit * 2}px ${spacing.medium} ${spacing.normal};\n  }\n  h1 {\n    ${fonts.sizes('22px', '30px')};\n    color: ${colors.white};\n    text-shadow: 0 2px 4px rgba(0, 0, 0, 0.25);\n    margin: 0;\n    font-weight: ${fonts.weight.semibold};\n    ${mq.range({ from: breakpoints.mobileWide })} {\n      margin: 0 0 ${spacing.small};\n      ${fonts.sizes('26px', '30px')};\n    }\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes('40px', '44px')};\n    }\n    ${mq.range({ from: breakpoints.desktop })} {\n      ${fonts.sizes('48px', '54px')};\n    }\n  }\n\n  p {\n    color: ${colors.white};\n    display: inline-block;\n    margin: 0;\n    padding: 0;\n    border-radius: 4px;\n    ${fonts.sizes('12px', '18px')};\n    ${mq.range({ from: breakpoints.mobileWide })} {\n      ${fonts.sizes('15px', '20px')};\n    }\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes('18px', '24px')};\n    }\n    ${mq.range({ from: breakpoints.wide })} {\n      ${fonts.sizes('20px', '32px')};\n    }\n  }\n`;\n\nconst EmptySlideshow = styled.div`\n  background: rgba(255, 255, 255, 0.08);\n  margin-bottom: $spacing--large * 4;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  height: 40vw;\n`;\n\nconst defaultTransitionSwipeEnd = 'transform 600ms cubic-bezier(0, 0.76, 0.09, 1)';\nconst defaultTransitionText = 'opacity 600ms ease';\n\nconst renderSlideItem = (slide: MovieType) => (\n  <SlideshowItem\n    key={slide.id}\n    role=\"img\"\n    aria-label={(slide.metaImage && slide.metaImage.alt) || ''}\n    style={{\n      backgroundImage: `url(${(slide.metaImage && slide.metaImage.url) || ''})`,\n    }}\n  />\n);\n\nconst FilmSlideshow = ({ autoSlide = false, slideshow = [], slideInterval = 5000 }: Props) => {\n  const [swipeDistance, setSwipeDistance] = useState(0);\n  const [slideIndex, setSlideIndex] = useState(0);\n  const [slideIndexTarget, setSlideIndexTarget] = useState(0);\n  const [animationComplete, setAnimationComplete] = useState(true);\n  const slideRef = useRef<HTMLDivElement>(null);\n  const slideText = useRef<HTMLDivElement>(null);\n  let timer = useRef<ReturnType<typeof setTimeout> | null>(null);\n\n  const gotoSlide = useCallback((indexTarget: number, useAnimation = false) => {\n    setSwipeDistance(0);\n    if (timer.current) {\n      clearTimeout(timer.current);\n    }\n    setSlideIndexTarget(indexTarget);\n    setAnimationComplete(!useAnimation);\n  }, []);\n\n  const onChangedSlide = () => {\n    if (!animationComplete) {\n      if (slideRef.current) {\n        slideRef.current.style.transition = 'none';\n        slideRef.current.style.transform = `translateX(${slideIndexTarget * 100}vw))`;\n      }\n\n      setAnimationComplete(true);\n      setSlideIndex(slideIndexTarget);\n    } else if (slideIndexTarget === -1) {\n      if (slideRef.current) {\n        // Go to last slide for continuous loop\n        slideRef.current.style.transition = 'none';\n        slideRef.current.style.transform = `translateX(${slideshow.length * 100}vw))`;\n      }\n\n      setSlideIndex(slideshow.length - 1);\n      setSlideIndexTarget(slideshow.length - 1);\n      setAnimationComplete(true);\n    } else if (slideIndexTarget === slideshow.length) {\n      if (slideRef.current) {\n        // Go to first slide for continuous loop\n        slideRef.current.style.transition = 'none';\n        slideRef.current.style.transform = `translateX(100vw))`;\n      }\n      setSlideIndex(0);\n      setSlideIndexTarget(0);\n      setAnimationComplete(true);\n    } else {\n      setAnimationComplete(true);\n      setSlideIndex(slideIndexTarget);\n    }\n  };\n\n  const onSwipeEnd = () => {\n    let slide;\n    if (swipeDistance > 40) {\n      slide = -1;\n    } else if (swipeDistance < -40) {\n      slide = 1;\n    } else {\n      slide = 0;\n    }\n    if (slideRef.current && slideText.current) {\n      slideRef.current.style.transition = defaultTransitionSwipeEnd;\n      slideText.current.style.transition = defaultTransitionText;\n      slideText.current.style.opacity = '1';\n    }\n    setSwipeDistance(0);\n\n    initTimer();\n\n    if (slide !== 0) {\n      setSlideIndex(slideIndex + slide);\n      setSlideIndexTarget(slideIndex + slide);\n    } else {\n      // Reset transfrom\n      if (slideRef.current) {\n        slideRef.current.style.transform = getSlidePosition(slideIndex + slide);\n      }\n    }\n  };\n\n  const onSwipe = (eventData: SwipeEventData) => {\n    if (eventData.dir === 'Up' || eventData.dir === 'Down') {\n      return;\n    }\n    if (timer.current) {\n      clearTimeout(timer.current);\n    }\n    setSwipeDistance(eventData.deltaX);\n    if (slideRef && slideRef.current) {\n      slideRef.current.style.transition = 'none';\n      slideRef.current.style.transform = getSlidePosition(slideIndexTarget);\n    }\n    const opacityText = 1 - Math.min(100, Math.abs(swipeDistance)) / 100;\n    if (slideText && slideText.current) {\n      slideText.current.style.transition = 'none';\n      slideText.current.style.opacity = opacityText.toString();\n    }\n  };\n\n  const onTransitionEnd = () => {\n    const slideshowLength = slideshow.length;\n    if (slideIndex === -1) {\n      if (slideRef.current) {\n        slideRef.current.style.transition = 'none';\n        slideRef.current.style.transform = getSlidePosition(slideshowLength - 1);\n      }\n      setSlideIndex(slideshowLength - 1);\n      setSlideIndexTarget(slideshowLength - 1);\n    } else if (slideIndex >= slideshowLength) {\n      if (slideRef.current) {\n        slideRef.current.style.transition = 'none';\n        slideRef.current.style.transform = getSlidePosition(0);\n      }\n      setSlideIndex(0);\n      setSlideIndexTarget(0);\n    }\n  };\n\n  const getSlidePosition = (target: number) => {\n    if (swipeDistance !== 0) {\n      return `translateX(calc(${swipeDistance}px -\n        ${(target + 1) * 100}vw))`;\n    }\n    return `translateX(-${(target + 1) * 100}vw)`;\n  };\n\n  const initTimer = useCallback(() => {\n    if (autoSlide) {\n      timer.current = setTimeout(() => {\n        gotoSlide(slideIndex + 1);\n      }, slideInterval);\n    }\n  }, [autoSlide, gotoSlide, slideInterval, slideIndex]);\n\n  useEffect(() => {\n    initTimer();\n  }, [initTimer]);\n\n  const handlers = useSwipeable({\n    onSwiped: onSwipeEnd,\n    onSwiping: onSwipe,\n  });\n\n  if (slideshow.length === 0) {\n    return (\n      <div>\n        <EmptySlideshow>\n          <Spinner inverted />\n        </EmptySlideshow>\n      </div>\n    );\n  }\n\n  const slideshowWidth = `${(slideshow.length + 2) * 100}vw`;\n  let activeSlide = slideIndex;\n  if (activeSlide < 0) {\n    activeSlide = slideshow.length - 1;\n  } else if (activeSlide >= slideshow.length) {\n    activeSlide = 0;\n  }\n\n  const backgroundImage = slideshow[activeSlide].metaImage;\n\n  return (\n    <SlideshowWrapper {...handlers}>\n      <>\n        <SlideLinkWrapper>\n          <OneColumn>\n            <SlideshowLink to={slideshow[activeSlide].path} out={!animationComplete}>\n              <SlideshowInfo ref={slideText}>\n                <h1>{slideshow[activeSlide].title}</h1>\n                <p>{slideshow[activeSlide].metaDescription}</p>\n              </SlideshowInfo>\n            </SlideshowLink>\n          </OneColumn>\n        </SlideLinkWrapper>\n        <NavigationArrow\n          slideIndexTarget={slideIndexTarget > 0 ? slideIndexTarget - 1 : slideshow.length - 1}\n          gotoSlide={gotoSlide}\n        />\n        <NavigationArrow\n          slideIndexTarget={slideIndexTarget < slideshow.length - 1 ? slideIndexTarget + 1 : 0}\n          gotoSlide={gotoSlide}\n          rightArrow\n        />\n        {!animationComplete && (\n          <SlideshowItem\n            fadeOver\n            role=\"img\"\n            onAnimationEnd={onChangedSlide}\n            style={{\n              backgroundImage: `url(${(backgroundImage && backgroundImage.url) || ''})`,\n            }}\n          />\n        )}\n        <div\n          ref={slideRef}\n          css={itemWrapperCSS}\n          onTransitionEnd={onTransitionEnd}\n          style={{\n            width: slideshowWidth,\n            transform: getSlidePosition(slideIndex),\n          }}>\n          {renderSlideItem(slideshow[slideshow.length - 1])}\n          {slideshow.map(renderSlideItem)}\n          {renderSlideItem(slideshow[0])}\n        </div>\n        <SlideshowIndicator slideshow={slideshow} activeSlide={activeSlide} gotoSlide={gotoSlide} />\n      </>\n    </SlideshowWrapper>\n  );\n};\n\nexport default FilmSlideshow;\n"]} */"));
107
+ var SlideshowWrapper = (0, _styledBase["default"])("section", {
108
+ target: "essc37o3",
109
+ label: "SlideshowWrapper"
110
+ })("&:hover{", _NavigationArrow.StyledNavigationArrow, "{opacity:1;transform:translate(0,0);}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FilmSlideshow.tsx"],"names":[],"mappings":"AAgIuC","file":"FilmSlideshow.tsx","sourcesContent":["/**\n * Copyright (c) 2016-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { useCallback, useEffect, useRef, useState } from 'react';\nimport { SwipeEventData, useSwipeable } from 'react-swipeable';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/core';\nimport { breakpoints, mq, spacing, spacingUnit, fonts, colors } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\nimport { OneColumn } from '../Layout';\nimport Spinner from '../Spinner';\nimport NavigationArrow, { StyledNavigationArrow } from './NavigationArrow';\nimport SlideshowIndicator from './SlideshowIndicator';\nimport { MovieType } from './types';\n\ninterface Props {\n  autoSlide?: boolean;\n  randomStart?: boolean;\n  slideshow: MovieType[];\n  slideInterval?: number;\n}\n\nconst SlideLinkWrapper = styled.div`\n  margin: 0 auto;\n  display: flex;\n  justify-content: flex-start;\n  align-items: flex-end;\n  position: absolute;\n  z-index: 2;\n  height: 100vw;\n  width: 100%;\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    height: 100vw;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 75vw;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    height: 55vw;\n  }\n  ${mq.range({ from: breakpoints.wide })} {\n    height: 40vw;\n  }\n  ${mq.range({ from: breakpoints.ultraWide })} {\n    height: 36vw;\n  }\n`;\n\nconst itemWrapperCSS = css`\n  display: flex;\n  box-shadow: none;\n`;\n\ninterface SlideshowItemProps {\n  fadeOver?: boolean;\n}\n\nconst SlideshowItem = styled.div<SlideshowItemProps>`\n  width: 100vw;\n  height: 100vw;\n  /* aspect ratios */\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    height: 100vw;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 75vw;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    height: 55vw;\n  }\n  ${mq.range({ from: breakpoints.wide })} {\n    height: 40vw;\n  }\n  ${mq.range({ from: breakpoints.ultraWide })} {\n    height: 36vw;\n  }\n  background-color: '#222';\n  background-size: cover;\n  background-position-x: center;\n  background-position-y: center;\n  border: 0;\n  position: ${(props) => (props.fadeOver ? 'absolute' : 'relative')};\n  animation: ${(props) => props.fadeOver && 'fadeIn 400ms ease'};\n  z-index: ${(props) => props.fadeOver && 1};\n  &:before {\n    content: '';\n    opacity: 0.4;\n    background: #091a2a;\n    top: 0;\n    left: 0;\n    bottom: 0;\n    right: 0;\n    position: absolute;\n    z-index: 1;\n  }\n`;\n\ninterface SlideshowLinkProps {\n  out?: boolean;\n}\n\nconst SlideshowLink = styled(SafeLink)<SlideshowLinkProps>`\n  display: flex;\n  box-shadow: none;\n  transition: all 400ms ease;\n  opacity: ${(props) => props.out && 0};\n  animation: ${(props) => !props.out && 'fadeInBottomFixed 600ms ease'};\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    padding-bottom: ${spacing.medium};\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-bottom: ${spacing.large};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-bottom: ${spacingUnit * 3}px;\n  }\n  &:hover {\n    h1 {\n      text-decoration: underline;\n    }\n  }\n`;\n\nconst SlideshowWrapper = styled.section`\n  &:hover {\n    ${StyledNavigationArrow} {\n      opacity: 1;\n      transform: translate(0, 0);\n    }\n  }\n`;\n\nconst SlideshowInfo = styled.div`\n  border: 0;\n  background: none;\n  background-color: rgba(3, 23, 43, 0.7);\n  border-radius: 4px;\n  padding: ${spacing.medium} ${spacing.medium} ${spacing.medium} ${spacing.normal};\n  margin: 0 -20px;\n  width: 100vw;\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    margin: 0;\n    width: 100%;\n    padding: ${spacing.medium} ${spacingUnit * 2}px ${spacing.medium} ${spacing.normal};\n  }\n  h1 {\n    ${fonts.sizes('22px', '30px')};\n    color: ${colors.white};\n    text-shadow: 0 2px 4px rgba(0, 0, 0, 0.25);\n    margin: 0;\n    font-weight: ${fonts.weight.semibold};\n    ${mq.range({ from: breakpoints.mobileWide })} {\n      margin: 0 0 ${spacing.small};\n      ${fonts.sizes('26px', '30px')};\n    }\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes('40px', '44px')};\n    }\n    ${mq.range({ from: breakpoints.desktop })} {\n      ${fonts.sizes('48px', '54px')};\n    }\n  }\n\n  p {\n    color: ${colors.white};\n    display: inline-block;\n    margin: 0;\n    padding: 0;\n    border-radius: 4px;\n    ${fonts.sizes('12px', '18px')};\n    ${mq.range({ from: breakpoints.mobileWide })} {\n      ${fonts.sizes('15px', '20px')};\n    }\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes('18px', '24px')};\n    }\n    ${mq.range({ from: breakpoints.wide })} {\n      ${fonts.sizes('20px', '32px')};\n    }\n  }\n`;\n\nconst EmptySlideshow = styled.div`\n  background: rgba(255, 255, 255, 0.08);\n  margin-bottom: $spacing--large * 4;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  height: 40vw;\n`;\n\nconst defaultTransitionSwipeEnd = 'transform 600ms cubic-bezier(0, 0.76, 0.09, 1)';\nconst defaultTransitionText = 'opacity 600ms ease';\n\nconst renderSlideItem = (slide: MovieType) => (\n  <SlideshowItem\n    key={slide.id}\n    role=\"img\"\n    aria-label={(slide.metaImage && slide.metaImage.alt) || ''}\n    style={{\n      backgroundImage: `url(${(slide.metaImage && slide.metaImage.url) || ''})`,\n    }}\n  />\n);\n\nconst FilmSlideshow = ({ autoSlide = false, slideshow = [], slideInterval = 5000 }: Props) => {\n  const [swipeDistance, setSwipeDistance] = useState(0);\n  const [slideIndex, setSlideIndex] = useState(0);\n  const [slideIndexTarget, setSlideIndexTarget] = useState(0);\n  const [animationComplete, setAnimationComplete] = useState(true);\n  const slideRef = useRef<HTMLDivElement>(null);\n  const slideText = useRef<HTMLDivElement>(null);\n  let timer = useRef<ReturnType<typeof setTimeout> | null>(null);\n\n  const gotoSlide = useCallback((indexTarget: number, useAnimation = false) => {\n    setSwipeDistance(0);\n    if (timer.current) {\n      clearTimeout(timer.current);\n    }\n    setSlideIndexTarget(indexTarget);\n    setAnimationComplete(!useAnimation);\n  }, []);\n\n  const onChangedSlide = () => {\n    if (!animationComplete) {\n      if (slideRef.current) {\n        slideRef.current.style.transition = 'none';\n        slideRef.current.style.transform = `translateX(${slideIndexTarget * 100}vw))`;\n      }\n\n      setAnimationComplete(true);\n      setSlideIndex(slideIndexTarget);\n    } else if (slideIndexTarget === -1) {\n      if (slideRef.current) {\n        // Go to last slide for continuous loop\n        slideRef.current.style.transition = 'none';\n        slideRef.current.style.transform = `translateX(${slideshow.length * 100}vw))`;\n      }\n\n      setSlideIndex(slideshow.length - 1);\n      setSlideIndexTarget(slideshow.length - 1);\n      setAnimationComplete(true);\n    } else if (slideIndexTarget === slideshow.length) {\n      if (slideRef.current) {\n        // Go to first slide for continuous loop\n        slideRef.current.style.transition = 'none';\n        slideRef.current.style.transform = `translateX(100vw))`;\n      }\n      setSlideIndex(0);\n      setSlideIndexTarget(0);\n      setAnimationComplete(true);\n    } else {\n      setAnimationComplete(true);\n      setSlideIndex(slideIndexTarget);\n    }\n  };\n\n  const onSwipeEnd = () => {\n    let slide;\n    if (swipeDistance > 40) {\n      slide = -1;\n    } else if (swipeDistance < -40) {\n      slide = 1;\n    } else {\n      slide = 0;\n    }\n    if (slideRef.current && slideText.current) {\n      slideRef.current.style.transition = defaultTransitionSwipeEnd;\n      slideText.current.style.transition = defaultTransitionText;\n      slideText.current.style.opacity = '1';\n    }\n    setSwipeDistance(0);\n\n    initTimer();\n\n    if (slide !== 0) {\n      setSlideIndex(slideIndex + slide);\n      setSlideIndexTarget(slideIndex + slide);\n    } else {\n      // Reset transfrom\n      if (slideRef.current) {\n        slideRef.current.style.transform = getSlidePosition(slideIndex + slide);\n      }\n    }\n  };\n\n  const onSwipe = (eventData: SwipeEventData) => {\n    if (eventData.dir === 'Up' || eventData.dir === 'Down') {\n      return;\n    }\n    if (timer.current) {\n      clearTimeout(timer.current);\n    }\n    setSwipeDistance(eventData.deltaX);\n    if (slideRef && slideRef.current) {\n      slideRef.current.style.transition = 'none';\n      slideRef.current.style.transform = getSlidePosition(slideIndexTarget);\n    }\n    const opacityText = 1 - Math.min(100, Math.abs(swipeDistance)) / 100;\n    if (slideText && slideText.current) {\n      slideText.current.style.transition = 'none';\n      slideText.current.style.opacity = opacityText.toString();\n    }\n  };\n\n  const onTransitionEnd = () => {\n    const slideshowLength = slideshow.length;\n    if (slideIndex === -1) {\n      if (slideRef.current) {\n        slideRef.current.style.transition = 'none';\n        slideRef.current.style.transform = getSlidePosition(slideshowLength - 1);\n      }\n      setSlideIndex(slideshowLength - 1);\n      setSlideIndexTarget(slideshowLength - 1);\n    } else if (slideIndex >= slideshowLength) {\n      if (slideRef.current) {\n        slideRef.current.style.transition = 'none';\n        slideRef.current.style.transform = getSlidePosition(0);\n      }\n      setSlideIndex(0);\n      setSlideIndexTarget(0);\n    }\n  };\n\n  const getSlidePosition = (target: number) => {\n    if (swipeDistance !== 0) {\n      return `translateX(calc(${swipeDistance}px -\n        ${(target + 1) * 100}vw))`;\n    }\n    return `translateX(-${(target + 1) * 100}vw)`;\n  };\n\n  const initTimer = useCallback(() => {\n    if (autoSlide) {\n      timer.current = setTimeout(() => {\n        gotoSlide(slideIndex + 1);\n      }, slideInterval);\n    }\n  }, [autoSlide, gotoSlide, slideInterval, slideIndex]);\n\n  useEffect(() => {\n    initTimer();\n  }, [initTimer]);\n\n  const handlers = useSwipeable({\n    onSwiped: onSwipeEnd,\n    onSwiping: onSwipe,\n  });\n\n  if (slideshow.length === 0) {\n    return (\n      <div>\n        <EmptySlideshow>\n          <Spinner inverted />\n        </EmptySlideshow>\n      </div>\n    );\n  }\n\n  const slideshowWidth = `${(slideshow.length + 2) * 100}vw`;\n  let activeSlide = slideIndex;\n  if (activeSlide < 0) {\n    activeSlide = slideshow.length - 1;\n  } else if (activeSlide >= slideshow.length) {\n    activeSlide = 0;\n  }\n\n  const backgroundImage = slideshow[activeSlide].metaImage;\n\n  return (\n    <SlideshowWrapper {...handlers}>\n      <>\n        <SlideLinkWrapper>\n          <OneColumn>\n            <SlideshowLink to={slideshow[activeSlide].path} out={!animationComplete}>\n              <SlideshowInfo ref={slideText}>\n                <h1>{slideshow[activeSlide].title}</h1>\n                <p>{slideshow[activeSlide].metaDescription}</p>\n              </SlideshowInfo>\n            </SlideshowLink>\n          </OneColumn>\n        </SlideLinkWrapper>\n        <NavigationArrow\n          slideIndexTarget={slideIndexTarget > 0 ? slideIndexTarget - 1 : slideshow.length - 1}\n          gotoSlide={gotoSlide}\n        />\n        <NavigationArrow\n          slideIndexTarget={slideIndexTarget < slideshow.length - 1 ? slideIndexTarget + 1 : 0}\n          gotoSlide={gotoSlide}\n          rightArrow\n        />\n        {!animationComplete && (\n          <SlideshowItem\n            fadeOver\n            role=\"img\"\n            onAnimationEnd={onChangedSlide}\n            style={{\n              backgroundImage: `url(${(backgroundImage && backgroundImage.url) || ''})`,\n            }}\n          />\n        )}\n        <div\n          ref={slideRef}\n          css={itemWrapperCSS}\n          onTransitionEnd={onTransitionEnd}\n          style={{\n            width: slideshowWidth,\n            transform: getSlidePosition(slideIndex),\n          }}>\n          {renderSlideItem(slideshow[slideshow.length - 1])}\n          {slideshow.map(renderSlideItem)}\n          {renderSlideItem(slideshow[0])}\n        </div>\n        <SlideshowIndicator slideshow={slideshow} activeSlide={activeSlide} gotoSlide={gotoSlide} />\n      </>\n    </SlideshowWrapper>\n  );\n};\n\nexport default FilmSlideshow;\n"]} */"));
111
+ var SlideshowInfo = (0, _styledBase["default"])("div", {
112
+ target: "essc37o4",
113
+ label: "SlideshowInfo"
114
+ })("border:0;background:none;background-color:rgba(3,23,43,0.7);border-radius:4px;padding:", _core2.spacing.medium, " ", _core2.spacing.medium, " ", _core2.spacing.medium, " ", _core2.spacing.normal, ";margin:0 -20px;width:100vw;", _core2.mq.range({
115
+ from: _core2.breakpoints.mobileWide
116
+ }), "{margin:0;width:100%;padding:", _core2.spacing.medium, " ", _core2.spacingUnit * 2, "px ", _core2.spacing.medium, " ", _core2.spacing.normal, ";}h1{", _core2.fonts.sizes('22px', '30px'), ";color:", _core2.colors.white, ";text-shadow:0 2px 4px rgba(0,0,0,0.25);margin:0;font-weight:", _core2.fonts.weight.semibold, ";", _core2.mq.range({
117
+ from: _core2.breakpoints.mobileWide
118
+ }), "{margin:0 0 ", _core2.spacing.small, ";", _core2.fonts.sizes('26px', '30px'), ";}", _core2.mq.range({
119
+ from: _core2.breakpoints.tablet
120
+ }), "{", _core2.fonts.sizes('40px', '44px'), ";}", _core2.mq.range({
121
+ from: _core2.breakpoints.desktop
122
+ }), "{", _core2.fonts.sizes('48px', '54px'), ";}}p{color:", _core2.colors.white, ";display:inline-block;margin:0;padding:0;border-radius:4px;", _core2.fonts.sizes('12px', '18px'), ";", _core2.mq.range({
123
+ from: _core2.breakpoints.mobileWide
124
+ }), "{", _core2.fonts.sizes('15px', '20px'), ";}", _core2.mq.range({
125
+ from: _core2.breakpoints.tablet
126
+ }), "{", _core2.fonts.sizes('18px', '24px'), ";}", _core2.mq.range({
127
+ from: _core2.breakpoints.wide
128
+ }), "{", _core2.fonts.sizes('20px', '32px'), ";}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FilmSlideshow.tsx"],"names":[],"mappings":"AAyIgC","file":"FilmSlideshow.tsx","sourcesContent":["/**\n * Copyright (c) 2016-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { useCallback, useEffect, useRef, useState } from 'react';\nimport { SwipeEventData, useSwipeable } from 'react-swipeable';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/core';\nimport { breakpoints, mq, spacing, spacingUnit, fonts, colors } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\nimport { OneColumn } from '../Layout';\nimport Spinner from '../Spinner';\nimport NavigationArrow, { StyledNavigationArrow } from './NavigationArrow';\nimport SlideshowIndicator from './SlideshowIndicator';\nimport { MovieType } from './types';\n\ninterface Props {\n  autoSlide?: boolean;\n  randomStart?: boolean;\n  slideshow: MovieType[];\n  slideInterval?: number;\n}\n\nconst SlideLinkWrapper = styled.div`\n  margin: 0 auto;\n  display: flex;\n  justify-content: flex-start;\n  align-items: flex-end;\n  position: absolute;\n  z-index: 2;\n  height: 100vw;\n  width: 100%;\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    height: 100vw;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 75vw;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    height: 55vw;\n  }\n  ${mq.range({ from: breakpoints.wide })} {\n    height: 40vw;\n  }\n  ${mq.range({ from: breakpoints.ultraWide })} {\n    height: 36vw;\n  }\n`;\n\nconst itemWrapperCSS = css`\n  display: flex;\n  box-shadow: none;\n`;\n\ninterface SlideshowItemProps {\n  fadeOver?: boolean;\n}\n\nconst SlideshowItem = styled.div<SlideshowItemProps>`\n  width: 100vw;\n  height: 100vw;\n  /* aspect ratios */\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    height: 100vw;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 75vw;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    height: 55vw;\n  }\n  ${mq.range({ from: breakpoints.wide })} {\n    height: 40vw;\n  }\n  ${mq.range({ from: breakpoints.ultraWide })} {\n    height: 36vw;\n  }\n  background-color: '#222';\n  background-size: cover;\n  background-position-x: center;\n  background-position-y: center;\n  border: 0;\n  position: ${(props) => (props.fadeOver ? 'absolute' : 'relative')};\n  animation: ${(props) => props.fadeOver && 'fadeIn 400ms ease'};\n  z-index: ${(props) => props.fadeOver && 1};\n  &:before {\n    content: '';\n    opacity: 0.4;\n    background: #091a2a;\n    top: 0;\n    left: 0;\n    bottom: 0;\n    right: 0;\n    position: absolute;\n    z-index: 1;\n  }\n`;\n\ninterface SlideshowLinkProps {\n  out?: boolean;\n}\n\nconst SlideshowLink = styled(SafeLink)<SlideshowLinkProps>`\n  display: flex;\n  box-shadow: none;\n  transition: all 400ms ease;\n  opacity: ${(props) => props.out && 0};\n  animation: ${(props) => !props.out && 'fadeInBottomFixed 600ms ease'};\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    padding-bottom: ${spacing.medium};\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-bottom: ${spacing.large};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-bottom: ${spacingUnit * 3}px;\n  }\n  &:hover {\n    h1 {\n      text-decoration: underline;\n    }\n  }\n`;\n\nconst SlideshowWrapper = styled.section`\n  &:hover {\n    ${StyledNavigationArrow} {\n      opacity: 1;\n      transform: translate(0, 0);\n    }\n  }\n`;\n\nconst SlideshowInfo = styled.div`\n  border: 0;\n  background: none;\n  background-color: rgba(3, 23, 43, 0.7);\n  border-radius: 4px;\n  padding: ${spacing.medium} ${spacing.medium} ${spacing.medium} ${spacing.normal};\n  margin: 0 -20px;\n  width: 100vw;\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    margin: 0;\n    width: 100%;\n    padding: ${spacing.medium} ${spacingUnit * 2}px ${spacing.medium} ${spacing.normal};\n  }\n  h1 {\n    ${fonts.sizes('22px', '30px')};\n    color: ${colors.white};\n    text-shadow: 0 2px 4px rgba(0, 0, 0, 0.25);\n    margin: 0;\n    font-weight: ${fonts.weight.semibold};\n    ${mq.range({ from: breakpoints.mobileWide })} {\n      margin: 0 0 ${spacing.small};\n      ${fonts.sizes('26px', '30px')};\n    }\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes('40px', '44px')};\n    }\n    ${mq.range({ from: breakpoints.desktop })} {\n      ${fonts.sizes('48px', '54px')};\n    }\n  }\n\n  p {\n    color: ${colors.white};\n    display: inline-block;\n    margin: 0;\n    padding: 0;\n    border-radius: 4px;\n    ${fonts.sizes('12px', '18px')};\n    ${mq.range({ from: breakpoints.mobileWide })} {\n      ${fonts.sizes('15px', '20px')};\n    }\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes('18px', '24px')};\n    }\n    ${mq.range({ from: breakpoints.wide })} {\n      ${fonts.sizes('20px', '32px')};\n    }\n  }\n`;\n\nconst EmptySlideshow = styled.div`\n  background: rgba(255, 255, 255, 0.08);\n  margin-bottom: $spacing--large * 4;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  height: 40vw;\n`;\n\nconst defaultTransitionSwipeEnd = 'transform 600ms cubic-bezier(0, 0.76, 0.09, 1)';\nconst defaultTransitionText = 'opacity 600ms ease';\n\nconst renderSlideItem = (slide: MovieType) => (\n  <SlideshowItem\n    key={slide.id}\n    role=\"img\"\n    aria-label={(slide.metaImage && slide.metaImage.alt) || ''}\n    style={{\n      backgroundImage: `url(${(slide.metaImage && slide.metaImage.url) || ''})`,\n    }}\n  />\n);\n\nconst FilmSlideshow = ({ autoSlide = false, slideshow = [], slideInterval = 5000 }: Props) => {\n  const [swipeDistance, setSwipeDistance] = useState(0);\n  const [slideIndex, setSlideIndex] = useState(0);\n  const [slideIndexTarget, setSlideIndexTarget] = useState(0);\n  const [animationComplete, setAnimationComplete] = useState(true);\n  const slideRef = useRef<HTMLDivElement>(null);\n  const slideText = useRef<HTMLDivElement>(null);\n  let timer = useRef<ReturnType<typeof setTimeout> | null>(null);\n\n  const gotoSlide = useCallback((indexTarget: number, useAnimation = false) => {\n    setSwipeDistance(0);\n    if (timer.current) {\n      clearTimeout(timer.current);\n    }\n    setSlideIndexTarget(indexTarget);\n    setAnimationComplete(!useAnimation);\n  }, []);\n\n  const onChangedSlide = () => {\n    if (!animationComplete) {\n      if (slideRef.current) {\n        slideRef.current.style.transition = 'none';\n        slideRef.current.style.transform = `translateX(${slideIndexTarget * 100}vw))`;\n      }\n\n      setAnimationComplete(true);\n      setSlideIndex(slideIndexTarget);\n    } else if (slideIndexTarget === -1) {\n      if (slideRef.current) {\n        // Go to last slide for continuous loop\n        slideRef.current.style.transition = 'none';\n        slideRef.current.style.transform = `translateX(${slideshow.length * 100}vw))`;\n      }\n\n      setSlideIndex(slideshow.length - 1);\n      setSlideIndexTarget(slideshow.length - 1);\n      setAnimationComplete(true);\n    } else if (slideIndexTarget === slideshow.length) {\n      if (slideRef.current) {\n        // Go to first slide for continuous loop\n        slideRef.current.style.transition = 'none';\n        slideRef.current.style.transform = `translateX(100vw))`;\n      }\n      setSlideIndex(0);\n      setSlideIndexTarget(0);\n      setAnimationComplete(true);\n    } else {\n      setAnimationComplete(true);\n      setSlideIndex(slideIndexTarget);\n    }\n  };\n\n  const onSwipeEnd = () => {\n    let slide;\n    if (swipeDistance > 40) {\n      slide = -1;\n    } else if (swipeDistance < -40) {\n      slide = 1;\n    } else {\n      slide = 0;\n    }\n    if (slideRef.current && slideText.current) {\n      slideRef.current.style.transition = defaultTransitionSwipeEnd;\n      slideText.current.style.transition = defaultTransitionText;\n      slideText.current.style.opacity = '1';\n    }\n    setSwipeDistance(0);\n\n    initTimer();\n\n    if (slide !== 0) {\n      setSlideIndex(slideIndex + slide);\n      setSlideIndexTarget(slideIndex + slide);\n    } else {\n      // Reset transfrom\n      if (slideRef.current) {\n        slideRef.current.style.transform = getSlidePosition(slideIndex + slide);\n      }\n    }\n  };\n\n  const onSwipe = (eventData: SwipeEventData) => {\n    if (eventData.dir === 'Up' || eventData.dir === 'Down') {\n      return;\n    }\n    if (timer.current) {\n      clearTimeout(timer.current);\n    }\n    setSwipeDistance(eventData.deltaX);\n    if (slideRef && slideRef.current) {\n      slideRef.current.style.transition = 'none';\n      slideRef.current.style.transform = getSlidePosition(slideIndexTarget);\n    }\n    const opacityText = 1 - Math.min(100, Math.abs(swipeDistance)) / 100;\n    if (slideText && slideText.current) {\n      slideText.current.style.transition = 'none';\n      slideText.current.style.opacity = opacityText.toString();\n    }\n  };\n\n  const onTransitionEnd = () => {\n    const slideshowLength = slideshow.length;\n    if (slideIndex === -1) {\n      if (slideRef.current) {\n        slideRef.current.style.transition = 'none';\n        slideRef.current.style.transform = getSlidePosition(slideshowLength - 1);\n      }\n      setSlideIndex(slideshowLength - 1);\n      setSlideIndexTarget(slideshowLength - 1);\n    } else if (slideIndex >= slideshowLength) {\n      if (slideRef.current) {\n        slideRef.current.style.transition = 'none';\n        slideRef.current.style.transform = getSlidePosition(0);\n      }\n      setSlideIndex(0);\n      setSlideIndexTarget(0);\n    }\n  };\n\n  const getSlidePosition = (target: number) => {\n    if (swipeDistance !== 0) {\n      return `translateX(calc(${swipeDistance}px -\n        ${(target + 1) * 100}vw))`;\n    }\n    return `translateX(-${(target + 1) * 100}vw)`;\n  };\n\n  const initTimer = useCallback(() => {\n    if (autoSlide) {\n      timer.current = setTimeout(() => {\n        gotoSlide(slideIndex + 1);\n      }, slideInterval);\n    }\n  }, [autoSlide, gotoSlide, slideInterval, slideIndex]);\n\n  useEffect(() => {\n    initTimer();\n  }, [initTimer]);\n\n  const handlers = useSwipeable({\n    onSwiped: onSwipeEnd,\n    onSwiping: onSwipe,\n  });\n\n  if (slideshow.length === 0) {\n    return (\n      <div>\n        <EmptySlideshow>\n          <Spinner inverted />\n        </EmptySlideshow>\n      </div>\n    );\n  }\n\n  const slideshowWidth = `${(slideshow.length + 2) * 100}vw`;\n  let activeSlide = slideIndex;\n  if (activeSlide < 0) {\n    activeSlide = slideshow.length - 1;\n  } else if (activeSlide >= slideshow.length) {\n    activeSlide = 0;\n  }\n\n  const backgroundImage = slideshow[activeSlide].metaImage;\n\n  return (\n    <SlideshowWrapper {...handlers}>\n      <>\n        <SlideLinkWrapper>\n          <OneColumn>\n            <SlideshowLink to={slideshow[activeSlide].path} out={!animationComplete}>\n              <SlideshowInfo ref={slideText}>\n                <h1>{slideshow[activeSlide].title}</h1>\n                <p>{slideshow[activeSlide].metaDescription}</p>\n              </SlideshowInfo>\n            </SlideshowLink>\n          </OneColumn>\n        </SlideLinkWrapper>\n        <NavigationArrow\n          slideIndexTarget={slideIndexTarget > 0 ? slideIndexTarget - 1 : slideshow.length - 1}\n          gotoSlide={gotoSlide}\n        />\n        <NavigationArrow\n          slideIndexTarget={slideIndexTarget < slideshow.length - 1 ? slideIndexTarget + 1 : 0}\n          gotoSlide={gotoSlide}\n          rightArrow\n        />\n        {!animationComplete && (\n          <SlideshowItem\n            fadeOver\n            role=\"img\"\n            onAnimationEnd={onChangedSlide}\n            style={{\n              backgroundImage: `url(${(backgroundImage && backgroundImage.url) || ''})`,\n            }}\n          />\n        )}\n        <div\n          ref={slideRef}\n          css={itemWrapperCSS}\n          onTransitionEnd={onTransitionEnd}\n          style={{\n            width: slideshowWidth,\n            transform: getSlidePosition(slideIndex),\n          }}>\n          {renderSlideItem(slideshow[slideshow.length - 1])}\n          {slideshow.map(renderSlideItem)}\n          {renderSlideItem(slideshow[0])}\n        </div>\n        <SlideshowIndicator slideshow={slideshow} activeSlide={activeSlide} gotoSlide={gotoSlide} />\n      </>\n    </SlideshowWrapper>\n  );\n};\n\nexport default FilmSlideshow;\n"]} */"));
129
+ var EmptySlideshow = (0, _styledBase["default"])("div", {
130
+ target: "essc37o5",
131
+ label: "EmptySlideshow"
132
+ })(process.env.NODE_ENV === "production" ? {
133
+ name: "1ovku45",
134
+ styles: "background:rgba(255,255,255,0.08);margin-bottom:$spacing--large * 4;display:flex;align-items:center;justify-content:center;height:40vw;"
135
+ } : {
136
+ name: "1ovku45",
137
+ styles: "background:rgba(255,255,255,0.08);margin-bottom:$spacing--large * 4;display:flex;align-items:center;justify-content:center;height:40vw;",
138
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FilmSlideshow.tsx"],"names":[],"mappings":"AA2LiC","file":"FilmSlideshow.tsx","sourcesContent":["/**\n * Copyright (c) 2016-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { useCallback, useEffect, useRef, useState } from 'react';\nimport { SwipeEventData, useSwipeable } from 'react-swipeable';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/core';\nimport { breakpoints, mq, spacing, spacingUnit, fonts, colors } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\nimport { OneColumn } from '../Layout';\nimport Spinner from '../Spinner';\nimport NavigationArrow, { StyledNavigationArrow } from './NavigationArrow';\nimport SlideshowIndicator from './SlideshowIndicator';\nimport { MovieType } from './types';\n\ninterface Props {\n  autoSlide?: boolean;\n  randomStart?: boolean;\n  slideshow: MovieType[];\n  slideInterval?: number;\n}\n\nconst SlideLinkWrapper = styled.div`\n  margin: 0 auto;\n  display: flex;\n  justify-content: flex-start;\n  align-items: flex-end;\n  position: absolute;\n  z-index: 2;\n  height: 100vw;\n  width: 100%;\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    height: 100vw;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 75vw;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    height: 55vw;\n  }\n  ${mq.range({ from: breakpoints.wide })} {\n    height: 40vw;\n  }\n  ${mq.range({ from: breakpoints.ultraWide })} {\n    height: 36vw;\n  }\n`;\n\nconst itemWrapperCSS = css`\n  display: flex;\n  box-shadow: none;\n`;\n\ninterface SlideshowItemProps {\n  fadeOver?: boolean;\n}\n\nconst SlideshowItem = styled.div<SlideshowItemProps>`\n  width: 100vw;\n  height: 100vw;\n  /* aspect ratios */\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    height: 100vw;\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    height: 75vw;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    height: 55vw;\n  }\n  ${mq.range({ from: breakpoints.wide })} {\n    height: 40vw;\n  }\n  ${mq.range({ from: breakpoints.ultraWide })} {\n    height: 36vw;\n  }\n  background-color: '#222';\n  background-size: cover;\n  background-position-x: center;\n  background-position-y: center;\n  border: 0;\n  position: ${(props) => (props.fadeOver ? 'absolute' : 'relative')};\n  animation: ${(props) => props.fadeOver && 'fadeIn 400ms ease'};\n  z-index: ${(props) => props.fadeOver && 1};\n  &:before {\n    content: '';\n    opacity: 0.4;\n    background: #091a2a;\n    top: 0;\n    left: 0;\n    bottom: 0;\n    right: 0;\n    position: absolute;\n    z-index: 1;\n  }\n`;\n\ninterface SlideshowLinkProps {\n  out?: boolean;\n}\n\nconst SlideshowLink = styled(SafeLink)<SlideshowLinkProps>`\n  display: flex;\n  box-shadow: none;\n  transition: all 400ms ease;\n  opacity: ${(props) => props.out && 0};\n  animation: ${(props) => !props.out && 'fadeInBottomFixed 600ms ease'};\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    padding-bottom: ${spacing.medium};\n  }\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding-bottom: ${spacing.large};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-bottom: ${spacingUnit * 3}px;\n  }\n  &:hover {\n    h1 {\n      text-decoration: underline;\n    }\n  }\n`;\n\nconst SlideshowWrapper = styled.section`\n  &:hover {\n    ${StyledNavigationArrow} {\n      opacity: 1;\n      transform: translate(0, 0);\n    }\n  }\n`;\n\nconst SlideshowInfo = styled.div`\n  border: 0;\n  background: none;\n  background-color: rgba(3, 23, 43, 0.7);\n  border-radius: 4px;\n  padding: ${spacing.medium} ${spacing.medium} ${spacing.medium} ${spacing.normal};\n  margin: 0 -20px;\n  width: 100vw;\n  ${mq.range({ from: breakpoints.mobileWide })} {\n    margin: 0;\n    width: 100%;\n    padding: ${spacing.medium} ${spacingUnit * 2}px ${spacing.medium} ${spacing.normal};\n  }\n  h1 {\n    ${fonts.sizes('22px', '30px')};\n    color: ${colors.white};\n    text-shadow: 0 2px 4px rgba(0, 0, 0, 0.25);\n    margin: 0;\n    font-weight: ${fonts.weight.semibold};\n    ${mq.range({ from: breakpoints.mobileWide })} {\n      margin: 0 0 ${spacing.small};\n      ${fonts.sizes('26px', '30px')};\n    }\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes('40px', '44px')};\n    }\n    ${mq.range({ from: breakpoints.desktop })} {\n      ${fonts.sizes('48px', '54px')};\n    }\n  }\n\n  p {\n    color: ${colors.white};\n    display: inline-block;\n    margin: 0;\n    padding: 0;\n    border-radius: 4px;\n    ${fonts.sizes('12px', '18px')};\n    ${mq.range({ from: breakpoints.mobileWide })} {\n      ${fonts.sizes('15px', '20px')};\n    }\n    ${mq.range({ from: breakpoints.tablet })} {\n      ${fonts.sizes('18px', '24px')};\n    }\n    ${mq.range({ from: breakpoints.wide })} {\n      ${fonts.sizes('20px', '32px')};\n    }\n  }\n`;\n\nconst EmptySlideshow = styled.div`\n  background: rgba(255, 255, 255, 0.08);\n  margin-bottom: $spacing--large * 4;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  height: 40vw;\n`;\n\nconst defaultTransitionSwipeEnd = 'transform 600ms cubic-bezier(0, 0.76, 0.09, 1)';\nconst defaultTransitionText = 'opacity 600ms ease';\n\nconst renderSlideItem = (slide: MovieType) => (\n  <SlideshowItem\n    key={slide.id}\n    role=\"img\"\n    aria-label={(slide.metaImage && slide.metaImage.alt) || ''}\n    style={{\n      backgroundImage: `url(${(slide.metaImage && slide.metaImage.url) || ''})`,\n    }}\n  />\n);\n\nconst FilmSlideshow = ({ autoSlide = false, slideshow = [], slideInterval = 5000 }: Props) => {\n  const [swipeDistance, setSwipeDistance] = useState(0);\n  const [slideIndex, setSlideIndex] = useState(0);\n  const [slideIndexTarget, setSlideIndexTarget] = useState(0);\n  const [animationComplete, setAnimationComplete] = useState(true);\n  const slideRef = useRef<HTMLDivElement>(null);\n  const slideText = useRef<HTMLDivElement>(null);\n  let timer = useRef<ReturnType<typeof setTimeout> | null>(null);\n\n  const gotoSlide = useCallback((indexTarget: number, useAnimation = false) => {\n    setSwipeDistance(0);\n    if (timer.current) {\n      clearTimeout(timer.current);\n    }\n    setSlideIndexTarget(indexTarget);\n    setAnimationComplete(!useAnimation);\n  }, []);\n\n  const onChangedSlide = () => {\n    if (!animationComplete) {\n      if (slideRef.current) {\n        slideRef.current.style.transition = 'none';\n        slideRef.current.style.transform = `translateX(${slideIndexTarget * 100}vw))`;\n      }\n\n      setAnimationComplete(true);\n      setSlideIndex(slideIndexTarget);\n    } else if (slideIndexTarget === -1) {\n      if (slideRef.current) {\n        // Go to last slide for continuous loop\n        slideRef.current.style.transition = 'none';\n        slideRef.current.style.transform = `translateX(${slideshow.length * 100}vw))`;\n      }\n\n      setSlideIndex(slideshow.length - 1);\n      setSlideIndexTarget(slideshow.length - 1);\n      setAnimationComplete(true);\n    } else if (slideIndexTarget === slideshow.length) {\n      if (slideRef.current) {\n        // Go to first slide for continuous loop\n        slideRef.current.style.transition = 'none';\n        slideRef.current.style.transform = `translateX(100vw))`;\n      }\n      setSlideIndex(0);\n      setSlideIndexTarget(0);\n      setAnimationComplete(true);\n    } else {\n      setAnimationComplete(true);\n      setSlideIndex(slideIndexTarget);\n    }\n  };\n\n  const onSwipeEnd = () => {\n    let slide;\n    if (swipeDistance > 40) {\n      slide = -1;\n    } else if (swipeDistance < -40) {\n      slide = 1;\n    } else {\n      slide = 0;\n    }\n    if (slideRef.current && slideText.current) {\n      slideRef.current.style.transition = defaultTransitionSwipeEnd;\n      slideText.current.style.transition = defaultTransitionText;\n      slideText.current.style.opacity = '1';\n    }\n    setSwipeDistance(0);\n\n    initTimer();\n\n    if (slide !== 0) {\n      setSlideIndex(slideIndex + slide);\n      setSlideIndexTarget(slideIndex + slide);\n    } else {\n      // Reset transfrom\n      if (slideRef.current) {\n        slideRef.current.style.transform = getSlidePosition(slideIndex + slide);\n      }\n    }\n  };\n\n  const onSwipe = (eventData: SwipeEventData) => {\n    if (eventData.dir === 'Up' || eventData.dir === 'Down') {\n      return;\n    }\n    if (timer.current) {\n      clearTimeout(timer.current);\n    }\n    setSwipeDistance(eventData.deltaX);\n    if (slideRef && slideRef.current) {\n      slideRef.current.style.transition = 'none';\n      slideRef.current.style.transform = getSlidePosition(slideIndexTarget);\n    }\n    const opacityText = 1 - Math.min(100, Math.abs(swipeDistance)) / 100;\n    if (slideText && slideText.current) {\n      slideText.current.style.transition = 'none';\n      slideText.current.style.opacity = opacityText.toString();\n    }\n  };\n\n  const onTransitionEnd = () => {\n    const slideshowLength = slideshow.length;\n    if (slideIndex === -1) {\n      if (slideRef.current) {\n        slideRef.current.style.transition = 'none';\n        slideRef.current.style.transform = getSlidePosition(slideshowLength - 1);\n      }\n      setSlideIndex(slideshowLength - 1);\n      setSlideIndexTarget(slideshowLength - 1);\n    } else if (slideIndex >= slideshowLength) {\n      if (slideRef.current) {\n        slideRef.current.style.transition = 'none';\n        slideRef.current.style.transform = getSlidePosition(0);\n      }\n      setSlideIndex(0);\n      setSlideIndexTarget(0);\n    }\n  };\n\n  const getSlidePosition = (target: number) => {\n    if (swipeDistance !== 0) {\n      return `translateX(calc(${swipeDistance}px -\n        ${(target + 1) * 100}vw))`;\n    }\n    return `translateX(-${(target + 1) * 100}vw)`;\n  };\n\n  const initTimer = useCallback(() => {\n    if (autoSlide) {\n      timer.current = setTimeout(() => {\n        gotoSlide(slideIndex + 1);\n      }, slideInterval);\n    }\n  }, [autoSlide, gotoSlide, slideInterval, slideIndex]);\n\n  useEffect(() => {\n    initTimer();\n  }, [initTimer]);\n\n  const handlers = useSwipeable({\n    onSwiped: onSwipeEnd,\n    onSwiping: onSwipe,\n  });\n\n  if (slideshow.length === 0) {\n    return (\n      <div>\n        <EmptySlideshow>\n          <Spinner inverted />\n        </EmptySlideshow>\n      </div>\n    );\n  }\n\n  const slideshowWidth = `${(slideshow.length + 2) * 100}vw`;\n  let activeSlide = slideIndex;\n  if (activeSlide < 0) {\n    activeSlide = slideshow.length - 1;\n  } else if (activeSlide >= slideshow.length) {\n    activeSlide = 0;\n  }\n\n  const backgroundImage = slideshow[activeSlide].metaImage;\n\n  return (\n    <SlideshowWrapper {...handlers}>\n      <>\n        <SlideLinkWrapper>\n          <OneColumn>\n            <SlideshowLink to={slideshow[activeSlide].path} out={!animationComplete}>\n              <SlideshowInfo ref={slideText}>\n                <h1>{slideshow[activeSlide].title}</h1>\n                <p>{slideshow[activeSlide].metaDescription}</p>\n              </SlideshowInfo>\n            </SlideshowLink>\n          </OneColumn>\n        </SlideLinkWrapper>\n        <NavigationArrow\n          slideIndexTarget={slideIndexTarget > 0 ? slideIndexTarget - 1 : slideshow.length - 1}\n          gotoSlide={gotoSlide}\n        />\n        <NavigationArrow\n          slideIndexTarget={slideIndexTarget < slideshow.length - 1 ? slideIndexTarget + 1 : 0}\n          gotoSlide={gotoSlide}\n          rightArrow\n        />\n        {!animationComplete && (\n          <SlideshowItem\n            fadeOver\n            role=\"img\"\n            onAnimationEnd={onChangedSlide}\n            style={{\n              backgroundImage: `url(${(backgroundImage && backgroundImage.url) || ''})`,\n            }}\n          />\n        )}\n        <div\n          ref={slideRef}\n          css={itemWrapperCSS}\n          onTransitionEnd={onTransitionEnd}\n          style={{\n            width: slideshowWidth,\n            transform: getSlidePosition(slideIndex),\n          }}>\n          {renderSlideItem(slideshow[slideshow.length - 1])}\n          {slideshow.map(renderSlideItem)}\n          {renderSlideItem(slideshow[0])}\n        </div>\n        <SlideshowIndicator slideshow={slideshow} activeSlide={activeSlide} gotoSlide={gotoSlide} />\n      </>\n    </SlideshowWrapper>\n  );\n};\n\nexport default FilmSlideshow;\n"]} */",
139
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
51
140
  });
52
141
  var defaultTransitionSwipeEnd = 'transform 600ms cubic-bezier(0, 0.76, 0.09, 1)';
53
142
  var defaultTransitionText = 'opacity 600ms ease';
54
143
 
55
144
  var renderSlideItem = function renderSlideItem(slide) {
56
- return (0, _core.jsx)("div", _extends({}, classes('item'), {
145
+ return (0, _core.jsx)(SlideshowItem, {
57
146
  key: slide.id,
58
147
  role: "img",
59
148
  "aria-label": slide.metaImage && slide.metaImage.alt || '',
60
149
  style: {
61
150
  backgroundImage: "url(".concat(slide.metaImage && slide.metaImage.url || '', ")")
62
151
  }
63
- }));
152
+ });
64
153
  };
65
154
 
66
155
  var FilmSlideshow = function FilmSlideshow(_ref) {
@@ -242,7 +331,7 @@ var FilmSlideshow = function FilmSlideshow(_ref) {
242
331
  });
243
332
 
244
333
  if (slideshow.length === 0) {
245
- return (0, _core.jsx)("div", null, (0, _core.jsx)("div", classes('slideshow'), (0, _core.jsx)(_Spinner["default"], {
334
+ return (0, _core.jsx)("div", null, (0, _core.jsx)(EmptySlideshow, null, (0, _core.jsx)(_Spinner["default"], {
246
335
  inverted: true
247
336
  })));
248
337
  }
@@ -257,34 +346,34 @@ var FilmSlideshow = function FilmSlideshow(_ref) {
257
346
  }
258
347
 
259
348
  var backgroundImage = slideshow[activeSlide].metaImage;
260
- return (0, _core.jsx)("section", _extends({}, classes(''), handlers), (0, _core.jsx)(_react["default"].Fragment, null, (0, _core.jsx)("div", classes('slide-link-wrapper'), (0, _core.jsx)(_Layout.OneColumn, null, (0, _core.jsx)(_safelink["default"], _extends({
261
- to: slideshow[activeSlide].path
262
- }, classes('item-wrapper', 'text', {
349
+ return (0, _core.jsx)(SlideshowWrapper, handlers, (0, _core.jsx)(_react["default"].Fragment, null, (0, _core.jsx)(SlideLinkWrapper, null, (0, _core.jsx)(_Layout.OneColumn, null, (0, _core.jsx)(SlideshowLink, {
350
+ to: slideshow[activeSlide].path,
263
351
  out: !animationComplete
264
- })), (0, _core.jsx)("div", _extends({}, classes('slide-info'), {
352
+ }, (0, _core.jsx)(SlideshowInfo, {
265
353
  ref: slideText
266
- }), (0, _core.jsx)("h1", null, slideshow[activeSlide].title), (0, _core.jsx)("p", null, slideshow[activeSlide].metaDescription))))), (0, _core.jsx)(_NavigationArrow["default"], {
354
+ }, (0, _core.jsx)("h1", null, slideshow[activeSlide].title), (0, _core.jsx)("p", null, slideshow[activeSlide].metaDescription))))), (0, _core.jsx)(_NavigationArrow["default"], {
267
355
  slideIndexTarget: slideIndexTarget > 0 ? slideIndexTarget - 1 : slideshow.length - 1,
268
356
  gotoSlide: gotoSlide
269
357
  }), (0, _core.jsx)(_NavigationArrow["default"], {
270
358
  slideIndexTarget: slideIndexTarget < slideshow.length - 1 ? slideIndexTarget + 1 : 0,
271
359
  gotoSlide: gotoSlide,
272
360
  rightArrow: true
273
- }), !animationComplete && (0, _core.jsx)("div", _extends({}, classes('item', 'fade-over'), {
361
+ }), !animationComplete && (0, _core.jsx)(SlideshowItem, {
362
+ fadeOver: true,
274
363
  role: "img",
275
364
  onAnimationEnd: onChangedSlide,
276
365
  style: {
277
366
  backgroundImage: "url(".concat(backgroundImage && backgroundImage.url || '', ")")
278
367
  }
279
- })), (0, _core.jsx)("div", _extends({
280
- ref: slideRef
281
- }, classes('item-wrapper'), {
368
+ }), (0, _core.jsx)("div", {
369
+ ref: slideRef,
370
+ css: itemWrapperCSS,
282
371
  onTransitionEnd: onTransitionEnd,
283
372
  style: {
284
373
  width: slideshowWidth,
285
374
  transform: getSlidePosition(slideIndex)
286
375
  }
287
- }), renderSlideItem(slideshow[slideshow.length - 1]), slideshow.map(renderSlideItem), renderSlideItem(slideshow[0])), (0, _core.jsx)(_SlideshowIndicator["default"], {
376
+ }, renderSlideItem(slideshow[slideshow.length - 1]), slideshow.map(renderSlideItem), renderSlideItem(slideshow[0])), (0, _core.jsx)(_SlideshowIndicator["default"], {
288
377
  slideshow: slideshow,
289
378
  activeSlide: activeSlide,
290
379
  gotoSlide: gotoSlide
@@ -5,24 +5,34 @@ Object.defineProperty(exports, "__esModule", {
5
5
  });
6
6
  exports["default"] = void 0;
7
7
 
8
- var _react = _interopRequireDefault(require("react"));
8
+ var _styledBase = _interopRequireDefault(require("@emotion/styled-base"));
9
9
 
10
- var _reactBemHelper = _interopRequireDefault(require("react-bem-helper"));
10
+ var _react = _interopRequireDefault(require("react"));
11
11
 
12
- var _core = require("@emotion/core");
12
+ var _core = require("@ndla/core");
13
13
 
14
14
  var _reactI18next = require("react-i18next");
15
15
 
16
16
  var _FilmContentCard = _interopRequireDefault(require("./FilmContentCard"));
17
17
 
18
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
18
+ var _filmStyles = require("./filmStyles");
19
19
 
20
- function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
20
+ var _core2 = require("@emotion/core");
21
21
 
22
- var movieListClasses = new _reactBemHelper["default"]({
23
- name: 'film-movielist',
24
- prefix: 'c-'
25
- });
22
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
23
+
24
+ var MovieListing = (0, _styledBase["default"])("div", {
25
+ target: "e1t64qur0",
26
+ label: "MovieListing"
27
+ })("display:flex;flex-wrap:wrap;margin:", _core.spacing.small, " 0;margin-left:", function (props) {
28
+ return props.marginLeft && "".concat(props.marginLeft, "px");
29
+ }, ";", (0, _filmStyles.setAnimations)(), ";> div{opacity:0;animation-fill-mode:forwards;animation-name:fadeIn;animation-duration:300ms;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIk1vdmllR3JpZC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBYWtEIiwiZmlsZSI6Ik1vdmllR3JpZC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgc3BhY2luZyB9IGZyb20gJ0BuZGxhL2NvcmUnO1xuaW1wb3J0IHsgQ2FsY3VsYXRlZENhcm91c2VsUHJvcHMgfSBmcm9tICdAbmRsYS9jYXJvdXNlbCc7XG5pbXBvcnQgeyB1c2VUcmFuc2xhdGlvbiB9IGZyb20gJ3JlYWN0LWkxOG5leHQnO1xuaW1wb3J0IEZpbG1Db250ZW50Q2FyZCBmcm9tICcuL0ZpbG1Db250ZW50Q2FyZCc7XG5pbXBvcnQgeyBNb3ZpZVJlc291cmNlVHlwZSwgTW92aWVUeXBlIH0gZnJvbSAnLi90eXBlcyc7XG5pbXBvcnQgeyBzZXRBbmltYXRpb25zLCBTdHlsZWRIZWFkaW5nSDEgfSBmcm9tICcuL2ZpbG1TdHlsZXMnO1xuXG5pbnRlcmZhY2UgTW92aWVMaXN0aW5nUHJvcHMge1xuICBtYXJnaW5MZWZ0PzogbnVtYmVyO1xufVxuXG5jb25zdCBNb3ZpZUxpc3RpbmcgPSBzdHlsZWQuZGl2PE1vdmllTGlzdGluZ1Byb3BzPmBcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC13cmFwOiB3cmFwO1xuICBtYXJnaW46ICR7c3BhY2luZy5zbWFsbH0gMDtcbiAgbWFyZ2luLWxlZnQ6ICR7KHByb3BzKSA9PiBwcm9wcy5tYXJnaW5MZWZ0ICYmIGAke3Byb3BzLm1hcmdpbkxlZnR9cHhgfTtcbiAgJHtzZXRBbmltYXRpb25zKCl9O1xuICA+IGRpdiB7XG4gICAgb3BhY2l0eTogMDtcbiAgICBhbmltYXRpb24tZmlsbC1tb2RlOiBmb3J3YXJkcztcbiAgICBhbmltYXRpb24tbmFtZTogZmFkZUluO1xuICAgIGFuaW1hdGlvbi1kdXJhdGlvbjogMzAwbXM7XG4gIH1cbmA7XG5cbmludGVyZmFjZSBMb2FkaW5nUGxhY2Vob2xkZXJQcm9wcyB7XG4gIGhlaWdodD86IHN0cmluZztcbn1cblxuY29uc3QgTG9hZGluZ1BsYWNlaG9sZGVyID0gc3R5bGVkLmRpdjxMb2FkaW5nUGxhY2Vob2xkZXJQcm9wcz5gXG4gIGhlaWdodDogJHsocHJvcHMpID0+IHByb3BzLmhlaWdodH07XG5gO1xuXG5pbnRlcmZhY2UgUHJvcHMge1xuICBhdXRvU2l6ZWRQcm9wczogQ2FsY3VsYXRlZENhcm91c2VsUHJvcHM7XG4gIHJlc291cmNlVHlwZU5hbWU/OiBNb3ZpZVJlc291cmNlVHlwZTtcbiAgZmV0Y2hpbmdNb3ZpZXNCeVR5cGU6IGJvb2xlYW47XG4gIG1vdmllc0J5VHlwZTogTW92aWVUeXBlW107XG4gIHJlc291cmNlVHlwZXM6IE1vdmllUmVzb3VyY2VUeXBlW107XG4gIGxvYWRpbmdQbGFjZWhvbGRlckhlaWdodD86IHN0cmluZztcbiAgcmVzaXplVGh1bWJuYWlsSW1hZ2VzPzogYm9vbGVhbjtcbn1cblxuY29uc3QgTW92aWVHcmlkID0gKHtcbiAgcmVzb3VyY2VUeXBlTmFtZSxcbiAgZmV0Y2hpbmdNb3ZpZXNCeVR5cGUsXG4gIG1vdmllc0J5VHlwZSxcbiAgcmVzb3VyY2VUeXBlcyxcbiAgbG9hZGluZ1BsYWNlaG9sZGVySGVpZ2h0LFxuICBhdXRvU2l6ZWRQcm9wcyxcbiAgcmVzaXplVGh1bWJuYWlsSW1hZ2VzLFxufTogUHJvcHMpID0+IHtcbiAgY29uc3QgeyB0IH0gPSB1c2VUcmFuc2xhdGlvbigpO1xuICByZXR1cm4gKFxuICAgIDxzZWN0aW9uPlxuICAgICAgPFN0eWxlZEhlYWRpbmdIMSBtYXJnaW5MZWZ0PXthdXRvU2l6ZWRQcm9wcy5tYXJnaW59PlxuICAgICAgICB7cmVzb3VyY2VUeXBlTmFtZSAmJiByZXNvdXJjZVR5cGVOYW1lLm5hbWV9XG4gICAgICAgIDxzbWFsbD5cbiAgICAgICAgICB7ZmV0Y2hpbmdNb3ZpZXNCeVR5cGVcbiAgICAgICAgICAgID8gdCgnbmRsYUZpbG0ubG9hZGluZ01vdmllcycpXG4gICAgICAgICAgICA6IGAke21vdmllc0J5VHlwZS5sZW5ndGh9ICR7dCgnbmRsYUZpbG0ubW92aWVNYXRjaEluQ2F0ZWdvcnknKX1gfVxuICAgICAgICA8L3NtYWxsPlxuICAgICAgPC9TdHlsZWRIZWFkaW5nSDE+XG4gICAgICA8TW92aWVMaXN0aW5nIG1hcmdpbkxlZnQ9e2F1dG9TaXplZFByb3BzLm1hcmdpbn0+XG4gICAgICAgIHtmZXRjaGluZ01vdmllc0J5VHlwZSAmJiA8TG9hZGluZ1BsYWNlaG9sZGVyIGhlaWdodD17bG9hZGluZ1BsYWNlaG9sZGVySGVpZ2h0fSAvPn1cbiAgICAgICAgeyFmZXRjaGluZ01vdmllc0J5VHlwZSAmJlxuICAgICAgICAgIG1vdmllc0J5VHlwZS5tYXAoKG1vdmllKSA9PiAoXG4gICAgICAgICAgICA8RmlsbUNvbnRlbnRDYXJkXG4gICAgICAgICAgICAgIGhpZGVUYWdzXG4gICAgICAgICAgICAgIG1vdmllPXttb3ZpZX1cbiAgICAgICAgICAgICAgY29sdW1uV2lkdGg9e2F1dG9TaXplZFByb3BzLmNvbHVtbldpZHRofVxuICAgICAgICAgICAgICBkaXN0YW5jZUJldHdlZW5JdGVtcz17YXV0b1NpemVkUHJvcHMuZGlzdGFuY2VCZXR3ZWVuSXRlbXN9XG4gICAgICAgICAgICAgIHJlc291cmNlVHlwZXM9e3Jlc291cmNlVHlwZXN9XG4gICAgICAgICAgICAgIHJlc2l6ZVRodW1ibmFpbEltYWdlcz17cmVzaXplVGh1bWJuYWlsSW1hZ2VzfVxuICAgICAgICAgICAgLz5cbiAgICAgICAgICApKX1cbiAgICAgIDwvTW92aWVMaXN0aW5nPlxuICAgIDwvc2VjdGlvbj5cbiAgKTtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IE1vdmllR3JpZDtcbiJdfQ== */"));
30
+ var LoadingPlaceholder = (0, _styledBase["default"])("div", {
31
+ target: "e1t64qur1",
32
+ label: "LoadingPlaceholder"
33
+ })("height:", function (props) {
34
+ return props.height;
35
+ }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIk1vdmllR3JpZC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBK0I4RCIsImZpbGUiOiJNb3ZpZUdyaWQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IHNwYWNpbmcgfSBmcm9tICdAbmRsYS9jb3JlJztcbmltcG9ydCB7IENhbGN1bGF0ZWRDYXJvdXNlbFByb3BzIH0gZnJvbSAnQG5kbGEvY2Fyb3VzZWwnO1xuaW1wb3J0IHsgdXNlVHJhbnNsYXRpb24gfSBmcm9tICdyZWFjdC1pMThuZXh0JztcbmltcG9ydCBGaWxtQ29udGVudENhcmQgZnJvbSAnLi9GaWxtQ29udGVudENhcmQnO1xuaW1wb3J0IHsgTW92aWVSZXNvdXJjZVR5cGUsIE1vdmllVHlwZSB9IGZyb20gJy4vdHlwZXMnO1xuaW1wb3J0IHsgc2V0QW5pbWF0aW9ucywgU3R5bGVkSGVhZGluZ0gxIH0gZnJvbSAnLi9maWxtU3R5bGVzJztcblxuaW50ZXJmYWNlIE1vdmllTGlzdGluZ1Byb3BzIHtcbiAgbWFyZ2luTGVmdD86IG51bWJlcjtcbn1cblxuY29uc3QgTW92aWVMaXN0aW5nID0gc3R5bGVkLmRpdjxNb3ZpZUxpc3RpbmdQcm9wcz5gXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXgtd3JhcDogd3JhcDtcbiAgbWFyZ2luOiAke3NwYWNpbmcuc21hbGx9IDA7XG4gIG1hcmdpbi1sZWZ0OiAkeyhwcm9wcykgPT4gcHJvcHMubWFyZ2luTGVmdCAmJiBgJHtwcm9wcy5tYXJnaW5MZWZ0fXB4YH07XG4gICR7c2V0QW5pbWF0aW9ucygpfTtcbiAgPiBkaXYge1xuICAgIG9wYWNpdHk6IDA7XG4gICAgYW5pbWF0aW9uLWZpbGwtbW9kZTogZm9yd2FyZHM7XG4gICAgYW5pbWF0aW9uLW5hbWU6IGZhZGVJbjtcbiAgICBhbmltYXRpb24tZHVyYXRpb246IDMwMG1zO1xuICB9XG5gO1xuXG5pbnRlcmZhY2UgTG9hZGluZ1BsYWNlaG9sZGVyUHJvcHMge1xuICBoZWlnaHQ/OiBzdHJpbmc7XG59XG5cbmNvbnN0IExvYWRpbmdQbGFjZWhvbGRlciA9IHN0eWxlZC5kaXY8TG9hZGluZ1BsYWNlaG9sZGVyUHJvcHM+YFxuICBoZWlnaHQ6ICR7KHByb3BzKSA9PiBwcm9wcy5oZWlnaHR9O1xuYDtcblxuaW50ZXJmYWNlIFByb3BzIHtcbiAgYXV0b1NpemVkUHJvcHM6IENhbGN1bGF0ZWRDYXJvdXNlbFByb3BzO1xuICByZXNvdXJjZVR5cGVOYW1lPzogTW92aWVSZXNvdXJjZVR5cGU7XG4gIGZldGNoaW5nTW92aWVzQnlUeXBlOiBib29sZWFuO1xuICBtb3ZpZXNCeVR5cGU6IE1vdmllVHlwZVtdO1xuICByZXNvdXJjZVR5cGVzOiBNb3ZpZVJlc291cmNlVHlwZVtdO1xuICBsb2FkaW5nUGxhY2Vob2xkZXJIZWlnaHQ/OiBzdHJpbmc7XG4gIHJlc2l6ZVRodW1ibmFpbEltYWdlcz86IGJvb2xlYW47XG59XG5cbmNvbnN0IE1vdmllR3JpZCA9ICh7XG4gIHJlc291cmNlVHlwZU5hbWUsXG4gIGZldGNoaW5nTW92aWVzQnlUeXBlLFxuICBtb3ZpZXNCeVR5cGUsXG4gIHJlc291cmNlVHlwZXMsXG4gIGxvYWRpbmdQbGFjZWhvbGRlckhlaWdodCxcbiAgYXV0b1NpemVkUHJvcHMsXG4gIHJlc2l6ZVRodW1ibmFpbEltYWdlcyxcbn06IFByb3BzKSA9PiB7XG4gIGNvbnN0IHsgdCB9ID0gdXNlVHJhbnNsYXRpb24oKTtcbiAgcmV0dXJuIChcbiAgICA8c2VjdGlvbj5cbiAgICAgIDxTdHlsZWRIZWFkaW5nSDEgbWFyZ2luTGVmdD17YXV0b1NpemVkUHJvcHMubWFyZ2lufT5cbiAgICAgICAge3Jlc291cmNlVHlwZU5hbWUgJiYgcmVzb3VyY2VUeXBlTmFtZS5uYW1lfVxuICAgICAgICA8c21hbGw+XG4gICAgICAgICAge2ZldGNoaW5nTW92aWVzQnlUeXBlXG4gICAgICAgICAgICA/IHQoJ25kbGFGaWxtLmxvYWRpbmdNb3ZpZXMnKVxuICAgICAgICAgICAgOiBgJHttb3ZpZXNCeVR5cGUubGVuZ3RofSAke3QoJ25kbGFGaWxtLm1vdmllTWF0Y2hJbkNhdGVnb3J5Jyl9YH1cbiAgICAgICAgPC9zbWFsbD5cbiAgICAgIDwvU3R5bGVkSGVhZGluZ0gxPlxuICAgICAgPE1vdmllTGlzdGluZyBtYXJnaW5MZWZ0PXthdXRvU2l6ZWRQcm9wcy5tYXJnaW59PlxuICAgICAgICB7ZmV0Y2hpbmdNb3ZpZXNCeVR5cGUgJiYgPExvYWRpbmdQbGFjZWhvbGRlciBoZWlnaHQ9e2xvYWRpbmdQbGFjZWhvbGRlckhlaWdodH0gLz59XG4gICAgICAgIHshZmV0Y2hpbmdNb3ZpZXNCeVR5cGUgJiZcbiAgICAgICAgICBtb3ZpZXNCeVR5cGUubWFwKChtb3ZpZSkgPT4gKFxuICAgICAgICAgICAgPEZpbG1Db250ZW50Q2FyZFxuICAgICAgICAgICAgICBoaWRlVGFnc1xuICAgICAgICAgICAgICBtb3ZpZT17bW92aWV9XG4gICAgICAgICAgICAgIGNvbHVtbldpZHRoPXthdXRvU2l6ZWRQcm9wcy5jb2x1bW5XaWR0aH1cbiAgICAgICAgICAgICAgZGlzdGFuY2VCZXR3ZWVuSXRlbXM9e2F1dG9TaXplZFByb3BzLmRpc3RhbmNlQmV0d2Vlbkl0ZW1zfVxuICAgICAgICAgICAgICByZXNvdXJjZVR5cGVzPXtyZXNvdXJjZVR5cGVzfVxuICAgICAgICAgICAgICByZXNpemVUaHVtYm5haWxJbWFnZXM9e3Jlc2l6ZVRodW1ibmFpbEltYWdlc31cbiAgICAgICAgICAgIC8+XG4gICAgICAgICAgKSl9XG4gICAgICA8L01vdmllTGlzdGluZz5cbiAgICA8L3NlY3Rpb24+XG4gICk7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBNb3ZpZUdyaWQ7XG4iXX0= */"));
26
36
 
27
37
  var MovieGrid = function MovieGrid(_ref) {
28
38
  var resourceTypeName = _ref.resourceTypeName,
@@ -36,14 +46,14 @@ var MovieGrid = function MovieGrid(_ref) {
36
46
  var _useTranslation = (0, _reactI18next.useTranslation)(),
37
47
  t = _useTranslation.t;
38
48
 
39
- return (0, _core.jsx)("section", null, (0, _core.jsx)("h1", _extends({}, movieListClasses('heading'), {
40
- css: /*#__PURE__*/(0, _core.css)("margin-left:", autoSizedProps.margin, "px;;label:MovieGrid;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIk1vdmllR3JpZC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBcUNnQiIsImZpbGUiOiJNb3ZpZUdyaWQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcbmltcG9ydCBCRU1IZWxwZXIgZnJvbSAncmVhY3QtYmVtLWhlbHBlcic7XG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9jb3JlJztcbmltcG9ydCB7IENhbGN1bGF0ZWRDYXJvdXNlbFByb3BzIH0gZnJvbSAnQG5kbGEvY2Fyb3VzZWwnO1xuaW1wb3J0IHsgdXNlVHJhbnNsYXRpb24gfSBmcm9tICdyZWFjdC1pMThuZXh0JztcbmltcG9ydCBGaWxtQ29udGVudENhcmQgZnJvbSAnLi9GaWxtQ29udGVudENhcmQnO1xuaW1wb3J0IHsgTW92aWVSZXNvdXJjZVR5cGUsIE1vdmllVHlwZSB9IGZyb20gJy4vdHlwZXMnO1xuXG5jb25zdCBtb3ZpZUxpc3RDbGFzc2VzID0gbmV3IEJFTUhlbHBlcih7XG4gIG5hbWU6ICdmaWxtLW1vdmllbGlzdCcsXG4gIHByZWZpeDogJ2MtJyxcbn0pO1xuXG5pbnRlcmZhY2UgUHJvcHMge1xuICBhdXRvU2l6ZWRQcm9wczogQ2FsY3VsYXRlZENhcm91c2VsUHJvcHM7XG4gIHJlc291cmNlVHlwZU5hbWU/OiBNb3ZpZVJlc291cmNlVHlwZTtcbiAgZmV0Y2hpbmdNb3ZpZXNCeVR5cGU6IGJvb2xlYW47XG4gIG1vdmllc0J5VHlwZTogTW92aWVUeXBlW107XG4gIHJlc291cmNlVHlwZXM6IE1vdmllUmVzb3VyY2VUeXBlW107XG4gIGxvYWRpbmdQbGFjZWhvbGRlckhlaWdodD86IHN0cmluZztcbiAgcmVzaXplVGh1bWJuYWlsSW1hZ2VzPzogYm9vbGVhbjtcbn1cblxuY29uc3QgTW92aWVHcmlkID0gKHtcbiAgcmVzb3VyY2VUeXBlTmFtZSxcbiAgZmV0Y2hpbmdNb3ZpZXNCeVR5cGUsXG4gIG1vdmllc0J5VHlwZSxcbiAgcmVzb3VyY2VUeXBlcyxcbiAgbG9hZGluZ1BsYWNlaG9sZGVySGVpZ2h0LFxuICBhdXRvU2l6ZWRQcm9wcyxcbiAgcmVzaXplVGh1bWJuYWlsSW1hZ2VzLFxufTogUHJvcHMpID0+IHtcbiAgY29uc3QgeyB0IH0gPSB1c2VUcmFuc2xhdGlvbigpO1xuICByZXR1cm4gKFxuICAgIDxzZWN0aW9uPlxuICAgICAgPGgxXG4gICAgICAgIHsuLi5tb3ZpZUxpc3RDbGFzc2VzKCdoZWFkaW5nJyl9XG4gICAgICAgIGNzcz17Y3NzYFxuICAgICAgICAgIG1hcmdpbi1sZWZ0OiAke2F1dG9TaXplZFByb3BzLm1hcmdpbn1weDtcbiAgICAgICAgYH0+XG4gICAgICAgIHtyZXNvdXJjZVR5cGVOYW1lICYmIHJlc291cmNlVHlwZU5hbWUubmFtZX1cbiAgICAgICAgPHNtYWxsPlxuICAgICAgICAgIHtmZXRjaGluZ01vdmllc0J5VHlwZVxuICAgICAgICAgICAgPyB0KCduZGxhRmlsbS5sb2FkaW5nTW92aWVzJylcbiAgICAgICAgICAgIDogYCR7bW92aWVzQnlUeXBlLmxlbmd0aH0gJHt0KCduZGxhRmlsbS5tb3ZpZU1hdGNoSW5DYXRlZ29yeScpfWB9XG4gICAgICAgIDwvc21hbGw+XG4gICAgICA8L2gxPlxuICAgICAgPGRpdlxuICAgICAgICB7Li4ubW92aWVMaXN0Q2xhc3NlcygnbW92aWUtbGlzdGluZycpfVxuICAgICAgICBjc3M9e2Nzc2BcbiAgICAgICAgICBtYXJnaW4tbGVmdDogJHthdXRvU2l6ZWRQcm9wcy5tYXJnaW59cHg7XG4gICAgICAgIGB9PlxuICAgICAgICB7ZmV0Y2hpbmdNb3ZpZXNCeVR5cGUgJiYgKFxuICAgICAgICAgIDxkaXZcbiAgICAgICAgICAgIGNzcz17Y3NzYFxuICAgICAgICAgICAgICBoZWlnaHQ6ICR7bG9hZGluZ1BsYWNlaG9sZGVySGVpZ2h0fTtcbiAgICAgICAgICAgIGB9XG4gICAgICAgICAgLz5cbiAgICAgICAgKX1cbiAgICAgICAgeyFmZXRjaGluZ01vdmllc0J5VHlwZSAmJlxuICAgICAgICAgIG1vdmllc0J5VHlwZS5tYXAoKG1vdmllKSA9PiAoXG4gICAgICAgICAgICA8RmlsbUNvbnRlbnRDYXJkXG4gICAgICAgICAgICAgIGhpZGVUYWdzXG4gICAgICAgICAgICAgIG1vdmllPXttb3ZpZX1cbiAgICAgICAgICAgICAgY29sdW1uV2lkdGg9e2F1dG9TaXplZFByb3BzLmNvbHVtbldpZHRofVxuICAgICAgICAgICAgICBkaXN0YW5jZUJldHdlZW5JdGVtcz17YXV0b1NpemVkUHJvcHMuZGlzdGFuY2VCZXR3ZWVuSXRlbXN9XG4gICAgICAgICAgICAgIHJlc291cmNlVHlwZXM9e3Jlc291cmNlVHlwZXN9XG4gICAgICAgICAgICAgIHJlc2l6ZVRodW1ibmFpbEltYWdlcz17cmVzaXplVGh1bWJuYWlsSW1hZ2VzfVxuICAgICAgICAgICAgLz5cbiAgICAgICAgICApKX1cbiAgICAgIDwvZGl2PlxuICAgIDwvc2VjdGlvbj5cbiAgKTtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IE1vdmllR3JpZDtcbiJdfQ== */"))
41
- }), resourceTypeName && resourceTypeName.name, (0, _core.jsx)("small", null, fetchingMoviesByType ? t('ndlaFilm.loadingMovies') : "".concat(moviesByType.length, " ").concat(t('ndlaFilm.movieMatchInCategory')))), (0, _core.jsx)("div", _extends({}, movieListClasses('movie-listing'), {
42
- css: /*#__PURE__*/(0, _core.css)("margin-left:", autoSizedProps.margin, "px;;label:MovieGrid;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIk1vdmllR3JpZC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBaURnQiIsImZpbGUiOiJNb3ZpZUdyaWQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcbmltcG9ydCBCRU1IZWxwZXIgZnJvbSAncmVhY3QtYmVtLWhlbHBlcic7XG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9jb3JlJztcbmltcG9ydCB7IENhbGN1bGF0ZWRDYXJvdXNlbFByb3BzIH0gZnJvbSAnQG5kbGEvY2Fyb3VzZWwnO1xuaW1wb3J0IHsgdXNlVHJhbnNsYXRpb24gfSBmcm9tICdyZWFjdC1pMThuZXh0JztcbmltcG9ydCBGaWxtQ29udGVudENhcmQgZnJvbSAnLi9GaWxtQ29udGVudENhcmQnO1xuaW1wb3J0IHsgTW92aWVSZXNvdXJjZVR5cGUsIE1vdmllVHlwZSB9IGZyb20gJy4vdHlwZXMnO1xuXG5jb25zdCBtb3ZpZUxpc3RDbGFzc2VzID0gbmV3IEJFTUhlbHBlcih7XG4gIG5hbWU6ICdmaWxtLW1vdmllbGlzdCcsXG4gIHByZWZpeDogJ2MtJyxcbn0pO1xuXG5pbnRlcmZhY2UgUHJvcHMge1xuICBhdXRvU2l6ZWRQcm9wczogQ2FsY3VsYXRlZENhcm91c2VsUHJvcHM7XG4gIHJlc291cmNlVHlwZU5hbWU/OiBNb3ZpZVJlc291cmNlVHlwZTtcbiAgZmV0Y2hpbmdNb3ZpZXNCeVR5cGU6IGJvb2xlYW47XG4gIG1vdmllc0J5VHlwZTogTW92aWVUeXBlW107XG4gIHJlc291cmNlVHlwZXM6IE1vdmllUmVzb3VyY2VUeXBlW107XG4gIGxvYWRpbmdQbGFjZWhvbGRlckhlaWdodD86IHN0cmluZztcbiAgcmVzaXplVGh1bWJuYWlsSW1hZ2VzPzogYm9vbGVhbjtcbn1cblxuY29uc3QgTW92aWVHcmlkID0gKHtcbiAgcmVzb3VyY2VUeXBlTmFtZSxcbiAgZmV0Y2hpbmdNb3ZpZXNCeVR5cGUsXG4gIG1vdmllc0J5VHlwZSxcbiAgcmVzb3VyY2VUeXBlcyxcbiAgbG9hZGluZ1BsYWNlaG9sZGVySGVpZ2h0LFxuICBhdXRvU2l6ZWRQcm9wcyxcbiAgcmVzaXplVGh1bWJuYWlsSW1hZ2VzLFxufTogUHJvcHMpID0+IHtcbiAgY29uc3QgeyB0IH0gPSB1c2VUcmFuc2xhdGlvbigpO1xuICByZXR1cm4gKFxuICAgIDxzZWN0aW9uPlxuICAgICAgPGgxXG4gICAgICAgIHsuLi5tb3ZpZUxpc3RDbGFzc2VzKCdoZWFkaW5nJyl9XG4gICAgICAgIGNzcz17Y3NzYFxuICAgICAgICAgIG1hcmdpbi1sZWZ0OiAke2F1dG9TaXplZFByb3BzLm1hcmdpbn1weDtcbiAgICAgICAgYH0+XG4gICAgICAgIHtyZXNvdXJjZVR5cGVOYW1lICYmIHJlc291cmNlVHlwZU5hbWUubmFtZX1cbiAgICAgICAgPHNtYWxsPlxuICAgICAgICAgIHtmZXRjaGluZ01vdmllc0J5VHlwZVxuICAgICAgICAgICAgPyB0KCduZGxhRmlsbS5sb2FkaW5nTW92aWVzJylcbiAgICAgICAgICAgIDogYCR7bW92aWVzQnlUeXBlLmxlbmd0aH0gJHt0KCduZGxhRmlsbS5tb3ZpZU1hdGNoSW5DYXRlZ29yeScpfWB9XG4gICAgICAgIDwvc21hbGw+XG4gICAgICA8L2gxPlxuICAgICAgPGRpdlxuICAgICAgICB7Li4ubW92aWVMaXN0Q2xhc3NlcygnbW92aWUtbGlzdGluZycpfVxuICAgICAgICBjc3M9e2Nzc2BcbiAgICAgICAgICBtYXJnaW4tbGVmdDogJHthdXRvU2l6ZWRQcm9wcy5tYXJnaW59cHg7XG4gICAgICAgIGB9PlxuICAgICAgICB7ZmV0Y2hpbmdNb3ZpZXNCeVR5cGUgJiYgKFxuICAgICAgICAgIDxkaXZcbiAgICAgICAgICAgIGNzcz17Y3NzYFxuICAgICAgICAgICAgICBoZWlnaHQ6ICR7bG9hZGluZ1BsYWNlaG9sZGVySGVpZ2h0fTtcbiAgICAgICAgICAgIGB9XG4gICAgICAgICAgLz5cbiAgICAgICAgKX1cbiAgICAgICAgeyFmZXRjaGluZ01vdmllc0J5VHlwZSAmJlxuICAgICAgICAgIG1vdmllc0J5VHlwZS5tYXAoKG1vdmllKSA9PiAoXG4gICAgICAgICAgICA8RmlsbUNvbnRlbnRDYXJkXG4gICAgICAgICAgICAgIGhpZGVUYWdzXG4gICAgICAgICAgICAgIG1vdmllPXttb3ZpZX1cbiAgICAgICAgICAgICAgY29sdW1uV2lkdGg9e2F1dG9TaXplZFByb3BzLmNvbHVtbldpZHRofVxuICAgICAgICAgICAgICBkaXN0YW5jZUJldHdlZW5JdGVtcz17YXV0b1NpemVkUHJvcHMuZGlzdGFuY2VCZXR3ZWVuSXRlbXN9XG4gICAgICAgICAgICAgIHJlc291cmNlVHlwZXM9e3Jlc291cmNlVHlwZXN9XG4gICAgICAgICAgICAgIHJlc2l6ZVRodW1ibmFpbEltYWdlcz17cmVzaXplVGh1bWJuYWlsSW1hZ2VzfVxuICAgICAgICAgICAgLz5cbiAgICAgICAgICApKX1cbiAgICAgIDwvZGl2PlxuICAgIDwvc2VjdGlvbj5cbiAgKTtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IE1vdmllR3JpZDtcbiJdfQ== */"))
43
- }), fetchingMoviesByType && (0, _core.jsx)("div", {
44
- css: /*#__PURE__*/(0, _core.css)("height:", loadingPlaceholderHeight, ";;label:MovieGrid;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIk1vdmllR3JpZC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBc0RvQiIsImZpbGUiOiJNb3ZpZUdyaWQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcbmltcG9ydCBCRU1IZWxwZXIgZnJvbSAncmVhY3QtYmVtLWhlbHBlcic7XG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9jb3JlJztcbmltcG9ydCB7IENhbGN1bGF0ZWRDYXJvdXNlbFByb3BzIH0gZnJvbSAnQG5kbGEvY2Fyb3VzZWwnO1xuaW1wb3J0IHsgdXNlVHJhbnNsYXRpb24gfSBmcm9tICdyZWFjdC1pMThuZXh0JztcbmltcG9ydCBGaWxtQ29udGVudENhcmQgZnJvbSAnLi9GaWxtQ29udGVudENhcmQnO1xuaW1wb3J0IHsgTW92aWVSZXNvdXJjZVR5cGUsIE1vdmllVHlwZSB9IGZyb20gJy4vdHlwZXMnO1xuXG5jb25zdCBtb3ZpZUxpc3RDbGFzc2VzID0gbmV3IEJFTUhlbHBlcih7XG4gIG5hbWU6ICdmaWxtLW1vdmllbGlzdCcsXG4gIHByZWZpeDogJ2MtJyxcbn0pO1xuXG5pbnRlcmZhY2UgUHJvcHMge1xuICBhdXRvU2l6ZWRQcm9wczogQ2FsY3VsYXRlZENhcm91c2VsUHJvcHM7XG4gIHJlc291cmNlVHlwZU5hbWU/OiBNb3ZpZVJlc291cmNlVHlwZTtcbiAgZmV0Y2hpbmdNb3ZpZXNCeVR5cGU6IGJvb2xlYW47XG4gIG1vdmllc0J5VHlwZTogTW92aWVUeXBlW107XG4gIHJlc291cmNlVHlwZXM6IE1vdmllUmVzb3VyY2VUeXBlW107XG4gIGxvYWRpbmdQbGFjZWhvbGRlckhlaWdodD86IHN0cmluZztcbiAgcmVzaXplVGh1bWJuYWlsSW1hZ2VzPzogYm9vbGVhbjtcbn1cblxuY29uc3QgTW92aWVHcmlkID0gKHtcbiAgcmVzb3VyY2VUeXBlTmFtZSxcbiAgZmV0Y2hpbmdNb3ZpZXNCeVR5cGUsXG4gIG1vdmllc0J5VHlwZSxcbiAgcmVzb3VyY2VUeXBlcyxcbiAgbG9hZGluZ1BsYWNlaG9sZGVySGVpZ2h0LFxuICBhdXRvU2l6ZWRQcm9wcyxcbiAgcmVzaXplVGh1bWJuYWlsSW1hZ2VzLFxufTogUHJvcHMpID0+IHtcbiAgY29uc3QgeyB0IH0gPSB1c2VUcmFuc2xhdGlvbigpO1xuICByZXR1cm4gKFxuICAgIDxzZWN0aW9uPlxuICAgICAgPGgxXG4gICAgICAgIHsuLi5tb3ZpZUxpc3RDbGFzc2VzKCdoZWFkaW5nJyl9XG4gICAgICAgIGNzcz17Y3NzYFxuICAgICAgICAgIG1hcmdpbi1sZWZ0OiAke2F1dG9TaXplZFByb3BzLm1hcmdpbn1weDtcbiAgICAgICAgYH0+XG4gICAgICAgIHtyZXNvdXJjZVR5cGVOYW1lICYmIHJlc291cmNlVHlwZU5hbWUubmFtZX1cbiAgICAgICAgPHNtYWxsPlxuICAgICAgICAgIHtmZXRjaGluZ01vdmllc0J5VHlwZVxuICAgICAgICAgICAgPyB0KCduZGxhRmlsbS5sb2FkaW5nTW92aWVzJylcbiAgICAgICAgICAgIDogYCR7bW92aWVzQnlUeXBlLmxlbmd0aH0gJHt0KCduZGxhRmlsbS5tb3ZpZU1hdGNoSW5DYXRlZ29yeScpfWB9XG4gICAgICAgIDwvc21hbGw+XG4gICAgICA8L2gxPlxuICAgICAgPGRpdlxuICAgICAgICB7Li4ubW92aWVMaXN0Q2xhc3NlcygnbW92aWUtbGlzdGluZycpfVxuICAgICAgICBjc3M9e2Nzc2BcbiAgICAgICAgICBtYXJnaW4tbGVmdDogJHthdXRvU2l6ZWRQcm9wcy5tYXJnaW59cHg7XG4gICAgICAgIGB9PlxuICAgICAgICB7ZmV0Y2hpbmdNb3ZpZXNCeVR5cGUgJiYgKFxuICAgICAgICAgIDxkaXZcbiAgICAgICAgICAgIGNzcz17Y3NzYFxuICAgICAgICAgICAgICBoZWlnaHQ6ICR7bG9hZGluZ1BsYWNlaG9sZGVySGVpZ2h0fTtcbiAgICAgICAgICAgIGB9XG4gICAgICAgICAgLz5cbiAgICAgICAgKX1cbiAgICAgICAgeyFmZXRjaGluZ01vdmllc0J5VHlwZSAmJlxuICAgICAgICAgIG1vdmllc0J5VHlwZS5tYXAoKG1vdmllKSA9PiAoXG4gICAgICAgICAgICA8RmlsbUNvbnRlbnRDYXJkXG4gICAgICAgICAgICAgIGhpZGVUYWdzXG4gICAgICAgICAgICAgIG1vdmllPXttb3ZpZX1cbiAgICAgICAgICAgICAgY29sdW1uV2lkdGg9e2F1dG9TaXplZFByb3BzLmNvbHVtbldpZHRofVxuICAgICAgICAgICAgICBkaXN0YW5jZUJldHdlZW5JdGVtcz17YXV0b1NpemVkUHJvcHMuZGlzdGFuY2VCZXR3ZWVuSXRlbXN9XG4gICAgICAgICAgICAgIHJlc291cmNlVHlwZXM9e3Jlc291cmNlVHlwZXN9XG4gICAgICAgICAgICAgIHJlc2l6ZVRodW1ibmFpbEltYWdlcz17cmVzaXplVGh1bWJuYWlsSW1hZ2VzfVxuICAgICAgICAgICAgLz5cbiAgICAgICAgICApKX1cbiAgICAgIDwvZGl2PlxuICAgIDwvc2VjdGlvbj5cbiAgKTtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IE1vdmllR3JpZDtcbiJdfQ== */"))
49
+ return (0, _core2.jsx)("section", null, (0, _core2.jsx)(_filmStyles.StyledHeadingH1, {
50
+ marginLeft: autoSizedProps.margin
51
+ }, resourceTypeName && resourceTypeName.name, (0, _core2.jsx)("small", null, fetchingMoviesByType ? t('ndlaFilm.loadingMovies') : "".concat(moviesByType.length, " ").concat(t('ndlaFilm.movieMatchInCategory')))), (0, _core2.jsx)(MovieListing, {
52
+ marginLeft: autoSizedProps.margin
53
+ }, fetchingMoviesByType && (0, _core2.jsx)(LoadingPlaceholder, {
54
+ height: loadingPlaceholderHeight
45
55
  }), !fetchingMoviesByType && moviesByType.map(function (movie) {
46
- return (0, _core.jsx)(_FilmContentCard["default"], {
56
+ return (0, _core2.jsx)(_FilmContentCard["default"], {
47
57
  hideTags: true,
48
58
  movie: movie,
49
59
  columnWidth: autoSizedProps.columnWidth,
@@ -5,12 +5,16 @@
5
5
  * LICENSE file in the root directory of this source tree.
6
6
  *
7
7
  */
8
- /// <reference types="react" />
8
+ import React from 'react';
9
9
  interface Props {
10
10
  slideIndexTarget: number;
11
11
  slideshowLength?: number;
12
12
  gotoSlide: (indexTarget: number, useAnimation: boolean) => void;
13
13
  rightArrow?: boolean;
14
14
  }
15
+ interface StyledNavigationArrowProps {
16
+ right?: boolean;
17
+ }
18
+ export declare const StyledNavigationArrow: import("@emotion/styled-base").StyledComponent<React.DetailedHTMLProps<React.HTMLAttributes<HTMLDivElement>, HTMLDivElement>, StyledNavigationArrowProps, object>;
15
19
  declare const NavigationArrow: ({ slideIndexTarget, gotoSlide, rightArrow }: Props) => JSX.Element;
16
20
  export default NavigationArrow;