@ndla/ui 16.0.0 → 16.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (86) hide show
  1. package/es/NDLAFilm/CategorySelect.js +51 -25
  2. package/es/NDLAFilm/FilmMovieList.js +14 -10
  3. package/es/NDLAFilm/FilmMovieSearch.js +23 -10
  4. package/es/NDLAFilm/FilmSlideshow.js +117 -19
  5. package/es/NDLAFilm/MovieGrid.js +23 -14
  6. package/es/NDLAFilm/NavigationArrow.js +33 -7
  7. package/es/NDLAFilm/SlideshowIndicator.js +27 -11
  8. package/es/NDLAFilm/filmStyles.js +23 -0
  9. package/es/Notion/ConceptNotion.js +1 -1
  10. package/es/Notion/index.js +2 -1
  11. package/es/RadioButtonGroup/RadioButtonGroup.js +28 -9
  12. package/es/Resource/resourceComponents.js +17 -9
  13. package/es/TreeStructure/FolderItem.js +39 -28
  14. package/es/TreeStructure/FolderItems.js +8 -5
  15. package/es/TreeStructure/TreeStructure.js +10 -11
  16. package/es/TreeStructure/TreeStructureWrapper.js +2 -2
  17. package/es/all.css +1 -1
  18. package/es/index.js +1 -1
  19. package/es/locale/messages-en.js +1 -1
  20. package/es/locale/messages-nb.js +1 -1
  21. package/es/locale/messages-nn.js +1 -1
  22. package/es/locale/messages-se.js +1 -1
  23. package/es/locale/messages-sma.js +1 -1
  24. package/lib/Breadcrumblist/index.d.ts +1 -0
  25. package/lib/NDLAFilm/CategorySelect.js +52 -30
  26. package/lib/NDLAFilm/FilmMovieList.js +17 -13
  27. package/lib/NDLAFilm/FilmMovieSearch.js +29 -17
  28. package/lib/NDLAFilm/FilmSlideshow.js +113 -24
  29. package/lib/NDLAFilm/MovieGrid.js +26 -16
  30. package/lib/NDLAFilm/NavigationArrow.d.ts +5 -1
  31. package/lib/NDLAFilm/NavigationArrow.js +34 -10
  32. package/lib/NDLAFilm/SlideshowIndicator.js +34 -13
  33. package/lib/NDLAFilm/filmStyles.d.ts +8 -0
  34. package/lib/NDLAFilm/filmStyles.js +38 -0
  35. package/lib/Notion/ConceptNotion.d.ts +1 -1
  36. package/lib/Notion/ConceptNotion.js +1 -1
  37. package/lib/Notion/index.d.ts +4 -1
  38. package/lib/Notion/index.js +11 -3
  39. package/lib/RadioButtonGroup/RadioButtonGroup.js +28 -13
  40. package/lib/Resource/resourceComponents.js +17 -9
  41. package/lib/TreeStructure/FolderItem.d.ts +3 -2
  42. package/lib/TreeStructure/FolderItem.js +38 -28
  43. package/lib/TreeStructure/FolderItems.d.ts +1 -1
  44. package/lib/TreeStructure/FolderItems.js +8 -5
  45. package/lib/TreeStructure/TreeStructure.d.ts +1 -1
  46. package/lib/TreeStructure/TreeStructure.js +10 -11
  47. package/lib/TreeStructure/TreeStructure.types.d.ts +6 -3
  48. package/lib/TreeStructure/TreeStructureWrapper.js +2 -2
  49. package/lib/all.css +1 -1
  50. package/lib/index.d.ts +6 -2
  51. package/lib/index.js +7 -0
  52. package/lib/locale/messages-en.js +1 -1
  53. package/lib/locale/messages-nb.js +1 -1
  54. package/lib/locale/messages-nn.js +1 -1
  55. package/lib/locale/messages-se.js +1 -1
  56. package/lib/locale/messages-sma.js +1 -1
  57. package/package.json +13 -13
  58. package/src/Breadcrumblist/{index.tsx → index.ts} +1 -0
  59. package/src/NDLAFilm/CategorySelect.tsx +110 -23
  60. package/src/NDLAFilm/FilmMovieList.tsx +13 -11
  61. package/src/NDLAFilm/FilmMovieSearch.tsx +45 -14
  62. package/src/NDLAFilm/FilmSlideshow.tsx +186 -25
  63. package/src/NDLAFilm/MovieGrid.tsx +33 -25
  64. package/src/NDLAFilm/NavigationArrow.tsx +76 -10
  65. package/src/NDLAFilm/SlideshowIndicator.tsx +53 -11
  66. package/src/NDLAFilm/component.film-movielist.scss +0 -46
  67. package/src/NDLAFilm/filmStyles.ts +33 -0
  68. package/src/Notion/ConceptNotion.tsx +2 -1
  69. package/src/Notion/index.ts +4 -1
  70. package/src/RadioButtonGroup/RadioButtonGroup.tsx +82 -11
  71. package/src/Resource/resourceComponents.tsx +1 -3
  72. package/src/TreeStructure/FolderItem.tsx +40 -19
  73. package/src/TreeStructure/FolderItems.tsx +3 -0
  74. package/src/TreeStructure/TreeStructure.tsx +7 -11
  75. package/src/TreeStructure/TreeStructure.types.ts +7 -3
  76. package/src/TreeStructure/TreeStructureWrapper.tsx +1 -1
  77. package/src/index.ts +15 -2
  78. package/src/locale/messages-en.ts +1 -1
  79. package/src/locale/messages-nb.ts +1 -1
  80. package/src/locale/messages-nn.ts +1 -1
  81. package/src/locale/messages-se.ts +1 -1
  82. package/src/locale/messages-sma.ts +1 -1
  83. package/src/main.scss +0 -3
  84. package/src/NDLAFilm/component.film-moviesearch.scss +0 -127
  85. package/src/NDLAFilm/component.film-slideshow.scss +0 -258
  86. package/src/RadioButtonGroup/component.radio-button-group.scss +0 -67
