@ndla/ui 44.0.24 → 45.0.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 (93) hide show
  1. package/es/CampaignBlock/CampaignBlock.js +13 -16
  2. package/es/CompetenceGoalTab/CompetenceItem.js +9 -9
  3. package/es/Embed/ImageEmbed.js +17 -9
  4. package/es/ErrorMessage/ErrorMessage.js +7 -7
  5. package/es/Layout/PageContainer.js +7 -3
  6. package/es/LicenseByline/EmbedByline.js +6 -6
  7. package/es/List/OrderedList.js +1 -1
  8. package/es/List/UnOrderedList.js +1 -1
  9. package/es/NDLAFilm/AllMoviesAlphabetically.js +11 -9
  10. package/es/NDLAFilm/FilmContentCard.js +45 -29
  11. package/es/NDLAFilm/FilmContentCardTags.js +13 -9
  12. package/es/NDLAFilm/FilmMovieList.js +7 -16
  13. package/es/NDLAFilm/FilmMovieSearch.js +4 -4
  14. package/es/NDLAFilm/FilmSlideshow.js +55 -106
  15. package/es/NDLAFilm/MovieGrid.js +9 -12
  16. package/es/NDLAFilm/filmStyles.js +4 -4
  17. package/es/Table/Table.js +8 -6
  18. package/es/all.css +1 -1
  19. package/es/locale/messages-en.js +3 -2
  20. package/es/locale/messages-nb.js +3 -2
  21. package/es/locale/messages-nn.js +3 -2
  22. package/es/locale/messages-se.js +2 -1
  23. package/es/locale/messages-sma.js +3 -2
  24. package/lib/CampaignBlock/CampaignBlock.d.ts +3 -3
  25. package/lib/CampaignBlock/CampaignBlock.js +13 -16
  26. package/lib/CompetenceGoalTab/CompetenceItem.js +9 -9
  27. package/lib/Embed/ImageEmbed.d.ts +6 -6
  28. package/lib/Embed/ImageEmbed.js +17 -9
  29. package/lib/ErrorMessage/ErrorMessage.js +7 -7
  30. package/lib/Layout/PageContainer.d.ts +3 -3
  31. package/lib/Layout/PageContainer.js +16 -11
  32. package/lib/LicenseByline/EmbedByline.js +6 -6
  33. package/lib/List/OrderedList.js +1 -1
  34. package/lib/List/UnOrderedList.js +1 -1
  35. package/lib/NDLAFilm/AllMoviesAlphabetically.js +11 -9
  36. package/lib/NDLAFilm/FilmContentCard.d.ts +3 -4
  37. package/lib/NDLAFilm/FilmContentCard.js +50 -35
  38. package/lib/NDLAFilm/FilmContentCardTags.js +13 -9
  39. package/lib/NDLAFilm/FilmMovieList.d.ts +1 -4
  40. package/lib/NDLAFilm/FilmMovieList.js +14 -21
  41. package/lib/NDLAFilm/FilmMovieSearch.js +4 -4
  42. package/lib/NDLAFilm/FilmSlideshow.d.ts +0 -9
  43. package/lib/NDLAFilm/FilmSlideshow.js +54 -106
  44. package/lib/NDLAFilm/MovieGrid.d.ts +1 -4
  45. package/lib/NDLAFilm/MovieGrid.js +8 -11
  46. package/lib/NDLAFilm/filmStyles.d.ts +2 -6
  47. package/lib/NDLAFilm/filmStyles.js +3 -3
  48. package/lib/Table/Table.js +8 -6
  49. package/lib/all.css +1 -1
  50. package/lib/locale/messages-en.d.ts +1 -0
  51. package/lib/locale/messages-en.js +3 -2
  52. package/lib/locale/messages-nb.d.ts +1 -0
  53. package/lib/locale/messages-nb.js +3 -2
  54. package/lib/locale/messages-nn.d.ts +1 -0
  55. package/lib/locale/messages-nn.js +3 -2
  56. package/lib/locale/messages-se.d.ts +1 -0
  57. package/lib/locale/messages-se.js +2 -1
  58. package/lib/locale/messages-sma.d.ts +1 -0
  59. package/lib/locale/messages-sma.js +3 -2
  60. package/package.json +20 -20
  61. package/src/Aside/component.aside.scss +1 -2
  62. package/src/CampaignBlock/CampaignBlock.stories.tsx +5 -8
  63. package/src/CampaignBlock/CampaignBlock.tsx +15 -17
  64. package/src/CompetenceGoalTab/CompetenceItem.tsx +0 -1
  65. package/src/Embed/ImageEmbed.tsx +13 -12
  66. package/src/ErrorMessage/ErrorMessage.tsx +1 -1
  67. package/src/FactBox/component.factbox.scss +1 -2
  68. package/src/Layout/PageContainer.tsx +8 -3
  69. package/src/LicenseByline/EmbedByline.tsx +3 -3
  70. package/src/List/OrderedList.tsx +1 -0
  71. package/src/List/UnOrderedList.tsx +0 -3
  72. package/src/NDLAFilm/AllMoviesAlphabetically.tsx +2 -0
  73. package/src/NDLAFilm/FilmContentCard.tsx +48 -51
  74. package/src/NDLAFilm/FilmContentCardTags.tsx +5 -2
  75. package/src/NDLAFilm/FilmMovieList.tsx +4 -21
  76. package/src/NDLAFilm/FilmMovieSearch.tsx +0 -1
  77. package/src/NDLAFilm/FilmSlideshow.tsx +47 -100
  78. package/src/NDLAFilm/MovieGrid.tsx +11 -17
  79. package/src/NDLAFilm/filmStyles.ts +8 -7
  80. package/src/Table/Table.tsx +8 -1
  81. package/src/locale/messages-en.ts +3 -2
  82. package/src/locale/messages-nb.ts +3 -2
  83. package/src/locale/messages-nn.ts +3 -2
  84. package/src/locale/messages-se.ts +2 -1
  85. package/src/locale/messages-sma.ts +3 -2
  86. package/es/NDLAFilm/NavigationArrow.js +0 -54
  87. package/es/NDLAFilm/SlideshowIndicator.js +0 -47
  88. package/lib/NDLAFilm/NavigationArrow.d.ts +0 -23
  89. package/lib/NDLAFilm/NavigationArrow.js +0 -63
  90. package/lib/NDLAFilm/SlideshowIndicator.d.ts +0 -15
  91. package/lib/NDLAFilm/SlideshowIndicator.js +0 -55
  92. package/src/NDLAFilm/NavigationArrow.tsx +0 -108
  93. package/src/NDLAFilm/SlideshowIndicator.tsx +0 -82
@@ -1,10 +1,4 @@
1
- function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
2
1
  import _styled from "@emotion/styled/base";
