@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,9 @@
1
1
  "use strict";
2
2
 
3
- 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); }
4
3
  Object.defineProperty(exports, "__esModule", {
5
4
  value: true
6
5
  });
7
- exports.slideshowBreakpoints = exports.default = void 0;
6
+ exports.default = void 0;
8
7
  var _base = _interopRequireDefault(require("@emotion/styled/base"));
9
8
  var _react = require("react");
10
9
  var _carousel = require("@ndla/carousel");
@@ -13,13 +12,9 @@ var _safelink = _interopRequireDefault(require("@ndla/safelink"));
13
12
  var _button = require("@ndla/button");
14
13
  var _common = require("@ndla/icons/common");
15
14
  var _FilmContentCard = _interopRequireDefault(require("./FilmContentCard"));
15
+ var _Image = _interopRequireDefault(require("../Image"));
16
16
  var _jsxRuntime = require("@emotion/react/jsx-runtime");
17
17
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
18
- 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; }
19
- 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; }
20
- 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; }
21
- function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return _typeof(key) === "symbol" ? key : String(key); }
22
- 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); }
23
18
  function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
24
19
  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."); }
25
20
  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); }
@@ -33,43 +28,6 @@ function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringif
33
28
  * LICENSE file in the root directory of this source tree.
34
29
  *
35
30
  */