@@ -1,3 +1,5 @@
1
+ import _styled from "@emotion/styled-base";
2
+
1
3
  function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
2
4
 
3
5
  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."); }
@@ -10,7 +12,7 @@ function _iterableToArrayLimit(arr, i) { if (typeof Symbol === "undefined" || !(
10
12
 
11
13
  function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
12
14
 
13
- 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); }
15
+ 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)."; }
14
16
 
15
17
  /**
16
18
  * Copyright (c) 2016-present, NDLA.
@@ -21,29 +23,125 @@ function _extends() { _extends = Object.assign || function (target) { for (var i
21
23
  */
22
24
  import React, { useCallback, useEffect, useRef, useState } from 'react';
23
25
  import { useSwipeable } from 'react-swipeable';
24
- import BEMHelper from 'react-bem-helper';
26
+ import { css } from '@emotion/core';
27
+ import { breakpoints, mq, spacing, spacingUnit, fonts, colors } from '@ndla/core';
25
28
  import SafeLink from '@ndla/safelink';
26
29
  import { OneColumn } from '../Layout';
27
30
  import Spinner from '../Spinner';
28
- import NavigationArrow from './NavigationArrow';
31
+ import NavigationArrow, { StyledNavigationArrow } from './NavigationArrow';
29
32
  import SlideshowIndicator from './SlideshowIndicator';
30
33
  import { jsx as ___EmotionJSX } from "@emotion/core";