3
- function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
4
- function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
5
- function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
6
- function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return _typeof(key) === "symbol" ? key : String(key); }
7
- function _toPrimitive(input, hint) { if (_typeof(input) !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (_typeof(res) !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); }
8
2
  function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
9
3
  function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
10
4
  function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
@@ -21,50 +15,15 @@ function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringif
21
15
  */
22
16
 
23
17
  import { useCallback, useState } from 'react';
24
- import { Carousel, CarouselAutosize } from '@ndla/carousel';
25
- import { breakpoints, colors, misc, mq, spacing, spacingUnit } from '@ndla/core';
18
+ import { Carousel } from '@ndla/carousel';
19
+ import { breakpoints, colors, misc, mq, spacing } from '@ndla/core';
26
20
  import SafeLink from '@ndla/safelink';
27
21
  import { IconButtonV2 } from '@ndla/button';
28
22
  import { ChevronLeft, ChevronRight } from '@ndla/icons/common';
29
23
  import FilmContentCard from './FilmContentCard';
24
+ import Image from '../Image';
30
25
  import { jsx as _jsx } from "@emotion/react/jsx-runtime";
31
26
  import { jsxs as _jsxs } from "@emotion/react/jsx-runtime";
32
- export var slideshowBreakpoints = [{
33
- until: 'mobileWide',
34
- columnsPrSlide: 2,
35
- distanceBetweenItems: spacingUnit / 2,
36
- margin: spacingUnit,
37
- arrowOffset: 13
38
- }, {
39
- until: 'tabletWide',
40
- columnsPrSlide: 3,
41
- distanceBetweenItems: spacingUnit / 2,
42
- margin: spacingUnit,
43
- arrowOffset: 13
44
- }, {
45
- until: 'desktop',
46
- columnsPrSlide: 3,
47
- distanceBetweenItems: spacingUnit,
48
- margin: spacingUnit * 2,
49
- arrowOffset: 0
50
- }, {
51
- until: 'wide',
52
- columnsPrSlide: 3,
53
- distanceBetweenItems: spacingUnit,
54
- margin: spacingUnit * 2,
55
- arrowOffset: 0
56
- }, {
57
- until: 'ultraWide',
58
- columnsPrSlide: 3,
59
- distanceBetweenItems: spacingUnit,
60
- margin: spacingUnit * 3.5,
61
- arrowOffset: 0
62
- }, {
63
- columnsPrSlide: 3,
64
- distanceBetweenItems: spacingUnit,
65
- margin: spacingUnit * 3.5,
66
- arrowOffset: 0
67
- }];
68
27
  var SlideInfoWrapper = /*#__PURE__*/_styled("div", {
69
28
  target: "essc37o6",
70
29
  label: "SlideInfoWrapper"
@@ -72,7 +31,7 @@ var SlideInfoWrapper = /*#__PURE__*/_styled("div", {
72
31
  until: breakpoints.desktop
73
32
  }), "{top:30%;max-width:60%;min-width:60%;}", mq.range({
74
33
  until: breakpoints.tablet
75
- }), "{max-width:90%;min-width:90%;left:5%;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FilmSlideshow.tsx"],"names":[],"mappings":"AAyEmC","file":"FilmSlideshow.tsx","sourcesContent":["/**\n * Copyright (c) 2023-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 { useCallback, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { Carousel, CarouselAutosize } from '@ndla/carousel';\nimport { breakpoints, colors, misc, mq, spacing, spacingUnit } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\nimport { IconButtonV2 } from '@ndla/button';\nimport { ChevronLeft, ChevronRight } from '@ndla/icons/common';\nimport FilmContentCard from './FilmContentCard';\nimport { MovieType } from './types';\n\nexport const slideshowBreakpoints: {\n  until?: keyof typeof breakpoints;\n  columnsPrSlide: number;\n  distanceBetweenItems: number;\n  arrowOffset: number;\n  margin?: number;\n  maxColumnWidth?: number;\n}[] = [\n  {\n    until: 'mobileWide',\n    columnsPrSlide: 2,\n    distanceBetweenItems: spacingUnit / 2,\n    margin: spacingUnit,\n    arrowOffset: 13,\n  },\n  {\n    until: 'tabletWide',\n    columnsPrSlide: 3,\n    distanceBetweenItems: spacingUnit / 2,\n    margin: spacingUnit,\n    arrowOffset: 13,\n  },\n  {\n    until: 'desktop',\n    columnsPrSlide: 3,\n    distanceBetweenItems: spacingUnit,\n    margin: spacingUnit * 2,\n    arrowOffset: 0,\n  },\n  {\n    until: 'wide',\n    columnsPrSlide: 3,\n    distanceBetweenItems: spacingUnit,\n    margin: spacingUnit * 2,\n    arrowOffset: 0,\n  },\n  {\n    until: 'ultraWide',\n    columnsPrSlide: 3,\n    distanceBetweenItems: spacingUnit,\n    margin: spacingUnit * 3.5,\n    arrowOffset: 0,\n  },\n  {\n    columnsPrSlide: 3,\n    distanceBetweenItems: spacingUnit,\n    margin: spacingUnit * 3.5,\n    arrowOffset: 0,\n  },\n];\n\ninterface Props {\n  slideshow: MovieType[];\n}\n\nconst SlideInfoWrapper = styled.div`\n  position: absolute;\n  color: ${colors.white};\n  max-width: 40%;\n  min-width: 40%;\n  top: 40%;\n  right: 5%;\n  ${mq.range({ until: breakpoints.desktop })} {\n    top: 30%;\n    max-width: 60%;\n    min-width: 60%;\n  }\n  ${mq.range({ until: breakpoints.tablet })} {\n    max-width: 90%;\n    min-width: 90%;\n    left: 5%;\n  }\n`;\n\nconst StyledSafeLink = styled(SafeLink)`\n  position: relative;\n  display: block;\n  box-shadow: none;\n`;\n\nconst InfoWrapper = styled.div`\n  padding: ${spacing.normal};\n  border-radius: ${misc.borderRadius};\n  border: 0.5px solid ${colors.brand.primary};\n  background-color: rgba(11, 29, 45, 0.8);\n  h3 {\n    margin: 0px;\n  }\n`;\n\nconst StyledImg = styled.img`\n  max-height: 600px;\n  object-position: top;\n  width: 100%;\n  aspect-ratio: 16/9;\n  ${mq.range({ until: breakpoints.tablet })} {\n    min-height: 440px;\n    max-height: 440px;\n  }\n  object-fit: cover;\n`;\n\nconst CarouselContainer = styled.div`\n  margin-top: -50px;\n  ${mq.range({ from: breakpoints.tablet })} {\n    margin-top: -70px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    margin-top: -150px;\n  }\n`;\n\ninterface StyledFilmContentCardProps {\n  current?: boolean;\n}\n\nconst SlideshowButton = styled(IconButtonV2)`\n  margin-top: ${spacing.normal};\n`;\n\nconst shouldForwardProp = (p: string) => p !== 'current';\n\nconst StyledFilmContentCard = styled(FilmContentCard, { shouldForwardProp })<StyledFilmContentCardProps>`\n  margin-bottom: 2%;\n  transform: ${(p) => (p.current ? 'translateY(0%)' : 'translateY(10%)')};\n  transition: all 200ms;\n`;\n\nconst FilmSlideshow = ({ slideshow }: Props) => {\n  const [currentSlide, setCurrentSlide] = useState(slideshow[0]);\n\n  return (\n    <CarouselAutosize breakpoints={slideshowBreakpoints} itemsLength={slideshow.length}>\n      {(autoSizedProps) => (\n        <section>\n          <StyledSafeLink to={currentSlide.path} tabIndex={-1} aria-hidden>\n            <StyledImg src={currentSlide.metaImage?.url ?? ''} alt={currentSlide.metaImage?.alt ?? ''} />\n            <SlideInfoWrapper>\n              <InfoWrapper>\n                <h3>{currentSlide.title}</h3>\n                <span id=\"currentMovieDescription\">{currentSlide.metaDescription}</span>\n              </InfoWrapper>\n            </SlideInfoWrapper>\n          </StyledSafeLink>\n          <CarouselContainer>\n            <Carousel\n              leftButton={\n                <SlideshowButton aria-label={''}>\n                  <ChevronLeft />\n                </SlideshowButton>\n              }\n              rightButton={\n                <SlideshowButton aria-label={''}>\n                  <ChevronRight />\n                </SlideshowButton>\n              }\n              items={slideshow.map((movie) => (\n                <FilmCard\n                  key={movie.id}\n                  current={movie.id === currentSlide.id}\n                  movie={movie}\n                  columnWidth={autoSizedProps.columnWidth}\n                  setCurrentSlide={() => setCurrentSlide(movie)}\n                />\n              ))}\n              {...autoSizedProps}\n            />\n          </CarouselContainer>\n        </section>\n      )}\n    </CarouselAutosize>\n  );\n};\n\ninterface FilmCardProps {\n  setCurrentSlide: () => void;\n  movie: MovieType;\n  current: boolean;\n  columnWidth: number;\n}\n\nconst FilmCard = ({ setCurrentSlide, movie, current, columnWidth }: FilmCardProps) => {\n  const [hoverCallback, setHoverCallback] = useState<ReturnType<typeof setTimeout> | undefined>(undefined);\n\n  const onHover = useCallback(() => {\n    const timeout = setTimeout(() => setCurrentSlide(), 500);\n    setHoverCallback(timeout);\n  }, [setCurrentSlide]);\n\n  return (\n    <StyledFilmContentCard\n      onMouseEnter={onHover}\n      onMouseLeave={() => {\n        if (hoverCallback) {\n          clearTimeout(hoverCallback);\n          setHoverCallback(undefined);\n        }\n      }}\n      onFocus={() => setCurrentSlide()}\n      current={current}\n      aria-describedby={'currentMovieDescription'}\n      key={movie.id}\n      movie={movie}\n      columnWidth={columnWidth}\n      resourceTypes={[]}\n    />\n  );\n};\n\nexport default FilmSlideshow;\n"]} */"));
34
+ }), "{max-width:90%;min-width:90%;left:5%;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkZpbG1TbGlkZXNob3cudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXVCbUMiLCJmaWxlIjoiRmlsbVNsaWRlc2hvdy50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAyMy1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCB7IHVzZUNhbGxiYWNrLCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IENhcm91c2VsIH0gZnJvbSAnQG5kbGEvY2Fyb3VzZWwnO1xuaW1wb3J0IHsgYnJlYWtwb2ludHMsIGNvbG9ycywgbWlzYywgbXEsIHNwYWNpbmcgfSBmcm9tICdAbmRsYS9jb3JlJztcbmltcG9ydCBTYWZlTGluayBmcm9tICdAbmRsYS9zYWZlbGluayc7XG5pbXBvcnQgeyBJY29uQnV0dG9uVjIgfSBmcm9tICdAbmRsYS9idXR0b24nO1xuaW1wb3J0IHsgQ2hldnJvbkxlZnQsIENoZXZyb25SaWdodCB9IGZyb20gJ0BuZGxhL2ljb25zL2NvbW1vbic7XG5pbXBvcnQgRmlsbUNvbnRlbnRDYXJkIGZyb20gJy4vRmlsbUNvbnRlbnRDYXJkJztcbmltcG9ydCB7IE1vdmllVHlwZSB9IGZyb20gJy4vdHlwZXMnO1xuaW1wb3J0IEltYWdlIGZyb20gJy4uL0ltYWdlJztcblxuaW50ZXJmYWNlIFByb3BzIHtcbiAgc2xpZGVzaG93OiBNb3ZpZVR5cGVbXTtcbn1cblxuY29uc3QgU2xpZGVJbmZvV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgY29sb3I6ICR7Y29sb3JzLndoaXRlfTtcbiAgbWF4LXdpZHRoOiA0MCU7XG4gIG1pbi13aWR0aDogNDAlO1xuICB0b3A6IDQwJTtcbiAgcmlnaHQ6IDUlO1xuICAke21xLnJhbmdlKHsgdW50aWw6IGJyZWFrcG9pbnRzLmRlc2t0b3AgfSl9IHtcbiAgICB0b3A6IDMwJTtcbiAgICBtYXgtd2lkdGg6IDYwJTtcbiAgICBtaW4td2lkdGg6IDYwJTtcbiAgfVxuICAke21xLnJhbmdlKHsgdW50aWw6IGJyZWFrcG9pbnRzLnRhYmxldCB9KX0ge1xuICAgIG1heC13aWR0aDogOTAlO1xuICAgIG1pbi13aWR0aDogOTAlO1xuICAgIGxlZnQ6IDUlO1xuICB9XG5gO1xuXG5jb25zdCBTdHlsZWRTYWZlTGluayA9IHN0eWxlZChTYWZlTGluaylgXG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgZGlzcGxheTogYmxvY2s7XG4gIGJveC1zaGFkb3c6IG5vbmU7XG5gO1xuXG5jb25zdCBJbmZvV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIHBhZGRpbmc6ICR7c3BhY2luZy5ub3JtYWx9O1xuICBib3JkZXItcmFkaXVzOiAke21pc2MuYm9yZGVyUmFkaXVzfTtcbiAgYm9yZGVyOiAwLjVweCBzb2xpZCAke2NvbG9ycy5icmFuZC5wcmltYXJ5fTtcbiAgYmFja2dyb3VuZC1jb2xvcjogcmdiYSgxMSwgMjksIDQ1LCAwLjgpO1xuICBoMyB7XG4gICAgbWFyZ2luOiAwcHg7XG4gIH1cbmA7XG5cbmNvbnN0IFN0eWxlZEltZyA9IHN0eWxlZChJbWFnZSlgXG4gIG1heC1oZWlnaHQ6IDYwMHB4O1xuICBtaW4taGVpZ2h0OiA2MDBweDtcbiAgb2JqZWN0LXBvc2l0aW9uOiB0b3A7XG4gIHdpZHRoOiAxMDAlO1xuICBhc3BlY3QtcmF0aW86IDE2Lzk7XG4gICR7bXEucmFuZ2UoeyB1bnRpbDogYnJlYWtwb2ludHMudGFibGV0IH0pfSB7XG4gICAgbWluLWhlaWdodDogNDQwcHg7XG4gICAgbWF4LWhlaWdodDogNDQwcHg7XG4gIH1cbiAgb2JqZWN0LWZpdDogY292ZXI7XG5gO1xuXG5jb25zdCBDYXJvdXNlbENvbnRhaW5lciA9IHN0eWxlZC5kaXZgXG4gIG1hcmdpbi10b3A6IC01MHB4O1xuICAke21xLnJhbmdlKHsgZnJvbTogYnJlYWtwb2ludHMudGFibGV0IH0pfSB7XG4gICAgbWFyZ2luLXRvcDogLTcwcHg7XG4gIH1cbiAgJHttcS5yYW5nZSh7IGZyb206IGJyZWFrcG9pbnRzLmRlc2t0b3AgfSl9IHtcbiAgICBtYXJnaW4tdG9wOiAtMTYwcHg7XG4gIH1cbmA7XG5cbmludGVyZmFjZSBTdHlsZWRGaWxtQ29udGVudENhcmRQcm9wcyB7XG4gIGN1cnJlbnQ/OiBib29sZWFuO1xufVxuXG5jb25zdCBTbGlkZXNob3dCdXR0b24gPSBzdHlsZWQoSWNvbkJ1dHRvblYyKWBcbiAgbWFyZ2luLXRvcDogJHtzcGFjaW5nLm5vcm1hbH07XG5gO1xuXG5jb25zdCBzaG91bGRGb3J3YXJkUHJvcCA9IChwOiBzdHJpbmcpID0+IHAgIT09ICdjdXJyZW50JztcblxuY29uc3QgU3R5bGVkRmlsbUNvbnRlbnRDYXJkID0gc3R5bGVkKEZpbG1Db250ZW50Q2FyZCwgeyBzaG91bGRGb3J3YXJkUHJvcCB9KTxTdHlsZWRGaWxtQ29udGVudENhcmRQcm9wcz5gXG4gIG1hcmdpbi1ib3R0b206IDIlO1xuICB0cmFuc2Zvcm06ICR7KHApID0+IChwLmN1cnJlbnQgPyAndHJhbnNsYXRlWSgwJSknIDogJ3RyYW5zbGF0ZVkoMTAlKScpfTtcbiAgdHJhbnNpdGlvbjogYWxsIDIwMG1zO1xuYDtcblxuY29uc3QgRmlsbVNsaWRlc2hvdyA9ICh7IHNsaWRlc2hvdyB9OiBQcm9wcykgPT4ge1xuICBjb25zdCBbY3VycmVudFNsaWRlLCBzZXRDdXJyZW50U2xpZGVdID0gdXNlU3RhdGUoc2xpZGVzaG93WzBdKTtcblxuICByZXR1cm4gKFxuICAgIDxzZWN0aW9uPlxuICAgICAgPFN0eWxlZFNhZmVMaW5rIHRvPXtjdXJyZW50U2xpZGUucGF0aH0gdGFiSW5kZXg9ey0xfSBhcmlhLWhpZGRlbj5cbiAgICAgICAgPFN0eWxlZEltZ1xuICAgICAgICAgIHNyYz17Y3VycmVudFNsaWRlLm1ldGFJbWFnZT8udXJsID8/ICcnfVxuICAgICAgICAgIHNpemVzPVwiKG1pbi13aWR0aDogMTE0MHB4KSAxMTQwcHgsIChtaW4td2lkdGg6IDcyMHB4KSAxMDB2dywgMTAwdndcIlxuICAgICAgICAgIGFsdD1cIlwiXG4gICAgICAgIC8+XG4gICAgICAgIDxTbGlkZUluZm9XcmFwcGVyPlxuICAgICAgICAgIDxJbmZvV3JhcHBlcj5cbiAgICAgICAgICAgIDxoMz57Y3VycmVudFNsaWRlLnRpdGxlfTwvaDM+XG4gICAgICAgICAgICA8c3BhbiBpZD1cImN1cnJlbnRNb3ZpZURlc2NyaXB0aW9uXCI+e2N1cnJlbnRTbGlkZS5tZXRhRGVzY3JpcHRpb259PC9zcGFuPlxuICAgICAgICAgIDwvSW5mb1dyYXBwZXI+XG4gICAgICAgIDwvU2xpZGVJbmZvV3JhcHBlcj5cbiAgICAgIDwvU3R5bGVkU2FmZUxpbms+XG4gICAgICA8Q2Fyb3VzZWxDb250YWluZXI+XG4gICAgICAgIDxDYXJvdXNlbFxuICAgICAgICAgIGxlZnRCdXR0b249e1xuICAgICAgICAgICAgPFNsaWRlc2hvd0J1dHRvbiBhcmlhLWxhYmVsPVwiXCI+XG4gICAgICAgICAgICAgIDxDaGV2cm9uTGVmdCAvPlxuICAgICAgICAgICAgPC9TbGlkZXNob3dCdXR0b24+XG4gICAgICAgICAgfVxuICAgICAgICAgIHJpZ2h0QnV0dG9uPXtcbiAgICAgICAgICAgIDxTbGlkZXNob3dCdXR0b24gYXJpYS1sYWJlbD1cIlwiPlxuICAgICAgICAgICAgICA8Q2hldnJvblJpZ2h0IC8+XG4gICAgICAgICAgICA8L1NsaWRlc2hvd0J1dHRvbj5cbiAgICAgICAgICB9XG4gICAgICAgICAgaXRlbXM9e3NsaWRlc2hvdy5tYXAoKG1vdmllKSA9PiAoXG4gICAgICAgICAgICA8RmlsbUNhcmRcbiAgICAgICAgICAgICAga2V5PXttb3ZpZS5pZH1cbiAgICAgICAgICAgICAgY3VycmVudD17bW92aWUuaWQgPT09IGN1cnJlbnRTbGlkZS5pZH1cbiAgICAgICAgICAgICAgbW92aWU9e21vdmllfVxuICAgICAgICAgICAgICBzZXRDdXJyZW50U2xpZGU9e3NldEN1cnJlbnRTbGlkZX1cbiAgICAgICAgICAgIC8+XG4gICAgICAgICAgKSl9XG4gICAgICAgIC8+XG4gICAgICA8L0Nhcm91c2VsQ29udGFpbmVyPlxuICAgIDwvc2VjdGlvbj5cbiAgKTtcbn07XG5cbmludGVyZmFjZSBGaWxtQ2FyZFByb3BzIHtcbiAgc2V0Q3VycmVudFNsaWRlOiAobW92aWU6IE1vdmllVHlwZSkgPT4gdm9pZDtcbiAgbW92aWU6IE1vdmllVHlwZTtcbiAgY3VycmVudDogYm9vbGVhbjtcbn1cblxuY29uc3QgRmlsbUNhcmQgPSAoeyBzZXRDdXJyZW50U2xpZGUsIG1vdmllLCBjdXJyZW50IH06IEZpbG1DYXJkUHJvcHMpID0+IHtcbiAgY29uc3QgW2hvdmVyQ2FsbGJhY2ssIHNldEhvdmVyQ2FsbGJhY2tdID0gdXNlU3RhdGU8UmV0dXJuVHlwZTx0eXBlb2Ygc2V0VGltZW91dD4gfCB1bmRlZmluZWQ+KHVuZGVmaW5lZCk7XG5cbiAgY29uc3Qgb25Ib3ZlciA9IHVzZUNhbGxiYWNrKCgpID0+IHtcbiAgICBjb25zdCB0aW1lb3V0ID0gc2V0VGltZW91dCgoKSA9PiBzZXRDdXJyZW50U2xpZGUobW92aWUpLCA1MDApO1xuICAgIHNldEhvdmVyQ2FsbGJhY2sodGltZW91dCk7XG4gIH0sIFttb3ZpZSwgc2V0Q3VycmVudFNsaWRlXSk7XG5cbiAgcmV0dXJuIChcbiAgICA8U3R5bGVkRmlsbUNvbnRlbnRDYXJkXG4gICAgICBvbk1vdXNlRW50ZXI9e29uSG92ZXJ9XG4gICAgICBvbk1vdXNlTGVhdmU9eygpID0+IHtcbiAgICAgICAgaWYgKGhvdmVyQ2FsbGJhY2spIHtcbiAgICAgICAgICBjbGVhclRpbWVvdXQoaG92ZXJDYWxsYmFjayk7XG4gICAgICAgICAgc2V0SG92ZXJDYWxsYmFjayh1bmRlZmluZWQpO1xuICAgICAgICB9XG4gICAgICB9fVxuICAgICAgb25Gb2N1cz17KCkgPT4gc2V0Q3VycmVudFNsaWRlKG1vdmllKX1cbiAgICAgIGN1cnJlbnQ9e2N1cnJlbnR9XG4gICAgICBhcmlhLWRlc2NyaWJlZGJ5PXsnY3VycmVudE1vdmllRGVzY3JpcHRpb24nfVxuICAgICAga2V5PXttb3ZpZS5pZH1cbiAgICAgIG1vdmllPXttb3ZpZX1cbiAgICAgIHJlc291cmNlVHlwZXM9e1tdfVxuICAgIC8+XG4gICk7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBGaWxtU2xpZGVzaG93O1xuIl19 */"));
76
35
  var StyledSafeLink = /*#__PURE__*/_styled(SafeLink, {
77
36
  target: "essc37o5",
78
37
  label: "StyledSafeLink"
@@ -82,19 +41,19 @@ var StyledSafeLink = /*#__PURE__*/_styled(SafeLink, {
82
41
  } : {
83
42
  name: "rmwyk3",
84
43
  styles: "position:relative;display:block;box-shadow:none",
85
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FilmSlideshow.tsx"],"names":[],"mappings":"AA4FuC","file":"FilmSlideshow.tsx","sourcesContent":["/**\n * Copyright (c) 2023-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 { useCallback, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { Carousel, CarouselAutosize } from '@ndla/carousel';\nimport { breakpoints, colors, misc, mq, spacing, spacingUnit } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\nimport { IconButtonV2 } from '@ndla/button';\nimport { ChevronLeft, ChevronRight } from '@ndla/icons/common';\nimport FilmContentCard from './FilmContentCard';\nimport { MovieType } from './types';\n\nexport const slideshowBreakpoints: {\n  until?: keyof typeof breakpoints;\n  columnsPrSlide: number;\n  distanceBetweenItems: number;\n  arrowOffset: number;\n  margin?: number;\n  maxColumnWidth?: number;\n}[] = [\n  {\n    until: 'mobileWide',\n    columnsPrSlide: 2,\n    distanceBetweenItems: spacingUnit / 2,\n    margin: spacingUnit,\n    arrowOffset: 13,\n  },\n  {\n    until: 'tabletWide',\n    columnsPrSlide: 3,\n    distanceBetweenItems: spacingUnit / 2,\n    margin: spacingUnit,\n    arrowOffset: 13,\n  },\n  {\n    until: 'desktop',\n    columnsPrSlide: 3,\n    distanceBetweenItems: spacingUnit,\n    margin: spacingUnit * 2,\n    arrowOffset: 0,\n  },\n  {\n    until: 'wide',\n    columnsPrSlide: 3,\n    distanceBetweenItems: spacingUnit,\n    margin: spacingUnit * 2,\n    arrowOffset: 0,\n  },\n  {\n    until: 'ultraWide',\n    columnsPrSlide: 3,\n    distanceBetweenItems: spacingUnit,\n    margin: spacingUnit * 3.5,\n    arrowOffset: 0,\n  },\n  {\n    columnsPrSlide: 3,\n    distanceBetweenItems: spacingUnit,\n    margin: spacingUnit * 3.5,\n    arrowOffset: 0,\n  },\n];\n\ninterface Props {\n  slideshow: MovieType[];\n}\n\nconst SlideInfoWrapper = styled.div`\n  position: absolute;\n  color: ${colors.white};\n  max-width: 40%;\n  min-width: 40%;\n  top: 40%;\n  right: 5%;\n  ${mq.range({ until: breakpoints.desktop })} {\n    top: 30%;\n    max-width: 60%;\n    min-width: 60%;\n  }\n  ${mq.range({ until: breakpoints.tablet })} {\n    max-width: 90%;\n    min-width: 90%;\n    left: 5%;\n  }\n`;\n\nconst StyledSafeLink = styled(SafeLink)`\n  position: relative;\n  display: block;\n  box-shadow: none;\n`;\n\nconst InfoWrapper = styled.div`\n  padding: ${spacing.normal};\n  border-radius: ${misc.borderRadius};\n  border: 0.5px solid ${colors.brand.primary};\n  background-color: rgba(11, 29, 45, 0.8);\n  h3 {\n    margin: 0px;\n  }\n`;\n\nconst StyledImg = styled.img`\n  max-height: 600px;\n  object-position: top;\n  width: 100%;\n  aspect-ratio: 16/9;\n  ${mq.range({ until: breakpoints.tablet })} {\n    min-height: 440px;\n    max-height: 440px;\n  }\n  object-fit: cover;\n`;\n\nconst CarouselContainer = styled.div`\n  margin-top: -50px;\n  ${mq.range({ from: breakpoints.tablet })} {\n    margin-top: -70px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    margin-top: -150px;\n  }\n`;\n\ninterface StyledFilmContentCardProps {\n  current?: boolean;\n}\n\nconst SlideshowButton = styled(IconButtonV2)`\n  margin-top: ${spacing.normal};\n`;\n\nconst shouldForwardProp = (p: string) => p !== 'current';\n\nconst StyledFilmContentCard = styled(FilmContentCard, { shouldForwardProp })<StyledFilmContentCardProps>`\n  margin-bottom: 2%;\n  transform: ${(p) => (p.current ? 'translateY(0%)' : 'translateY(10%)')};\n  transition: all 200ms;\n`;\n\nconst FilmSlideshow = ({ slideshow }: Props) => {\n  const [currentSlide, setCurrentSlide] = useState(slideshow[0]);\n\n  return (\n    <CarouselAutosize breakpoints={slideshowBreakpoints} itemsLength={slideshow.length}>\n      {(autoSizedProps) => (\n        <section>\n          <StyledSafeLink to={currentSlide.path} tabIndex={-1} aria-hidden>\n            <StyledImg src={currentSlide.metaImage?.url ?? ''} alt={currentSlide.metaImage?.alt ?? ''} />\n            <SlideInfoWrapper>\n              <InfoWrapper>\n                <h3>{currentSlide.title}</h3>\n                <span id=\"currentMovieDescription\">{currentSlide.metaDescription}</span>\n              </InfoWrapper>\n            </SlideInfoWrapper>\n          </StyledSafeLink>\n          <CarouselContainer>\n            <Carousel\n              leftButton={\n                <SlideshowButton aria-label={''}>\n                  <ChevronLeft />\n                </SlideshowButton>\n              }\n              rightButton={\n                <SlideshowButton aria-label={''}>\n                  <ChevronRight />\n                </SlideshowButton>\n              }\n              items={slideshow.map((movie) => (\n                <FilmCard\n                  key={movie.id}\n                  current={movie.id === currentSlide.id}\n                  movie={movie}\n                  columnWidth={autoSizedProps.columnWidth}\n                  setCurrentSlide={() => setCurrentSlide(movie)}\n                />\n              ))}\n              {...autoSizedProps}\n            />\n          </CarouselContainer>\n        </section>\n      )}\n    </CarouselAutosize>\n  );\n};\n\ninterface FilmCardProps {\n  setCurrentSlide: () => void;\n  movie: MovieType;\n  current: boolean;\n  columnWidth: number;\n}\n\nconst FilmCard = ({ setCurrentSlide, movie, current, columnWidth }: FilmCardProps) => {\n  const [hoverCallback, setHoverCallback] = useState<ReturnType<typeof setTimeout> | undefined>(undefined);\n\n  const onHover = useCallback(() => {\n    const timeout = setTimeout(() => setCurrentSlide(), 500);\n    setHoverCallback(timeout);\n  }, [setCurrentSlide]);\n\n  return (\n    <StyledFilmContentCard\n      onMouseEnter={onHover}\n      onMouseLeave={() => {\n        if (hoverCallback) {\n          clearTimeout(hoverCallback);\n          setHoverCallback(undefined);\n        }\n      }}\n      onFocus={() => setCurrentSlide()}\n      current={current}\n      aria-describedby={'currentMovieDescription'}\n      key={movie.id}\n      movie={movie}\n      columnWidth={columnWidth}\n      resourceTypes={[]}\n    />\n  );\n};\n\nexport default FilmSlideshow;\n"]} */",
44
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkZpbG1TbGlkZXNob3cudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTBDdUMiLCJmaWxlIjoiRmlsbVNsaWRlc2hvdy50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAyMy1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCB7IHVzZUNhbGxiYWNrLCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IENhcm91c2VsIH0gZnJvbSAnQG5kbGEvY2Fyb3VzZWwnO1xuaW1wb3J0IHsgYnJlYWtwb2ludHMsIGNvbG9ycywgbWlzYywgbXEsIHNwYWNpbmcgfSBmcm9tICdAbmRsYS9jb3JlJztcbmltcG9ydCBTYWZlTGluayBmcm9tICdAbmRsYS9zYWZlbGluayc7XG5pbXBvcnQgeyBJY29uQnV0dG9uVjIgfSBmcm9tICdAbmRsYS9idXR0b24nO1xuaW1wb3J0IHsgQ2hldnJvbkxlZnQsIENoZXZyb25SaWdodCB9IGZyb20gJ0BuZGxhL2ljb25zL2NvbW1vbic7XG5pbXBvcnQgRmlsbUNvbnRlbnRDYXJkIGZyb20gJy4vRmlsbUNvbnRlbnRDYXJkJztcbmltcG9ydCB7IE1vdmllVHlwZSB9IGZyb20gJy4vdHlwZXMnO1xuaW1wb3J0IEltYWdlIGZyb20gJy4uL0ltYWdlJztcblxuaW50ZXJmYWNlIFByb3BzIHtcbiAgc2xpZGVzaG93OiBNb3ZpZVR5cGVbXTtcbn1cblxuY29uc3QgU2xpZGVJbmZvV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgY29sb3I6ICR7Y29sb3JzLndoaXRlfTtcbiAgbWF4LXdpZHRoOiA0MCU7XG4gIG1pbi13aWR0aDogNDAlO1xuICB0b3A6IDQwJTtcbiAgcmlnaHQ6IDUlO1xuICAke21xLnJhbmdlKHsgdW50aWw6IGJyZWFrcG9pbnRzLmRlc2t0b3AgfSl9IHtcbiAgICB0b3A6IDMwJTtcbiAgICBtYXgtd2lkdGg6IDYwJTtcbiAgICBtaW4td2lkdGg6IDYwJTtcbiAgfVxuICAke21xLnJhbmdlKHsgdW50aWw6IGJyZWFrcG9pbnRzLnRhYmxldCB9KX0ge1xuICAgIG1heC13aWR0aDogOTAlO1xuICAgIG1pbi13aWR0aDogOTAlO1xuICAgIGxlZnQ6IDUlO1xuICB9XG5gO1xuXG5jb25zdCBTdHlsZWRTYWZlTGluayA9IHN0eWxlZChTYWZlTGluaylgXG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgZGlzcGxheTogYmxvY2s7XG4gIGJveC1zaGFkb3c6IG5vbmU7XG5gO1xuXG5jb25zdCBJbmZvV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIHBhZGRpbmc6ICR7c3BhY2luZy5ub3JtYWx9O1xuICBib3JkZXItcmFkaXVzOiAke21pc2MuYm9yZGVyUmFkaXVzfTtcbiAgYm9yZGVyOiAwLjVweCBzb2xpZCAke2NvbG9ycy5icmFuZC5wcmltYXJ5fTtcbiAgYmFja2dyb3VuZC1jb2xvcjogcmdiYSgxMSwgMjksIDQ1LCAwLjgpO1xuICBoMyB7XG4gICAgbWFyZ2luOiAwcHg7XG4gIH1cbmA7XG5cbmNvbnN0IFN0eWxlZEltZyA9IHN0eWxlZChJbWFnZSlgXG4gIG1heC1oZWlnaHQ6IDYwMHB4O1xuICBtaW4taGVpZ2h0OiA2MDBweDtcbiAgb2JqZWN0LXBvc2l0aW9uOiB0b3A7XG4gIHdpZHRoOiAxMDAlO1xuICBhc3BlY3QtcmF0aW86IDE2Lzk7XG4gICR7bXEucmFuZ2UoeyB1bnRpbDogYnJlYWtwb2ludHMudGFibGV0IH0pfSB7XG4gICAgbWluLWhlaWdodDogNDQwcHg7XG4gICAgbWF4LWhlaWdodDogNDQwcHg7XG4gIH1cbiAgb2JqZWN0LWZpdDogY292ZXI7XG5gO1xuXG5jb25zdCBDYXJvdXNlbENvbnRhaW5lciA9IHN0eWxlZC5kaXZgXG4gIG1hcmdpbi10b3A6IC01MHB4O1xuICAke21xLnJhbmdlKHsgZnJvbTogYnJlYWtwb2ludHMudGFibGV0IH0pfSB7XG4gICAgbWFyZ2luLXRvcDogLTcwcHg7XG4gIH1cbiAgJHttcS5yYW5nZSh7IGZyb206IGJyZWFrcG9pbnRzLmRlc2t0b3AgfSl9IHtcbiAgICBtYXJnaW4tdG9wOiAtMTYwcHg7XG4gIH1cbmA7XG5cbmludGVyZmFjZSBTdHlsZWRGaWxtQ29udGVudENhcmRQcm9wcyB7XG4gIGN1cnJlbnQ/OiBib29sZWFuO1xufVxuXG5jb25zdCBTbGlkZXNob3dCdXR0b24gPSBzdHlsZWQoSWNvbkJ1dHRvblYyKWBcbiAgbWFyZ2luLXRvcDogJHtzcGFjaW5nLm5vcm1hbH07XG5gO1xuXG5jb25zdCBzaG91bGRGb3J3YXJkUHJvcCA9IChwOiBzdHJpbmcpID0+IHAgIT09ICdjdXJyZW50JztcblxuY29uc3QgU3R5bGVkRmlsbUNvbnRlbnRDYXJkID0gc3R5bGVkKEZpbG1Db250ZW50Q2FyZCwgeyBzaG91bGRGb3J3YXJkUHJvcCB9KTxTdHlsZWRGaWxtQ29udGVudENhcmRQcm9wcz5gXG4gIG1hcmdpbi1ib3R0b206IDIlO1xuICB0cmFuc2Zvcm06ICR7KHApID0+IChwLmN1cnJlbnQgPyAndHJhbnNsYXRlWSgwJSknIDogJ3RyYW5zbGF0ZVkoMTAlKScpfTtcbiAgdHJhbnNpdGlvbjogYWxsIDIwMG1zO1xuYDtcblxuY29uc3QgRmlsbVNsaWRlc2hvdyA9ICh7IHNsaWRlc2hvdyB9OiBQcm9wcykgPT4ge1xuICBjb25zdCBbY3VycmVudFNsaWRlLCBzZXRDdXJyZW50U2xpZGVdID0gdXNlU3RhdGUoc2xpZGVzaG93WzBdKTtcblxuICByZXR1cm4gKFxuICAgIDxzZWN0aW9uPlxuICAgICAgPFN0eWxlZFNhZmVMaW5rIHRvPXtjdXJyZW50U2xpZGUucGF0aH0gdGFiSW5kZXg9ey0xfSBhcmlhLWhpZGRlbj5cbiAgICAgICAgPFN0eWxlZEltZ1xuICAgICAgICAgIHNyYz17Y3VycmVudFNsaWRlLm1ldGFJbWFnZT8udXJsID8/ICcnfVxuICAgICAgICAgIHNpemVzPVwiKG1pbi13aWR0aDogMTE0MHB4KSAxMTQwcHgsIChtaW4td2lkdGg6IDcyMHB4KSAxMDB2dywgMTAwdndcIlxuICAgICAgICAgIGFsdD1cIlwiXG4gICAgICAgIC8+XG4gICAgICAgIDxTbGlkZUluZm9XcmFwcGVyPlxuICAgICAgICAgIDxJbmZvV3JhcHBlcj5cbiAgICAgICAgICAgIDxoMz57Y3VycmVudFNsaWRlLnRpdGxlfTwvaDM+XG4gICAgICAgICAgICA8c3BhbiBpZD1cImN1cnJlbnRNb3ZpZURlc2NyaXB0aW9uXCI+e2N1cnJlbnRTbGlkZS5tZXRhRGVzY3JpcHRpb259PC9zcGFuPlxuICAgICAgICAgIDwvSW5mb1dyYXBwZXI+XG4gICAgICAgIDwvU2xpZGVJbmZvV3JhcHBlcj5cbiAgICAgIDwvU3R5bGVkU2FmZUxpbms+XG4gICAgICA8Q2Fyb3VzZWxDb250YWluZXI+XG4gICAgICAgIDxDYXJvdXNlbFxuICAgICAgICAgIGxlZnRCdXR0b249e1xuICAgICAgICAgICAgPFNsaWRlc2hvd0J1dHRvbiBhcmlhLWxhYmVsPVwiXCI+XG4gICAgICAgICAgICAgIDxDaGV2cm9uTGVmdCAvPlxuICAgICAgICAgICAgPC9TbGlkZXNob3dCdXR0b24+XG4gICAgICAgICAgfVxuICAgICAgICAgIHJpZ2h0QnV0dG9uPXtcbiAgICAgICAgICAgIDxTbGlkZXNob3dCdXR0b24gYXJpYS1sYWJlbD1cIlwiPlxuICAgICAgICAgICAgICA8Q2hldnJvblJpZ2h0IC8+XG4gICAgICAgICAgICA8L1NsaWRlc2hvd0J1dHRvbj5cbiAgICAgICAgICB9XG4gICAgICAgICAgaXRlbXM9e3NsaWRlc2hvdy5tYXAoKG1vdmllKSA9PiAoXG4gICAgICAgICAgICA8RmlsbUNhcmRcbiAgICAgICAgICAgICAga2V5PXttb3ZpZS5pZH1cbiAgICAgICAgICAgICAgY3VycmVudD17bW92aWUuaWQgPT09IGN1cnJlbnRTbGlkZS5pZH1cbiAgICAgICAgICAgICAgbW92aWU9e21vdmllfVxuICAgICAgICAgICAgICBzZXRDdXJyZW50U2xpZGU9e3NldEN1cnJlbnRTbGlkZX1cbiAgICAgICAgICAgIC8+XG4gICAgICAgICAgKSl9XG4gICAgICAgIC8+XG4gICAgICA8L0Nhcm91c2VsQ29udGFpbmVyPlxuICAgIDwvc2VjdGlvbj5cbiAgKTtcbn07XG5cbmludGVyZmFjZSBGaWxtQ2FyZFByb3BzIHtcbiAgc2V0Q3VycmVudFNsaWRlOiAobW92aWU6IE1vdmllVHlwZSkgPT4gdm9pZDtcbiAgbW92aWU6IE1vdmllVHlwZTtcbiAgY3VycmVudDogYm9vbGVhbjtcbn1cblxuY29uc3QgRmlsbUNhcmQgPSAoeyBzZXRDdXJyZW50U2xpZGUsIG1vdmllLCBjdXJyZW50IH06IEZpbG1DYXJkUHJvcHMpID0+IHtcbiAgY29uc3QgW2hvdmVyQ2FsbGJhY2ssIHNldEhvdmVyQ2FsbGJhY2tdID0gdXNlU3RhdGU8UmV0dXJuVHlwZTx0eXBlb2Ygc2V0VGltZW91dD4gfCB1bmRlZmluZWQ+KHVuZGVmaW5lZCk7XG5cbiAgY29uc3Qgb25Ib3ZlciA9IHVzZUNhbGxiYWNrKCgpID0+IHtcbiAgICBjb25zdCB0aW1lb3V0ID0gc2V0VGltZW91dCgoKSA9PiBzZXRDdXJyZW50U2xpZGUobW92aWUpLCA1MDApO1xuICAgIHNldEhvdmVyQ2FsbGJhY2sodGltZW91dCk7XG4gIH0sIFttb3ZpZSwgc2V0Q3VycmVudFNsaWRlXSk7XG5cbiAgcmV0dXJuIChcbiAgICA8U3R5bGVkRmlsbUNvbnRlbnRDYXJkXG4gICAgICBvbk1vdXNlRW50ZXI9e29uSG92ZXJ9XG4gICAgICBvbk1vdXNlTGVhdmU9eygpID0+IHtcbiAgICAgICAgaWYgKGhvdmVyQ2FsbGJhY2spIHtcbiAgICAgICAgICBjbGVhclRpbWVvdXQoaG92ZXJDYWxsYmFjayk7XG4gICAgICAgICAgc2V0SG92ZXJDYWxsYmFjayh1bmRlZmluZWQpO1xuICAgICAgICB9XG4gICAgICB9fVxuICAgICAgb25Gb2N1cz17KCkgPT4gc2V0Q3VycmVudFNsaWRlKG1vdmllKX1cbiAgICAgIGN1cnJlbnQ9e2N1cnJlbnR9XG4gICAgICBhcmlhLWRlc2NyaWJlZGJ5PXsnY3VycmVudE1vdmllRGVzY3JpcHRpb24nfVxuICAgICAga2V5PXttb3ZpZS5pZH1cbiAgICAgIG1vdmllPXttb3ZpZX1cbiAgICAgIHJlc291cmNlVHlwZXM9e1tdfVxuICAgIC8+XG4gICk7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBGaWxtU2xpZGVzaG93O1xuIl19 */",
86
45
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
87
46
  });
88
47
  var InfoWrapper = /*#__PURE__*/_styled("div", {
89
48
  target: "essc37o4",
90
49
  label: "InfoWrapper"
91
- })("padding:", spacing.normal, ";border-radius:", misc.borderRadius, ";border:0.5px solid ", colors.brand.primary, ";background-color:rgba(11, 29, 45, 0.8);h3{margin:0px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FilmSlideshow.tsx"],"names":[],"mappings":"AAkG8B","file":"FilmSlideshow.tsx","sourcesContent":["/**\n * Copyright (c) 2023-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 { useCallback, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { Carousel, CarouselAutosize } from '@ndla/carousel';\nimport { breakpoints, colors, misc, mq, spacing, spacingUnit } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\nimport { IconButtonV2 } from '@ndla/button';\nimport { ChevronLeft, ChevronRight } from '@ndla/icons/common';\nimport FilmContentCard from './FilmContentCard';\nimport { MovieType } from './types';\n\nexport const slideshowBreakpoints: {\n  until?: keyof typeof breakpoints;\n  columnsPrSlide: number;\n  distanceBetweenItems: number;\n  arrowOffset: number;\n  margin?: number;\n  maxColumnWidth?: number;\n}[] = [\n  {\n    until: 'mobileWide',\n    columnsPrSlide: 2,\n    distanceBetweenItems: spacingUnit / 2,\n    margin: spacingUnit,\n    arrowOffset: 13,\n  },\n  {\n    until: 'tabletWide',\n    columnsPrSlide: 3,\n    distanceBetweenItems: spacingUnit / 2,\n    margin: spacingUnit,\n    arrowOffset: 13,\n  },\n  {\n    until: 'desktop',\n    columnsPrSlide: 3,\n    distanceBetweenItems: spacingUnit,\n    margin: spacingUnit * 2,\n    arrowOffset: 0,\n  },\n  {\n    until: 'wide',\n    columnsPrSlide: 3,\n    distanceBetweenItems: spacingUnit,\n    margin: spacingUnit * 2,\n    arrowOffset: 0,\n  },\n  {\n    until: 'ultraWide',\n    columnsPrSlide: 3,\n    distanceBetweenItems: spacingUnit,\n    margin: spacingUnit * 3.5,\n    arrowOffset: 0,\n  },\n  {\n    columnsPrSlide: 3,\n    distanceBetweenItems: spacingUnit,\n    margin: spacingUnit * 3.5,\n    arrowOffset: 0,\n  },\n];\n\ninterface Props {\n  slideshow: MovieType[];\n}\n\nconst SlideInfoWrapper = styled.div`\n  position: absolute;\n  color: ${colors.white};\n  max-width: 40%;\n  min-width: 40%;\n  top: 40%;\n  right: 5%;\n  ${mq.range({ until: breakpoints.desktop })} {\n    top: 30%;\n    max-width: 60%;\n    min-width: 60%;\n  }\n  ${mq.range({ until: breakpoints.tablet })} {\n    max-width: 90%;\n    min-width: 90%;\n    left: 5%;\n  }\n`;\n\nconst StyledSafeLink = styled(SafeLink)`\n  position: relative;\n  display: block;\n  box-shadow: none;\n`;\n\nconst InfoWrapper = styled.div`\n  padding: ${spacing.normal};\n  border-radius: ${misc.borderRadius};\n  border: 0.5px solid ${colors.brand.primary};\n  background-color: rgba(11, 29, 45, 0.8);\n  h3 {\n    margin: 0px;\n  }\n`;\n\nconst StyledImg = styled.img`\n  max-height: 600px;\n  object-position: top;\n  width: 100%;\n  aspect-ratio: 16/9;\n  ${mq.range({ until: breakpoints.tablet })} {\n    min-height: 440px;\n    max-height: 440px;\n  }\n  object-fit: cover;\n`;\n\nconst CarouselContainer = styled.div`\n  margin-top: -50px;\n  ${mq.range({ from: breakpoints.tablet })} {\n    margin-top: -70px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    margin-top: -150px;\n  }\n`;\n\ninterface StyledFilmContentCardProps {\n  current?: boolean;\n}\n\nconst SlideshowButton = styled(IconButtonV2)`\n  margin-top: ${spacing.normal};\n`;\n\nconst shouldForwardProp = (p: string) => p !== 'current';\n\nconst StyledFilmContentCard = styled(FilmContentCard, { shouldForwardProp })<StyledFilmContentCardProps>`\n  margin-bottom: 2%;\n  transform: ${(p) => (p.current ? 'translateY(0%)' : 'translateY(10%)')};\n  transition: all 200ms;\n`;\n\nconst FilmSlideshow = ({ slideshow }: Props) => {\n  const [currentSlide, setCurrentSlide] = useState(slideshow[0]);\n\n  return (\n    <CarouselAutosize breakpoints={slideshowBreakpoints} itemsLength={slideshow.length}>\n      {(autoSizedProps) => (\n        <section>\n          <StyledSafeLink to={currentSlide.path} tabIndex={-1} aria-hidden>\n            <StyledImg src={currentSlide.metaImage?.url ?? ''} alt={currentSlide.metaImage?.alt ?? ''} />\n            <SlideInfoWrapper>\n              <InfoWrapper>\n                <h3>{currentSlide.title}</h3>\n                <span id=\"currentMovieDescription\">{currentSlide.metaDescription}</span>\n              </InfoWrapper>\n            </SlideInfoWrapper>\n          </StyledSafeLink>\n          <CarouselContainer>\n            <Carousel\n              leftButton={\n                <SlideshowButton aria-label={''}>\n                  <ChevronLeft />\n                </SlideshowButton>\n              }\n              rightButton={\n                <SlideshowButton aria-label={''}>\n                  <ChevronRight />\n                </SlideshowButton>\n              }\n              items={slideshow.map((movie) => (\n                <FilmCard\n                  key={movie.id}\n                  current={movie.id === currentSlide.id}\n                  movie={movie}\n                  columnWidth={autoSizedProps.columnWidth}\n                  setCurrentSlide={() => setCurrentSlide(movie)}\n                />\n              ))}\n              {...autoSizedProps}\n            />\n          </CarouselContainer>\n        </section>\n      )}\n    </CarouselAutosize>\n  );\n};\n\ninterface FilmCardProps {\n  setCurrentSlide: () => void;\n  movie: MovieType;\n  current: boolean;\n  columnWidth: number;\n}\n\nconst FilmCard = ({ setCurrentSlide, movie, current, columnWidth }: FilmCardProps) => {\n  const [hoverCallback, setHoverCallback] = useState<ReturnType<typeof setTimeout> | undefined>(undefined);\n\n  const onHover = useCallback(() => {\n    const timeout = setTimeout(() => setCurrentSlide(), 500);\n    setHoverCallback(timeout);\n  }, [setCurrentSlide]);\n\n  return (\n    <StyledFilmContentCard\n      onMouseEnter={onHover}\n      onMouseLeave={() => {\n        if (hoverCallback) {\n          clearTimeout(hoverCallback);\n          setHoverCallback(undefined);\n        }\n      }}\n      onFocus={() => setCurrentSlide()}\n      current={current}\n      aria-describedby={'currentMovieDescription'}\n      key={movie.id}\n      movie={movie}\n      columnWidth={columnWidth}\n      resourceTypes={[]}\n    />\n  );\n};\n\nexport default FilmSlideshow;\n"]} */"));
92
- var StyledImg = /*#__PURE__*/_styled("img", {
50
+ })("padding:", spacing.normal, ";border-radius:", misc.borderRadius, ";border:0.5px solid ", colors.brand.primary, ";background-color:rgba(11, 29, 45, 0.8);h3{margin:0px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkZpbG1TbGlkZXNob3cudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWdEOEIiLCJmaWxlIjoiRmlsbVNsaWRlc2hvdy50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAyMy1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCB7IHVzZUNhbGxiYWNrLCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IENhcm91c2VsIH0gZnJvbSAnQG5kbGEvY2Fyb3VzZWwnO1xuaW1wb3J0IHsgYnJlYWtwb2ludHMsIGNvbG9ycywgbWlzYywgbXEsIHNwYWNpbmcgfSBmcm9tICdAbmRsYS9jb3JlJztcbmltcG9ydCBTYWZlTGluayBmcm9tICdAbmRsYS9zYWZlbGluayc7XG5pbXBvcnQgeyBJY29uQnV0dG9uVjIgfSBmcm9tICdAbmRsYS9idXR0b24nO1xuaW1wb3J0IHsgQ2hldnJvbkxlZnQsIENoZXZyb25SaWdodCB9IGZyb20gJ0BuZGxhL2ljb25zL2NvbW1vbic7XG5pbXBvcnQgRmlsbUNvbnRlbnRDYXJkIGZyb20gJy4vRmlsbUNvbnRlbnRDYXJkJztcbmltcG9ydCB7IE1vdmllVHlwZSB9IGZyb20gJy4vdHlwZXMnO1xuaW1wb3J0IEltYWdlIGZyb20gJy4uL0ltYWdlJztcblxuaW50ZXJmYWNlIFByb3BzIHtcbiAgc2xpZGVzaG93OiBNb3ZpZVR5cGVbXTtcbn1cblxuY29uc3QgU2xpZGVJbmZvV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgY29sb3I6ICR7Y29sb3JzLndoaXRlfTtcbiAgbWF4LXdpZHRoOiA0MCU7XG4gIG1pbi13aWR0aDogNDAlO1xuICB0b3A6IDQwJTtcbiAgcmlnaHQ6IDUlO1xuICAke21xLnJhbmdlKHsgdW50aWw6IGJyZWFrcG9pbnRzLmRlc2t0b3AgfSl9IHtcbiAgICB0b3A6IDMwJTtcbiAgICBtYXgtd2lkdGg6IDYwJTtcbiAgICBtaW4td2lkdGg6IDYwJTtcbiAgfVxuICAke21xLnJhbmdlKHsgdW50aWw6IGJyZWFrcG9pbnRzLnRhYmxldCB9KX0ge1xuICAgIG1heC13aWR0aDogOTAlO1xuICAgIG1pbi13aWR0aDogOTAlO1xuICAgIGxlZnQ6IDUlO1xuICB9XG5gO1xuXG5jb25zdCBTdHlsZWRTYWZlTGluayA9IHN0eWxlZChTYWZlTGluaylgXG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgZGlzcGxheTogYmxvY2s7XG4gIGJveC1zaGFkb3c6IG5vbmU7XG5gO1xuXG5jb25zdCBJbmZvV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIHBhZGRpbmc6ICR7c3BhY2luZy5ub3JtYWx9O1xuICBib3JkZXItcmFkaXVzOiAke21pc2MuYm9yZGVyUmFkaXVzfTtcbiAgYm9yZGVyOiAwLjVweCBzb2xpZCAke2NvbG9ycy5icmFuZC5wcmltYXJ5fTtcbiAgYmFja2dyb3VuZC1jb2xvcjogcmdiYSgxMSwgMjksIDQ1LCAwLjgpO1xuICBoMyB7XG4gICAgbWFyZ2luOiAwcHg7XG4gIH1cbmA7XG5cbmNvbnN0IFN0eWxlZEltZyA9IHN0eWxlZChJbWFnZSlgXG4gIG1heC1oZWlnaHQ6IDYwMHB4O1xuICBtaW4taGVpZ2h0OiA2MDBweDtcbiAgb2JqZWN0LXBvc2l0aW9uOiB0b3A7XG4gIHdpZHRoOiAxMDAlO1xuICBhc3BlY3QtcmF0aW86IDE2Lzk7XG4gICR7bXEucmFuZ2UoeyB1bnRpbDogYnJlYWtwb2ludHMudGFibGV0IH0pfSB7XG4gICAgbWluLWhlaWdodDogNDQwcHg7XG4gICAgbWF4LWhlaWdodDogNDQwcHg7XG4gIH1cbiAgb2JqZWN0LWZpdDogY292ZXI7XG5gO1xuXG5jb25zdCBDYXJvdXNlbENvbnRhaW5lciA9IHN0eWxlZC5kaXZgXG4gIG1hcmdpbi10b3A6IC01MHB4O1xuICAke21xLnJhbmdlKHsgZnJvbTogYnJlYWtwb2ludHMudGFibGV0IH0pfSB7XG4gICAgbWFyZ2luLXRvcDogLTcwcHg7XG4gIH1cbiAgJHttcS5yYW5nZSh7IGZyb206IGJyZWFrcG9pbnRzLmRlc2t0b3AgfSl9IHtcbiAgICBtYXJnaW4tdG9wOiAtMTYwcHg7XG4gIH1cbmA7XG5cbmludGVyZmFjZSBTdHlsZWRGaWxtQ29udGVudENhcmRQcm9wcyB7XG4gIGN1cnJlbnQ/OiBib29sZWFuO1xufVxuXG5jb25zdCBTbGlkZXNob3dCdXR0b24gPSBzdHlsZWQoSWNvbkJ1dHRvblYyKWBcbiAgbWFyZ2luLXRvcDogJHtzcGFjaW5nLm5vcm1hbH07XG5gO1xuXG5jb25zdCBzaG91bGRGb3J3YXJkUHJvcCA9IChwOiBzdHJpbmcpID0+IHAgIT09ICdjdXJyZW50JztcblxuY29uc3QgU3R5bGVkRmlsbUNvbnRlbnRDYXJkID0gc3R5bGVkKEZpbG1Db250ZW50Q2FyZCwgeyBzaG91bGRGb3J3YXJkUHJvcCB9KTxTdHlsZWRGaWxtQ29udGVudENhcmRQcm9wcz5gXG4gIG1hcmdpbi1ib3R0b206IDIlO1xuICB0cmFuc2Zvcm06ICR7KHApID0+IChwLmN1cnJlbnQgPyAndHJhbnNsYXRlWSgwJSknIDogJ3RyYW5zbGF0ZVkoMTAlKScpfTtcbiAgdHJhbnNpdGlvbjogYWxsIDIwMG1zO1xuYDtcblxuY29uc3QgRmlsbVNsaWRlc2hvdyA9ICh7IHNsaWRlc2hvdyB9OiBQcm9wcykgPT4ge1xuICBjb25zdCBbY3VycmVudFNsaWRlLCBzZXRDdXJyZW50U2xpZGVdID0gdXNlU3RhdGUoc2xpZGVzaG93WzBdKTtcblxuICByZXR1cm4gKFxuICAgIDxzZWN0aW9uPlxuICAgICAgPFN0eWxlZFNhZmVMaW5rIHRvPXtjdXJyZW50U2xpZGUucGF0aH0gdGFiSW5kZXg9ey0xfSBhcmlhLWhpZGRlbj5cbiAgICAgICAgPFN0eWxlZEltZ1xuICAgICAgICAgIHNyYz17Y3VycmVudFNsaWRlLm1ldGFJbWFnZT8udXJsID8/ICcnfVxuICAgICAgICAgIHNpemVzPVwiKG1pbi13aWR0aDogMTE0MHB4KSAxMTQwcHgsIChtaW4td2lkdGg6IDcyMHB4KSAxMDB2dywgMTAwdndcIlxuICAgICAgICAgIGFsdD1cIlwiXG4gICAgICAgIC8+XG4gICAgICAgIDxTbGlkZUluZm9XcmFwcGVyPlxuICAgICAgICAgIDxJbmZvV3JhcHBlcj5cbiAgICAgICAgICAgIDxoMz57Y3VycmVudFNsaWRlLnRpdGxlfTwvaDM+XG4gICAgICAgICAgICA8c3BhbiBpZD1cImN1cnJlbnRNb3ZpZURlc2NyaXB0aW9uXCI+e2N1cnJlbnRTbGlkZS5tZXRhRGVzY3JpcHRpb259PC9zcGFuPlxuICAgICAgICAgIDwvSW5mb1dyYXBwZXI+XG4gICAgICAgIDwvU2xpZGVJbmZvV3JhcHBlcj5cbiAgICAgIDwvU3R5bGVkU2FmZUxpbms+XG4gICAgICA8Q2Fyb3VzZWxDb250YWluZXI+XG4gICAgICAgIDxDYXJvdXNlbFxuICAgICAgICAgIGxlZnRCdXR0b249e1xuICAgICAgICAgICAgPFNsaWRlc2hvd0J1dHRvbiBhcmlhLWxhYmVsPVwiXCI+XG4gICAgICAgICAgICAgIDxDaGV2cm9uTGVmdCAvPlxuICAgICAgICAgICAgPC9TbGlkZXNob3dCdXR0b24+XG4gICAgICAgICAgfVxuICAgICAgICAgIHJpZ2h0QnV0dG9uPXtcbiAgICAgICAgICAgIDxTbGlkZXNob3dCdXR0b24gYXJpYS1sYWJlbD1cIlwiPlxuICAgICAgICAgICAgICA8Q2hldnJvblJpZ2h0IC8+XG4gICAgICAgICAgICA8L1NsaWRlc2hvd0J1dHRvbj5cbiAgICAgICAgICB9XG4gICAgICAgICAgaXRlbXM9e3NsaWRlc2hvdy5tYXAoKG1vdmllKSA9PiAoXG4gICAgICAgICAgICA8RmlsbUNhcmRcbiAgICAgICAgICAgICAga2V5PXttb3ZpZS5pZH1cbiAgICAgICAgICAgICAgY3VycmVudD17bW92aWUuaWQgPT09IGN1cnJlbnRTbGlkZS5pZH1cbiAgICAgICAgICAgICAgbW92aWU9e21vdmllfVxuICAgICAgICAgICAgICBzZXRDdXJyZW50U2xpZGU9e3NldEN1cnJlbnRTbGlkZX1cbiAgICAgICAgICAgIC8+XG4gICAgICAgICAgKSl9XG4gICAgICAgIC8+XG4gICAgICA8L0Nhcm91c2VsQ29udGFpbmVyPlxuICAgIDwvc2VjdGlvbj5cbiAgKTtcbn07XG5cbmludGVyZmFjZSBGaWxtQ2FyZFByb3BzIHtcbiAgc2V0Q3VycmVudFNsaWRlOiAobW92aWU6IE1vdmllVHlwZSkgPT4gdm9pZDtcbiAgbW92aWU6IE1vdmllVHlwZTtcbiAgY3VycmVudDogYm9vbGVhbjtcbn1cblxuY29uc3QgRmlsbUNhcmQgPSAoeyBzZXRDdXJyZW50U2xpZGUsIG1vdmllLCBjdXJyZW50IH06IEZpbG1DYXJkUHJvcHMpID0+IHtcbiAgY29uc3QgW2hvdmVyQ2FsbGJhY2ssIHNldEhvdmVyQ2FsbGJhY2tdID0gdXNlU3RhdGU8UmV0dXJuVHlwZTx0eXBlb2Ygc2V0VGltZW91dD4gfCB1bmRlZmluZWQ+KHVuZGVmaW5lZCk7XG5cbiAgY29uc3Qgb25Ib3ZlciA9IHVzZUNhbGxiYWNrKCgpID0+IHtcbiAgICBjb25zdCB0aW1lb3V0ID0gc2V0VGltZW91dCgoKSA9PiBzZXRDdXJyZW50U2xpZGUobW92aWUpLCA1MDApO1xuICAgIHNldEhvdmVyQ2FsbGJhY2sodGltZW91dCk7XG4gIH0sIFttb3ZpZSwgc2V0Q3VycmVudFNsaWRlXSk7XG5cbiAgcmV0dXJuIChcbiAgICA8U3R5bGVkRmlsbUNvbnRlbnRDYXJkXG4gICAgICBvbk1vdXNlRW50ZXI9e29uSG92ZXJ9XG4gICAgICBvbk1vdXNlTGVhdmU9eygpID0+IHtcbiAgICAgICAgaWYgKGhvdmVyQ2FsbGJhY2spIHtcbiAgICAgICAgICBjbGVhclRpbWVvdXQoaG92ZXJDYWxsYmFjayk7XG4gICAgICAgICAgc2V0SG92ZXJDYWxsYmFjayh1bmRlZmluZWQpO1xuICAgICAgICB9XG4gICAgICB9fVxuICAgICAgb25Gb2N1cz17KCkgPT4gc2V0Q3VycmVudFNsaWRlKG1vdmllKX1cbiAgICAgIGN1cnJlbnQ9e2N1cnJlbnR9XG4gICAgICBhcmlhLWRlc2NyaWJlZGJ5PXsnY3VycmVudE1vdmllRGVzY3JpcHRpb24nfVxuICAgICAga2V5PXttb3ZpZS5pZH1cbiAgICAgIG1vdmllPXttb3ZpZX1cbiAgICAgIHJlc291cmNlVHlwZXM9e1tdfVxuICAgIC8+XG4gICk7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBGaWxtU2xpZGVzaG93O1xuIl19 */"));
51
+ var StyledImg = /*#__PURE__*/_styled(Image, {
93
52
  target: "essc37o3",
94
53
  label: "StyledImg"
95
- })("max-height:600px;object-position:top;width:100%;aspect-ratio:16/9;", mq.range({
54
+ })("max-height:600px;min-height:600px;object-position:top;width:100%;aspect-ratio:16/9;", mq.range({
96
55
  until: breakpoints.tablet
97
- }), "{min-height:440px;max-height:440px;}object-fit:cover;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FilmSlideshow.tsx"],"names":[],"mappings":"AA4G4B","file":"FilmSlideshow.tsx","sourcesContent":["/**\n * Copyright (c) 2023-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 { useCallback, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { Carousel, CarouselAutosize } from '@ndla/carousel';\nimport { breakpoints, colors, misc, mq, spacing, spacingUnit } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\nimport { IconButtonV2 } from '@ndla/button';\nimport { ChevronLeft, ChevronRight } from '@ndla/icons/common';\nimport FilmContentCard from './FilmContentCard';\nimport { MovieType } from './types';\n\nexport const slideshowBreakpoints: {\n  until?: keyof typeof breakpoints;\n  columnsPrSlide: number;\n  distanceBetweenItems: number;\n  arrowOffset: number;\n  margin?: number;\n  maxColumnWidth?: number;\n}[] = [\n  {\n    until: 'mobileWide',\n    columnsPrSlide: 2,\n    distanceBetweenItems: spacingUnit / 2,\n    margin: spacingUnit,\n    arrowOffset: 13,\n  },\n  {\n    until: 'tabletWide',\n    columnsPrSlide: 3,\n    distanceBetweenItems: spacingUnit / 2,\n    margin: spacingUnit,\n    arrowOffset: 13,\n  },\n  {\n    until: 'desktop',\n    columnsPrSlide: 3,\n    distanceBetweenItems: spacingUnit,\n    margin: spacingUnit * 2,\n    arrowOffset: 0,\n  },\n  {\n    until: 'wide',\n    columnsPrSlide: 3,\n    distanceBetweenItems: spacingUnit,\n    margin: spacingUnit * 2,\n    arrowOffset: 0,\n  },\n  {\n    until: 'ultraWide',\n    columnsPrSlide: 3,\n    distanceBetweenItems: spacingUnit,\n    margin: spacingUnit * 3.5,\n    arrowOffset: 0,\n  },\n  {\n    columnsPrSlide: 3,\n    distanceBetweenItems: spacingUnit,\n    margin: spacingUnit * 3.5,\n    arrowOffset: 0,\n  },\n];\n\ninterface Props {\n  slideshow: MovieType[];\n}\n\nconst SlideInfoWrapper = styled.div`\n  position: absolute;\n  color: ${colors.white};\n  max-width: 40%;\n  min-width: 40%;\n  top: 40%;\n  right: 5%;\n  ${mq.range({ until: breakpoints.desktop })} {\n    top: 30%;\n    max-width: 60%;\n    min-width: 60%;\n  }\n  ${mq.range({ until: breakpoints.tablet })} {\n    max-width: 90%;\n    min-width: 90%;\n    left: 5%;\n  }\n`;\n\nconst StyledSafeLink = styled(SafeLink)`\n  position: relative;\n  display: block;\n  box-shadow: none;\n`;\n\nconst InfoWrapper = styled.div`\n  padding: ${spacing.normal};\n  border-radius: ${misc.borderRadius};\n  border: 0.5px solid ${colors.brand.primary};\n  background-color: rgba(11, 29, 45, 0.8);\n  h3 {\n    margin: 0px;\n  }\n`;\n\nconst StyledImg = styled.img`\n  max-height: 600px;\n  object-position: top;\n  width: 100%;\n  aspect-ratio: 16/9;\n  ${mq.range({ until: breakpoints.tablet })} {\n    min-height: 440px;\n    max-height: 440px;\n  }\n  object-fit: cover;\n`;\n\nconst CarouselContainer = styled.div`\n  margin-top: -50px;\n  ${mq.range({ from: breakpoints.tablet })} {\n    margin-top: -70px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    margin-top: -150px;\n  }\n`;\n\ninterface StyledFilmContentCardProps {\n  current?: boolean;\n}\n\nconst SlideshowButton = styled(IconButtonV2)`\n  margin-top: ${spacing.normal};\n`;\n\nconst shouldForwardProp = (p: string) => p !== 'current';\n\nconst StyledFilmContentCard = styled(FilmContentCard, { shouldForwardProp })<StyledFilmContentCardProps>`\n  margin-bottom: 2%;\n  transform: ${(p) => (p.current ? 'translateY(0%)' : 'translateY(10%)')};\n  transition: all 200ms;\n`;\n\nconst FilmSlideshow = ({ slideshow }: Props) => {\n  const [currentSlide, setCurrentSlide] = useState(slideshow[0]);\n\n  return (\n    <CarouselAutosize breakpoints={slideshowBreakpoints} itemsLength={slideshow.length}>\n      {(autoSizedProps) => (\n        <section>\n          <StyledSafeLink to={currentSlide.path} tabIndex={-1} aria-hidden>\n            <StyledImg src={currentSlide.metaImage?.url ?? ''} alt={currentSlide.metaImage?.alt ?? ''} />\n            <SlideInfoWrapper>\n              <InfoWrapper>\n                <h3>{currentSlide.title}</h3>\n                <span id=\"currentMovieDescription\">{currentSlide.metaDescription}</span>\n              </InfoWrapper>\n            </SlideInfoWrapper>\n          </StyledSafeLink>\n          <CarouselContainer>\n            <Carousel\n              leftButton={\n                <SlideshowButton aria-label={''}>\n                  <ChevronLeft />\n                </SlideshowButton>\n              }\n              rightButton={\n                <SlideshowButton aria-label={''}>\n                  <ChevronRight />\n                </SlideshowButton>\n              }\n              items={slideshow.map((movie) => (\n                <FilmCard\n                  key={movie.id}\n                  current={movie.id === currentSlide.id}\n                  movie={movie}\n                  columnWidth={autoSizedProps.columnWidth}\n                  setCurrentSlide={() => setCurrentSlide(movie)}\n                />\n              ))}\n              {...autoSizedProps}\n            />\n          </CarouselContainer>\n        </section>\n      )}\n    </CarouselAutosize>\n  );\n};\n\ninterface FilmCardProps {\n  setCurrentSlide: () => void;\n  movie: MovieType;\n  current: boolean;\n  columnWidth: number;\n}\n\nconst FilmCard = ({ setCurrentSlide, movie, current, columnWidth }: FilmCardProps) => {\n  const [hoverCallback, setHoverCallback] = useState<ReturnType<typeof setTimeout> | undefined>(undefined);\n\n  const onHover = useCallback(() => {\n    const timeout = setTimeout(() => setCurrentSlide(), 500);\n    setHoverCallback(timeout);\n  }, [setCurrentSlide]);\n\n  return (\n    <StyledFilmContentCard\n      onMouseEnter={onHover}\n      onMouseLeave={() => {\n        if (hoverCallback) {\n          clearTimeout(hoverCallback);\n          setHoverCallback(undefined);\n        }\n      }}\n      onFocus={() => setCurrentSlide()}\n      current={current}\n      aria-describedby={'currentMovieDescription'}\n      key={movie.id}\n      movie={movie}\n      columnWidth={columnWidth}\n      resourceTypes={[]}\n    />\n  );\n};\n\nexport default FilmSlideshow;\n"]} */"));
56
+ }), "{min-height:440px;max-height:440px;}object-fit:cover;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkZpbG1TbGlkZXNob3cudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTBEK0IiLCJmaWxlIjoiRmlsbVNsaWRlc2hvdy50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAyMy1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCB7IHVzZUNhbGxiYWNrLCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IENhcm91c2VsIH0gZnJvbSAnQG5kbGEvY2Fyb3VzZWwnO1xuaW1wb3J0IHsgYnJlYWtwb2ludHMsIGNvbG9ycywgbWlzYywgbXEsIHNwYWNpbmcgfSBmcm9tICdAbmRsYS9jb3JlJztcbmltcG9ydCBTYWZlTGluayBmcm9tICdAbmRsYS9zYWZlbGluayc7XG5pbXBvcnQgeyBJY29uQnV0dG9uVjIgfSBmcm9tICdAbmRsYS9idXR0b24nO1xuaW1wb3J0IHsgQ2hldnJvbkxlZnQsIENoZXZyb25SaWdodCB9IGZyb20gJ0BuZGxhL2ljb25zL2NvbW1vbic7XG5pbXBvcnQgRmlsbUNvbnRlbnRDYXJkIGZyb20gJy4vRmlsbUNvbnRlbnRDYXJkJztcbmltcG9ydCB7IE1vdmllVHlwZSB9IGZyb20gJy4vdHlwZXMnO1xuaW1wb3J0IEltYWdlIGZyb20gJy4uL0ltYWdlJztcblxuaW50ZXJmYWNlIFByb3BzIHtcbiAgc2xpZGVzaG93OiBNb3ZpZVR5cGVbXTtcbn1cblxuY29uc3QgU2xpZGVJbmZvV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgY29sb3I6ICR7Y29sb3JzLndoaXRlfTtcbiAgbWF4LXdpZHRoOiA0MCU7XG4gIG1pbi13aWR0aDogNDAlO1xuICB0b3A6IDQwJTtcbiAgcmlnaHQ6IDUlO1xuICAke21xLnJhbmdlKHsgdW50aWw6IGJyZWFrcG9pbnRzLmRlc2t0b3AgfSl9IHtcbiAgICB0b3A6IDMwJTtcbiAgICBtYXgtd2lkdGg6IDYwJTtcbiAgICBtaW4td2lkdGg6IDYwJTtcbiAgfVxuICAke21xLnJhbmdlKHsgdW50aWw6IGJyZWFrcG9pbnRzLnRhYmxldCB9KX0ge1xuICAgIG1heC13aWR0aDogOTAlO1xuICAgIG1pbi13aWR0aDogOTAlO1xuICAgIGxlZnQ6IDUlO1xuICB9XG5gO1xuXG5jb25zdCBTdHlsZWRTYWZlTGluayA9IHN0eWxlZChTYWZlTGluaylgXG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgZGlzcGxheTogYmxvY2s7XG4gIGJveC1zaGFkb3c6IG5vbmU7XG5gO1xuXG5jb25zdCBJbmZvV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIHBhZGRpbmc6ICR7c3BhY2luZy5ub3JtYWx9O1xuICBib3JkZXItcmFkaXVzOiAke21pc2MuYm9yZGVyUmFkaXVzfTtcbiAgYm9yZGVyOiAwLjVweCBzb2xpZCAke2NvbG9ycy5icmFuZC5wcmltYXJ5fTtcbiAgYmFja2dyb3VuZC1jb2xvcjogcmdiYSgxMSwgMjksIDQ1LCAwLjgpO1xuICBoMyB7XG4gICAgbWFyZ2luOiAwcHg7XG4gIH1cbmA7XG5cbmNvbnN0IFN0eWxlZEltZyA9IHN0eWxlZChJbWFnZSlgXG4gIG1heC1oZWlnaHQ6IDYwMHB4O1xuICBtaW4taGVpZ2h0OiA2MDBweDtcbiAgb2JqZWN0LXBvc2l0aW9uOiB0b3A7XG4gIHdpZHRoOiAxMDAlO1xuICBhc3BlY3QtcmF0aW86IDE2Lzk7XG4gICR7bXEucmFuZ2UoeyB1bnRpbDogYnJlYWtwb2ludHMudGFibGV0IH0pfSB7XG4gICAgbWluLWhlaWdodDogNDQwcHg7XG4gICAgbWF4LWhlaWdodDogNDQwcHg7XG4gIH1cbiAgb2JqZWN0LWZpdDogY292ZXI7XG5gO1xuXG5jb25zdCBDYXJvdXNlbENvbnRhaW5lciA9IHN0eWxlZC5kaXZgXG4gIG1hcmdpbi10b3A6IC01MHB4O1xuICAke21xLnJhbmdlKHsgZnJvbTogYnJlYWtwb2ludHMudGFibGV0IH0pfSB7XG4gICAgbWFyZ2luLXRvcDogLTcwcHg7XG4gIH1cbiAgJHttcS5yYW5nZSh7IGZyb206IGJyZWFrcG9pbnRzLmRlc2t0b3AgfSl9IHtcbiAgICBtYXJnaW4tdG9wOiAtMTYwcHg7XG4gIH1cbmA7XG5cbmludGVyZmFjZSBTdHlsZWRGaWxtQ29udGVudENhcmRQcm9wcyB7XG4gIGN1cnJlbnQ/OiBib29sZWFuO1xufVxuXG5jb25zdCBTbGlkZXNob3dCdXR0b24gPSBzdHlsZWQoSWNvbkJ1dHRvblYyKWBcbiAgbWFyZ2luLXRvcDogJHtzcGFjaW5nLm5vcm1hbH07XG5gO1xuXG5jb25zdCBzaG91bGRGb3J3YXJkUHJvcCA9IChwOiBzdHJpbmcpID0+IHAgIT09ICdjdXJyZW50JztcblxuY29uc3QgU3R5bGVkRmlsbUNvbnRlbnRDYXJkID0gc3R5bGVkKEZpbG1Db250ZW50Q2FyZCwgeyBzaG91bGRGb3J3YXJkUHJvcCB9KTxTdHlsZWRGaWxtQ29udGVudENhcmRQcm9wcz5gXG4gIG1hcmdpbi1ib3R0b206IDIlO1xuICB0cmFuc2Zvcm06ICR7KHApID0+IChwLmN1cnJlbnQgPyAndHJhbnNsYXRlWSgwJSknIDogJ3RyYW5zbGF0ZVkoMTAlKScpfTtcbiAgdHJhbnNpdGlvbjogYWxsIDIwMG1zO1xuYDtcblxuY29uc3QgRmlsbVNsaWRlc2hvdyA9ICh7IHNsaWRlc2hvdyB9OiBQcm9wcykgPT4ge1xuICBjb25zdCBbY3VycmVudFNsaWRlLCBzZXRDdXJyZW50U2xpZGVdID0gdXNlU3RhdGUoc2xpZGVzaG93WzBdKTtcblxuICByZXR1cm4gKFxuICAgIDxzZWN0aW9uPlxuICAgICAgPFN0eWxlZFNhZmVMaW5rIHRvPXtjdXJyZW50U2xpZGUucGF0aH0gdGFiSW5kZXg9ey0xfSBhcmlhLWhpZGRlbj5cbiAgICAgICAgPFN0eWxlZEltZ1xuICAgICAgICAgIHNyYz17Y3VycmVudFNsaWRlLm1ldGFJbWFnZT8udXJsID8/ICcnfVxuICAgICAgICAgIHNpemVzPVwiKG1pbi13aWR0aDogMTE0MHB4KSAxMTQwcHgsIChtaW4td2lkdGg6IDcyMHB4KSAxMDB2dywgMTAwdndcIlxuICAgICAgICAgIGFsdD1cIlwiXG4gICAgICAgIC8+XG4gICAgICAgIDxTbGlkZUluZm9XcmFwcGVyPlxuICAgICAgICAgIDxJbmZvV3JhcHBlcj5cbiAgICAgICAgICAgIDxoMz57Y3VycmVudFNsaWRlLnRpdGxlfTwvaDM+XG4gICAgICAgICAgICA8c3BhbiBpZD1cImN1cnJlbnRNb3ZpZURlc2NyaXB0aW9uXCI+e2N1cnJlbnRTbGlkZS5tZXRhRGVzY3JpcHRpb259PC9zcGFuPlxuICAgICAgICAgIDwvSW5mb1dyYXBwZXI+XG4gICAgICAgIDwvU2xpZGVJbmZvV3JhcHBlcj5cbiAgICAgIDwvU3R5bGVkU2FmZUxpbms+XG4gICAgICA8Q2Fyb3VzZWxDb250YWluZXI+XG4gICAgICAgIDxDYXJvdXNlbFxuICAgICAgICAgIGxlZnRCdXR0b249e1xuICAgICAgICAgICAgPFNsaWRlc2hvd0J1dHRvbiBhcmlhLWxhYmVsPVwiXCI+XG4gICAgICAgICAgICAgIDxDaGV2cm9uTGVmdCAvPlxuICAgICAgICAgICAgPC9TbGlkZXNob3dCdXR0b24+XG4gICAgICAgICAgfVxuICAgICAgICAgIHJpZ2h0QnV0dG9uPXtcbiAgICAgICAgICAgIDxTbGlkZXNob3dCdXR0b24gYXJpYS1sYWJlbD1cIlwiPlxuICAgICAgICAgICAgICA8Q2hldnJvblJpZ2h0IC8+XG4gICAgICAgICAgICA8L1NsaWRlc2hvd0J1dHRvbj5cbiAgICAgICAgICB9XG4gICAgICAgICAgaXRlbXM9e3NsaWRlc2hvdy5tYXAoKG1vdmllKSA9PiAoXG4gICAgICAgICAgICA8RmlsbUNhcmRcbiAgICAgICAgICAgICAga2V5PXttb3ZpZS5pZH1cbiAgICAgICAgICAgICAgY3VycmVudD17bW92aWUuaWQgPT09IGN1cnJlbnRTbGlkZS5pZH1cbiAgICAgICAgICAgICAgbW92aWU9e21vdmllfVxuICAgICAgICAgICAgICBzZXRDdXJyZW50U2xpZGU9e3NldEN1cnJlbnRTbGlkZX1cbiAgICAgICAgICAgIC8+XG4gICAgICAgICAgKSl9XG4gICAgICAgIC8+XG4gICAgICA8L0Nhcm91c2VsQ29udGFpbmVyPlxuICAgIDwvc2VjdGlvbj5cbiAgKTtcbn07XG5cbmludGVyZmFjZSBGaWxtQ2FyZFByb3BzIHtcbiAgc2V0Q3VycmVudFNsaWRlOiAobW92aWU6IE1vdmllVHlwZSkgPT4gdm9pZDtcbiAgbW92aWU6IE1vdmllVHlwZTtcbiAgY3VycmVudDogYm9vbGVhbjtcbn1cblxuY29uc3QgRmlsbUNhcmQgPSAoeyBzZXRDdXJyZW50U2xpZGUsIG1vdmllLCBjdXJyZW50IH06IEZpbG1DYXJkUHJvcHMpID0+IHtcbiAgY29uc3QgW2hvdmVyQ2FsbGJhY2ssIHNldEhvdmVyQ2FsbGJhY2tdID0gdXNlU3RhdGU8UmV0dXJuVHlwZTx0eXBlb2Ygc2V0VGltZW91dD4gfCB1bmRlZmluZWQ+KHVuZGVmaW5lZCk7XG5cbiAgY29uc3Qgb25Ib3ZlciA9IHVzZUNhbGxiYWNrKCgpID0+IHtcbiAgICBjb25zdCB0aW1lb3V0ID0gc2V0VGltZW91dCgoKSA9PiBzZXRDdXJyZW50U2xpZGUobW92aWUpLCA1MDApO1xuICAgIHNldEhvdmVyQ2FsbGJhY2sodGltZW91dCk7XG4gIH0sIFttb3ZpZSwgc2V0Q3VycmVudFNsaWRlXSk7XG5cbiAgcmV0dXJuIChcbiAgICA8U3R5bGVkRmlsbUNvbnRlbnRDYXJkXG4gICAgICBvbk1vdXNlRW50ZXI9e29uSG92ZXJ9XG4gICAgICBvbk1vdXNlTGVhdmU9eygpID0+IHtcbiAgICAgICAgaWYgKGhvdmVyQ2FsbGJhY2spIHtcbiAgICAgICAgICBjbGVhclRpbWVvdXQoaG92ZXJDYWxsYmFjayk7XG4gICAgICAgICAgc2V0SG92ZXJDYWxsYmFjayh1bmRlZmluZWQpO1xuICAgICAgICB9XG4gICAgICB9fVxuICAgICAgb25Gb2N1cz17KCkgPT4gc2V0Q3VycmVudFNsaWRlKG1vdmllKX1cbiAgICAgIGN1cnJlbnQ9e2N1cnJlbnR9XG4gICAgICBhcmlhLWRlc2NyaWJlZGJ5PXsnY3VycmVudE1vdmllRGVzY3JpcHRpb24nfVxuICAgICAga2V5PXttb3ZpZS5pZH1cbiAgICAgIG1vdmllPXttb3ZpZX1cbiAgICAgIHJlc291cmNlVHlwZXM9e1tdfVxuICAgIC8+XG4gICk7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBGaWxtU2xpZGVzaG93O1xuIl19 */"));
98
57
  var CarouselContainer = /*#__PURE__*/_styled("div", {
99
58
  target: "essc37o2",
100
59
  label: "CarouselContainer"
@@ -102,11 +61,11 @@ var CarouselContainer = /*#__PURE__*/_styled("div", {
102
61
  from: breakpoints.tablet
103
62
  }), "{margin-top:-70px;}", mq.range({
104
63
  from: breakpoints.desktop
105
- }), "{margin-top:-150px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FilmSlideshow.tsx"],"names":[],"mappings":"AAwHoC","file":"FilmSlideshow.tsx","sourcesContent":["/**\n * Copyright (c) 2023-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 { useCallback, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { Carousel, CarouselAutosize } from '@ndla/carousel';\nimport { breakpoints, colors, misc, mq, spacing, spacingUnit } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\nimport { IconButtonV2 } from '@ndla/button';\nimport { ChevronLeft, ChevronRight } from '@ndla/icons/common';\nimport FilmContentCard from './FilmContentCard';\nimport { MovieType } from './types';\n\nexport const slideshowBreakpoints: {\n  until?: keyof typeof breakpoints;\n  columnsPrSlide: number;\n  distanceBetweenItems: number;\n  arrowOffset: number;\n  margin?: number;\n  maxColumnWidth?: number;\n}[] = [\n  {\n    until: 'mobileWide',\n    columnsPrSlide: 2,\n    distanceBetweenItems: spacingUnit / 2,\n    margin: spacingUnit,\n    arrowOffset: 13,\n  },\n  {\n    until: 'tabletWide',\n    columnsPrSlide: 3,\n    distanceBetweenItems: spacingUnit / 2,\n    margin: spacingUnit,\n    arrowOffset: 13,\n  },\n  {\n    until: 'desktop',\n    columnsPrSlide: 3,\n    distanceBetweenItems: spacingUnit,\n    margin: spacingUnit * 2,\n    arrowOffset: 0,\n  },\n  {\n    until: 'wide',\n    columnsPrSlide: 3,\n    distanceBetweenItems: spacingUnit,\n    margin: spacingUnit * 2,\n    arrowOffset: 0,\n  },\n  {\n    until: 'ultraWide',\n    columnsPrSlide: 3,\n    distanceBetweenItems: spacingUnit,\n    margin: spacingUnit * 3.5,\n    arrowOffset: 0,\n  },\n  {\n    columnsPrSlide: 3,\n    distanceBetweenItems: spacingUnit,\n    margin: spacingUnit * 3.5,\n    arrowOffset: 0,\n  },\n];\n\ninterface Props {\n  slideshow: MovieType[];\n}\n\nconst SlideInfoWrapper = styled.div`\n  position: absolute;\n  color: ${colors.white};\n  max-width: 40%;\n  min-width: 40%;\n  top: 40%;\n  right: 5%;\n  ${mq.range({ until: breakpoints.desktop })} {\n    top: 30%;\n    max-width: 60%;\n    min-width: 60%;\n  }\n  ${mq.range({ until: breakpoints.tablet })} {\n    max-width: 90%;\n    min-width: 90%;\n    left: 5%;\n  }\n`;\n\nconst StyledSafeLink = styled(SafeLink)`\n  position: relative;\n  display: block;\n  box-shadow: none;\n`;\n\nconst InfoWrapper = styled.div`\n  padding: ${spacing.normal};\n  border-radius: ${misc.borderRadius};\n  border: 0.5px solid ${colors.brand.primary};\n  background-color: rgba(11, 29, 45, 0.8);\n  h3 {\n    margin: 0px;\n  }\n`;\n\nconst StyledImg = styled.img`\n  max-height: 600px;\n  object-position: top;\n  width: 100%;\n  aspect-ratio: 16/9;\n  ${mq.range({ until: breakpoints.tablet })} {\n    min-height: 440px;\n    max-height: 440px;\n  }\n  object-fit: cover;\n`;\n\nconst CarouselContainer = styled.div`\n  margin-top: -50px;\n  ${mq.range({ from: breakpoints.tablet })} {\n    margin-top: -70px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    margin-top: -150px;\n  }\n`;\n\ninterface StyledFilmContentCardProps {\n  current?: boolean;\n}\n\nconst SlideshowButton = styled(IconButtonV2)`\n  margin-top: ${spacing.normal};\n`;\n\nconst shouldForwardProp = (p: string) => p !== 'current';\n\nconst StyledFilmContentCard = styled(FilmContentCard, { shouldForwardProp })<StyledFilmContentCardProps>`\n  margin-bottom: 2%;\n  transform: ${(p) => (p.current ? 'translateY(0%)' : 'translateY(10%)')};\n  transition: all 200ms;\n`;\n\nconst FilmSlideshow = ({ slideshow }: Props) => {\n  const [currentSlide, setCurrentSlide] = useState(slideshow[0]);\n\n  return (\n    <CarouselAutosize breakpoints={slideshowBreakpoints} itemsLength={slideshow.length}>\n      {(autoSizedProps) => (\n        <section>\n          <StyledSafeLink to={currentSlide.path} tabIndex={-1} aria-hidden>\n            <StyledImg src={currentSlide.metaImage?.url ?? ''} alt={currentSlide.metaImage?.alt ?? ''} />\n            <SlideInfoWrapper>\n              <InfoWrapper>\n                <h3>{currentSlide.title}</h3>\n                <span id=\"currentMovieDescription\">{currentSlide.metaDescription}</span>\n              </InfoWrapper>\n            </SlideInfoWrapper>\n          </StyledSafeLink>\n          <CarouselContainer>\n            <Carousel\n              leftButton={\n                <SlideshowButton aria-label={''}>\n                  <ChevronLeft />\n                </SlideshowButton>\n              }\n              rightButton={\n                <SlideshowButton aria-label={''}>\n                  <ChevronRight />\n                </SlideshowButton>\n              }\n              items={slideshow.map((movie) => (\n                <FilmCard\n                  key={movie.id}\n                  current={movie.id === currentSlide.id}\n                  movie={movie}\n                  columnWidth={autoSizedProps.columnWidth}\n                  setCurrentSlide={() => setCurrentSlide(movie)}\n                />\n              ))}\n              {...autoSizedProps}\n            />\n          </CarouselContainer>\n        </section>\n      )}\n    </CarouselAutosize>\n  );\n};\n\ninterface FilmCardProps {\n  setCurrentSlide: () => void;\n  movie: MovieType;\n  current: boolean;\n  columnWidth: number;\n}\n\nconst FilmCard = ({ setCurrentSlide, movie, current, columnWidth }: FilmCardProps) => {\n  const [hoverCallback, setHoverCallback] = useState<ReturnType<typeof setTimeout> | undefined>(undefined);\n\n  const onHover = useCallback(() => {\n    const timeout = setTimeout(() => setCurrentSlide(), 500);\n    setHoverCallback(timeout);\n  }, [setCurrentSlide]);\n\n  return (\n    <StyledFilmContentCard\n      onMouseEnter={onHover}\n      onMouseLeave={() => {\n        if (hoverCallback) {\n          clearTimeout(hoverCallback);\n          setHoverCallback(undefined);\n        }\n      }}\n      onFocus={() => setCurrentSlide()}\n      current={current}\n      aria-describedby={'currentMovieDescription'}\n      key={movie.id}\n      movie={movie}\n      columnWidth={columnWidth}\n      resourceTypes={[]}\n    />\n  );\n};\n\nexport default FilmSlideshow;\n"]} */"));
64
+ }), "{margin-top:-160px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkZpbG1TbGlkZXNob3cudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXVFb0MiLCJmaWxlIjoiRmlsbVNsaWRlc2hvdy50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAyMy1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCB7IHVzZUNhbGxiYWNrLCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IENhcm91c2VsIH0gZnJvbSAnQG5kbGEvY2Fyb3VzZWwnO1xuaW1wb3J0IHsgYnJlYWtwb2ludHMsIGNvbG9ycywgbWlzYywgbXEsIHNwYWNpbmcgfSBmcm9tICdAbmRsYS9jb3JlJztcbmltcG9ydCBTYWZlTGluayBmcm9tICdAbmRsYS9zYWZlbGluayc7XG5pbXBvcnQgeyBJY29uQnV0dG9uVjIgfSBmcm9tICdAbmRsYS9idXR0b24nO1xuaW1wb3J0IHsgQ2hldnJvbkxlZnQsIENoZXZyb25SaWdodCB9IGZyb20gJ0BuZGxhL2ljb25zL2NvbW1vbic7XG5pbXBvcnQgRmlsbUNvbnRlbnRDYXJkIGZyb20gJy4vRmlsbUNvbnRlbnRDYXJkJztcbmltcG9ydCB7IE1vdmllVHlwZSB9IGZyb20gJy4vdHlwZXMnO1xuaW1wb3J0IEltYWdlIGZyb20gJy4uL0ltYWdlJztcblxuaW50ZXJmYWNlIFByb3BzIHtcbiAgc2xpZGVzaG93OiBNb3ZpZVR5cGVbXTtcbn1cblxuY29uc3QgU2xpZGVJbmZvV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgY29sb3I6ICR7Y29sb3JzLndoaXRlfTtcbiAgbWF4LXdpZHRoOiA0MCU7XG4gIG1pbi13aWR0aDogNDAlO1xuICB0b3A6IDQwJTtcbiAgcmlnaHQ6IDUlO1xuICAke21xLnJhbmdlKHsgdW50aWw6IGJyZWFrcG9pbnRzLmRlc2t0b3AgfSl9IHtcbiAgICB0b3A6IDMwJTtcbiAgICBtYXgtd2lkdGg6IDYwJTtcbiAgICBtaW4td2lkdGg6IDYwJTtcbiAgfVxuICAke21xLnJhbmdlKHsgdW50aWw6IGJyZWFrcG9pbnRzLnRhYmxldCB9KX0ge1xuICAgIG1heC13aWR0aDogOTAlO1xuICAgIG1pbi13aWR0aDogOTAlO1xuICAgIGxlZnQ6IDUlO1xuICB9XG5gO1xuXG5jb25zdCBTdHlsZWRTYWZlTGluayA9IHN0eWxlZChTYWZlTGluaylgXG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgZGlzcGxheTogYmxvY2s7XG4gIGJveC1zaGFkb3c6IG5vbmU7XG5gO1xuXG5jb25zdCBJbmZvV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIHBhZGRpbmc6ICR7c3BhY2luZy5ub3JtYWx9O1xuICBib3JkZXItcmFkaXVzOiAke21pc2MuYm9yZGVyUmFkaXVzfTtcbiAgYm9yZGVyOiAwLjVweCBzb2xpZCAke2NvbG9ycy5icmFuZC5wcmltYXJ5fTtcbiAgYmFja2dyb3VuZC1jb2xvcjogcmdiYSgxMSwgMjksIDQ1LCAwLjgpO1xuICBoMyB7XG4gICAgbWFyZ2luOiAwcHg7XG4gIH1cbmA7XG5cbmNvbnN0IFN0eWxlZEltZyA9IHN0eWxlZChJbWFnZSlgXG4gIG1heC1oZWlnaHQ6IDYwMHB4O1xuICBtaW4taGVpZ2h0OiA2MDBweDtcbiAgb2JqZWN0LXBvc2l0aW9uOiB0b3A7XG4gIHdpZHRoOiAxMDAlO1xuICBhc3BlY3QtcmF0aW86IDE2Lzk7XG4gICR7bXEucmFuZ2UoeyB1bnRpbDogYnJlYWtwb2ludHMudGFibGV0IH0pfSB7XG4gICAgbWluLWhlaWdodDogNDQwcHg7XG4gICAgbWF4LWhlaWdodDogNDQwcHg7XG4gIH1cbiAgb2JqZWN0LWZpdDogY292ZXI7XG5gO1xuXG5jb25zdCBDYXJvdXNlbENvbnRhaW5lciA9IHN0eWxlZC5kaXZgXG4gIG1hcmdpbi10b3A6IC01MHB4O1xuICAke21xLnJhbmdlKHsgZnJvbTogYnJlYWtwb2ludHMudGFibGV0IH0pfSB7XG4gICAgbWFyZ2luLXRvcDogLTcwcHg7XG4gIH1cbiAgJHttcS5yYW5nZSh7IGZyb206IGJyZWFrcG9pbnRzLmRlc2t0b3AgfSl9IHtcbiAgICBtYXJnaW4tdG9wOiAtMTYwcHg7XG4gIH1cbmA7XG5cbmludGVyZmFjZSBTdHlsZWRGaWxtQ29udGVudENhcmRQcm9wcyB7XG4gIGN1cnJlbnQ/OiBib29sZWFuO1xufVxuXG5jb25zdCBTbGlkZXNob3dCdXR0b24gPSBzdHlsZWQoSWNvbkJ1dHRvblYyKWBcbiAgbWFyZ2luLXRvcDogJHtzcGFjaW5nLm5vcm1hbH07XG5gO1xuXG5jb25zdCBzaG91bGRGb3J3YXJkUHJvcCA9IChwOiBzdHJpbmcpID0+IHAgIT09ICdjdXJyZW50JztcblxuY29uc3QgU3R5bGVkRmlsbUNvbnRlbnRDYXJkID0gc3R5bGVkKEZpbG1Db250ZW50Q2FyZCwgeyBzaG91bGRGb3J3YXJkUHJvcCB9KTxTdHlsZWRGaWxtQ29udGVudENhcmRQcm9wcz5gXG4gIG1hcmdpbi1ib3R0b206IDIlO1xuICB0cmFuc2Zvcm06ICR7KHApID0+IChwLmN1cnJlbnQgPyAndHJhbnNsYXRlWSgwJSknIDogJ3RyYW5zbGF0ZVkoMTAlKScpfTtcbiAgdHJhbnNpdGlvbjogYWxsIDIwMG1zO1xuYDtcblxuY29uc3QgRmlsbVNsaWRlc2hvdyA9ICh7IHNsaWRlc2hvdyB9OiBQcm9wcykgPT4ge1xuICBjb25zdCBbY3VycmVudFNsaWRlLCBzZXRDdXJyZW50U2xpZGVdID0gdXNlU3RhdGUoc2xpZGVzaG93WzBdKTtcblxuICByZXR1cm4gKFxuICAgIDxzZWN0aW9uPlxuICAgICAgPFN0eWxlZFNhZmVMaW5rIHRvPXtjdXJyZW50U2xpZGUucGF0aH0gdGFiSW5kZXg9ey0xfSBhcmlhLWhpZGRlbj5cbiAgICAgICAgPFN0eWxlZEltZ1xuICAgICAgICAgIHNyYz17Y3VycmVudFNsaWRlLm1ldGFJbWFnZT8udXJsID8/ICcnfVxuICAgICAgICAgIHNpemVzPVwiKG1pbi13aWR0aDogMTE0MHB4KSAxMTQwcHgsIChtaW4td2lkdGg6IDcyMHB4KSAxMDB2dywgMTAwdndcIlxuICAgICAgICAgIGFsdD1cIlwiXG4gICAgICAgIC8+XG4gICAgICAgIDxTbGlkZUluZm9XcmFwcGVyPlxuICAgICAgICAgIDxJbmZvV3JhcHBlcj5cbiAgICAgICAgICAgIDxoMz57Y3VycmVudFNsaWRlLnRpdGxlfTwvaDM+XG4gICAgICAgICAgICA8c3BhbiBpZD1cImN1cnJlbnRNb3ZpZURlc2NyaXB0aW9uXCI+e2N1cnJlbnRTbGlkZS5tZXRhRGVzY3JpcHRpb259PC9zcGFuPlxuICAgICAgICAgIDwvSW5mb1dyYXBwZXI+XG4gICAgICAgIDwvU2xpZGVJbmZvV3JhcHBlcj5cbiAgICAgIDwvU3R5bGVkU2FmZUxpbms+XG4gICAgICA8Q2Fyb3VzZWxDb250YWluZXI+XG4gICAgICAgIDxDYXJvdXNlbFxuICAgICAgICAgIGxlZnRCdXR0b249e1xuICAgICAgICAgICAgPFNsaWRlc2hvd0J1dHRvbiBhcmlhLWxhYmVsPVwiXCI+XG4gICAgICAgICAgICAgIDxDaGV2cm9uTGVmdCAvPlxuICAgICAgICAgICAgPC9TbGlkZXNob3dCdXR0b24+XG4gICAgICAgICAgfVxuICAgICAgICAgIHJpZ2h0QnV0dG9uPXtcbiAgICAgICAgICAgIDxTbGlkZXNob3dCdXR0b24gYXJpYS1sYWJlbD1cIlwiPlxuICAgICAgICAgICAgICA8Q2hldnJvblJpZ2h0IC8+XG4gICAgICAgICAgICA8L1NsaWRlc2hvd0J1dHRvbj5cbiAgICAgICAgICB9XG4gICAgICAgICAgaXRlbXM9e3NsaWRlc2hvdy5tYXAoKG1vdmllKSA9PiAoXG4gICAgICAgICAgICA8RmlsbUNhcmRcbiAgICAgICAgICAgICAga2V5PXttb3ZpZS5pZH1cbiAgICAgICAgICAgICAgY3VycmVudD17bW92aWUuaWQgPT09IGN1cnJlbnRTbGlkZS5pZH1cbiAgICAgICAgICAgICAgbW92aWU9e21vdmllfVxuICAgICAgICAgICAgICBzZXRDdXJyZW50U2xpZGU9e3NldEN1cnJlbnRTbGlkZX1cbiAgICAgICAgICAgIC8+XG4gICAgICAgICAgKSl9XG4gICAgICAgIC8+XG4gICAgICA8L0Nhcm91c2VsQ29udGFpbmVyPlxuICAgIDwvc2VjdGlvbj5cbiAgKTtcbn07XG5cbmludGVyZmFjZSBGaWxtQ2FyZFByb3BzIHtcbiAgc2V0Q3VycmVudFNsaWRlOiAobW92aWU6IE1vdmllVHlwZSkgPT4gdm9pZDtcbiAgbW92aWU6IE1vdmllVHlwZTtcbiAgY3VycmVudDogYm9vbGVhbjtcbn1cblxuY29uc3QgRmlsbUNhcmQgPSAoeyBzZXRDdXJyZW50U2xpZGUsIG1vdmllLCBjdXJyZW50IH06IEZpbG1DYXJkUHJvcHMpID0+IHtcbiAgY29uc3QgW2hvdmVyQ2FsbGJhY2ssIHNldEhvdmVyQ2FsbGJhY2tdID0gdXNlU3RhdGU8UmV0dXJuVHlwZTx0eXBlb2Ygc2V0VGltZW91dD4gfCB1bmRlZmluZWQ+KHVuZGVmaW5lZCk7XG5cbiAgY29uc3Qgb25Ib3ZlciA9IHVzZUNhbGxiYWNrKCgpID0+IHtcbiAgICBjb25zdCB0aW1lb3V0ID0gc2V0VGltZW91dCgoKSA9PiBzZXRDdXJyZW50U2xpZGUobW92aWUpLCA1MDApO1xuICAgIHNldEhvdmVyQ2FsbGJhY2sodGltZW91dCk7XG4gIH0sIFttb3ZpZSwgc2V0Q3VycmVudFNsaWRlXSk7XG5cbiAgcmV0dXJuIChcbiAgICA8U3R5bGVkRmlsbUNvbnRlbnRDYXJkXG4gICAgICBvbk1vdXNlRW50ZXI9e29uSG92ZXJ9XG4gICAgICBvbk1vdXNlTGVhdmU9eygpID0+IHtcbiAgICAgICAgaWYgKGhvdmVyQ2FsbGJhY2spIHtcbiAgICAgICAgICBjbGVhclRpbWVvdXQoaG92ZXJDYWxsYmFjayk7XG4gICAgICAgICAgc2V0SG92ZXJDYWxsYmFjayh1bmRlZmluZWQpO1xuICAgICAgICB9XG4gICAgICB9fVxuICAgICAgb25Gb2N1cz17KCkgPT4gc2V0Q3VycmVudFNsaWRlKG1vdmllKX1cbiAgICAgIGN1cnJlbnQ9e2N1cnJlbnR9XG4gICAgICBhcmlhLWRlc2NyaWJlZGJ5PXsnY3VycmVudE1vdmllRGVzY3JpcHRpb24nfVxuICAgICAga2V5PXttb3ZpZS5pZH1cbiAgICAgIG1vdmllPXttb3ZpZX1cbiAgICAgIHJlc291cmNlVHlwZXM9e1tdfVxuICAgIC8+XG4gICk7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBGaWxtU2xpZGVzaG93O1xuIl19 */"));
106
65
  var SlideshowButton = /*#__PURE__*/_styled(IconButtonV2, {
107
66
  target: "essc37o1",
108
67
  label: "SlideshowButton"
109
- })("margin-top:", spacing.normal, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FilmSlideshow.tsx"],"names":[],"mappings":"AAsI4C","file":"FilmSlideshow.tsx","sourcesContent":["/**\n * Copyright (c) 2023-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 { useCallback, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { Carousel, CarouselAutosize } from '@ndla/carousel';\nimport { breakpoints, colors, misc, mq, spacing, spacingUnit } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\nimport { IconButtonV2 } from '@ndla/button';\nimport { ChevronLeft, ChevronRight } from '@ndla/icons/common';\nimport FilmContentCard from './FilmContentCard';\nimport { MovieType } from './types';\n\nexport const slideshowBreakpoints: {\n  until?: keyof typeof breakpoints;\n  columnsPrSlide: number;\n  distanceBetweenItems: number;\n  arrowOffset: number;\n  margin?: number;\n  maxColumnWidth?: number;\n}[] = [\n  {\n    until: 'mobileWide',\n    columnsPrSlide: 2,\n    distanceBetweenItems: spacingUnit / 2,\n    margin: spacingUnit,\n    arrowOffset: 13,\n  },\n  {\n    until: 'tabletWide',\n    columnsPrSlide: 3,\n    distanceBetweenItems: spacingUnit / 2,\n    margin: spacingUnit,\n    arrowOffset: 13,\n  },\n  {\n    until: 'desktop',\n    columnsPrSlide: 3,\n    distanceBetweenItems: spacingUnit,\n    margin: spacingUnit * 2,\n    arrowOffset: 0,\n  },\n  {\n    until: 'wide',\n    columnsPrSlide: 3,\n    distanceBetweenItems: spacingUnit,\n    margin: spacingUnit * 2,\n    arrowOffset: 0,\n  },\n  {\n    until: 'ultraWide',\n    columnsPrSlide: 3,\n    distanceBetweenItems: spacingUnit,\n    margin: spacingUnit * 3.5,\n    arrowOffset: 0,\n  },\n  {\n    columnsPrSlide: 3,\n    distanceBetweenItems: spacingUnit,\n    margin: spacingUnit * 3.5,\n    arrowOffset: 0,\n  },\n];\n\ninterface Props {\n  slideshow: MovieType[];\n}\n\nconst SlideInfoWrapper = styled.div`\n  position: absolute;\n  color: ${colors.white};\n  max-width: 40%;\n  min-width: 40%;\n  top: 40%;\n  right: 5%;\n  ${mq.range({ until: breakpoints.desktop })} {\n    top: 30%;\n    max-width: 60%;\n    min-width: 60%;\n  }\n  ${mq.range({ until: breakpoints.tablet })} {\n    max-width: 90%;\n    min-width: 90%;\n    left: 5%;\n  }\n`;\n\nconst StyledSafeLink = styled(SafeLink)`\n  position: relative;\n  display: block;\n  box-shadow: none;\n`;\n\nconst InfoWrapper = styled.div`\n  padding: ${spacing.normal};\n  border-radius: ${misc.borderRadius};\n  border: 0.5px solid ${colors.brand.primary};\n  background-color: rgba(11, 29, 45, 0.8);\n  h3 {\n    margin: 0px;\n  }\n`;\n\nconst StyledImg = styled.img`\n  max-height: 600px;\n  object-position: top;\n  width: 100%;\n  aspect-ratio: 16/9;\n  ${mq.range({ until: breakpoints.tablet })} {\n    min-height: 440px;\n    max-height: 440px;\n  }\n  object-fit: cover;\n`;\n\nconst CarouselContainer = styled.div`\n  margin-top: -50px;\n  ${mq.range({ from: breakpoints.tablet })} {\n    margin-top: -70px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    margin-top: -150px;\n  }\n`;\n\ninterface StyledFilmContentCardProps {\n  current?: boolean;\n}\n\nconst SlideshowButton = styled(IconButtonV2)`\n  margin-top: ${spacing.normal};\n`;\n\nconst shouldForwardProp = (p: string) => p !== 'current';\n\nconst StyledFilmContentCard = styled(FilmContentCard, { shouldForwardProp })<StyledFilmContentCardProps>`\n  margin-bottom: 2%;\n  transform: ${(p) => (p.current ? 'translateY(0%)' : 'translateY(10%)')};\n  transition: all 200ms;\n`;\n\nconst FilmSlideshow = ({ slideshow }: Props) => {\n  const [currentSlide, setCurrentSlide] = useState(slideshow[0]);\n\n  return (\n    <CarouselAutosize breakpoints={slideshowBreakpoints} itemsLength={slideshow.length}>\n      {(autoSizedProps) => (\n        <section>\n          <StyledSafeLink to={currentSlide.path} tabIndex={-1} aria-hidden>\n            <StyledImg src={currentSlide.metaImage?.url ?? ''} alt={currentSlide.metaImage?.alt ?? ''} />\n            <SlideInfoWrapper>\n              <InfoWrapper>\n                <h3>{currentSlide.title}</h3>\n                <span id=\"currentMovieDescription\">{currentSlide.metaDescription}</span>\n              </InfoWrapper>\n            </SlideInfoWrapper>\n          </StyledSafeLink>\n          <CarouselContainer>\n            <Carousel\n              leftButton={\n                <SlideshowButton aria-label={''}>\n                  <ChevronLeft />\n                </SlideshowButton>\n              }\n              rightButton={\n                <SlideshowButton aria-label={''}>\n                  <ChevronRight />\n                </SlideshowButton>\n              }\n              items={slideshow.map((movie) => (\n                <FilmCard\n                  key={movie.id}\n                  current={movie.id === currentSlide.id}\n                  movie={movie}\n                  columnWidth={autoSizedProps.columnWidth}\n                  setCurrentSlide={() => setCurrentSlide(movie)}\n                />\n              ))}\n              {...autoSizedProps}\n            />\n          </CarouselContainer>\n        </section>\n      )}\n    </CarouselAutosize>\n  );\n};\n\ninterface FilmCardProps {\n  setCurrentSlide: () => void;\n  movie: MovieType;\n  current: boolean;\n  columnWidth: number;\n}\n\nconst FilmCard = ({ setCurrentSlide, movie, current, columnWidth }: FilmCardProps) => {\n  const [hoverCallback, setHoverCallback] = useState<ReturnType<typeof setTimeout> | undefined>(undefined);\n\n  const onHover = useCallback(() => {\n    const timeout = setTimeout(() => setCurrentSlide(), 500);\n    setHoverCallback(timeout);\n  }, [setCurrentSlide]);\n\n  return (\n    <StyledFilmContentCard\n      onMouseEnter={onHover}\n      onMouseLeave={() => {\n        if (hoverCallback) {\n          clearTimeout(hoverCallback);\n          setHoverCallback(undefined);\n        }\n      }}\n      onFocus={() => setCurrentSlide()}\n      current={current}\n      aria-describedby={'currentMovieDescription'}\n      key={movie.id}\n      movie={movie}\n      columnWidth={columnWidth}\n      resourceTypes={[]}\n    />\n  );\n};\n\nexport default FilmSlideshow;\n"]} */"));
68
+ })("margin-top:", spacing.normal, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkZpbG1TbGlkZXNob3cudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXFGNEMiLCJmaWxlIjoiRmlsbVNsaWRlc2hvdy50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAyMy1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCB7IHVzZUNhbGxiYWNrLCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IENhcm91c2VsIH0gZnJvbSAnQG5kbGEvY2Fyb3VzZWwnO1xuaW1wb3J0IHsgYnJlYWtwb2ludHMsIGNvbG9ycywgbWlzYywgbXEsIHNwYWNpbmcgfSBmcm9tICdAbmRsYS9jb3JlJztcbmltcG9ydCBTYWZlTGluayBmcm9tICdAbmRsYS9zYWZlbGluayc7XG5pbXBvcnQgeyBJY29uQnV0dG9uVjIgfSBmcm9tICdAbmRsYS9idXR0b24nO1xuaW1wb3J0IHsgQ2hldnJvbkxlZnQsIENoZXZyb25SaWdodCB9IGZyb20gJ0BuZGxhL2ljb25zL2NvbW1vbic7XG5pbXBvcnQgRmlsbUNvbnRlbnRDYXJkIGZyb20gJy4vRmlsbUNvbnRlbnRDYXJkJztcbmltcG9ydCB7IE1vdmllVHlwZSB9IGZyb20gJy4vdHlwZXMnO1xuaW1wb3J0IEltYWdlIGZyb20gJy4uL0ltYWdlJztcblxuaW50ZXJmYWNlIFByb3BzIHtcbiAgc2xpZGVzaG93OiBNb3ZpZVR5cGVbXTtcbn1cblxuY29uc3QgU2xpZGVJbmZvV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgY29sb3I6ICR7Y29sb3JzLndoaXRlfTtcbiAgbWF4LXdpZHRoOiA0MCU7XG4gIG1pbi13aWR0aDogNDAlO1xuICB0b3A6IDQwJTtcbiAgcmlnaHQ6IDUlO1xuICAke21xLnJhbmdlKHsgdW50aWw6IGJyZWFrcG9pbnRzLmRlc2t0b3AgfSl9IHtcbiAgICB0b3A6IDMwJTtcbiAgICBtYXgtd2lkdGg6IDYwJTtcbiAgICBtaW4td2lkdGg6IDYwJTtcbiAgfVxuICAke21xLnJhbmdlKHsgdW50aWw6IGJyZWFrcG9pbnRzLnRhYmxldCB9KX0ge1xuICAgIG1heC13aWR0aDogOTAlO1xuICAgIG1pbi13aWR0aDogOTAlO1xuICAgIGxlZnQ6IDUlO1xuICB9XG5gO1xuXG5jb25zdCBTdHlsZWRTYWZlTGluayA9IHN0eWxlZChTYWZlTGluaylgXG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgZGlzcGxheTogYmxvY2s7XG4gIGJveC1zaGFkb3c6IG5vbmU7XG5gO1xuXG5jb25zdCBJbmZvV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIHBhZGRpbmc6ICR7c3BhY2luZy5ub3JtYWx9O1xuICBib3JkZXItcmFkaXVzOiAke21pc2MuYm9yZGVyUmFkaXVzfTtcbiAgYm9yZGVyOiAwLjVweCBzb2xpZCAke2NvbG9ycy5icmFuZC5wcmltYXJ5fTtcbiAgYmFja2dyb3VuZC1jb2xvcjogcmdiYSgxMSwgMjksIDQ1LCAwLjgpO1xuICBoMyB7XG4gICAgbWFyZ2luOiAwcHg7XG4gIH1cbmA7XG5cbmNvbnN0IFN0eWxlZEltZyA9IHN0eWxlZChJbWFnZSlgXG4gIG1heC1oZWlnaHQ6IDYwMHB4O1xuICBtaW4taGVpZ2h0OiA2MDBweDtcbiAgb2JqZWN0LXBvc2l0aW9uOiB0b3A7XG4gIHdpZHRoOiAxMDAlO1xuICBhc3BlY3QtcmF0aW86IDE2Lzk7XG4gICR7bXEucmFuZ2UoeyB1bnRpbDogYnJlYWtwb2ludHMudGFibGV0IH0pfSB7XG4gICAgbWluLWhlaWdodDogNDQwcHg7XG4gICAgbWF4LWhlaWdodDogNDQwcHg7XG4gIH1cbiAgb2JqZWN0LWZpdDogY292ZXI7XG5gO1xuXG5jb25zdCBDYXJvdXNlbENvbnRhaW5lciA9IHN0eWxlZC5kaXZgXG4gIG1hcmdpbi10b3A6IC01MHB4O1xuICAke21xLnJhbmdlKHsgZnJvbTogYnJlYWtwb2ludHMudGFibGV0IH0pfSB7XG4gICAgbWFyZ2luLXRvcDogLTcwcHg7XG4gIH1cbiAgJHttcS5yYW5nZSh7IGZyb206IGJyZWFrcG9pbnRzLmRlc2t0b3AgfSl9IHtcbiAgICBtYXJnaW4tdG9wOiAtMTYwcHg7XG4gIH1cbmA7XG5cbmludGVyZmFjZSBTdHlsZWRGaWxtQ29udGVudENhcmRQcm9wcyB7XG4gIGN1cnJlbnQ/OiBib29sZWFuO1xufVxuXG5jb25zdCBTbGlkZXNob3dCdXR0b24gPSBzdHlsZWQoSWNvbkJ1dHRvblYyKWBcbiAgbWFyZ2luLXRvcDogJHtzcGFjaW5nLm5vcm1hbH07XG5gO1xuXG5jb25zdCBzaG91bGRGb3J3YXJkUHJvcCA9IChwOiBzdHJpbmcpID0+IHAgIT09ICdjdXJyZW50JztcblxuY29uc3QgU3R5bGVkRmlsbUNvbnRlbnRDYXJkID0gc3R5bGVkKEZpbG1Db250ZW50Q2FyZCwgeyBzaG91bGRGb3J3YXJkUHJvcCB9KTxTdHlsZWRGaWxtQ29udGVudENhcmRQcm9wcz5gXG4gIG1hcmdpbi1ib3R0b206IDIlO1xuICB0cmFuc2Zvcm06ICR7KHApID0+IChwLmN1cnJlbnQgPyAndHJhbnNsYXRlWSgwJSknIDogJ3RyYW5zbGF0ZVkoMTAlKScpfTtcbiAgdHJhbnNpdGlvbjogYWxsIDIwMG1zO1xuYDtcblxuY29uc3QgRmlsbVNsaWRlc2hvdyA9ICh7IHNsaWRlc2hvdyB9OiBQcm9wcykgPT4ge1xuICBjb25zdCBbY3VycmVudFNsaWRlLCBzZXRDdXJyZW50U2xpZGVdID0gdXNlU3RhdGUoc2xpZGVzaG93WzBdKTtcblxuICByZXR1cm4gKFxuICAgIDxzZWN0aW9uPlxuICAgICAgPFN0eWxlZFNhZmVMaW5rIHRvPXtjdXJyZW50U2xpZGUucGF0aH0gdGFiSW5kZXg9ey0xfSBhcmlhLWhpZGRlbj5cbiAgICAgICAgPFN0eWxlZEltZ1xuICAgICAgICAgIHNyYz17Y3VycmVudFNsaWRlLm1ldGFJbWFnZT8udXJsID8/ICcnfVxuICAgICAgICAgIHNpemVzPVwiKG1pbi13aWR0aDogMTE0MHB4KSAxMTQwcHgsIChtaW4td2lkdGg6IDcyMHB4KSAxMDB2dywgMTAwdndcIlxuICAgICAgICAgIGFsdD1cIlwiXG4gICAgICAgIC8+XG4gICAgICAgIDxTbGlkZUluZm9XcmFwcGVyPlxuICAgICAgICAgIDxJbmZvV3JhcHBlcj5cbiAgICAgICAgICAgIDxoMz57Y3VycmVudFNsaWRlLnRpdGxlfTwvaDM+XG4gICAgICAgICAgICA8c3BhbiBpZD1cImN1cnJlbnRNb3ZpZURlc2NyaXB0aW9uXCI+e2N1cnJlbnRTbGlkZS5tZXRhRGVzY3JpcHRpb259PC9zcGFuPlxuICAgICAgICAgIDwvSW5mb1dyYXBwZXI+XG4gICAgICAgIDwvU2xpZGVJbmZvV3JhcHBlcj5cbiAgICAgIDwvU3R5bGVkU2FmZUxpbms+XG4gICAgICA8Q2Fyb3VzZWxDb250YWluZXI+XG4gICAgICAgIDxDYXJvdXNlbFxuICAgICAgICAgIGxlZnRCdXR0b249e1xuICAgICAgICAgICAgPFNsaWRlc2hvd0J1dHRvbiBhcmlhLWxhYmVsPVwiXCI+XG4gICAgICAgICAgICAgIDxDaGV2cm9uTGVmdCAvPlxuICAgICAgICAgICAgPC9TbGlkZXNob3dCdXR0b24+XG4gICAgICAgICAgfVxuICAgICAgICAgIHJpZ2h0QnV0dG9uPXtcbiAgICAgICAgICAgIDxTbGlkZXNob3dCdXR0b24gYXJpYS1sYWJlbD1cIlwiPlxuICAgICAgICAgICAgICA8Q2hldnJvblJpZ2h0IC8+XG4gICAgICAgICAgICA8L1NsaWRlc2hvd0J1dHRvbj5cbiAgICAgICAgICB9XG4gICAgICAgICAgaXRlbXM9e3NsaWRlc2hvdy5tYXAoKG1vdmllKSA9PiAoXG4gICAgICAgICAgICA8RmlsbUNhcmRcbiAgICAgICAgICAgICAga2V5PXttb3ZpZS5pZH1cbiAgICAgICAgICAgICAgY3VycmVudD17bW92aWUuaWQgPT09IGN1cnJlbnRTbGlkZS5pZH1cbiAgICAgICAgICAgICAgbW92aWU9e21vdmllfVxuICAgICAgICAgICAgICBzZXRDdXJyZW50U2xpZGU9e3NldEN1cnJlbnRTbGlkZX1cbiAgICAgICAgICAgIC8+XG4gICAgICAgICAgKSl9XG4gICAgICAgIC8+XG4gICAgICA8L0Nhcm91c2VsQ29udGFpbmVyPlxuICAgIDwvc2VjdGlvbj5cbiAgKTtcbn07XG5cbmludGVyZmFjZSBGaWxtQ2FyZFByb3BzIHtcbiAgc2V0Q3VycmVudFNsaWRlOiAobW92aWU6IE1vdmllVHlwZSkgPT4gdm9pZDtcbiAgbW92aWU6IE1vdmllVHlwZTtcbiAgY3VycmVudDogYm9vbGVhbjtcbn1cblxuY29uc3QgRmlsbUNhcmQgPSAoeyBzZXRDdXJyZW50U2xpZGUsIG1vdmllLCBjdXJyZW50IH06IEZpbG1DYXJkUHJvcHMpID0+IHtcbiAgY29uc3QgW2hvdmVyQ2FsbGJhY2ssIHNldEhvdmVyQ2FsbGJhY2tdID0gdXNlU3RhdGU8UmV0dXJuVHlwZTx0eXBlb2Ygc2V0VGltZW91dD4gfCB1bmRlZmluZWQ+KHVuZGVmaW5lZCk7XG5cbiAgY29uc3Qgb25Ib3ZlciA9IHVzZUNhbGxiYWNrKCgpID0+IHtcbiAgICBjb25zdCB0aW1lb3V0ID0gc2V0VGltZW91dCgoKSA9PiBzZXRDdXJyZW50U2xpZGUobW92aWUpLCA1MDApO1xuICAgIHNldEhvdmVyQ2FsbGJhY2sodGltZW91dCk7XG4gIH0sIFttb3ZpZSwgc2V0Q3VycmVudFNsaWRlXSk7XG5cbiAgcmV0dXJuIChcbiAgICA8U3R5bGVkRmlsbUNvbnRlbnRDYXJkXG4gICAgICBvbk1vdXNlRW50ZXI9e29uSG92ZXJ9XG4gICAgICBvbk1vdXNlTGVhdmU9eygpID0+IHtcbiAgICAgICAgaWYgKGhvdmVyQ2FsbGJhY2spIHtcbiAgICAgICAgICBjbGVhclRpbWVvdXQoaG92ZXJDYWxsYmFjayk7XG4gICAgICAgICAgc2V0SG92ZXJDYWxsYmFjayh1bmRlZmluZWQpO1xuICAgICAgICB9XG4gICAgICB9fVxuICAgICAgb25Gb2N1cz17KCkgPT4gc2V0Q3VycmVudFNsaWRlKG1vdmllKX1cbiAgICAgIGN1cnJlbnQ9e2N1cnJlbnR9XG4gICAgICBhcmlhLWRlc2NyaWJlZGJ5PXsnY3VycmVudE1vdmllRGVzY3JpcHRpb24nfVxuICAgICAga2V5PXttb3ZpZS5pZH1cbiAgICAgIG1vdmllPXttb3ZpZX1cbiAgICAgIHJlc291cmNlVHlwZXM9e1tdfVxuICAgIC8+XG4gICk7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBGaWxtU2xpZGVzaG93O1xuIl19 */"));
110
69
  var shouldForwardProp = function shouldForwardProp(p) {
111
70
  return p !== 'current';
112
71
  };
@@ -116,77 +75,68 @@ var StyledFilmContentCard = /*#__PURE__*/_styled(FilmContentCard, {
116
75
  label: "StyledFilmContentCard"
117
76
  })("margin-bottom:2%;transform:", function (p) {
118
77
  return p.current ? 'translateY(0%)' : 'translateY(10%)';
119
- }, ";transition:all 200ms;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["FilmSlideshow.tsx"],"names":[],"mappings":"AA4IwG","file":"FilmSlideshow.tsx","sourcesContent":["/**\n * Copyright (c) 2023-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 { useCallback, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { Carousel, CarouselAutosize } from '@ndla/carousel';\nimport { breakpoints, colors, misc, mq, spacing, spacingUnit } from '@ndla/core';\nimport SafeLink from '@ndla/safelink';\nimport { IconButtonV2 } from '@ndla/button';\nimport { ChevronLeft, ChevronRight } from '@ndla/icons/common';\nimport FilmContentCard from './FilmContentCard';\nimport { MovieType } from './types';\n\nexport const slideshowBreakpoints: {\n  until?: keyof typeof breakpoints;\n  columnsPrSlide: number;\n  distanceBetweenItems: number;\n  arrowOffset: number;\n  margin?: number;\n  maxColumnWidth?: number;\n}[] = [\n  {\n    until: 'mobileWide',\n    columnsPrSlide: 2,\n    distanceBetweenItems: spacingUnit / 2,\n    margin: spacingUnit,\n    arrowOffset: 13,\n  },\n  {\n    until: 'tabletWide',\n    columnsPrSlide: 3,\n    distanceBetweenItems: spacingUnit / 2,\n    margin: spacingUnit,\n    arrowOffset: 13,\n  },\n  {\n    until: 'desktop',\n    columnsPrSlide: 3,\n    distanceBetweenItems: spacingUnit,\n    margin: spacingUnit * 2,\n    arrowOffset: 0,\n  },\n  {\n    until: 'wide',\n    columnsPrSlide: 3,\n    distanceBetweenItems: spacingUnit,\n    margin: spacingUnit * 2,\n    arrowOffset: 0,\n  },\n  {\n    until: 'ultraWide',\n    columnsPrSlide: 3,\n    distanceBetweenItems: spacingUnit,\n    margin: spacingUnit * 3.5,\n    arrowOffset: 0,\n  },\n  {\n    columnsPrSlide: 3,\n    distanceBetweenItems: spacingUnit,\n    margin: spacingUnit * 3.5,\n    arrowOffset: 0,\n  },\n];\n\ninterface Props {\n  slideshow: MovieType[];\n}\n\nconst SlideInfoWrapper = styled.div`\n  position: absolute;\n  color: ${colors.white};\n  max-width: 40%;\n  min-width: 40%;\n  top: 40%;\n  right: 5%;\n  ${mq.range({ until: breakpoints.desktop })} {\n    top: 30%;\n    max-width: 60%;\n    min-width: 60%;\n  }\n  ${mq.range({ until: breakpoints.tablet })} {\n    max-width: 90%;\n    min-width: 90%;\n    left: 5%;\n  }\n`;\n\nconst StyledSafeLink = styled(SafeLink)`\n  position: relative;\n  display: block;\n  box-shadow: none;\n`;\n\nconst InfoWrapper = styled.div`\n  padding: ${spacing.normal};\n  border-radius: ${misc.borderRadius};\n  border: 0.5px solid ${colors.brand.primary};\n  background-color: rgba(11, 29, 45, 0.8);\n  h3 {\n    margin: 0px;\n  }\n`;\n\nconst StyledImg = styled.img`\n  max-height: 600px;\n  object-position: top;\n  width: 100%;\n  aspect-ratio: 16/9;\n  ${mq.range({ until: breakpoints.tablet })} {\n    min-height: 440px;\n    max-height: 440px;\n  }\n  object-fit: cover;\n`;\n\nconst CarouselContainer = styled.div`\n  margin-top: -50px;\n  ${mq.range({ from: breakpoints.tablet })} {\n    margin-top: -70px;\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    margin-top: -150px;\n  }\n`;\n\ninterface StyledFilmContentCardProps {\n  current?: boolean;\n}\n\nconst SlideshowButton = styled(IconButtonV2)`\n  margin-top: ${spacing.normal};\n`;\n\nconst shouldForwardProp = (p: string) => p !== 'current';\n\nconst StyledFilmContentCard = styled(FilmContentCard, { shouldForwardProp })<StyledFilmContentCardProps>`\n  margin-bottom: 2%;\n  transform: ${(p) => (p.current ? 'translateY(0%)' : 'translateY(10%)')};\n  transition: all 200ms;\n`;\n\nconst FilmSlideshow = ({ slideshow }: Props) => {\n  const [currentSlide, setCurrentSlide] = useState(slideshow[0]);\n\n  return (\n    <CarouselAutosize breakpoints={slideshowBreakpoints} itemsLength={slideshow.length}>\n      {(autoSizedProps) => (\n        <section>\n          <StyledSafeLink to={currentSlide.path} tabIndex={-1} aria-hidden>\n            <StyledImg src={currentSlide.metaImage?.url ?? ''} alt={currentSlide.metaImage?.alt ?? ''} />\n            <SlideInfoWrapper>\n              <InfoWrapper>\n                <h3>{currentSlide.title}</h3>\n                <span id=\"currentMovieDescription\">{currentSlide.metaDescription}</span>\n              </InfoWrapper>\n            </SlideInfoWrapper>\n          </StyledSafeLink>\n          <CarouselContainer>\n            <Carousel\n              leftButton={\n                <SlideshowButton aria-label={''}>\n                  <ChevronLeft />\n                </SlideshowButton>\n              }\n              rightButton={\n                <SlideshowButton aria-label={''}>\n                  <ChevronRight />\n                </SlideshowButton>\n              }\n              items={slideshow.map((movie) => (\n                <FilmCard\n                  key={movie.id}\n                  current={movie.id === currentSlide.id}\n                  movie={movie}\n                  columnWidth={autoSizedProps.columnWidth}\n                  setCurrentSlide={() => setCurrentSlide(movie)}\n                />\n              ))}\n              {...autoSizedProps}\n            />\n          </CarouselContainer>\n        </section>\n      )}\n    </CarouselAutosize>\n  );\n};\n\ninterface FilmCardProps {\n  setCurrentSlide: () => void;\n  movie: MovieType;\n  current: boolean;\n  columnWidth: number;\n}\n\nconst FilmCard = ({ setCurrentSlide, movie, current, columnWidth }: FilmCardProps) => {\n  const [hoverCallback, setHoverCallback] = useState<ReturnType<typeof setTimeout> | undefined>(undefined);\n\n  const onHover = useCallback(() => {\n    const timeout = setTimeout(() => setCurrentSlide(), 500);\n    setHoverCallback(timeout);\n  }, [setCurrentSlide]);\n\n  return (\n    <StyledFilmContentCard\n      onMouseEnter={onHover}\n      onMouseLeave={() => {\n        if (hoverCallback) {\n          clearTimeout(hoverCallback);\n          setHoverCallback(undefined);\n        }\n      }}\n      onFocus={() => setCurrentSlide()}\n      current={current}\n      aria-describedby={'currentMovieDescription'}\n      key={movie.id}\n      movie={movie}\n      columnWidth={columnWidth}\n      resourceTypes={[]}\n    />\n  );\n};\n\nexport default FilmSlideshow;\n"]} */"));
78
+ }, ";transition:all 200ms;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkZpbG1TbGlkZXNob3cudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTJGd0ciLCJmaWxlIjoiRmlsbVNsaWRlc2hvdy50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAyMy1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCB7IHVzZUNhbGxiYWNrLCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IENhcm91c2VsIH0gZnJvbSAnQG5kbGEvY2Fyb3VzZWwnO1xuaW1wb3J0IHsgYnJlYWtwb2ludHMsIGNvbG9ycywgbWlzYywgbXEsIHNwYWNpbmcgfSBmcm9tICdAbmRsYS9jb3JlJztcbmltcG9ydCBTYWZlTGluayBmcm9tICdAbmRsYS9zYWZlbGluayc7XG5pbXBvcnQgeyBJY29uQnV0dG9uVjIgfSBmcm9tICdAbmRsYS9idXR0b24nO1xuaW1wb3J0IHsgQ2hldnJvbkxlZnQsIENoZXZyb25SaWdodCB9IGZyb20gJ0BuZGxhL2ljb25zL2NvbW1vbic7XG5pbXBvcnQgRmlsbUNvbnRlbnRDYXJkIGZyb20gJy4vRmlsbUNvbnRlbnRDYXJkJztcbmltcG9ydCB7IE1vdmllVHlwZSB9IGZyb20gJy4vdHlwZXMnO1xuaW1wb3J0IEltYWdlIGZyb20gJy4uL0ltYWdlJztcblxuaW50ZXJmYWNlIFByb3BzIHtcbiAgc2xpZGVzaG93OiBNb3ZpZVR5cGVbXTtcbn1cblxuY29uc3QgU2xpZGVJbmZvV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgY29sb3I6ICR7Y29sb3JzLndoaXRlfTtcbiAgbWF4LXdpZHRoOiA0MCU7XG4gIG1pbi13aWR0aDogNDAlO1xuICB0b3A6IDQwJTtcbiAgcmlnaHQ6IDUlO1xuICAke21xLnJhbmdlKHsgdW50aWw6IGJyZWFrcG9pbnRzLmRlc2t0b3AgfSl9IHtcbiAgICB0b3A6IDMwJTtcbiAgICBtYXgtd2lkdGg6IDYwJTtcbiAgICBtaW4td2lkdGg6IDYwJTtcbiAgfVxuICAke21xLnJhbmdlKHsgdW50aWw6IGJyZWFrcG9pbnRzLnRhYmxldCB9KX0ge1xuICAgIG1heC13aWR0aDogOTAlO1xuICAgIG1pbi13aWR0aDogOTAlO1xuICAgIGxlZnQ6IDUlO1xuICB9XG5gO1xuXG5jb25zdCBTdHlsZWRTYWZlTGluayA9IHN0eWxlZChTYWZlTGluaylgXG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgZGlzcGxheTogYmxvY2s7XG4gIGJveC1zaGFkb3c6IG5vbmU7XG5gO1xuXG5jb25zdCBJbmZvV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIHBhZGRpbmc6ICR7c3BhY2luZy5ub3JtYWx9O1xuICBib3JkZXItcmFkaXVzOiAke21pc2MuYm9yZGVyUmFkaXVzfTtcbiAgYm9yZGVyOiAwLjVweCBzb2xpZCAke2NvbG9ycy5icmFuZC5wcmltYXJ5fTtcbiAgYmFja2dyb3VuZC1jb2xvcjogcmdiYSgxMSwgMjksIDQ1LCAwLjgpO1xuICBoMyB7XG4gICAgbWFyZ2luOiAwcHg7XG4gIH1cbmA7XG5cbmNvbnN0IFN0eWxlZEltZyA9IHN0eWxlZChJbWFnZSlgXG4gIG1heC1oZWlnaHQ6IDYwMHB4O1xuICBtaW4taGVpZ2h0OiA2MDBweDtcbiAgb2JqZWN0LXBvc2l0aW9uOiB0b3A7XG4gIHdpZHRoOiAxMDAlO1xuICBhc3BlY3QtcmF0aW86IDE2Lzk7XG4gICR7bXEucmFuZ2UoeyB1bnRpbDogYnJlYWtwb2ludHMudGFibGV0IH0pfSB7XG4gICAgbWluLWhlaWdodDogNDQwcHg7XG4gICAgbWF4LWhlaWdodDogNDQwcHg7XG4gIH1cbiAgb2JqZWN0LWZpdDogY292ZXI7XG5gO1xuXG5jb25zdCBDYXJvdXNlbENvbnRhaW5lciA9IHN0eWxlZC5kaXZgXG4gIG1hcmdpbi10b3A6IC01MHB4O1xuICAke21xLnJhbmdlKHsgZnJvbTogYnJlYWtwb2ludHMudGFibGV0IH0pfSB7XG4gICAgbWFyZ2luLXRvcDogLTcwcHg7XG4gIH1cbiAgJHttcS5yYW5nZSh7IGZyb206IGJyZWFrcG9pbnRzLmRlc2t0b3AgfSl9IHtcbiAgICBtYXJnaW4tdG9wOiAtMTYwcHg7XG4gIH1cbmA7XG5cbmludGVyZmFjZSBTdHlsZWRGaWxtQ29udGVudENhcmRQcm9wcyB7XG4gIGN1cnJlbnQ/OiBib29sZWFuO1xufVxuXG5jb25zdCBTbGlkZXNob3dCdXR0b24gPSBzdHlsZWQoSWNvbkJ1dHRvblYyKWBcbiAgbWFyZ2luLXRvcDogJHtzcGFjaW5nLm5vcm1hbH07XG5gO1xuXG5jb25zdCBzaG91bGRGb3J3YXJkUHJvcCA9IChwOiBzdHJpbmcpID0+IHAgIT09ICdjdXJyZW50JztcblxuY29uc3QgU3R5bGVkRmlsbUNvbnRlbnRDYXJkID0gc3R5bGVkKEZpbG1Db250ZW50Q2FyZCwgeyBzaG91bGRGb3J3YXJkUHJvcCB9KTxTdHlsZWRGaWxtQ29udGVudENhcmRQcm9wcz5gXG4gIG1hcmdpbi1ib3R0b206IDIlO1xuICB0cmFuc2Zvcm06ICR7KHApID0+IChwLmN1cnJlbnQgPyAndHJhbnNsYXRlWSgwJSknIDogJ3RyYW5zbGF0ZVkoMTAlKScpfTtcbiAgdHJhbnNpdGlvbjogYWxsIDIwMG1zO1xuYDtcblxuY29uc3QgRmlsbVNsaWRlc2hvdyA9ICh7IHNsaWRlc2hvdyB9OiBQcm9wcykgPT4ge1xuICBjb25zdCBbY3VycmVudFNsaWRlLCBzZXRDdXJyZW50U2xpZGVdID0gdXNlU3RhdGUoc2xpZGVzaG93WzBdKTtcblxuICByZXR1cm4gKFxuICAgIDxzZWN0aW9uPlxuICAgICAgPFN0eWxlZFNhZmVMaW5rIHRvPXtjdXJyZW50U2xpZGUucGF0aH0gdGFiSW5kZXg9ey0xfSBhcmlhLWhpZGRlbj5cbiAgICAgICAgPFN0eWxlZEltZ1xuICAgICAgICAgIHNyYz17Y3VycmVudFNsaWRlLm1ldGFJbWFnZT8udXJsID8/ICcnfVxuICAgICAgICAgIHNpemVzPVwiKG1pbi13aWR0aDogMTE0MHB4KSAxMTQwcHgsIChtaW4td2lkdGg6IDcyMHB4KSAxMDB2dywgMTAwdndcIlxuICAgICAgICAgIGFsdD1cIlwiXG4gICAgICAgIC8+XG4gICAgICAgIDxTbGlkZUluZm9XcmFwcGVyPlxuICAgICAgICAgIDxJbmZvV3JhcHBlcj5cbiAgICAgICAgICAgIDxoMz57Y3VycmVudFNsaWRlLnRpdGxlfTwvaDM+XG4gICAgICAgICAgICA8c3BhbiBpZD1cImN1cnJlbnRNb3ZpZURlc2NyaXB0aW9uXCI+e2N1cnJlbnRTbGlkZS5tZXRhRGVzY3JpcHRpb259PC9zcGFuPlxuICAgICAgICAgIDwvSW5mb1dyYXBwZXI+XG4gICAgICAgIDwvU2xpZGVJbmZvV3JhcHBlcj5cbiAgICAgIDwvU3R5bGVkU2FmZUxpbms+XG4gICAgICA8Q2Fyb3VzZWxDb250YWluZXI+XG4gICAgICAgIDxDYXJvdXNlbFxuICAgICAgICAgIGxlZnRCdXR0b249e1xuICAgICAgICAgICAgPFNsaWRlc2hvd0J1dHRvbiBhcmlhLWxhYmVsPVwiXCI+XG4gICAgICAgICAgICAgIDxDaGV2cm9uTGVmdCAvPlxuICAgICAgICAgICAgPC9TbGlkZXNob3dCdXR0b24+XG4gICAgICAgICAgfVxuICAgICAgICAgIHJpZ2h0QnV0dG9uPXtcbiAgICAgICAgICAgIDxTbGlkZXNob3dCdXR0b24gYXJpYS1sYWJlbD1cIlwiPlxuICAgICAgICAgICAgICA8Q2hldnJvblJpZ2h0IC8+XG4gICAgICAgICAgICA8L1NsaWRlc2hvd0J1dHRvbj5cbiAgICAgICAgICB9XG4gICAgICAgICAgaXRlbXM9e3NsaWRlc2hvdy5tYXAoKG1vdmllKSA9PiAoXG4gICAgICAgICAgICA8RmlsbUNhcmRcbiAgICAgICAgICAgICAga2V5PXttb3ZpZS5pZH1cbiAgICAgICAgICAgICAgY3VycmVudD17bW92aWUuaWQgPT09IGN1cnJlbnRTbGlkZS5pZH1cbiAgICAgICAgICAgICAgbW92aWU9e21vdmllfVxuICAgICAgICAgICAgICBzZXRDdXJyZW50U2xpZGU9e3NldEN1cnJlbnRTbGlkZX1cbiAgICAgICAgICAgIC8+XG4gICAgICAgICAgKSl9XG4gICAgICAgIC8+XG4gICAgICA8L0Nhcm91c2VsQ29udGFpbmVyPlxuICAgIDwvc2VjdGlvbj5cbiAgKTtcbn07XG5cbmludGVyZmFjZSBGaWxtQ2FyZFByb3BzIHtcbiAgc2V0Q3VycmVudFNsaWRlOiAobW92aWU6IE1vdmllVHlwZSkgPT4gdm9pZDtcbiAgbW92aWU6IE1vdmllVHlwZTtcbiAgY3VycmVudDogYm9vbGVhbjtcbn1cblxuY29uc3QgRmlsbUNhcmQgPSAoeyBzZXRDdXJyZW50U2xpZGUsIG1vdmllLCBjdXJyZW50IH06IEZpbG1DYXJkUHJvcHMpID0+IHtcbiAgY29uc3QgW2hvdmVyQ2FsbGJhY2ssIHNldEhvdmVyQ2FsbGJhY2tdID0gdXNlU3RhdGU8UmV0dXJuVHlwZTx0eXBlb2Ygc2V0VGltZW91dD4gfCB1bmRlZmluZWQ+KHVuZGVmaW5lZCk7XG5cbiAgY29uc3Qgb25Ib3ZlciA9IHVzZUNhbGxiYWNrKCgpID0+IHtcbiAgICBjb25zdCB0aW1lb3V0ID0gc2V0VGltZW91dCgoKSA9PiBzZXRDdXJyZW50U2xpZGUobW92aWUpLCA1MDApO1xuICAgIHNldEhvdmVyQ2FsbGJhY2sodGltZW91dCk7XG4gIH0sIFttb3ZpZSwgc2V0Q3VycmVudFNsaWRlXSk7XG5cbiAgcmV0dXJuIChcbiAgICA8U3R5bGVkRmlsbUNvbnRlbnRDYXJkXG4gICAgICBvbk1vdXNlRW50ZXI9e29uSG92ZXJ9XG4gICAgICBvbk1vdXNlTGVhdmU9eygpID0+IHtcbiAgICAgICAgaWYgKGhvdmVyQ2FsbGJhY2spIHtcbiAgICAgICAgICBjbGVhclRpbWVvdXQoaG92ZXJDYWxsYmFjayk7XG4gICAgICAgICAgc2V0SG92ZXJDYWxsYmFjayh1bmRlZmluZWQpO1xuICAgICAgICB9XG4gICAgICB9fVxuICAgICAgb25Gb2N1cz17KCkgPT4gc2V0Q3VycmVudFNsaWRlKG1vdmllKX1cbiAgICAgIGN1cnJlbnQ9e2N1cnJlbnR9XG4gICAgICBhcmlhLWRlc2NyaWJlZGJ5PXsnY3VycmVudE1vdmllRGVzY3JpcHRpb24nfVxuICAgICAga2V5PXttb3ZpZS5pZH1cbiAgICAgIG1vdmllPXttb3ZpZX1cbiAgICAgIHJlc291cmNlVHlwZXM9e1tdfVxuICAgIC8+XG4gICk7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBGaWxtU2xpZGVzaG93O1xuIl19 */"));
120
79
  var FilmSlideshow = function FilmSlideshow(_ref) {
80
+ var _currentSlide$metaIma, _currentSlide$metaIma2;
121
81
  var slideshow = _ref.slideshow;
122
82
  var _useState = useState(slideshow[0]),
123
83
  _useState2 = _slicedToArray(_useState, 2),
124
84
  currentSlide = _useState2[0],
125
- _setCurrentSlide = _useState2[1];
126
- return _jsx(CarouselAutosize, {
127
- breakpoints: slideshowBreakpoints,
128
- itemsLength: slideshow.length,
129
- children: function children(autoSizedProps) {
130
- var _currentSlide$metaIma, _currentSlide$metaIma2, _currentSlide$metaIma3, _currentSlide$metaIma4;
131
- return _jsxs("section", {
132
- children: [_jsxs(StyledSafeLink, {
133
- to: currentSlide.path,
134
- tabIndex: -1,
135
- "aria-hidden": true,
136
- children: [_jsx(StyledImg, {
137
- src: (_currentSlide$metaIma = (_currentSlide$metaIma2 = currentSlide.metaImage) === null || _currentSlide$metaIma2 === void 0 ? void 0 : _currentSlide$metaIma2.url) !== null && _currentSlide$metaIma !== void 0 ? _currentSlide$metaIma : '',
138
- alt: (_currentSlide$metaIma3 = (_currentSlide$metaIma4 = currentSlide.metaImage) === null || _currentSlide$metaIma4 === void 0 ? void 0 : _currentSlide$metaIma4.alt) !== null && _currentSlide$metaIma3 !== void 0 ? _currentSlide$metaIma3 : ''
139
- }), _jsx(SlideInfoWrapper, {
140
- children: _jsxs(InfoWrapper, {
141
- children: [_jsx("h3", {
142
- children: currentSlide.title
143
- }), _jsx("span", {
144
- id: "currentMovieDescription",
145
- children: currentSlide.metaDescription
146
- })]
147
- })
85
+ setCurrentSlide = _useState2[1];
86
+ return _jsxs("section", {
87
+ children: [_jsxs(StyledSafeLink, {
88
+ to: currentSlide.path,
89
+ tabIndex: -1,
90
+ "aria-hidden": true,
91
+ children: [_jsx(StyledImg, {
92
+ src: (_currentSlide$metaIma = (_currentSlide$metaIma2 = currentSlide.metaImage) === null || _currentSlide$metaIma2 === void 0 ? void 0 : _currentSlide$metaIma2.url) !== null && _currentSlide$metaIma !== void 0 ? _currentSlide$metaIma : '',
93
+ sizes: "(min-width: 1140px) 1140px, (min-width: 720px) 100vw, 100vw",
94
+ alt: ""
95
+ }), _jsx(SlideInfoWrapper, {
96
+ children: _jsxs(InfoWrapper, {
97
+ children: [_jsx("h3", {
98
+ children: currentSlide.title
99
+ }), _jsx("span", {
100
+ id: "currentMovieDescription",
101
+ children: currentSlide.metaDescription
148
102
  })]
149
- }), _jsx(CarouselContainer, {
150
- children: _jsx(Carousel, _objectSpread({
151
- leftButton: _jsx(SlideshowButton, {
152
- "aria-label": '',
153
- children: _jsx(ChevronLeft, {})
154
- }),
155
- rightButton: _jsx(SlideshowButton, {
156
- "aria-label": '',
157
- children: _jsx(ChevronRight, {})
158
- }),
159
- items: slideshow.map(function (movie) {
160
- return _jsx(FilmCard, {
161
- current: movie.id === currentSlide.id,
162
- movie: movie,
163
- columnWidth: autoSizedProps.columnWidth,
164
- setCurrentSlide: function setCurrentSlide() {
165
- return _setCurrentSlide(movie);
166
- }
167
- }, movie.id);
168
- })
169
- }, autoSizedProps))
170
- })]
171
- });
172
- }
103
+ })
104
+ })]
105
+ }), _jsx(CarouselContainer, {
106
+ children: _jsx(Carousel, {
107
+ leftButton: _jsx(SlideshowButton, {
108
+ "aria-label": "",
109
+ children: _jsx(ChevronLeft, {})
110
+ }),
111
+ rightButton: _jsx(SlideshowButton, {
112
+ "aria-label": "",
113
+ children: _jsx(ChevronRight, {})
114
+ }),
115
+ items: slideshow.map(function (movie) {
116
+ return _jsx(FilmCard, {
117
+ current: movie.id === currentSlide.id,
118
+ movie: movie,
119
+ setCurrentSlide: setCurrentSlide
120
+ }, movie.id);
121
+ })
122
+ })
123
+ })]
173
124
  });
174
125
  };
175
126
  var FilmCard = function FilmCard(_ref2) {
176
127
  var setCurrentSlide = _ref2.setCurrentSlide,
177
128
  movie = _ref2.movie,
178
- current = _ref2.current,
179
- columnWidth = _ref2.columnWidth;
129
+ current = _ref2.current;
180
130
  var _useState3 = useState(undefined),
181
131
  _useState4 = _slicedToArray(_useState3, 2),
182
132
  hoverCallback = _useState4[0],
183
133
  setHoverCallback = _useState4[1];
184
134
  var onHover = useCallback(function () {
185
135
  var timeout = setTimeout(function () {
186
- return setCurrentSlide();
136
+ return setCurrentSlide(movie);
187
137
  }, 500);
188
138
  setHoverCallback(timeout);
189
- }, [setCurrentSlide]);
139
+ }, [movie, setCurrentSlide]);
190
140
  return _jsx(StyledFilmContentCard, {
191
141
  onMouseEnter: onHover,
192
142
  onMouseLeave: function onMouseLeave() {
@@ -196,12 +146,11 @@ var FilmCard = function FilmCard(_ref2) {
196
146
  }
197
147
  },
198
148
  onFocus: function onFocus() {
199
- return setCurrentSlide();
149
+ return setCurrentSlide(movie);
200
150
  },
201
151
  current: current,
202
152
  "aria-describedby": 'currentMovieDescription',
203
153
  movie: movie,
204
- columnWidth: columnWidth,
205
154
  resourceTypes: []
206
155
  }, movie.id);
207
156
  };
@@ -1,5 +1,5 @@
1
1
  import _styled from "@emotion/styled/base";
2
- import { spacing } from '@ndla/core';
2
+ import { breakpoints, mq, spacing, spacingUnit } from '@ndla/core';
3
3
  import { useTranslation } from 'react-i18next';
4
4
  import FilmContentCard from './FilmContentCard';
5
5
  import { setAnimations, StyledHeadingH1 } from './filmStyles';
@@ -8,43 +8,40 @@ import { jsxs as _jsxs } from "@emotion/react/jsx-runtime";
8
8
  var MovieListing = /*#__PURE__*/_styled("div", {
9
9
  target: "e1t64qur1",
10
10
  label: "MovieListing"
11
- })("display:flex;flex-wrap:wrap;margin:", spacing.small, " 0;margin-left:", function (props) {
11
+ })("display:flex;flex-wrap:wrap;gap:", spacing.normal, ";margin:", spacing.small, " 0;margin-left:", function (props) {
12
12
  return props.marginLeft && "".concat(props.marginLeft, "px");
13
- }, ";", 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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIk1vdmllR3JpZC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBWWtEIiwiZmlsZSI6Ik1vdmllR3JpZC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBzcGFjaW5nIH0gZnJvbSAnQG5kbGEvY29yZSc7XG5pbXBvcnQgeyBDYWxjdWxhdGVkQ2Fyb3VzZWxQcm9wcyB9IGZyb20gJ0BuZGxhL2Nhcm91c2VsJztcbmltcG9ydCB7IHVzZVRyYW5zbGF0aW9uIH0gZnJvbSAncmVhY3QtaTE4bmV4dCc7XG5pbXBvcnQgRmlsbUNvbnRlbnRDYXJkIGZyb20gJy4vRmlsbUNvbnRlbnRDYXJkJztcbmltcG9ydCB7IE1vdmllUmVzb3VyY2VUeXBlLCBNb3ZpZVR5cGUgfSBmcm9tICcuL3R5cGVzJztcbmltcG9ydCB7IHNldEFuaW1hdGlvbnMsIFN0eWxlZEhlYWRpbmdIMSB9IGZyb20gJy4vZmlsbVN0eWxlcyc7XG5cbmludGVyZmFjZSBNb3ZpZUxpc3RpbmdQcm9wcyB7XG4gIG1hcmdpbkxlZnQ/OiBudW1iZXI7XG59XG5cbmNvbnN0IE1vdmllTGlzdGluZyA9IHN0eWxlZC5kaXY8TW92aWVMaXN0aW5nUHJvcHM+YFxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LXdyYXA6IHdyYXA7XG4gIG1hcmdpbjogJHtzcGFjaW5nLnNtYWxsfSAwO1xuICBtYXJnaW4tbGVmdDogJHsocHJvcHMpID0+IHByb3BzLm1hcmdpbkxlZnQgJiYgYCR7cHJvcHMubWFyZ2luTGVmdH1weGB9O1xuICAke3NldEFuaW1hdGlvbnMoKX07XG4gID4gZGl2IHtcbiAgICBvcGFjaXR5OiAwO1xuICAgIGFuaW1hdGlvbi1maWxsLW1vZGU6IGZvcndhcmRzO1xuICAgIGFuaW1hdGlvbi1uYW1lOiBmYWRlSW47XG4gICAgYW5pbWF0aW9uLWR1cmF0aW9uOiAzMDBtcztcbiAgfVxuYDtcblxuaW50ZXJmYWNlIExvYWRpbmdQbGFjZWhvbGRlclByb3BzIHtcbiAgaGVpZ2h0Pzogc3RyaW5nO1xufVxuXG5jb25zdCBMb2FkaW5nUGxhY2Vob2xkZXIgPSBzdHlsZWQuZGl2PExvYWRpbmdQbGFjZWhvbGRlclByb3BzPmBcbiAgaGVpZ2h0OiAkeyhwcm9wcykgPT4gcHJvcHMuaGVpZ2h0fTtcbmA7XG5cbmludGVyZmFjZSBQcm9wcyB7XG4gIGF1dG9TaXplZFByb3BzOiBDYWxjdWxhdGVkQ2Fyb3VzZWxQcm9wcztcbiAgcmVzb3VyY2VUeXBlTmFtZT86IE1vdmllUmVzb3VyY2VUeXBlO1xuICBmZXRjaGluZ01vdmllc0J5VHlwZTogYm9vbGVhbjtcbiAgbW92aWVzQnlUeXBlOiBNb3ZpZVR5cGVbXTtcbiAgcmVzb3VyY2VUeXBlczogTW92aWVSZXNvdXJjZVR5cGVbXTtcbiAgbG9hZGluZ1BsYWNlaG9sZGVySGVpZ2h0Pzogc3RyaW5nO1xuICByZXNpemVUaHVtYm5haWxJbWFnZXM/OiBib29sZWFuO1xufVxuXG5jb25zdCBNb3ZpZUdyaWQgPSAoe1xuICByZXNvdXJjZVR5cGVOYW1lLFxuICBmZXRjaGluZ01vdmllc0J5VHlwZSxcbiAgbW92aWVzQnlUeXBlLFxuICByZXNvdXJjZVR5cGVzLFxuICBsb2FkaW5nUGxhY2Vob2xkZXJIZWlnaHQsXG4gIGF1dG9TaXplZFByb3BzLFxuICByZXNpemVUaHVtYm5haWxJbWFnZXMsXG59OiBQcm9wcykgPT4ge1xuICBjb25zdCB7IHQgfSA9IHVzZVRyYW5zbGF0aW9uKCk7XG4gIHJldHVybiAoXG4gICAgPHNlY3Rpb24+XG4gICAgICA8U3R5bGVkSGVhZGluZ0gxIG1hcmdpbkxlZnQ9e2F1dG9TaXplZFByb3BzLm1hcmdpbn0+XG4gICAgICAgIHtyZXNvdXJjZVR5cGVOYW1lICYmIHJlc291cmNlVHlwZU5hbWUubmFtZX1cbiAgICAgICAgPHNtYWxsPlxuICAgICAgICAgIHtmZXRjaGluZ01vdmllc0J5VHlwZVxuICAgICAgICAgICAgPyB0KCduZGxhRmlsbS5sb2FkaW5nTW92aWVzJylcbiAgICAgICAgICAgIDogYCR7bW92aWVzQnlUeXBlLmxlbmd0aH0gJHt0KCduZGxhRmlsbS5tb3ZpZU1hdGNoSW5DYXRlZ29yeScpfWB9XG4gICAgICAgIDwvc21hbGw+XG4gICAgICA8L1N0eWxlZEhlYWRpbmdIMT5cbiAgICAgIDxNb3ZpZUxpc3RpbmcgbWFyZ2luTGVmdD17YXV0b1NpemVkUHJvcHMubWFyZ2lufT5cbiAgICAgICAge2ZldGNoaW5nTW92aWVzQnlUeXBlICYmIDxMb2FkaW5nUGxhY2Vob2xkZXIgaGVpZ2h0PXtsb2FkaW5nUGxhY2Vob2xkZXJIZWlnaHR9IC8+fVxuICAgICAgICB7IWZldGNoaW5nTW92aWVzQnlUeXBlICYmXG4gICAgICAgICAgbW92aWVzQnlUeXBlLm1hcCgobW92aWUsIGluZGV4KSA9PiAoXG4gICAgICAgICAgICA8RmlsbUNvbnRlbnRDYXJkXG4gICAgICAgICAgICAgIGtleT17aW5kZXh9XG4gICAgICAgICAgICAgIGhpZGVUYWdzXG4gICAgICAgICAgICAgIG1vdmllPXttb3ZpZX1cbiAgICAgICAgICAgICAgY29sdW1uV2lkdGg9e2F1dG9TaXplZFByb3BzLmNvbHVtbldpZHRofVxuICAgICAgICAgICAgICBkaXN0YW5jZUJldHdlZW5JdGVtcz17YXV0b1NpemVkUHJvcHMuZGlzdGFuY2VCZXR3ZWVuSXRlbXN9XG4gICAgICAgICAgICAgIHJlc291cmNlVHlwZXM9e3Jlc291cmNlVHlwZXN9XG4gICAgICAgICAgICAgIHJlc2l6ZVRodW1ibmFpbEltYWdlcz17cmVzaXplVGh1bWJuYWlsSW1hZ2VzfVxuICAgICAgICAgICAgLz5cbiAgICAgICAgICApKX1cbiAgICAgIDwvTW92aWVMaXN0aW5nPlxuICAgIDwvc2VjdGlvbj5cbiAgKTtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IE1vdmllR3JpZDtcbiJdfQ== */"));
13
+ }, ";", setAnimations(), ";margin-left:", spacing.normal, ";margin-right:", spacing.normal, ";", mq.range({
14
+ from: breakpoints.desktop
15
+ }), "{margin-left:", spacingUnit * 3, "px;margin-right:", spacingUnit * 3, "px;}>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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIk1vdmllR3JpZC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBV2tEIiwiZmlsZSI6Ik1vdmllR3JpZC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBicmVha3BvaW50cywgbXEsIHNwYWNpbmcsIHNwYWNpbmdVbml0IH0gZnJvbSAnQG5kbGEvY29yZSc7XG5pbXBvcnQgeyB1c2VUcmFuc2xhdGlvbiB9IGZyb20gJ3JlYWN0LWkxOG5leHQnO1xuaW1wb3J0IEZpbG1Db250ZW50Q2FyZCBmcm9tICcuL0ZpbG1Db250ZW50Q2FyZCc7XG5pbXBvcnQgeyBNb3ZpZVJlc291cmNlVHlwZSwgTW92aWVUeXBlIH0gZnJvbSAnLi90eXBlcyc7XG5pbXBvcnQgeyBzZXRBbmltYXRpb25zLCBTdHlsZWRIZWFkaW5nSDEgfSBmcm9tICcuL2ZpbG1TdHlsZXMnO1xuXG5pbnRlcmZhY2UgTW92aWVMaXN0aW5nUHJvcHMge1xuICBtYXJnaW5MZWZ0PzogbnVtYmVyO1xufVxuXG5jb25zdCBNb3ZpZUxpc3RpbmcgPSBzdHlsZWQuZGl2PE1vdmllTGlzdGluZ1Byb3BzPmBcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC13cmFwOiB3cmFwO1xuICBnYXA6ICR7c3BhY2luZy5ub3JtYWx9O1xuICBtYXJnaW46ICR7c3BhY2luZy5zbWFsbH0gMDtcbiAgbWFyZ2luLWxlZnQ6ICR7KHByb3BzKSA9PiBwcm9wcy5tYXJnaW5MZWZ0ICYmIGAke3Byb3BzLm1hcmdpbkxlZnR9cHhgfTtcbiAgJHtzZXRBbmltYXRpb25zKCl9O1xuICBtYXJnaW4tbGVmdDogJHtzcGFjaW5nLm5vcm1hbH07XG4gIG1hcmdpbi1yaWdodDogJHtzcGFjaW5nLm5vcm1hbH07XG4gICR7bXEucmFuZ2UoeyBmcm9tOiBicmVha3BvaW50cy5kZXNrdG9wIH0pfSB7XG4gICAgbWFyZ2luLWxlZnQ6ICR7c3BhY2luZ1VuaXQgKiAzfXB4O1xuICAgIG1hcmdpbi1yaWdodDogJHtzcGFjaW5nVW5pdCAqIDN9cHg7XG4gIH1cbiAgPiBkaXYge1xuICAgIG9wYWNpdHk6IDA7XG4gICAgYW5pbWF0aW9uLWZpbGwtbW9kZTogZm9yd2FyZHM7XG4gICAgYW5pbWF0aW9uLW5hbWU6IGZhZGVJbjtcbiAgICBhbmltYXRpb24tZHVyYXRpb246IDMwMG1zO1xuICB9XG5gO1xuXG5pbnRlcmZhY2UgTG9hZGluZ1BsYWNlaG9sZGVyUHJvcHMge1xuICBoZWlnaHQ/OiBzdHJpbmc7XG59XG5cbmNvbnN0IExvYWRpbmdQbGFjZWhvbGRlciA9IHN0eWxlZC5kaXY8TG9hZGluZ1BsYWNlaG9sZGVyUHJvcHM+YFxuICBoZWlnaHQ6ICR7KHByb3BzKSA9PiBwcm9wcy5oZWlnaHR9O1xuYDtcblxuaW50ZXJmYWNlIFByb3BzIHtcbiAgcmVzb3VyY2VUeXBlTmFtZT86IE1vdmllUmVzb3VyY2VUeXBlO1xuICBmZXRjaGluZ01vdmllc0J5VHlwZTogYm9vbGVhbjtcbiAgbW92aWVzQnlUeXBlOiBNb3ZpZVR5cGVbXTtcbiAgcmVzb3VyY2VUeXBlczogTW92aWVSZXNvdXJjZVR5cGVbXTtcbiAgbG9hZGluZ1BsYWNlaG9sZGVySGVpZ2h0Pzogc3RyaW5nO1xufVxuXG5jb25zdCBNb3ZpZUdyaWQgPSAoe1xuICByZXNvdXJjZVR5cGVOYW1lLFxuICBmZXRjaGluZ01vdmllc0J5VHlwZSxcbiAgbW92aWVzQnlUeXBlLFxuICByZXNvdXJjZVR5cGVzLFxuICBsb2FkaW5nUGxhY2Vob2xkZXJIZWlnaHQsXG59OiBQcm9wcykgPT4ge1xuICBjb25zdCB7IHQgfSA9IHVzZVRyYW5zbGF0aW9uKCk7XG4gIHJldHVybiAoXG4gICAgPHNlY3Rpb24+XG4gICAgICA8U3R5bGVkSGVhZGluZ0gxPlxuICAgICAgICB7cmVzb3VyY2VUeXBlTmFtZSAmJiByZXNvdXJjZVR5cGVOYW1lLm5hbWV9XG4gICAgICAgIDxzbWFsbD5cbiAgICAgICAgICB7ZmV0Y2hpbmdNb3ZpZXNCeVR5cGVcbiAgICAgICAgICAgID8gdCgnbmRsYUZpbG0ubG9hZGluZ01vdmllcycpXG4gICAgICAgICAgICA6IGAke21vdmllc0J5VHlwZS5sZW5ndGh9ICR7dCgnbmRsYUZpbG0ubW92aWVNYXRjaEluQ2F0ZWdvcnknKX1gfVxuICAgICAgICA8L3NtYWxsPlxuICAgICAgPC9TdHlsZWRIZWFkaW5nSDE+XG4gICAgICA8TW92aWVMaXN0aW5nPlxuICAgICAgICB7ZmV0Y2hpbmdNb3ZpZXNCeVR5cGUgJiYgPExvYWRpbmdQbGFjZWhvbGRlciBoZWlnaHQ9e2xvYWRpbmdQbGFjZWhvbGRlckhlaWdodH0gLz59XG4gICAgICAgIHshZmV0Y2hpbmdNb3ZpZXNCeVR5cGUgJiZcbiAgICAgICAgICBtb3ZpZXNCeVR5cGUubWFwKChtb3ZpZSwgaW5kZXgpID0+IChcbiAgICAgICAgICAgIDxGaWxtQ29udGVudENhcmQga2V5PXtpbmRleH0gaGlkZVRhZ3MgbW92aWU9e21vdmllfSByZXNvdXJjZVR5cGVzPXtyZXNvdXJjZVR5cGVzfSBsYXp5IHR5cGU9XCJsaXN0XCIgLz5cbiAgICAgICAgICApKX1cbiAgICAgIDwvTW92aWVMaXN0aW5nPlxuICAgIDwvc2VjdGlvbj5cbiAgKTtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IE1vdmllR3JpZDtcbiJdfQ== */"));
14
16
  var LoadingPlaceholder = /*#__PURE__*/_styled("div", {
15
17
  target: "e1t64qur0",
16
18
  label: "LoadingPlaceholder"
17
19
  })("height:", function (props) {
18
20
  return props.height;
19
- }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIk1vdmllR3JpZC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBOEI4RCIsImZpbGUiOiJNb3ZpZUdyaWQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgc3BhY2luZyB9IGZyb20gJ0BuZGxhL2NvcmUnO1xuaW1wb3J0IHsgQ2FsY3VsYXRlZENhcm91c2VsUHJvcHMgfSBmcm9tICdAbmRsYS9jYXJvdXNlbCc7XG5pbXBvcnQgeyB1c2VUcmFuc2xhdGlvbiB9IGZyb20gJ3JlYWN0LWkxOG5leHQnO1xuaW1wb3J0IEZpbG1Db250ZW50Q2FyZCBmcm9tICcuL0ZpbG1Db250ZW50Q2FyZCc7XG5pbXBvcnQgeyBNb3ZpZVJlc291cmNlVHlwZSwgTW92aWVUeXBlIH0gZnJvbSAnLi90eXBlcyc7XG5pbXBvcnQgeyBzZXRBbmltYXRpb25zLCBTdHlsZWRIZWFkaW5nSDEgfSBmcm9tICcuL2ZpbG1TdHlsZXMnO1xuXG5pbnRlcmZhY2UgTW92aWVMaXN0aW5nUHJvcHMge1xuICBtYXJnaW5MZWZ0PzogbnVtYmVyO1xufVxuXG5jb25zdCBNb3ZpZUxpc3RpbmcgPSBzdHlsZWQuZGl2PE1vdmllTGlzdGluZ1Byb3BzPmBcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC13cmFwOiB3cmFwO1xuICBtYXJnaW46ICR7c3BhY2luZy5zbWFsbH0gMDtcbiAgbWFyZ2luLWxlZnQ6ICR7KHByb3BzKSA9PiBwcm9wcy5tYXJnaW5MZWZ0ICYmIGAke3Byb3BzLm1hcmdpbkxlZnR9cHhgfTtcbiAgJHtzZXRBbmltYXRpb25zKCl9O1xuICA+IGRpdiB7XG4gICAgb3BhY2l0eTogMDtcbiAgICBhbmltYXRpb24tZmlsbC1tb2RlOiBmb3J3YXJkcztcbiAgICBhbmltYXRpb24tbmFtZTogZmFkZUluO1xuICAgIGFuaW1hdGlvbi1kdXJhdGlvbjogMzAwbXM7XG4gIH1cbmA7XG5cbmludGVyZmFjZSBMb2FkaW5nUGxhY2Vob2xkZXJQcm9wcyB7XG4gIGhlaWdodD86IHN0cmluZztcbn1cblxuY29uc3QgTG9hZGluZ1BsYWNlaG9sZGVyID0gc3R5bGVkLmRpdjxMb2FkaW5nUGxhY2Vob2xkZXJQcm9wcz5gXG4gIGhlaWdodDogJHsocHJvcHMpID0+IHByb3BzLmhlaWdodH07XG5gO1xuXG5pbnRlcmZhY2UgUHJvcHMge1xuICBhdXRvU2l6ZWRQcm9wczogQ2FsY3VsYXRlZENhcm91c2VsUHJvcHM7XG4gIHJlc291cmNlVHlwZU5hbWU/OiBNb3ZpZVJlc291cmNlVHlwZTtcbiAgZmV0Y2hpbmdNb3ZpZXNCeVR5cGU6IGJvb2xlYW47XG4gIG1vdmllc0J5VHlwZTogTW92aWVUeXBlW107XG4gIHJlc291cmNlVHlwZXM6IE1vdmllUmVzb3VyY2VUeXBlW107XG4gIGxvYWRpbmdQbGFjZWhvbGRlckhlaWdodD86IHN0cmluZztcbiAgcmVzaXplVGh1bWJuYWlsSW1hZ2VzPzogYm9vbGVhbjtcbn1cblxuY29uc3QgTW92aWVHcmlkID0gKHtcbiAgcmVzb3VyY2VUeXBlTmFtZSxcbiAgZmV0Y2hpbmdNb3ZpZXNCeVR5cGUsXG4gIG1vdmllc0J5VHlwZSxcbiAgcmVzb3VyY2VUeXBlcyxcbiAgbG9hZGluZ1BsYWNlaG9sZGVySGVpZ2h0LFxuICBhdXRvU2l6ZWRQcm9wcyxcbiAgcmVzaXplVGh1bWJuYWlsSW1hZ2VzLFxufTogUHJvcHMpID0+IHtcbiAgY29uc3QgeyB0IH0gPSB1c2VUcmFuc2xhdGlvbigpO1xuICByZXR1cm4gKFxuICAgIDxzZWN0aW9uPlxuICAgICAgPFN0eWxlZEhlYWRpbmdIMSBtYXJnaW5MZWZ0PXthdXRvU2l6ZWRQcm9wcy5tYXJnaW59PlxuICAgICAgICB7cmVzb3VyY2VUeXBlTmFtZSAmJiByZXNvdXJjZVR5cGVOYW1lLm5hbWV9XG4gICAgICAgIDxzbWFsbD5cbiAgICAgICAgICB7ZmV0Y2hpbmdNb3ZpZXNCeVR5cGVcbiAgICAgICAgICAgID8gdCgnbmRsYUZpbG0ubG9hZGluZ01vdmllcycpXG4gICAgICAgICAgICA6IGAke21vdmllc0J5VHlwZS5sZW5ndGh9ICR7dCgnbmRsYUZpbG0ubW92aWVNYXRjaEluQ2F0ZWdvcnknKX1gfVxuICAgICAgICA8L3NtYWxsPlxuICAgICAgPC9TdHlsZWRIZWFkaW5nSDE+XG4gICAgICA8TW92aWVMaXN0aW5nIG1hcmdpbkxlZnQ9e2F1dG9TaXplZFByb3BzLm1hcmdpbn0+XG4gICAgICAgIHtmZXRjaGluZ01vdmllc0J5VHlwZSAmJiA8TG9hZGluZ1BsYWNlaG9sZGVyIGhlaWdodD17bG9hZGluZ1BsYWNlaG9sZGVySGVpZ2h0fSAvPn1cbiAgICAgICAgeyFmZXRjaGluZ01vdmllc0J5VHlwZSAmJlxuICAgICAgICAgIG1vdmllc0J5VHlwZS5tYXAoKG1vdmllLCBpbmRleCkgPT4gKFxuICAgICAgICAgICAgPEZpbG1Db250ZW50Q2FyZFxuICAgICAgICAgICAgICBrZXk9e2luZGV4fVxuICAgICAgICAgICAgICBoaWRlVGFnc1xuICAgICAgICAgICAgICBtb3ZpZT17bW92aWV9XG4gICAgICAgICAgICAgIGNvbHVtbldpZHRoPXthdXRvU2l6ZWRQcm9wcy5jb2x1bW5XaWR0aH1cbiAgICAgICAgICAgICAgZGlzdGFuY2VCZXR3ZWVuSXRlbXM9e2F1dG9TaXplZFByb3BzLmRpc3RhbmNlQmV0d2Vlbkl0ZW1zfVxuICAgICAgICAgICAgICByZXNvdXJjZVR5cGVzPXtyZXNvdXJjZVR5cGVzfVxuICAgICAgICAgICAgICByZXNpemVUaHVtYm5haWxJbWFnZXM9e3Jlc2l6ZVRodW1ibmFpbEltYWdlc31cbiAgICAgICAgICAgIC8+XG4gICAgICAgICAgKSl9XG4gICAgICA8L01vdmllTGlzdGluZz5cbiAgICA8L3NlY3Rpb24+XG4gICk7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBNb3ZpZUdyaWQ7XG4iXX0= */"));
21
+ }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIk1vdmllR3JpZC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBb0M4RCIsImZpbGUiOiJNb3ZpZUdyaWQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgYnJlYWtwb2ludHMsIG1xLCBzcGFjaW5nLCBzcGFjaW5nVW5pdCB9IGZyb20gJ0BuZGxhL2NvcmUnO1xuaW1wb3J0IHsgdXNlVHJhbnNsYXRpb24gfSBmcm9tICdyZWFjdC1pMThuZXh0JztcbmltcG9ydCBGaWxtQ29udGVudENhcmQgZnJvbSAnLi9GaWxtQ29udGVudENhcmQnO1xuaW1wb3J0IHsgTW92aWVSZXNvdXJjZVR5cGUsIE1vdmllVHlwZSB9IGZyb20gJy4vdHlwZXMnO1xuaW1wb3J0IHsgc2V0QW5pbWF0aW9ucywgU3R5bGVkSGVhZGluZ0gxIH0gZnJvbSAnLi9maWxtU3R5bGVzJztcblxuaW50ZXJmYWNlIE1vdmllTGlzdGluZ1Byb3BzIHtcbiAgbWFyZ2luTGVmdD86IG51bWJlcjtcbn1cblxuY29uc3QgTW92aWVMaXN0aW5nID0gc3R5bGVkLmRpdjxNb3ZpZUxpc3RpbmdQcm9wcz5gXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXgtd3JhcDogd3JhcDtcbiAgZ2FwOiAke3NwYWNpbmcubm9ybWFsfTtcbiAgbWFyZ2luOiAke3NwYWNpbmcuc21hbGx9IDA7XG4gIG1hcmdpbi1sZWZ0OiAkeyhwcm9wcykgPT4gcHJvcHMubWFyZ2luTGVmdCAmJiBgJHtwcm9wcy5tYXJnaW5MZWZ0fXB4YH07XG4gICR7c2V0QW5pbWF0aW9ucygpfTtcbiAgbWFyZ2luLWxlZnQ6ICR7c3BhY2luZy5ub3JtYWx9O1xuICBtYXJnaW4tcmlnaHQ6ICR7c3BhY2luZy5ub3JtYWx9O1xuICAke21xLnJhbmdlKHsgZnJvbTogYnJlYWtwb2ludHMuZGVza3RvcCB9KX0ge1xuICAgIG1hcmdpbi1sZWZ0OiAke3NwYWNpbmdVbml0ICogM31weDtcbiAgICBtYXJnaW4tcmlnaHQ6ICR7c3BhY2luZ1VuaXQgKiAzfXB4O1xuICB9XG4gID4gZGl2IHtcbiAgICBvcGFjaXR5OiAwO1xuICAgIGFuaW1hdGlvbi1maWxsLW1vZGU6IGZvcndhcmRzO1xuICAgIGFuaW1hdGlvbi1uYW1lOiBmYWRlSW47XG4gICAgYW5pbWF0aW9uLWR1cmF0aW9uOiAzMDBtcztcbiAgfVxuYDtcblxuaW50ZXJmYWNlIExvYWRpbmdQbGFjZWhvbGRlclByb3BzIHtcbiAgaGVpZ2h0Pzogc3RyaW5nO1xufVxuXG5jb25zdCBMb2FkaW5nUGxhY2Vob2xkZXIgPSBzdHlsZWQuZGl2PExvYWRpbmdQbGFjZWhvbGRlclByb3BzPmBcbiAgaGVpZ2h0OiAkeyhwcm9wcykgPT4gcHJvcHMuaGVpZ2h0fTtcbmA7XG5cbmludGVyZmFjZSBQcm9wcyB7XG4gIHJlc291cmNlVHlwZU5hbWU/OiBNb3ZpZVJlc291cmNlVHlwZTtcbiAgZmV0Y2hpbmdNb3ZpZXNCeVR5cGU6IGJvb2xlYW47XG4gIG1vdmllc0J5VHlwZTogTW92aWVUeXBlW107XG4gIHJlc291cmNlVHlwZXM6IE1vdmllUmVzb3VyY2VUeXBlW107XG4gIGxvYWRpbmdQbGFjZWhvbGRlckhlaWdodD86IHN0cmluZztcbn1cblxuY29uc3QgTW92aWVHcmlkID0gKHtcbiAgcmVzb3VyY2VUeXBlTmFtZSxcbiAgZmV0Y2hpbmdNb3ZpZXNCeVR5cGUsXG4gIG1vdmllc0J5VHlwZSxcbiAgcmVzb3VyY2VUeXBlcyxcbiAgbG9hZGluZ1BsYWNlaG9sZGVySGVpZ2h0LFxufTogUHJvcHMpID0+IHtcbiAgY29uc3QgeyB0IH0gPSB1c2VUcmFuc2xhdGlvbigpO1xuICByZXR1cm4gKFxuICAgIDxzZWN0aW9uPlxuICAgICAgPFN0eWxlZEhlYWRpbmdIMT5cbiAgICAgICAge3Jlc291cmNlVHlwZU5hbWUgJiYgcmVzb3VyY2VUeXBlTmFtZS5uYW1lfVxuICAgICAgICA8c21hbGw+XG4gICAgICAgICAge2ZldGNoaW5nTW92aWVzQnlUeXBlXG4gICAgICAgICAgICA/IHQoJ25kbGFGaWxtLmxvYWRpbmdNb3ZpZXMnKVxuICAgICAgICAgICAgOiBgJHttb3ZpZXNCeVR5cGUubGVuZ3RofSAke3QoJ25kbGFGaWxtLm1vdmllTWF0Y2hJbkNhdGVnb3J5Jyl9YH1cbiAgICAgICAgPC9zbWFsbD5cbiAgICAgIDwvU3R5bGVkSGVhZGluZ0gxPlxuICAgICAgPE1vdmllTGlzdGluZz5cbiAgICAgICAge2ZldGNoaW5nTW92aWVzQnlUeXBlICYmIDxMb2FkaW5nUGxhY2Vob2xkZXIgaGVpZ2h0PXtsb2FkaW5nUGxhY2Vob2xkZXJIZWlnaHR9IC8+fVxuICAgICAgICB7IWZldGNoaW5nTW92aWVzQnlUeXBlICYmXG4gICAgICAgICAgbW92aWVzQnlUeXBlLm1hcCgobW92aWUsIGluZGV4KSA9PiAoXG4gICAgICAgICAgICA8RmlsbUNvbnRlbnRDYXJkIGtleT17aW5kZXh9IGhpZGVUYWdzIG1vdmllPXttb3ZpZX0gcmVzb3VyY2VUeXBlcz17cmVzb3VyY2VUeXBlc30gbGF6eSB0eXBlPVwibGlzdFwiIC8+XG4gICAgICAgICAgKSl9XG4gICAgICA8L01vdmllTGlzdGluZz5cbiAgICA8L3NlY3Rpb24+XG4gICk7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBNb3ZpZUdyaWQ7XG4iXX0= */"));
20
22
  var MovieGrid = function MovieGrid(_ref) {
21
23
  var resourceTypeName = _ref.resourceTypeName,
22
24
  fetchingMoviesByType = _ref.fetchingMoviesByType,
23
25
  moviesByType = _ref.moviesByType,
24
26
  resourceTypes = _ref.resourceTypes,
25
- loadingPlaceholderHeight = _ref.loadingPlaceholderHeight,
26
- autoSizedProps = _ref.autoSizedProps,
27
- resizeThumbnailImages = _ref.resizeThumbnailImages;
27
+ loadingPlaceholderHeight = _ref.loadingPlaceholderHeight;
28
28
  var _useTranslation = useTranslation(),
29
29
  t = _useTranslation.t;
30
30
  return _jsxs("section", {
31
31
  children: [_jsxs(StyledHeadingH1, {
32
- marginLeft: autoSizedProps.margin,
33
32
  children: [resourceTypeName && resourceTypeName.name, _jsx("small", {
34
33
  children: fetchingMoviesByType ? t('ndlaFilm.loadingMovies') : "".concat(moviesByType.length, " ").concat(t('ndlaFilm.movieMatchInCategory'))
35
34
  })]
36
35
  }), _jsxs(MovieListing, {
37
- marginLeft: autoSizedProps.margin,
38
36
  children: [fetchingMoviesByType && _jsx(LoadingPlaceholder, {
39
37
  height: loadingPlaceholderHeight
40
38
  }), !fetchingMoviesByType && moviesByType.map(function (movie, index) {
41
39
  return _jsx(FilmContentCard, {
42
40
  hideTags: true,
43
41
  movie: movie,
44
- columnWidth: autoSizedProps.columnWidth,
45
- distanceBetweenItems: autoSizedProps.distanceBetweenItems,
46
42
  resourceTypes: resourceTypes,
47
- resizeThumbnailImages: resizeThumbnailImages
43
+ lazy: true,
44
+ type: "list"
48
45
  }, index);
49
46
  })]
50
47
  })]
@@ -1,5 +1,5 @@
1
1
  import _styled from "@emotion/styled/base";
2
- import { fonts, spacing, colors } from '@ndla/core';
2
+ import { fonts, spacing, colors, mq, breakpoints, spacingUnit } from '@ndla/core';
3
3
  export var setAnimations = function setAnimations() {
4
4
  var styles = {};
5
5
  for (var i = 1; i < 20; i++) {
@@ -12,9 +12,9 @@ export var setAnimations = function setAnimations() {
12
12
  export var StyledHeadingH1 = /*#__PURE__*/_styled("h1", {
13
13
  target: "e1uw8gqd0",
14
14
  label: "StyledHeadingH1"
15
- })(fonts.sizes('22px', '26px'), ";font-weight:", fonts.weight.semibold, ";text-transform:uppercase;letter-spacing:0.05em;color:", colors.white, ";margin:", spacing.xsmall, " 0;margin-left:", function (props) {
16
- return props.marginLeft && "".concat(props.marginLeft, "px");
17
- }, ";small{font-weight:normal;padding-left:", spacing.small, ";color:", colors.brand.grey, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImZpbG1TdHlsZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBaUI0RCIsImZpbGUiOiJmaWxtU3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgZm9udHMsIHNwYWNpbmcsIGNvbG9ycyB9IGZyb20gJ0BuZGxhL2NvcmUnO1xuXG5leHBvcnQgY29uc3Qgc2V0QW5pbWF0aW9ucyA9ICgpID0+IHtcbiAgY29uc3Qgc3R5bGVzOiBhbnkgPSB7fTtcbiAgZm9yIChsZXQgaSA9IDE7IGkgPCAyMDsgaSsrKSB7XG4gICAgc3R5bGVzW2A+IGRpdjpudGgtY2hpbGQoJHtpICsgMX0pYF0gPSB7XG4gICAgICAnYW5pbWF0aW9uLWRlbGF5JzogYCR7aSAqIDUwfW1zYCxcbiAgICB9O1xuICB9XG4gIHJldHVybiBzdHlsZXM7XG59O1xuXG5pbnRlcmZhY2UgU3R5bGVkSGVhZGluZ1Byb3BzIHtcbiAgbWFyZ2luTGVmdD86IG51bWJlcjtcbn1cblxuZXhwb3J0IGNvbnN0IFN0eWxlZEhlYWRpbmdIMSA9IHN0eWxlZC5oMTxTdHlsZWRIZWFkaW5nUHJvcHM+YFxuICAke2ZvbnRzLnNpemVzKCcyMnB4JywgJzI2cHgnKX07XG4gIGZvbnQtd2VpZ2h0OiAke2ZvbnRzLndlaWdodC5zZW1pYm9sZH07XG4gIHRleHQtdHJhbnNmb3JtOiB1cHBlcmNhc2U7XG4gIGxldHRlci1zcGFjaW5nOiAwLjA1ZW07XG4gIGNvbG9yOiAke2NvbG9ycy53aGl0ZX07XG4gIG1hcmdpbjogJHtzcGFjaW5nLnhzbWFsbH0gMDtcbiAgbWFyZ2luLWxlZnQ6ICR7KHByb3BzKSA9PiBwcm9wcy5tYXJnaW5MZWZ0ICYmIGAke3Byb3BzLm1hcmdpbkxlZnR9cHhgfTtcbiAgc21hbGwge1xuICAgIGZvbnQtd2VpZ2h0OiBub3JtYWw7XG4gICAgcGFkZGluZy1sZWZ0OiAke3NwYWNpbmcuc21hbGx9O1xuICAgIGNvbG9yOiAke2NvbG9ycy5icmFuZC5ncmV5fTtcbiAgfVxuYDtcblxuZXhwb3J0IGNvbnN0IFN0eWxlZEhlYWRpbmdIMiA9IFN0eWxlZEhlYWRpbmdIMS53aXRoQ29tcG9uZW50KCdoMicpO1xuIl19 */"));
15
+ })(fonts.sizes('22px', '26px'), ";font-weight:", fonts.weight.semibold, ";text-transform:uppercase;letter-spacing:0.05em;color:", colors.white, ";margin:", spacing.xsmall, " 0;small{font-weight:normal;padding-left:", spacing.small, ";color:", colors.brand.grey, ";}margin-left:", spacing.normal, ";margin-right:", spacing.normal, ";", mq.range({
16
+ from: breakpoints.desktop
17
+ }), "{margin-left:", spacingUnit * 3, "px;margin-right:", spacingUnit * 3, "px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImZpbG1TdHlsZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBYXdDIiwiZmlsZSI6ImZpbG1TdHlsZXMudHMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBmb250cywgc3BhY2luZywgY29sb3JzLCBtcSwgYnJlYWtwb2ludHMsIHNwYWNpbmdVbml0IH0gZnJvbSAnQG5kbGEvY29yZSc7XG5cbmV4cG9ydCBjb25zdCBzZXRBbmltYXRpb25zID0gKCkgPT4ge1xuICBjb25zdCBzdHlsZXM6IGFueSA9IHt9O1xuICBmb3IgKGxldCBpID0gMTsgaSA8IDIwOyBpKyspIHtcbiAgICBzdHlsZXNbYD4gZGl2Om50aC1jaGlsZCgke2kgKyAxfSlgXSA9IHtcbiAgICAgICdhbmltYXRpb24tZGVsYXknOiBgJHtpICogNTB9bXNgLFxuICAgIH07XG4gIH1cbiAgcmV0dXJuIHN0eWxlcztcbn07XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRIZWFkaW5nSDEgPSBzdHlsZWQuaDFgXG4gICR7Zm9udHMuc2l6ZXMoJzIycHgnLCAnMjZweCcpfTtcbiAgZm9udC13ZWlnaHQ6ICR7Zm9udHMud2VpZ2h0LnNlbWlib2xkfTtcbiAgdGV4dC10cmFuc2Zvcm06IHVwcGVyY2FzZTtcbiAgbGV0dGVyLXNwYWNpbmc6IDAuMDVlbTtcbiAgY29sb3I6ICR7Y29sb3JzLndoaXRlfTtcbiAgbWFyZ2luOiAke3NwYWNpbmcueHNtYWxsfSAwO1xuICBzbWFsbCB7XG4gICAgZm9udC13ZWlnaHQ6IG5vcm1hbDtcbiAgICBwYWRkaW5nLWxlZnQ6ICR7c3BhY2luZy5zbWFsbH07XG4gICAgY29sb3I6ICR7Y29sb3JzLmJyYW5kLmdyZXl9O1xuICB9XG4gIG1hcmdpbi1sZWZ0OiAke3NwYWNpbmcubm9ybWFsfTtcbiAgbWFyZ2luLXJpZ2h0OiAke3NwYWNpbmcubm9ybWFsfTtcbiAgJHttcS5yYW5nZSh7IGZyb206IGJyZWFrcG9pbnRzLmRlc2t0b3AgfSl9IHtcbiAgICBtYXJnaW4tbGVmdDogJHtzcGFjaW5nVW5pdCAqIDN9cHg7XG4gICAgbWFyZ2luLXJpZ2h0OiAke3NwYWNpbmdVbml0ICogM31weDtcbiAgfVxuYDtcblxuZXhwb3J0IGNvbnN0IFN0eWxlZEhlYWRpbmdIMiA9IFN0eWxlZEhlYWRpbmdIMS53aXRoQ29tcG9uZW50KCdoMicpO1xuIl19 */"));
18
18
  export var StyledHeadingH2 = StyledHeadingH1.withComponent('h2', {
19
19
  target: "e1uw8gqd1",
20
20
  label: "StyledHeadingH2"