36
- var slideshowBreakpoints = [{
37
- until: 'mobileWide',
38
- columnsPrSlide: 2,
39
- distanceBetweenItems: _core.spacingUnit / 2,
40
- margin: _core.spacingUnit,
41
- arrowOffset: 13
42
- }, {
43
- until: 'tabletWide',
44
- columnsPrSlide: 3,
45
- distanceBetweenItems: _core.spacingUnit / 2,
46
- margin: _core.spacingUnit,
47
- arrowOffset: 13
48
- }, {
49
- until: 'desktop',
50
- columnsPrSlide: 3,
51
- distanceBetweenItems: _core.spacingUnit,
52
- margin: _core.spacingUnit * 2,
53
- arrowOffset: 0
54
- }, {
55
- until: 'wide',
56
- columnsPrSlide: 3,
57
- distanceBetweenItems: _core.spacingUnit,
58
- margin: _core.spacingUnit * 2,
59
- arrowOffset: 0
60
- }, {
61
- until: 'ultraWide',
62
- columnsPrSlide: 3,
63
- distanceBetweenItems: _core.spacingUnit,
64
- margin: _core.spacingUnit * 3.5,
65
- arrowOffset: 0
66
- }, {
67
- columnsPrSlide: 3,
68
- distanceBetweenItems: _core.spacingUnit,
69
- margin: _core.spacingUnit * 3.5,
70
- arrowOffset: 0
71
- }];
72
- exports.slideshowBreakpoints = slideshowBreakpoints;
73
31
  var SlideInfoWrapper = /*#__PURE__*/(0, _base.default)("div", {
74
32
  target: "essc37o6",
75
33
  label: "SlideInfoWrapper"
@@ -77,7 +35,7 @@ var SlideInfoWrapper = /*#__PURE__*/(0, _base.default)("div", {
77
35
  until: _core.breakpoints.desktop
78
36
  }), "{top:30%;max-width:60%;min-width:60%;}", _core.mq.range({
79
37
  until: _core.breakpoints.tablet
80
- }), "{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"]} */"));
38
+ }), "{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 */"));
81
39
  var StyledSafeLink = /*#__PURE__*/(0, _base.default)(_safelink.default, {
82
40
  target: "essc37o5",
83
41
  label: "StyledSafeLink"
@@ -87,19 +45,19 @@ var StyledSafeLink = /*#__PURE__*/(0, _base.default)(_safelink.default, {
87
45
  } : {
88
46
  name: "rmwyk3",
89
47
  styles: "position:relative;display:block;box-shadow:none",
90
- 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"]} */",
48
+ 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 */",
91
49
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
92
50
  });
93
51
  var InfoWrapper = /*#__PURE__*/(0, _base.default)("div", {
94
52
  target: "essc37o4",
95
53
  label: "InfoWrapper"
96
- })("padding:", _core.spacing.normal, ";border-radius:", _core.misc.borderRadius, ";border:0.5px solid ", _core.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"]} */"));
97
- var StyledImg = /*#__PURE__*/(0, _base.default)("img", {
54
+ })("padding:", _core.spacing.normal, ";border-radius:", _core.misc.borderRadius, ";border:0.5px solid ", _core.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 */"));
55
+ var StyledImg = /*#__PURE__*/(0, _base.default)(_Image.default, {
98
56
  target: "essc37o3",
99
57
  label: "StyledImg"
100
- })("max-height:600px;object-position:top;width:100%;aspect-ratio:16/9;", _core.mq.range({
58
+ })("max-height:600px;min-height:600px;object-position:top;width:100%;aspect-ratio:16/9;", _core.mq.range({
101
59
  until: _core.breakpoints.tablet
102
- }), "{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"]} */"));
60
+ }), "{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 */"));
103
61
  var CarouselContainer = /*#__PURE__*/(0, _base.default)("div", {
104
62
  target: "essc37o2",
105
63
  label: "CarouselContainer"
@@ -107,11 +65,11 @@ var CarouselContainer = /*#__PURE__*/(0, _base.default)("div", {
107
65
  from: _core.breakpoints.tablet
108
66
  }), "{margin-top:-70px;}", _core.mq.range({
109
67
  from: _core.breakpoints.desktop
110
- }), "{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"]} */"));
68
+ }), "{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 */"));
111
69
  var SlideshowButton = /*#__PURE__*/(0, _base.default)(_button.IconButtonV2, {
112
70
  target: "essc37o1",
113
71
  label: "SlideshowButton"
114
- })("margin-top:", _core.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"]} */"));
72
+ })("margin-top:", _core.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 */"));
115
73
  var shouldForwardProp = function shouldForwardProp(p) {
116
74
  return p !== 'current';
117
75
  };
@@ -121,77 +79,68 @@ var StyledFilmContentCard = /*#__PURE__*/(0, _base.default)(_FilmContentCard.def
121
79
  label: "StyledFilmContentCard"
122
80
  })("margin-bottom:2%;transform:", function (p) {
123
81
  return p.current ? 'translateY(0%)' : 'translateY(10%)';
124
- }, ";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"]} */"));
82
+ }, ";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 */"));
125
83
  var FilmSlideshow = function FilmSlideshow(_ref) {
84
+ var _currentSlide$metaIma, _currentSlide$metaIma2;
126
85
  var slideshow = _ref.slideshow;
127
86
  var _useState = (0, _react.useState)(slideshow[0]),
128
87
  _useState2 = _slicedToArray(_useState, 2),
129
88
  currentSlide = _useState2[0],
130
- _setCurrentSlide = _useState2[1];
131
- return (0, _jsxRuntime.jsx)(_carousel.CarouselAutosize, {
132
- breakpoints: slideshowBreakpoints,
133
- itemsLength: slideshow.length,
134
- children: function children(autoSizedProps) {
135
- var _currentSlide$metaIma, _currentSlide$metaIma2, _currentSlide$metaIma3, _currentSlide$metaIma4;
136
- return (0, _jsxRuntime.jsxs)("section", {
137
- children: [(0, _jsxRuntime.jsxs)(StyledSafeLink, {
138
- to: currentSlide.path,
139
- tabIndex: -1,
140
- "aria-hidden": true,
141
- children: [(0, _jsxRuntime.jsx)(StyledImg, {
142
- src: (_currentSlide$metaIma = (_currentSlide$metaIma2 = currentSlide.metaImage) === null || _currentSlide$metaIma2 === void 0 ? void 0 : _currentSlide$metaIma2.url) !== null && _currentSlide$metaIma !== void 0 ? _currentSlide$metaIma : '',
143
- alt: (_currentSlide$metaIma3 = (_currentSlide$metaIma4 = currentSlide.metaImage) === null || _currentSlide$metaIma4 === void 0 ? void 0 : _currentSlide$metaIma4.alt) !== null && _currentSlide$metaIma3 !== void 0 ? _currentSlide$metaIma3 : ''
144
- }), (0, _jsxRuntime.jsx)(SlideInfoWrapper, {
145
- children: (0, _jsxRuntime.jsxs)(InfoWrapper, {
146
- children: [(0, _jsxRuntime.jsx)("h3", {
147
- children: currentSlide.title
148
- }), (0, _jsxRuntime.jsx)("span", {
149
- id: "currentMovieDescription",
150
- children: currentSlide.metaDescription
151
- })]
152
- })
89
+ setCurrentSlide = _useState2[1];
90
+ return (0, _jsxRuntime.jsxs)("section", {
91
+ children: [(0, _jsxRuntime.jsxs)(StyledSafeLink, {
92
+ to: currentSlide.path,
93
+ tabIndex: -1,
94
+ "aria-hidden": true,
95
+ children: [(0, _jsxRuntime.jsx)(StyledImg, {
96
+ src: (_currentSlide$metaIma = (_currentSlide$metaIma2 = currentSlide.metaImage) === null || _currentSlide$metaIma2 === void 0 ? void 0 : _currentSlide$metaIma2.url) !== null && _currentSlide$metaIma !== void 0 ? _currentSlide$metaIma : '',
97
+ sizes: "(min-width: 1140px) 1140px, (min-width: 720px) 100vw, 100vw",
98
+ alt: ""
99
+ }), (0, _jsxRuntime.jsx)(SlideInfoWrapper, {
100
+ children: (0, _jsxRuntime.jsxs)(InfoWrapper, {
101
+ children: [(0, _jsxRuntime.jsx)("h3", {
102
+ children: currentSlide.title
103
+ }), (0, _jsxRuntime.jsx)("span", {
104
+ id: "currentMovieDescription",
105
+ children: currentSlide.metaDescription
153
106
  })]
154
- }), (0, _jsxRuntime.jsx)(CarouselContainer, {
155
- children: (0, _jsxRuntime.jsx)(_carousel.Carousel, _objectSpread({
156
- leftButton: (0, _jsxRuntime.jsx)(SlideshowButton, {
157
- "aria-label": '',
158
- children: (0, _jsxRuntime.jsx)(_common.ChevronLeft, {})
159
- }),
160
- rightButton: (0, _jsxRuntime.jsx)(SlideshowButton, {
161
- "aria-label": '',
162
- children: (0, _jsxRuntime.jsx)(_common.ChevronRight, {})
163
- }),
164
- items: slideshow.map(function (movie) {
165
- return (0, _jsxRuntime.jsx)(FilmCard, {
166
- current: movie.id === currentSlide.id,
167
- movie: movie,
168
- columnWidth: autoSizedProps.columnWidth,
169
- setCurrentSlide: function setCurrentSlide() {
170
- return _setCurrentSlide(movie);
171
- }
172
- }, movie.id);
173
- })
174
- }, autoSizedProps))
175
- })]
176
- });
177
- }
107
+ })
108
+ })]
109
+ }), (0, _jsxRuntime.jsx)(CarouselContainer, {
110
+ children: (0, _jsxRuntime.jsx)(_carousel.Carousel, {
111
+ leftButton: (0, _jsxRuntime.jsx)(SlideshowButton, {
112
+ "aria-label": "",
113
+ children: (0, _jsxRuntime.jsx)(_common.ChevronLeft, {})
114
+ }),
115
+ rightButton: (0, _jsxRuntime.jsx)(SlideshowButton, {
116
+ "aria-label": "",
117
+ children: (0, _jsxRuntime.jsx)(_common.ChevronRight, {})
118
+ }),
119
+ items: slideshow.map(function (movie) {
120
+ return (0, _jsxRuntime.jsx)(FilmCard, {
121
+ current: movie.id === currentSlide.id,
122
+ movie: movie,
123
+ setCurrentSlide: setCurrentSlide
124
+ }, movie.id);
125
+ })
126
+ })
127
+ })]
178
128
  });
179
129
  };
180
130
  var FilmCard = function FilmCard(_ref2) {
181
131
  var setCurrentSlide = _ref2.setCurrentSlide,
182
132
  movie = _ref2.movie,
183
- current = _ref2.current,
184
- columnWidth = _ref2.columnWidth;
133
+ current = _ref2.current;
185
134
  var _useState3 = (0, _react.useState)(undefined),
186
135
  _useState4 = _slicedToArray(_useState3, 2),
187
136
  hoverCallback = _useState4[0],
188
137
  setHoverCallback = _useState4[1];
189
138
  var onHover = (0, _react.useCallback)(function () {
190
139
  var timeout = setTimeout(function () {
191
- return setCurrentSlide();
140
+ return setCurrentSlide(movie);
192
141
  }, 500);
193
142
  setHoverCallback(timeout);
194
- }, [setCurrentSlide]);
143
+ }, [movie, setCurrentSlide]);
195
144
  return (0, _jsxRuntime.jsx)(StyledFilmContentCard, {
196
145
  onMouseEnter: onHover,
197
146
  onMouseLeave: function onMouseLeave() {
@@ -201,12 +150,11 @@ var FilmCard = function FilmCard(_ref2) {
201
150
  }
202
151
  },
203
152
  onFocus: function onFocus() {
204
- return setCurrentSlide();
153
+ return setCurrentSlide(movie);
205
154
  },
206
155
  current: current,
207
156
  "aria-describedby": 'currentMovieDescription',
208
157
  movie: movie,
209
- columnWidth: columnWidth,
210
158
  resourceTypes: []
211
159
  }, movie.id);
212
160
  };
@@ -1,13 +1,10 @@
1
- import { CalculatedCarouselProps } from '@ndla/carousel';
2
1
  import { MovieResourceType, MovieType } from './types';
3
2
  interface Props {
4
- autoSizedProps: CalculatedCarouselProps;
5
3
  resourceTypeName?: MovieResourceType;
6
4
  fetchingMoviesByType: boolean;
7
5
  moviesByType: MovieType[];
8
6
  resourceTypes: MovieResourceType[];
9
7
  loadingPlaceholderHeight?: string;
10
- resizeThumbnailImages?: boolean;
11
8
  }
12
- declare const MovieGrid: ({ resourceTypeName, fetchingMoviesByType, moviesByType, resourceTypes, loadingPlaceholderHeight, autoSizedProps, resizeThumbnailImages, }: Props) => import("@emotion/react/jsx-runtime").JSX.Element;
9
+ declare const MovieGrid: ({ resourceTypeName, fetchingMoviesByType, moviesByType, resourceTypes, loadingPlaceholderHeight, }: Props) => import("@emotion/react/jsx-runtime").JSX.Element;
13
10
  export default MovieGrid;
@@ -14,43 +14,40 @@ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { de
14
14
  var MovieListing = /*#__PURE__*/(0, _base.default)("div", {
15
15
  target: "e1t64qur1",
16
16
  label: "MovieListing"
17
- })("display:flex;flex-wrap:wrap;margin:", _core.spacing.small, " 0;margin-left:", function (props) {
17
+ })("display:flex;flex-wrap:wrap;gap:", _core.spacing.normal, ";margin:", _core.spacing.small, " 0;margin-left:", function (props) {
18
18
  return props.marginLeft && "".concat(props.marginLeft, "px");
19
- }, ";", (0, _filmStyles.setAnimations)(), ";>div{opacity:0;animation-fill-mode:forwards;animation-name:fadeIn;animation-duration:300ms;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIk1vdmllR3JpZC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBWWtEIiwiZmlsZSI6Ik1vdmllR3JpZC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBzcGFjaW5nIH0gZnJvbSAnQG5kbGEvY29yZSc7XG5pbXBvcnQgeyBDYWxjdWxhdGVkQ2Fyb3VzZWxQcm9wcyB9IGZyb20gJ0BuZGxhL2Nhcm91c2VsJztcbmltcG9ydCB7IHVzZVRyYW5zbGF0aW9uIH0gZnJvbSAncmVhY3QtaTE4bmV4dCc7XG5pbXBvcnQgRmlsbUNvbnRlbnRDYXJkIGZyb20gJy4vRmlsbUNvbnRlbnRDYXJkJztcbmltcG9ydCB7IE1vdmllUmVzb3VyY2VUeXBlLCBNb3ZpZVR5cGUgfSBmcm9tICcuL3R5cGVzJztcbmltcG9ydCB7IHNldEFuaW1hdGlvbnMsIFN0eWxlZEhlYWRpbmdIMSB9IGZyb20gJy4vZmlsbVN0eWxlcyc7XG5cbmludGVyZmFjZSBNb3ZpZUxpc3RpbmdQcm9wcyB7XG4gIG1hcmdpbkxlZnQ/OiBudW1iZXI7XG59XG5cbmNvbnN0IE1vdmllTGlzdGluZyA9IHN0eWxlZC5kaXY8TW92aWVMaXN0aW5nUHJvcHM+YFxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LXdyYXA6IHdyYXA7XG4gIG1hcmdpbjogJHtzcGFjaW5nLnNtYWxsfSAwO1xuICBtYXJnaW4tbGVmdDogJHsocHJvcHMpID0+IHByb3BzLm1hcmdpbkxlZnQgJiYgYCR7cHJvcHMubWFyZ2luTGVmdH1weGB9O1xuICAke3NldEFuaW1hdGlvbnMoKX07XG4gID4gZGl2IHtcbiAgICBvcGFjaXR5OiAwO1xuICAgIGFuaW1hdGlvbi1maWxsLW1vZGU6IGZvcndhcmRzO1xuICAgIGFuaW1hdGlvbi1uYW1lOiBmYWRlSW47XG4gICAgYW5pbWF0aW9uLWR1cmF0aW9uOiAzMDBtcztcbiAgfVxuYDtcblxuaW50ZXJmYWNlIExvYWRpbmdQbGFjZWhvbGRlclByb3BzIHtcbiAgaGVpZ2h0Pzogc3RyaW5nO1xufVxuXG5jb25zdCBMb2FkaW5nUGxhY2Vob2xkZXIgPSBzdHlsZWQuZGl2PExvYWRpbmdQbGFjZWhvbGRlclByb3BzPmBcbiAgaGVpZ2h0OiAkeyhwcm9wcykgPT4gcHJvcHMuaGVpZ2h0fTtcbmA7XG5cbmludGVyZmFjZSBQcm9wcyB7XG4gIGF1dG9TaXplZFByb3BzOiBDYWxjdWxhdGVkQ2Fyb3VzZWxQcm9wcztcbiAgcmVzb3VyY2VUeXBlTmFtZT86IE1vdmllUmVzb3VyY2VUeXBlO1xuICBmZXRjaGluZ01vdmllc0J5VHlwZTogYm9vbGVhbjtcbiAgbW92aWVzQnlUeXBlOiBNb3ZpZVR5cGVbXTtcbiAgcmVzb3VyY2VUeXBlczogTW92aWVSZXNvdXJjZVR5cGVbXTtcbiAgbG9hZGluZ1BsYWNlaG9sZGVySGVpZ2h0Pzogc3RyaW5nO1xuICByZXNpemVUaHVtYm5haWxJbWFnZXM/OiBib29sZWFuO1xufVxuXG5jb25zdCBNb3ZpZUdyaWQgPSAoe1xuICByZXNvdXJjZVR5cGVOYW1lLFxuICBmZXRjaGluZ01vdmllc0J5VHlwZSxcbiAgbW92aWVzQnlUeXBlLFxuICByZXNvdXJjZVR5cGVzLFxuICBsb2FkaW5nUGxhY2Vob2xkZXJIZWlnaHQsXG4gIGF1dG9TaXplZFByb3BzLFxuICByZXNpemVUaHVtYm5haWxJbWFnZXMsXG59OiBQcm9wcykgPT4ge1xuICBjb25zdCB7IHQgfSA9IHVzZVRyYW5zbGF0aW9uKCk7XG4gIHJldHVybiAoXG4gICAgPHNlY3Rpb24+XG4gICAgICA8U3R5bGVkSGVhZGluZ0gxIG1hcmdpbkxlZnQ9e2F1dG9TaXplZFByb3BzLm1hcmdpbn0+XG4gICAgICAgIHtyZXNvdXJjZVR5cGVOYW1lICYmIHJlc291cmNlVHlwZU5hbWUubmFtZX1cbiAgICAgICAgPHNtYWxsPlxuICAgICAgICAgIHtmZXRjaGluZ01vdmllc0J5VHlwZVxuICAgICAgICAgICAgPyB0KCduZGxhRmlsbS5sb2FkaW5nTW92aWVzJylcbiAgICAgICAgICAgIDogYCR7bW92aWVzQnlUeXBlLmxlbmd0aH0gJHt0KCduZGxhRmlsbS5tb3ZpZU1hdGNoSW5DYXRlZ29yeScpfWB9XG4gICAgICAgIDwvc21hbGw+XG4gICAgICA8L1N0eWxlZEhlYWRpbmdIMT5cbiAgICAgIDxNb3ZpZUxpc3RpbmcgbWFyZ2luTGVmdD17YXV0b1NpemVkUHJvcHMubWFyZ2lufT5cbiAgICAgICAge2ZldGNoaW5nTW92aWVzQnlUeXBlICYmIDxMb2FkaW5nUGxhY2Vob2xkZXIgaGVpZ2h0PXtsb2FkaW5nUGxhY2Vob2xkZXJIZWlnaHR9IC8+fVxuICAgICAgICB7IWZldGNoaW5nTW92aWVzQnlUeXBlICYmXG4gICAgICAgICAgbW92aWVzQnlUeXBlLm1hcCgobW92aWUsIGluZGV4KSA9PiAoXG4gICAgICAgICAgICA8RmlsbUNvbnRlbnRDYXJkXG4gICAgICAgICAgICAgIGtleT17aW5kZXh9XG4gICAgICAgICAgICAgIGhpZGVUYWdzXG4gICAgICAgICAgICAgIG1vdmllPXttb3ZpZX1cbiAgICAgICAgICAgICAgY29sdW1uV2lkdGg9e2F1dG9TaXplZFByb3BzLmNvbHVtbldpZHRofVxuICAgICAgICAgICAgICBkaXN0YW5jZUJldHdlZW5JdGVtcz17YXV0b1NpemVkUHJvcHMuZGlzdGFuY2VCZXR3ZWVuSXRlbXN9XG4gICAgICAgICAgICAgIHJlc291cmNlVHlwZXM9e3Jlc291cmNlVHlwZXN9XG4gICAgICAgICAgICAgIHJlc2l6ZVRodW1ibmFpbEltYWdlcz17cmVzaXplVGh1bWJuYWlsSW1hZ2VzfVxuICAgICAgICAgICAgLz5cbiAgICAgICAgICApKX1cbiAgICAgIDwvTW92aWVMaXN0aW5nPlxuICAgIDwvc2VjdGlvbj5cbiAgKTtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IE1vdmllR3JpZDtcbiJdfQ== */"));
19
+ }, ";", (0, _filmStyles.setAnimations)(), ";margin-left:", _core.spacing.normal, ";margin-right:", _core.spacing.normal, ";", _core.mq.range({
20
+ from: _core.breakpoints.desktop
21
+ }), "{margin-left:", _core.spacingUnit * 3, "px;margin-right:", _core.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== */"));
20
22
  var LoadingPlaceholder = /*#__PURE__*/(0, _base.default)("div", {
21
23
  target: "e1t64qur0",
22
24
  label: "LoadingPlaceholder"
23
25
  })("height:", function (props) {
24
26
  return props.height;
25
- }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIk1vdmllR3JpZC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBOEI4RCIsImZpbGUiOiJNb3ZpZUdyaWQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgc3BhY2luZyB9IGZyb20gJ0BuZGxhL2NvcmUnO1xuaW1wb3J0IHsgQ2FsY3VsYXRlZENhcm91c2VsUHJvcHMgfSBmcm9tICdAbmRsYS9jYXJvdXNlbCc7XG5pbXBvcnQgeyB1c2VUcmFuc2xhdGlvbiB9IGZyb20gJ3JlYWN0LWkxOG5leHQnO1xuaW1wb3J0IEZpbG1Db250ZW50Q2FyZCBmcm9tICcuL0ZpbG1Db250ZW50Q2FyZCc7XG5pbXBvcnQgeyBNb3ZpZVJlc291cmNlVHlwZSwgTW92aWVUeXBlIH0gZnJvbSAnLi90eXBlcyc7XG5pbXBvcnQgeyBzZXRBbmltYXRpb25zLCBTdHlsZWRIZWFkaW5nSDEgfSBmcm9tICcuL2ZpbG1TdHlsZXMnO1xuXG5pbnRlcmZhY2UgTW92aWVMaXN0aW5nUHJvcHMge1xuICBtYXJnaW5MZWZ0PzogbnVtYmVyO1xufVxuXG5jb25zdCBNb3ZpZUxpc3RpbmcgPSBzdHlsZWQuZGl2PE1vdmllTGlzdGluZ1Byb3BzPmBcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC13cmFwOiB3cmFwO1xuICBtYXJnaW46ICR7c3BhY2luZy5zbWFsbH0gMDtcbiAgbWFyZ2luLWxlZnQ6ICR7KHByb3BzKSA9PiBwcm9wcy5tYXJnaW5MZWZ0ICYmIGAke3Byb3BzLm1hcmdpbkxlZnR9cHhgfTtcbiAgJHtzZXRBbmltYXRpb25zKCl9O1xuICA+IGRpdiB7XG4gICAgb3BhY2l0eTogMDtcbiAgICBhbmltYXRpb24tZmlsbC1tb2RlOiBmb3J3YXJkcztcbiAgICBhbmltYXRpb24tbmFtZTogZmFkZUluO1xuICAgIGFuaW1hdGlvbi1kdXJhdGlvbjogMzAwbXM7XG4gIH1cbmA7XG5cbmludGVyZmFjZSBMb2FkaW5nUGxhY2Vob2xkZXJQcm9wcyB7XG4gIGhlaWdodD86IHN0cmluZztcbn1cblxuY29uc3QgTG9hZGluZ1BsYWNlaG9sZGVyID0gc3R5bGVkLmRpdjxMb2FkaW5nUGxhY2Vob2xkZXJQcm9wcz5gXG4gIGhlaWdodDogJHsocHJvcHMpID0+IHByb3BzLmhlaWdodH07XG5gO1xuXG5pbnRlcmZhY2UgUHJvcHMge1xuICBhdXRvU2l6ZWRQcm9wczogQ2FsY3VsYXRlZENhcm91c2VsUHJvcHM7XG4gIHJlc291cmNlVHlwZU5hbWU/OiBNb3ZpZVJlc291cmNlVHlwZTtcbiAgZmV0Y2hpbmdNb3ZpZXNCeVR5cGU6IGJvb2xlYW47XG4gIG1vdmllc0J5VHlwZTogTW92aWVUeXBlW107XG4gIHJlc291cmNlVHlwZXM6IE1vdmllUmVzb3VyY2VUeXBlW107XG4gIGxvYWRpbmdQbGFjZWhvbGRlckhlaWdodD86IHN0cmluZztcbiAgcmVzaXplVGh1bWJuYWlsSW1hZ2VzPzogYm9vbGVhbjtcbn1cblxuY29uc3QgTW92aWVHcmlkID0gKHtcbiAgcmVzb3VyY2VUeXBlTmFtZSxcbiAgZmV0Y2hpbmdNb3ZpZXNCeVR5cGUsXG4gIG1vdmllc0J5VHlwZSxcbiAgcmVzb3VyY2VUeXBlcyxcbiAgbG9hZGluZ1BsYWNlaG9sZGVySGVpZ2h0LFxuICBhdXRvU2l6ZWRQcm9wcyxcbiAgcmVzaXplVGh1bWJuYWlsSW1hZ2VzLFxufTogUHJvcHMpID0+IHtcbiAgY29uc3QgeyB0IH0gPSB1c2VUcmFuc2xhdGlvbigpO1xuICByZXR1cm4gKFxuICAgIDxzZWN0aW9uPlxuICAgICAgPFN0eWxlZEhlYWRpbmdIMSBtYXJnaW5MZWZ0PXthdXRvU2l6ZWRQcm9wcy5tYXJnaW59PlxuICAgICAgICB7cmVzb3VyY2VUeXBlTmFtZSAmJiByZXNvdXJjZVR5cGVOYW1lLm5hbWV9XG4gICAgICAgIDxzbWFsbD5cbiAgICAgICAgICB7ZmV0Y2hpbmdNb3ZpZXNCeVR5cGVcbiAgICAgICAgICAgID8gdCgnbmRsYUZpbG0ubG9hZGluZ01vdmllcycpXG4gICAgICAgICAgICA6IGAke21vdmllc0J5VHlwZS5sZW5ndGh9ICR7dCgnbmRsYUZpbG0ubW92aWVNYXRjaEluQ2F0ZWdvcnknKX1gfVxuICAgICAgICA8L3NtYWxsPlxuICAgICAgPC9TdHlsZWRIZWFkaW5nSDE+XG4gICAgICA8TW92aWVMaXN0aW5nIG1hcmdpbkxlZnQ9e2F1dG9TaXplZFByb3BzLm1hcmdpbn0+XG4gICAgICAgIHtmZXRjaGluZ01vdmllc0J5VHlwZSAmJiA8TG9hZGluZ1BsYWNlaG9sZGVyIGhlaWdodD17bG9hZGluZ1BsYWNlaG9sZGVySGVpZ2h0fSAvPn1cbiAgICAgICAgeyFmZXRjaGluZ01vdmllc0J5VHlwZSAmJlxuICAgICAgICAgIG1vdmllc0J5VHlwZS5tYXAoKG1vdmllLCBpbmRleCkgPT4gKFxuICAgICAgICAgICAgPEZpbG1Db250ZW50Q2FyZFxuICAgICAgICAgICAgICBrZXk9e2luZGV4fVxuICAgICAgICAgICAgICBoaWRlVGFnc1xuICAgICAgICAgICAgICBtb3ZpZT17bW92aWV9XG4gICAgICAgICAgICAgIGNvbHVtbldpZHRoPXthdXRvU2l6ZWRQcm9wcy5jb2x1bW5XaWR0aH1cbiAgICAgICAgICAgICAgZGlzdGFuY2VCZXR3ZWVuSXRlbXM9e2F1dG9TaXplZFByb3BzLmRpc3RhbmNlQmV0d2Vlbkl0ZW1zfVxuICAgICAgICAgICAgICByZXNvdXJjZVR5cGVzPXtyZXNvdXJjZVR5cGVzfVxuICAgICAgICAgICAgICByZXNpemVUaHVtYm5haWxJbWFnZXM9e3Jlc2l6ZVRodW1ibmFpbEltYWdlc31cbiAgICAgICAgICAgIC8+XG4gICAgICAgICAgKSl9XG4gICAgICA8L01vdmllTGlzdGluZz5cbiAgICA8L3NlY3Rpb24+XG4gICk7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBNb3ZpZUdyaWQ7XG4iXX0= */"));
27
+ }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIk1vdmllR3JpZC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBb0M4RCIsImZpbGUiOiJNb3ZpZUdyaWQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgYnJlYWtwb2ludHMsIG1xLCBzcGFjaW5nLCBzcGFjaW5nVW5pdCB9IGZyb20gJ0BuZGxhL2NvcmUnO1xuaW1wb3J0IHsgdXNlVHJhbnNsYXRpb24gfSBmcm9tICdyZWFjdC1pMThuZXh0JztcbmltcG9ydCBGaWxtQ29udGVudENhcmQgZnJvbSAnLi9GaWxtQ29udGVudENhcmQnO1xuaW1wb3J0IHsgTW92aWVSZXNvdXJjZVR5cGUsIE1vdmllVHlwZSB9IGZyb20gJy4vdHlwZXMnO1xuaW1wb3J0IHsgc2V0QW5pbWF0aW9ucywgU3R5bGVkSGVhZGluZ0gxIH0gZnJvbSAnLi9maWxtU3R5bGVzJztcblxuaW50ZXJmYWNlIE1vdmllTGlzdGluZ1Byb3BzIHtcbiAgbWFyZ2luTGVmdD86IG51bWJlcjtcbn1cblxuY29uc3QgTW92aWVMaXN0aW5nID0gc3R5bGVkLmRpdjxNb3ZpZUxpc3RpbmdQcm9wcz5gXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXgtd3JhcDogd3JhcDtcbiAgZ2FwOiAke3NwYWNpbmcubm9ybWFsfTtcbiAgbWFyZ2luOiAke3NwYWNpbmcuc21hbGx9IDA7XG4gIG1hcmdpbi1sZWZ0OiAkeyhwcm9wcykgPT4gcHJvcHMubWFyZ2luTGVmdCAmJiBgJHtwcm9wcy5tYXJnaW5MZWZ0fXB4YH07XG4gICR7c2V0QW5pbWF0aW9ucygpfTtcbiAgbWFyZ2luLWxlZnQ6ICR7c3BhY2luZy5ub3JtYWx9O1xuICBtYXJnaW4tcmlnaHQ6ICR7c3BhY2luZy5ub3JtYWx9O1xuICAke21xLnJhbmdlKHsgZnJvbTogYnJlYWtwb2ludHMuZGVza3RvcCB9KX0ge1xuICAgIG1hcmdpbi1sZWZ0OiAke3NwYWNpbmdVbml0ICogM31weDtcbiAgICBtYXJnaW4tcmlnaHQ6ICR7c3BhY2luZ1VuaXQgKiAzfXB4O1xuICB9XG4gID4gZGl2IHtcbiAgICBvcGFjaXR5OiAwO1xuICAgIGFuaW1hdGlvbi1maWxsLW1vZGU6IGZvcndhcmRzO1xuICAgIGFuaW1hdGlvbi1uYW1lOiBmYWRlSW47XG4gICAgYW5pbWF0aW9uLWR1cmF0aW9uOiAzMDBtcztcbiAgfVxuYDtcblxuaW50ZXJmYWNlIExvYWRpbmdQbGFjZWhvbGRlclByb3BzIHtcbiAgaGVpZ2h0Pzogc3RyaW5nO1xufVxuXG5jb25zdCBMb2FkaW5nUGxhY2Vob2xkZXIgPSBzdHlsZWQuZGl2PExvYWRpbmdQbGFjZWhvbGRlclByb3BzPmBcbiAgaGVpZ2h0OiAkeyhwcm9wcykgPT4gcHJvcHMuaGVpZ2h0fTtcbmA7XG5cbmludGVyZmFjZSBQcm9wcyB7XG4gIHJlc291cmNlVHlwZU5hbWU/OiBNb3ZpZVJlc291cmNlVHlwZTtcbiAgZmV0Y2hpbmdNb3ZpZXNCeVR5cGU6IGJvb2xlYW47XG4gIG1vdmllc0J5VHlwZTogTW92aWVUeXBlW107XG4gIHJlc291cmNlVHlwZXM6IE1vdmllUmVzb3VyY2VUeXBlW107XG4gIGxvYWRpbmdQbGFjZWhvbGRlckhlaWdodD86IHN0cmluZztcbn1cblxuY29uc3QgTW92aWVHcmlkID0gKHtcbiAgcmVzb3VyY2VUeXBlTmFtZSxcbiAgZmV0Y2hpbmdNb3ZpZXNCeVR5cGUsXG4gIG1vdmllc0J5VHlwZSxcbiAgcmVzb3VyY2VUeXBlcyxcbiAgbG9hZGluZ1BsYWNlaG9sZGVySGVpZ2h0LFxufTogUHJvcHMpID0+IHtcbiAgY29uc3QgeyB0IH0gPSB1c2VUcmFuc2xhdGlvbigpO1xuICByZXR1cm4gKFxuICAgIDxzZWN0aW9uPlxuICAgICAgPFN0eWxlZEhlYWRpbmdIMT5cbiAgICAgICAge3Jlc291cmNlVHlwZU5hbWUgJiYgcmVzb3VyY2VUeXBlTmFtZS5uYW1lfVxuICAgICAgICA8c21hbGw+XG4gICAgICAgICAge2ZldGNoaW5nTW92aWVzQnlUeXBlXG4gICAgICAgICAgICA/IHQoJ25kbGFGaWxtLmxvYWRpbmdNb3ZpZXMnKVxuICAgICAgICAgICAgOiBgJHttb3ZpZXNCeVR5cGUubGVuZ3RofSAke3QoJ25kbGFGaWxtLm1vdmllTWF0Y2hJbkNhdGVnb3J5Jyl9YH1cbiAgICAgICAgPC9zbWFsbD5cbiAgICAgIDwvU3R5bGVkSGVhZGluZ0gxPlxuICAgICAgPE1vdmllTGlzdGluZz5cbiAgICAgICAge2ZldGNoaW5nTW92aWVzQnlUeXBlICYmIDxMb2FkaW5nUGxhY2Vob2xkZXIgaGVpZ2h0PXtsb2FkaW5nUGxhY2Vob2xkZXJIZWlnaHR9IC8+fVxuICAgICAgICB7IWZldGNoaW5nTW92aWVzQnlUeXBlICYmXG4gICAgICAgICAgbW92aWVzQnlUeXBlLm1hcCgobW92aWUsIGluZGV4KSA9PiAoXG4gICAgICAgICAgICA8RmlsbUNvbnRlbnRDYXJkIGtleT17aW5kZXh9IGhpZGVUYWdzIG1vdmllPXttb3ZpZX0gcmVzb3VyY2VUeXBlcz17cmVzb3VyY2VUeXBlc30gbGF6eSB0eXBlPVwibGlzdFwiIC8+XG4gICAgICAgICAgKSl9XG4gICAgICA8L01vdmllTGlzdGluZz5cbiAgICA8L3NlY3Rpb24+XG4gICk7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBNb3ZpZUdyaWQ7XG4iXX0= */"));
26
28
  var MovieGrid = function MovieGrid(_ref) {
27
29
  var resourceTypeName = _ref.resourceTypeName,
28
30
  fetchingMoviesByType = _ref.fetchingMoviesByType,
29
31
  moviesByType = _ref.moviesByType,
30
32
  resourceTypes = _ref.resourceTypes,
31
- loadingPlaceholderHeight = _ref.loadingPlaceholderHeight,
32
- autoSizedProps = _ref.autoSizedProps,
33
- resizeThumbnailImages = _ref.resizeThumbnailImages;
33
+ loadingPlaceholderHeight = _ref.loadingPlaceholderHeight;
34
34
  var _useTranslation = (0, _reactI18next.useTranslation)(),
35
35
  t = _useTranslation.t;
36
36
  return (0, _jsxRuntime.jsxs)("section", {
37
37
  children: [(0, _jsxRuntime.jsxs)(_filmStyles.StyledHeadingH1, {
38
- marginLeft: autoSizedProps.margin,
39
38
  children: [resourceTypeName && resourceTypeName.name, (0, _jsxRuntime.jsx)("small", {
40
39
  children: fetchingMoviesByType ? t('ndlaFilm.loadingMovies') : "".concat(moviesByType.length, " ").concat(t('ndlaFilm.movieMatchInCategory'))
41
40
  })]
42
41
  }), (0, _jsxRuntime.jsxs)(MovieListing, {
43
- marginLeft: autoSizedProps.margin,
44
42
  children: [fetchingMoviesByType && (0, _jsxRuntime.jsx)(LoadingPlaceholder, {
45
43
  height: loadingPlaceholderHeight
46
44
  }), !fetchingMoviesByType && moviesByType.map(function (movie, index) {
47
45
  return (0, _jsxRuntime.jsx)(_FilmContentCard.default, {
48
46
  hideTags: true,
49
47
  movie: movie,
50
- columnWidth: autoSizedProps.columnWidth,
51
- distanceBetweenItems: autoSizedProps.distanceBetweenItems,
52
48
  resourceTypes: resourceTypes,
53
- resizeThumbnailImages: resizeThumbnailImages
49
+ lazy: true,
50
+ type: "list"
54
51
  }, index);
55
52
  })]
56
53
  })]
@@ -1,14 +1,10 @@
1
1
  /// <reference types="react" />
2
2
  export declare const setAnimations: () => any;
3
- interface StyledHeadingProps {
4
- marginLeft?: number;
5
- }
6
3
  export declare const StyledHeadingH1: import("@emotion/styled").StyledComponent<{
7
4
  theme?: import("@emotion/react").Theme | undefined;
8
5
  as?: import("react").ElementType<any> | undefined;
9
- } & StyledHeadingProps, import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLHeadingElement>, HTMLHeadingElement>, {}>;
6
+ }, import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLHeadingElement>, HTMLHeadingElement>, {}>;
10
7
  export declare const StyledHeadingH2: import("@emotion/styled").StyledComponent<{
11
8
  theme?: import("@emotion/react").Theme | undefined;
12
9
  as?: import("react").ElementType<any> | undefined;
13
- } & StyledHeadingProps, import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLHeadingElement>, HTMLHeadingElement>, {}>;
14
- export {};
10
+ }, import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLHeadingElement>, HTMLHeadingElement>, {}>;