31
- var classes = new BEMHelper({
32
- name: 'film-slideshow',
33
- prefix: 'c-'
34
+
35
+ var SlideLinkWrapper = _styled("div", {
36
+ target: "essc37o0",
37
+ label: "SlideLinkWrapper"
38
+ })("margin:0 auto;display:flex;justify-content:flex-start;align-items:flex-end;position:absolute;z-index:2;height:100vw;width:100%;", mq.range({
39
+ from: breakpoints.mobileWide
40
+ }), "{height:100vw;}", mq.range({
41
+ from: breakpoints.tablet
42
+ }), "{height:75vw;}", mq.range({
43
+ from: breakpoints.desktop
44
+ }), "{height:55vw;}", mq.range({
45
+ from: breakpoints.wide
46
+ }), "{height:40vw;}", mq.range({
47
+ from: breakpoints.ultraWide
48
+ }), "{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"]} */"));
49
+
50
+ var itemWrapperCSS = process.env.NODE_ENV === "production" ? {
51
+ name: "m1vhg0-itemWrapperCSS",
52
+ styles: "display:flex;box-shadow:none;;label:itemWrapperCSS;"
53
+ } : {
54
+ name: "m1vhg0-itemWrapperCSS",
55
+ styles: "display:flex;box-shadow:none;;label:itemWrapperCSS;",
56
+ 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"]} */",
57
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
58
+ };
59
+
60
+ var SlideshowItem = _styled("div", {
61
+ target: "essc37o1",
62
+ label: "SlideshowItem"
63
+ })("width:100vw;height:100vw;", mq.range({
64
+ from: breakpoints.mobileWide
65
+ }), "{height:100vw;}", mq.range({
66
+ from: breakpoints.tablet
67
+ }), "{height:75vw;}", mq.range({
68
+ from: breakpoints.desktop
69
+ }), "{height:55vw;}", mq.range({
70
+ from: breakpoints.wide
71
+ }), "{height:40vw;}", mq.range({
72
+ from: breakpoints.ultraWide
73
+ }), "{height:36vw;}background-color:'#222';background-size:cover;background-position-x:center;background-position-y:center;border:0;position:", function (props) {
74
+ return props.fadeOver ? 'absolute' : 'relative';
75
+ }, ";animation:", function (props) {
76
+ return props.fadeOver && 'fadeIn 400ms ease';
77
+ }, ";z-index:", function (props) {
78
+ return props.fadeOver && 1;
79
+ }, ";&: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"]} */"));
80
+
81
+ var SlideshowLink = /*#__PURE__*/_styled(SafeLink, {
82
+ target: "essc37o2",
83
+ label: "SlideshowLink"
84
+ })("display:flex;box-shadow:none;transition:all 400ms ease;opacity:", function (props) {
85
+ return props.out && 0;
86
+ }, ";animation:", function (props) {
87
+ return !props.out && 'fadeInBottomFixed 600ms ease';
88
+ }, ";", mq.range({
89
+ from: breakpoints.mobileWide
90
+ }), "{padding-bottom:", spacing.medium, ";}", mq.range({
91
+ from: breakpoints.tablet
92
+ }), "{padding-bottom:", spacing.large, ";}", mq.range({
93
+ from: breakpoints.desktop
94
+ }), "{padding-bottom:", 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"]} */"));
95
+
96
+ var SlideshowWrapper = _styled("section", {
97
+ target: "essc37o3",
98
+ label: "SlideshowWrapper"
99
+ })("&:hover{", 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"]} */"));
100
+
101
+ var SlideshowInfo = _styled("div", {
102
+ target: "essc37o4",
103
+ label: "SlideshowInfo"
104
+ })("border:0;background:none;background-color:rgba(3,23,43,0.7);border-radius:4px;padding:", spacing.medium, " ", spacing.medium, " ", spacing.medium, " ", spacing.normal, ";margin:0 -20px;width:100vw;", mq.range({
105
+ from: breakpoints.mobileWide
106
+ }), "{margin:0;width:100%;padding:", spacing.medium, " ", spacingUnit * 2, "px ", spacing.medium, " ", spacing.normal, ";}h1{", fonts.sizes('22px', '30px'), ";color:", colors.white, ";text-shadow:0 2px 4px rgba(0,0,0,0.25);margin:0;font-weight:", fonts.weight.semibold, ";", mq.range({
107
+ from: breakpoints.mobileWide
108
+ }), "{margin:0 0 ", spacing.small, ";", fonts.sizes('26px', '30px'), ";}", mq.range({
109
+ from: breakpoints.tablet
110
+ }), "{", fonts.sizes('40px', '44px'), ";}", mq.range({
111
+ from: breakpoints.desktop
112
+ }), "{", fonts.sizes('48px', '54px'), ";}}p{color:", colors.white, ";display:inline-block;margin:0;padding:0;border-radius:4px;", fonts.sizes('12px', '18px'), ";", mq.range({
113
+ from: breakpoints.mobileWide
114
+ }), "{", fonts.sizes('15px', '20px'), ";}", mq.range({
115
+ from: breakpoints.tablet
116
+ }), "{", fonts.sizes('18px', '24px'), ";}", mq.range({
117
+ from: breakpoints.wide
118
+ }), "{", 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"]} */"));
119
+
120
+ var EmptySlideshow = _styled("div", {
121
+ target: "essc37o5",
122
+ label: "EmptySlideshow"
123
+ })(process.env.NODE_ENV === "production" ? {
124
+ name: "1ovku45",
125
+ styles: "background:rgba(255,255,255,0.08);margin-bottom:$spacing--large * 4;display:flex;align-items:center;justify-content:center;height:40vw;"
126
+ } : {
127
+ name: "1ovku45",
128
+ styles: "background:rgba(255,255,255,0.08);margin-bottom:$spacing--large * 4;display:flex;align-items:center;justify-content:center;height:40vw;",
129
+ 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"]} */",
130
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
34
131
  });
132
+
35
133
  var defaultTransitionSwipeEnd = 'transform 600ms cubic-bezier(0, 0.76, 0.09, 1)';
36
134
  var defaultTransitionText = 'opacity 600ms ease';
37
135
 
38
136
  var renderSlideItem = function renderSlideItem(slide) {
39
- return ___EmotionJSX("div", _extends({}, classes('item'), {
137
+ return ___EmotionJSX(SlideshowItem, {
40
138
  key: slide.id,
41
139
  role: "img",
42
140
  "aria-label": slide.metaImage && slide.metaImage.alt || '',
43
141
  style: {
44
142
  backgroundImage: "url(".concat(slide.metaImage && slide.metaImage.url || '', ")")
45
143
  }
46
- }));
144
+ });
47
145
  };
48
146
 
49
147
  var FilmSlideshow = function FilmSlideshow(_ref) {
@@ -225,7 +323,7 @@ var FilmSlideshow = function FilmSlideshow(_ref) {
225
323
  });
226
324
 
227
325
  if (slideshow.length === 0) {
228
- return ___EmotionJSX("div", null, ___EmotionJSX("div", classes('slideshow'), ___EmotionJSX(Spinner, {
326
+ return ___EmotionJSX("div", null, ___EmotionJSX(EmptySlideshow, null, ___EmotionJSX(Spinner, {
229
327
  inverted: true
230
328
  })));
231
329
  }
@@ -240,34 +338,34 @@ var FilmSlideshow = function FilmSlideshow(_ref) {
240
338
  }
241
339
 
242
340
  var backgroundImage = slideshow[activeSlide].metaImage;
243
- return ___EmotionJSX("section", _extends({}, classes(''), handlers), ___EmotionJSX(React.Fragment, null, ___EmotionJSX("div", classes('slide-link-wrapper'), ___EmotionJSX(OneColumn, null, ___EmotionJSX(SafeLink, _extends({
244
- to: slideshow[activeSlide].path
245
- }, classes('item-wrapper', 'text', {
341
+ return ___EmotionJSX(SlideshowWrapper, handlers, ___EmotionJSX(React.Fragment, null, ___EmotionJSX(SlideLinkWrapper, null, ___EmotionJSX(OneColumn, null, ___EmotionJSX(SlideshowLink, {
342
+ to: slideshow[activeSlide].path,
246
343
  out: !animationComplete
247
- })), ___EmotionJSX("div", _extends({}, classes('slide-info'), {
344
+ }, ___EmotionJSX(SlideshowInfo, {
248
345
  ref: slideText
249
- }), ___EmotionJSX("h1", null, slideshow[activeSlide].title), ___EmotionJSX("p", null, slideshow[activeSlide].metaDescription))))), ___EmotionJSX(NavigationArrow, {
346
+ }, ___EmotionJSX("h1", null, slideshow[activeSlide].title), ___EmotionJSX("p", null, slideshow[activeSlide].metaDescription))))), ___EmotionJSX(NavigationArrow, {
250
347
  slideIndexTarget: slideIndexTarget > 0 ? slideIndexTarget - 1 : slideshow.length - 1,
251
348
  gotoSlide: gotoSlide
252
349
  }), ___EmotionJSX(NavigationArrow, {
253
350
  slideIndexTarget: slideIndexTarget < slideshow.length - 1 ? slideIndexTarget + 1 : 0,
254
351
  gotoSlide: gotoSlide,
255
352
  rightArrow: true
256
- }), !animationComplete && ___EmotionJSX("div", _extends({}, classes('item', 'fade-over'), {
353
+ }), !animationComplete && ___EmotionJSX(SlideshowItem, {
354
+ fadeOver: true,
257
355
  role: "img",
258
356
  onAnimationEnd: onChangedSlide,
259
357
  style: {
260
358
  backgroundImage: "url(".concat(backgroundImage && backgroundImage.url || '', ")")
261
359
  }
262
- })), ___EmotionJSX("div", _extends({
263
- ref: slideRef
264
- }, classes('item-wrapper'), {
360
+ }), ___EmotionJSX("div", {
361
+ ref: slideRef,
362
+ css: itemWrapperCSS,
265
363
  onTransitionEnd: onTransitionEnd,
266
364
  style: {
267
365
  width: slideshowWidth,
268
366
  transform: getSlidePosition(slideIndex)
269
367
  }
270
- }), renderSlideItem(slideshow[slideshow.length - 1]), slideshow.map(renderSlideItem), renderSlideItem(slideshow[0])), ___EmotionJSX(SlideshowIndicator, {
368
+ }, renderSlideItem(slideshow[slideshow.length - 1]), slideshow.map(renderSlideItem), renderSlideItem(slideshow[0])), ___EmotionJSX(SlideshowIndicator, {
271
369
  slideshow: slideshow,
272
370
  activeSlide: activeSlide,
273
371
  gotoSlide: gotoSlide
@@ -1,15 +1,24 @@
1
- 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); }
2
-
1
+ import _styled from "@emotion/styled-base";
3
2
  import React from 'react';
4
- import BEMHelper from 'react-bem-helper';
5
- import { css } from '@emotion/core';
3
+ import { spacing } from '@ndla/core';
6
4
  import { useTranslation } from 'react-i18next';
7
5
  import FilmContentCard from './FilmContentCard';
6
+ import { setAnimations, StyledHeadingH1 } from './filmStyles';
8
7
  import { jsx as ___EmotionJSX } from "@emotion/core";
9
- var movieListClasses = new BEMHelper({
10
- name: 'film-movielist',
11
- prefix: 'c-'
12
- });
8
+
9
+ var MovieListing = _styled("div", {
10
+ target: "e1t64qur0",
11
+ label: "MovieListing"
12
+ })("display:flex;flex-wrap:wrap;margin:", spacing.small, " 0;margin-left:", function (props) {
13
+ return props.marginLeft && "".concat(props.marginLeft, "px");
14
+ }, ";", 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== */"));
15
+
16
+ var LoadingPlaceholder = _styled("div", {
17
+ target: "e1t64qur1",
18
+ label: "LoadingPlaceholder"
19
+ })("height:", function (props) {
20
+ return props.height;
21
+ }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIk1vdmllR3JpZC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBK0I4RCIsImZpbGUiOiJNb3ZpZUdyaWQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IHNwYWNpbmcgfSBmcm9tICdAbmRsYS9jb3JlJztcbmltcG9ydCB7IENhbGN1bGF0ZWRDYXJvdXNlbFByb3BzIH0gZnJvbSAnQG5kbGEvY2Fyb3VzZWwnO1xuaW1wb3J0IHsgdXNlVHJhbnNsYXRpb24gfSBmcm9tICdyZWFjdC1pMThuZXh0JztcbmltcG9ydCBGaWxtQ29udGVudENhcmQgZnJvbSAnLi9GaWxtQ29udGVudENhcmQnO1xuaW1wb3J0IHsgTW92aWVSZXNvdXJjZVR5cGUsIE1vdmllVHlwZSB9IGZyb20gJy4vdHlwZXMnO1xuaW1wb3J0IHsgc2V0QW5pbWF0aW9ucywgU3R5bGVkSGVhZGluZ0gxIH0gZnJvbSAnLi9maWxtU3R5bGVzJztcblxuaW50ZXJmYWNlIE1vdmllTGlzdGluZ1Byb3BzIHtcbiAgbWFyZ2luTGVmdD86IG51bWJlcjtcbn1cblxuY29uc3QgTW92aWVMaXN0aW5nID0gc3R5bGVkLmRpdjxNb3ZpZUxpc3RpbmdQcm9wcz5gXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXgtd3JhcDogd3JhcDtcbiAgbWFyZ2luOiAke3NwYWNpbmcuc21hbGx9IDA7XG4gIG1hcmdpbi1sZWZ0OiAkeyhwcm9wcykgPT4gcHJvcHMubWFyZ2luTGVmdCAmJiBgJHtwcm9wcy5tYXJnaW5MZWZ0fXB4YH07XG4gICR7c2V0QW5pbWF0aW9ucygpfTtcbiAgPiBkaXYge1xuICAgIG9wYWNpdHk6IDA7XG4gICAgYW5pbWF0aW9uLWZpbGwtbW9kZTogZm9yd2FyZHM7XG4gICAgYW5pbWF0aW9uLW5hbWU6IGZhZGVJbjtcbiAgICBhbmltYXRpb24tZHVyYXRpb246IDMwMG1zO1xuICB9XG5gO1xuXG5pbnRlcmZhY2UgTG9hZGluZ1BsYWNlaG9sZGVyUHJvcHMge1xuICBoZWlnaHQ/OiBzdHJpbmc7XG59XG5cbmNvbnN0IExvYWRpbmdQbGFjZWhvbGRlciA9IHN0eWxlZC5kaXY8TG9hZGluZ1BsYWNlaG9sZGVyUHJvcHM+YFxuICBoZWlnaHQ6ICR7KHByb3BzKSA9PiBwcm9wcy5oZWlnaHR9O1xuYDtcblxuaW50ZXJmYWNlIFByb3BzIHtcbiAgYXV0b1NpemVkUHJvcHM6IENhbGN1bGF0ZWRDYXJvdXNlbFByb3BzO1xuICByZXNvdXJjZVR5cGVOYW1lPzogTW92aWVSZXNvdXJjZVR5cGU7XG4gIGZldGNoaW5nTW92aWVzQnlUeXBlOiBib29sZWFuO1xuICBtb3ZpZXNCeVR5cGU6IE1vdmllVHlwZVtdO1xuICByZXNvdXJjZVR5cGVzOiBNb3ZpZVJlc291cmNlVHlwZVtdO1xuICBsb2FkaW5nUGxhY2Vob2xkZXJIZWlnaHQ/OiBzdHJpbmc7XG4gIHJlc2l6ZVRodW1ibmFpbEltYWdlcz86IGJvb2xlYW47XG59XG5cbmNvbnN0IE1vdmllR3JpZCA9ICh7XG4gIHJlc291cmNlVHlwZU5hbWUsXG4gIGZldGNoaW5nTW92aWVzQnlUeXBlLFxuICBtb3ZpZXNCeVR5cGUsXG4gIHJlc291cmNlVHlwZXMsXG4gIGxvYWRpbmdQbGFjZWhvbGRlckhlaWdodCxcbiAgYXV0b1NpemVkUHJvcHMsXG4gIHJlc2l6ZVRodW1ibmFpbEltYWdlcyxcbn06IFByb3BzKSA9PiB7XG4gIGNvbnN0IHsgdCB9ID0gdXNlVHJhbnNsYXRpb24oKTtcbiAgcmV0dXJuIChcbiAgICA8c2VjdGlvbj5cbiAgICAgIDxTdHlsZWRIZWFkaW5nSDEgbWFyZ2luTGVmdD17YXV0b1NpemVkUHJvcHMubWFyZ2lufT5cbiAgICAgICAge3Jlc291cmNlVHlwZU5hbWUgJiYgcmVzb3VyY2VUeXBlTmFtZS5uYW1lfVxuICAgICAgICA8c21hbGw+XG4gICAgICAgICAge2ZldGNoaW5nTW92aWVzQnlUeXBlXG4gICAgICAgICAgICA/IHQoJ25kbGFGaWxtLmxvYWRpbmdNb3ZpZXMnKVxuICAgICAgICAgICAgOiBgJHttb3ZpZXNCeVR5cGUubGVuZ3RofSAke3QoJ25kbGFGaWxtLm1vdmllTWF0Y2hJbkNhdGVnb3J5Jyl9YH1cbiAgICAgICAgPC9zbWFsbD5cbiAgICAgIDwvU3R5bGVkSGVhZGluZ0gxPlxuICAgICAgPE1vdmllTGlzdGluZyBtYXJnaW5MZWZ0PXthdXRvU2l6ZWRQcm9wcy5tYXJnaW59PlxuICAgICAgICB7ZmV0Y2hpbmdNb3ZpZXNCeVR5cGUgJiYgPExvYWRpbmdQbGFjZWhvbGRlciBoZWlnaHQ9e2xvYWRpbmdQbGFjZWhvbGRlckhlaWdodH0gLz59XG4gICAgICAgIHshZmV0Y2hpbmdNb3ZpZXNCeVR5cGUgJiZcbiAgICAgICAgICBtb3ZpZXNCeVR5cGUubWFwKChtb3ZpZSkgPT4gKFxuICAgICAgICAgICAgPEZpbG1Db250ZW50Q2FyZFxuICAgICAgICAgICAgICBoaWRlVGFnc1xuICAgICAgICAgICAgICBtb3ZpZT17bW92aWV9XG4gICAgICAgICAgICAgIGNvbHVtbldpZHRoPXthdXRvU2l6ZWRQcm9wcy5jb2x1bW5XaWR0aH1cbiAgICAgICAgICAgICAgZGlzdGFuY2VCZXR3ZWVuSXRlbXM9e2F1dG9TaXplZFByb3BzLmRpc3RhbmNlQmV0d2Vlbkl0ZW1zfVxuICAgICAgICAgICAgICByZXNvdXJjZVR5cGVzPXtyZXNvdXJjZVR5cGVzfVxuICAgICAgICAgICAgICByZXNpemVUaHVtYm5haWxJbWFnZXM9e3Jlc2l6ZVRodW1ibmFpbEltYWdlc31cbiAgICAgICAgICAgIC8+XG4gICAgICAgICAgKSl9XG4gICAgICA8L01vdmllTGlzdGluZz5cbiAgICA8L3NlY3Rpb24+XG4gICk7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBNb3ZpZUdyaWQ7XG4iXX0= */"));
13
22
 
14
23
  var MovieGrid = function MovieGrid(_ref) {
15
24
  var resourceTypeName = _ref.resourceTypeName,
@@ -23,12 +32,12 @@ var MovieGrid = function MovieGrid(_ref) {
23
32
  var _useTranslation = useTranslation(),
24
33
  t = _useTranslation.t;
25
34
 
26
- return ___EmotionJSX("section", null, ___EmotionJSX("h1", _extends({}, movieListClasses('heading'), {
27
- css: /*#__PURE__*/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== */"))
28
- }), resourceTypeName && resourceTypeName.name, ___EmotionJSX("small", null, fetchingMoviesByType ? t('ndlaFilm.loadingMovies') : "".concat(moviesByType.length, " ").concat(t('ndlaFilm.movieMatchInCategory')))), ___EmotionJSX("div", _extends({}, movieListClasses('movie-listing'), {
29
- css: /*#__PURE__*/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== */"))
30
- }), fetchingMoviesByType && ___EmotionJSX("div", {
31
- css: /*#__PURE__*/css("height:", loadingPlaceholderHeight, ";;label:MovieGrid;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIk1vdmllR3JpZC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBc0RvQiIsImZpbGUiOiJNb3ZpZUdyaWQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcbmltcG9ydCBCRU1IZWxwZXIgZnJvbSAncmVhY3QtYmVtLWhlbHBlcic7XG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9jb3JlJztcbmltcG9ydCB7IENhbGN1bGF0ZWRDYXJvdXNlbFByb3BzIH0gZnJvbSAnQG5kbGEvY2Fyb3VzZWwnO1xuaW1wb3J0IHsgdXNlVHJhbnNsYXRpb24gfSBmcm9tICdyZWFjdC1pMThuZXh0JztcbmltcG9ydCBGaWxtQ29udGVudENhcmQgZnJvbSAnLi9GaWxtQ29udGVudENhcmQnO1xuaW1wb3J0IHsgTW92aWVSZXNvdXJjZVR5cGUsIE1vdmllVHlwZSB9IGZyb20gJy4vdHlwZXMnO1xuXG5jb25zdCBtb3ZpZUxpc3RDbGFzc2VzID0gbmV3IEJFTUhlbHBlcih7XG4gIG5hbWU6ICdmaWxtLW1vdmllbGlzdCcsXG4gIHByZWZpeDogJ2MtJyxcbn0pO1xuXG5pbnRlcmZhY2UgUHJvcHMge1xuICBhdXRvU2l6ZWRQcm9wczogQ2FsY3VsYXRlZENhcm91c2VsUHJvcHM7XG4gIHJlc291cmNlVHlwZU5hbWU/OiBNb3ZpZVJlc291cmNlVHlwZTtcbiAgZmV0Y2hpbmdNb3ZpZXNCeVR5cGU6IGJvb2xlYW47XG4gIG1vdmllc0J5VHlwZTogTW92aWVUeXBlW107XG4gIHJlc291cmNlVHlwZXM6IE1vdmllUmVzb3VyY2VUeXBlW107XG4gIGxvYWRpbmdQbGFjZWhvbGRlckhlaWdodD86IHN0cmluZztcbiAgcmVzaXplVGh1bWJuYWlsSW1hZ2VzPzogYm9vbGVhbjtcbn1cblxuY29uc3QgTW92aWVHcmlkID0gKHtcbiAgcmVzb3VyY2VUeXBlTmFtZSxcbiAgZmV0Y2hpbmdNb3ZpZXNCeVR5cGUsXG4gIG1vdmllc0J5VHlwZSxcbiAgcmVzb3VyY2VUeXBlcyxcbiAgbG9hZGluZ1BsYWNlaG9sZGVySGVpZ2h0LFxuICBhdXRvU2l6ZWRQcm9wcyxcbiAgcmVzaXplVGh1bWJuYWlsSW1hZ2VzLFxufTogUHJvcHMpID0+IHtcbiAgY29uc3QgeyB0IH0gPSB1c2VUcmFuc2xhdGlvbigpO1xuICByZXR1cm4gKFxuICAgIDxzZWN0aW9uPlxuICAgICAgPGgxXG4gICAgICAgIHsuLi5tb3ZpZUxpc3RDbGFzc2VzKCdoZWFkaW5nJyl9XG4gICAgICAgIGNzcz17Y3NzYFxuICAgICAgICAgIG1hcmdpbi1sZWZ0OiAke2F1dG9TaXplZFByb3BzLm1hcmdpbn1weDtcbiAgICAgICAgYH0+XG4gICAgICAgIHtyZXNvdXJjZVR5cGVOYW1lICYmIHJlc291cmNlVHlwZU5hbWUubmFtZX1cbiAgICAgICAgPHNtYWxsPlxuICAgICAgICAgIHtmZXRjaGluZ01vdmllc0J5VHlwZVxuICAgICAgICAgICAgPyB0KCduZGxhRmlsbS5sb2FkaW5nTW92aWVzJylcbiAgICAgICAgICAgIDogYCR7bW92aWVzQnlUeXBlLmxlbmd0aH0gJHt0KCduZGxhRmlsbS5tb3ZpZU1hdGNoSW5DYXRlZ29yeScpfWB9XG4gICAgICAgIDwvc21hbGw+XG4gICAgICA8L2gxPlxuICAgICAgPGRpdlxuICAgICAgICB7Li4ubW92aWVMaXN0Q2xhc3NlcygnbW92aWUtbGlzdGluZycpfVxuICAgICAgICBjc3M9e2Nzc2BcbiAgICAgICAgICBtYXJnaW4tbGVmdDogJHthdXRvU2l6ZWRQcm9wcy5tYXJnaW59cHg7XG4gICAgICAgIGB9PlxuICAgICAgICB7ZmV0Y2hpbmdNb3ZpZXNCeVR5cGUgJiYgKFxuICAgICAgICAgIDxkaXZcbiAgICAgICAgICAgIGNzcz17Y3NzYFxuICAgICAgICAgICAgICBoZWlnaHQ6ICR7bG9hZGluZ1BsYWNlaG9sZGVySGVpZ2h0fTtcbiAgICAgICAgICAgIGB9XG4gICAgICAgICAgLz5cbiAgICAgICAgKX1cbiAgICAgICAgeyFmZXRjaGluZ01vdmllc0J5VHlwZSAmJlxuICAgICAgICAgIG1vdmllc0J5VHlwZS5tYXAoKG1vdmllKSA9PiAoXG4gICAgICAgICAgICA8RmlsbUNvbnRlbnRDYXJkXG4gICAgICAgICAgICAgIGhpZGVUYWdzXG4gICAgICAgICAgICAgIG1vdmllPXttb3ZpZX1cbiAgICAgICAgICAgICAgY29sdW1uV2lkdGg9e2F1dG9TaXplZFByb3BzLmNvbHVtbldpZHRofVxuICAgICAgICAgICAgICBkaXN0YW5jZUJldHdlZW5JdGVtcz17YXV0b1NpemVkUHJvcHMuZGlzdGFuY2VCZXR3ZWVuSXRlbXN9XG4gICAgICAgICAgICAgIHJlc291cmNlVHlwZXM9e3Jlc291cmNlVHlwZXN9XG4gICAgICAgICAgICAgIHJlc2l6ZVRodW1ibmFpbEltYWdlcz17cmVzaXplVGh1bWJuYWlsSW1hZ2VzfVxuICAgICAgICAgICAgLz5cbiAgICAgICAgICApKX1cbiAgICAgIDwvZGl2PlxuICAgIDwvc2VjdGlvbj5cbiAgKTtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IE1vdmllR3JpZDtcbiJdfQ== */"))
35
+ return ___EmotionJSX("section", null, ___EmotionJSX(StyledHeadingH1, {
36
+ marginLeft: autoSizedProps.margin
37
+ }, resourceTypeName && resourceTypeName.name, ___EmotionJSX("small", null, fetchingMoviesByType ? t('ndlaFilm.loadingMovies') : "".concat(moviesByType.length, " ").concat(t('ndlaFilm.movieMatchInCategory')))), ___EmotionJSX(MovieListing, {
38
+ marginLeft: autoSizedProps.margin
39
+ }, fetchingMoviesByType && ___EmotionJSX(LoadingPlaceholder, {
40
+ height: loadingPlaceholderHeight
32
41
  }), !fetchingMoviesByType && moviesByType.map(function (movie) {
33
42
  return ___EmotionJSX(FilmContentCard, {
34
43
  hideTags: true,