@ndla/ui 16.0.0 → 16.1.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 (37) hide show
  1. package/es/NDLAFilm/CategorySelect.js +51 -25
  2. package/es/NDLAFilm/FilmMovieList.js +14 -10
  3. package/es/NDLAFilm/FilmMovieSearch.js +23 -10
  4. package/es/NDLAFilm/FilmSlideshow.js +117 -19
  5. package/es/NDLAFilm/MovieGrid.js +23 -14
  6. package/es/NDLAFilm/NavigationArrow.js +33 -7
  7. package/es/NDLAFilm/SlideshowIndicator.js +27 -11
  8. package/es/NDLAFilm/filmStyles.js +23 -0
  9. package/es/RadioButtonGroup/RadioButtonGroup.js +28 -9
  10. package/es/all.css +1 -1
  11. package/lib/NDLAFilm/CategorySelect.js +52 -30
  12. package/lib/NDLAFilm/FilmMovieList.js +17 -13
  13. package/lib/NDLAFilm/FilmMovieSearch.js +29 -17
  14. package/lib/NDLAFilm/FilmSlideshow.js +113 -24
  15. package/lib/NDLAFilm/MovieGrid.js +25 -15
  16. package/lib/NDLAFilm/NavigationArrow.d.ts +5 -1
  17. package/lib/NDLAFilm/NavigationArrow.js +34 -10
  18. package/lib/NDLAFilm/SlideshowIndicator.js +34 -13
  19. package/lib/NDLAFilm/filmStyles.d.ts +8 -0
  20. package/lib/NDLAFilm/filmStyles.js +38 -0
  21. package/lib/RadioButtonGroup/RadioButtonGroup.js +28 -13
  22. package/lib/all.css +1 -1
  23. package/package.json +2 -2
  24. package/src/NDLAFilm/CategorySelect.tsx +110 -23
  25. package/src/NDLAFilm/FilmMovieList.tsx +13 -11
  26. package/src/NDLAFilm/FilmMovieSearch.tsx +45 -14
  27. package/src/NDLAFilm/FilmSlideshow.tsx +186 -25
  28. package/src/NDLAFilm/MovieGrid.tsx +33 -25
  29. package/src/NDLAFilm/NavigationArrow.tsx +76 -10
  30. package/src/NDLAFilm/SlideshowIndicator.tsx +53 -11
  31. package/src/NDLAFilm/component.film-movielist.scss +0 -46
  32. package/src/NDLAFilm/filmStyles.ts +33 -0
  33. package/src/RadioButtonGroup/RadioButtonGroup.tsx +82 -11
  34. package/src/main.scss +0 -3
  35. package/src/NDLAFilm/component.film-moviesearch.scss +0 -127
  36. package/src/NDLAFilm/component.film-slideshow.scss +0 -258
  37. package/src/RadioButtonGroup/component.radio-button-group.scss +0 -67
@@ -1,6 +1,6 @@
1
- function _typeof(obj) { "@babel/helpers - typeof"; if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
1
+ import _styled from "@emotion/styled-base";
2
2
 
3
- function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
3
+ function _typeof(obj) { "@babel/helpers - typeof"; if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
4
4
 
5
5
  function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
6
6
 
@@ -24,16 +24,47 @@ function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.g
24
24
 
25
25
  function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
26
26
 
27
+ function _templateObject() {
28
+ var data = _taggedTemplateLiteral(["\n 0% {\n display: none;\n opacity: 0;\n }\n 1% {\n display: flex;\n transform: scale3d(0.95, 0.95, 0.95);\n opacity: 0;\n }\n 100% {\n opacity: 1;\n transform: scale3d(1, 1, 1);\n }\n"]);
29
+
30
+ _templateObject = function _templateObject() {
31
+ return data;
32
+ };
33
+
34
+ return data;
35
+ }
36
+
37
+ function _taggedTemplateLiteral(strings, raw) { if (!raw) { raw = strings.slice(0); } return Object.freeze(Object.defineProperties(strings, { raw: { value: Object.freeze(raw) } })); }
38
+
27
39
  import React, { Component } from 'react';
28
- import BEMHelper from 'react-bem-helper';
29
40
  import FocusTrapReact from 'focus-trap-react';
41
+ import { keyframes } from '@emotion/core';
42
+ import { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';
30
43
  import { ChevronDown } from '@ndla/icons/common';
31
44
  import { withTranslation } from 'react-i18next';
32
45
  import { jsx as ___EmotionJSX } from "@emotion/core";
33
- var classes = new BEMHelper({
34
- name: 'film-moviesearch',
35
- prefix: 'c-'
36
- });
46
+ var zoomInSelect = keyframes(_templateObject());
47
+
48
+ var DropdownContainer = _styled("div", {
49
+ target: "e10i3sm20",
50
+ label: "DropdownContainer"
51
+ })("position:relative;margin:0 0 ", spacing.normal, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CategorySelect.tsx"],"names":[],"mappings":"AAyBoC","file":"CategorySelect.tsx","sourcesContent":["import React, { Component } from 'react';\nimport FocusTrapReact from 'focus-trap-react';\nimport styled from '@emotion/styled';\nimport { keyframes } from '@emotion/core';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { ChevronDown } from '@ndla/icons/common';\nimport { WithTranslation, withTranslation } from 'react-i18next';\nimport { MovieResourceType } from './types';\n\nconst zoomInSelect = keyframes`\n  0% {\n    display: none;\n    opacity: 0;\n  }\n  1% {\n    display: flex;\n    transform: scale3d(0.95, 0.95, 0.95);\n    opacity: 0;\n  }\n  100% {\n    opacity: 1;\n    transform: scale3d(1, 1, 1);\n  }\n`;\n\nconst DropdownContainer = styled.div`\n  position: relative;\n  margin: 0 0 ${spacing.normal};\n`;\n\nconst DropdownButton = styled.button`\n  border-radius: 4px;\n  ${fonts.sizes('22px', '26px')};\n  border: 0;\n  text-transform: uppercase;\n  background: ${colors.ndlaFilm.filmColorBright};\n  color: ${colors.white};\n  padding: ${spacing.small} ${spacing.nsmall};\n  font-weight: ${fonts.weight.semibold};\n  display: flex;\n  align-items: center;\n  text-align: left;\n  justify-content: space-between;\n  width: 100%;\n  letter-spacing: 0.05em;\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.small} ${spacing.normal};\n  }\n  div:first-child {\n    ${mq.range({ until: breakpoints.tablet })} {\n      display: flex;\n      flex-direction: column;\n      small {\n        padding: 0;\n      }\n    }\n  }\n  small {\n    text-transform: none;\n    padding-left: ${spacing.small};\n    font-weight: normal;\n  }\n`;\n\ninterface DropdownWrapperProps {\n  offsetDropdown: number;\n}\n\nconst DropdownWrapper = styled.div<DropdownWrapperProps>`\n  top: -${(props) => props.offsetDropdown * 52 + 13}px;\n  ${DropdownButton} {\n    border-radius: 0;\n    text-transform: 0;\n    letter-spacing: 0;\n  }\n  display: flex;\n  flex-direction: column;\n  padding: $spacing--small 0;\n  background: ${colors.brand.lighter};\n  border-radius: 4px;\n  left: 0;\n  right: 0;\n  animation: ${zoomInSelect} 200ms ease;\n  box-shadow: 0 0 30px rgba(${colors.black}, 0.6);\n  position: absolute;\n  z-index: 9999;\n  button,\n  a {\n    color: ${colors.text.primary};\n    border: 0;\n    outline: 0;\n    text-align: left;\n    background: transparent;\n    padding: ${spacing.small};\n    padding-left: ${spacing.normal};\n    font-weight: ${fonts.weight.semibold};\n    text-decoration: none;\n    box-shadow: none;\n    transition: background 200ms ease;\n    &:hover,\n    &:focus {\n      color: ${colors.brand.primary};\n      background: rgba(0, 0, 0, 0.2);\n    }\n  }\n`;\n\ninterface Props extends WithTranslation {\n  resourceTypes: MovieResourceType[];\n  resourceTypeSelected?: MovieResourceType;\n  ariaControlId?: string;\n  onChangeResourceType: (resourceId?: string) => void;\n}\n\ninterface State {\n  resourceTypesIsOpen: boolean;\n}\nclass CategorySelect extends Component<Props, State> {\n  references: Record<string, HTMLButtonElement | null>;\n  constructor(props: Props) {\n    super(props);\n    this.state = {\n      resourceTypesIsOpen: false,\n    };\n    this.references = {};\n    this.createRef = this.createRef.bind(this);\n    this.openSelect = this.openSelect.bind(this);\n    this.onSelect = this.onSelect.bind(this);\n  }\n\n  createRef(el: HTMLButtonElement | null, name: string) {\n    this.references[name] = el;\n  }\n\n  openSelect() {\n    const { resourceTypeSelected } = this.props;\n    this.setState(\n      {\n        resourceTypesIsOpen: true,\n      },\n      () => {\n        if (resourceTypeSelected && this.references[resourceTypeSelected.id]) {\n          this.references[resourceTypeSelected.id]?.focus();\n        }\n      },\n    );\n  }\n\n  onSelect(val?: string) {\n    this.props.onChangeResourceType(val);\n    this.setState({\n      resourceTypesIsOpen: false,\n    });\n  }\n\n  render() {\n    const { resourceTypes, resourceTypeSelected, ariaControlId, t } = this.props;\n    const { resourceTypesIsOpen } = this.state;\n    const offsetDropDown = resourceTypeSelected\n      ? resourceTypes.findIndex((resource) => resource.id === resourceTypeSelected.id) + 1\n      : 0;\n\n    return (\n      <DropdownContainer className=\"u-12/12\">\n        <DropdownButton\n          aria-expanded={!resourceTypesIsOpen}\n          aria-controls=\"selectCategory\"\n          type=\"button\"\n          tabIndex={resourceTypesIsOpen ? -1 : 0}\n          onClick={this.openSelect}>\n          <div>\n            <span>{t('ndlaFilm.search.chooseCategory')}</span>\n            <small>\n              {(resourceTypeSelected && resourceTypeSelected.name) || t('ndlaFilm.search.categoryFromNdla')}\n            </small>\n          </div>\n          <div>\n            <ChevronDown className=\"c-icon--22\" />\n          </div>\n        </DropdownButton>\n        {resourceTypesIsOpen && (\n          <FocusTrapReact\n            active={resourceTypesIsOpen}\n            focusTrapOptions={{\n              onDeactivate: () => {\n                this.setState({ resourceTypesIsOpen: false });\n              },\n              clickOutsideDeactivates: true,\n              escapeDeactivates: true,\n            }}>\n            <DropdownWrapper id=\"selectCategory\" offsetDropdown={offsetDropDown}>\n              <DropdownButton aria-controls={ariaControlId} type=\"button\" onClick={() => this.onSelect()}>\n                <span>{t('ndlaFilm.search.categoryFromNdla')}</span>\n              </DropdownButton>\n              {resourceTypes.map((resourceType) => (\n                <DropdownButton\n                  aria-controls={ariaControlId}\n                  type=\"button\"\n                  ref={(el) => this.createRef(el, resourceType.id)}\n                  onClick={() => this.onSelect(resourceType.id)}\n                  data-id={resourceType.id}\n                  key={resourceType.id}>\n                  <span>{resourceType.name}</span>\n                </DropdownButton>\n              ))}\n            </DropdownWrapper>\n          </FocusTrapReact>\n        )}\n      </DropdownContainer>\n    );\n  }\n}\n\nexport default withTranslation()(CategorySelect);\n"]} */"));
52
+
53
+ var DropdownButton = _styled("button", {
54
+ target: "e10i3sm21",
55
+ label: "DropdownButton"
56
+ })("border-radius:4px;", fonts.sizes('22px', '26px'), ";border:0;text-transform:uppercase;background:", colors.ndlaFilm.filmColorBright, ";color:", colors.white, ";padding:", spacing.small, " ", spacing.nsmall, ";font-weight:", fonts.weight.semibold, ";display:flex;align-items:center;text-align:left;justify-content:space-between;width:100%;letter-spacing:0.05em;", mq.range({
57
+ from: breakpoints.tablet
58
+ }), "{padding:", spacing.small, " ", spacing.normal, ";}div:first-child{", mq.range({
59
+ until: breakpoints.tablet
60
+ }), "{display:flex;flex-direction:column;small{padding:0;}}}small{text-transform:none;padding-left:", spacing.small, ";font-weight:normal;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CategorySelect.tsx"],"names":[],"mappings":"AA8BoC","file":"CategorySelect.tsx","sourcesContent":["import React, { Component } from 'react';\nimport FocusTrapReact from 'focus-trap-react';\nimport styled from '@emotion/styled';\nimport { keyframes } from '@emotion/core';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { ChevronDown } from '@ndla/icons/common';\nimport { WithTranslation, withTranslation } from 'react-i18next';\nimport { MovieResourceType } from './types';\n\nconst zoomInSelect = keyframes`\n  0% {\n    display: none;\n    opacity: 0;\n  }\n  1% {\n    display: flex;\n    transform: scale3d(0.95, 0.95, 0.95);\n    opacity: 0;\n  }\n  100% {\n    opacity: 1;\n    transform: scale3d(1, 1, 1);\n  }\n`;\n\nconst DropdownContainer = styled.div`\n  position: relative;\n  margin: 0 0 ${spacing.normal};\n`;\n\nconst DropdownButton = styled.button`\n  border-radius: 4px;\n  ${fonts.sizes('22px', '26px')};\n  border: 0;\n  text-transform: uppercase;\n  background: ${colors.ndlaFilm.filmColorBright};\n  color: ${colors.white};\n  padding: ${spacing.small} ${spacing.nsmall};\n  font-weight: ${fonts.weight.semibold};\n  display: flex;\n  align-items: center;\n  text-align: left;\n  justify-content: space-between;\n  width: 100%;\n  letter-spacing: 0.05em;\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.small} ${spacing.normal};\n  }\n  div:first-child {\n    ${mq.range({ until: breakpoints.tablet })} {\n      display: flex;\n      flex-direction: column;\n      small {\n        padding: 0;\n      }\n    }\n  }\n  small {\n    text-transform: none;\n    padding-left: ${spacing.small};\n    font-weight: normal;\n  }\n`;\n\ninterface DropdownWrapperProps {\n  offsetDropdown: number;\n}\n\nconst DropdownWrapper = styled.div<DropdownWrapperProps>`\n  top: -${(props) => props.offsetDropdown * 52 + 13}px;\n  ${DropdownButton} {\n    border-radius: 0;\n    text-transform: 0;\n    letter-spacing: 0;\n  }\n  display: flex;\n  flex-direction: column;\n  padding: $spacing--small 0;\n  background: ${colors.brand.lighter};\n  border-radius: 4px;\n  left: 0;\n  right: 0;\n  animation: ${zoomInSelect} 200ms ease;\n  box-shadow: 0 0 30px rgba(${colors.black}, 0.6);\n  position: absolute;\n  z-index: 9999;\n  button,\n  a {\n    color: ${colors.text.primary};\n    border: 0;\n    outline: 0;\n    text-align: left;\n    background: transparent;\n    padding: ${spacing.small};\n    padding-left: ${spacing.normal};\n    font-weight: ${fonts.weight.semibold};\n    text-decoration: none;\n    box-shadow: none;\n    transition: background 200ms ease;\n    &:hover,\n    &:focus {\n      color: ${colors.brand.primary};\n      background: rgba(0, 0, 0, 0.2);\n    }\n  }\n`;\n\ninterface Props extends WithTranslation {\n  resourceTypes: MovieResourceType[];\n  resourceTypeSelected?: MovieResourceType;\n  ariaControlId?: string;\n  onChangeResourceType: (resourceId?: string) => void;\n}\n\ninterface State {\n  resourceTypesIsOpen: boolean;\n}\nclass CategorySelect extends Component<Props, State> {\n  references: Record<string, HTMLButtonElement | null>;\n  constructor(props: Props) {\n    super(props);\n    this.state = {\n      resourceTypesIsOpen: false,\n    };\n    this.references = {};\n    this.createRef = this.createRef.bind(this);\n    this.openSelect = this.openSelect.bind(this);\n    this.onSelect = this.onSelect.bind(this);\n  }\n\n  createRef(el: HTMLButtonElement | null, name: string) {\n    this.references[name] = el;\n  }\n\n  openSelect() {\n    const { resourceTypeSelected } = this.props;\n    this.setState(\n      {\n        resourceTypesIsOpen: true,\n      },\n      () => {\n        if (resourceTypeSelected && this.references[resourceTypeSelected.id]) {\n          this.references[resourceTypeSelected.id]?.focus();\n        }\n      },\n    );\n  }\n\n  onSelect(val?: string) {\n    this.props.onChangeResourceType(val);\n    this.setState({\n      resourceTypesIsOpen: false,\n    });\n  }\n\n  render() {\n    const { resourceTypes, resourceTypeSelected, ariaControlId, t } = this.props;\n    const { resourceTypesIsOpen } = this.state;\n    const offsetDropDown = resourceTypeSelected\n      ? resourceTypes.findIndex((resource) => resource.id === resourceTypeSelected.id) + 1\n      : 0;\n\n    return (\n      <DropdownContainer className=\"u-12/12\">\n        <DropdownButton\n          aria-expanded={!resourceTypesIsOpen}\n          aria-controls=\"selectCategory\"\n          type=\"button\"\n          tabIndex={resourceTypesIsOpen ? -1 : 0}\n          onClick={this.openSelect}>\n          <div>\n            <span>{t('ndlaFilm.search.chooseCategory')}</span>\n            <small>\n              {(resourceTypeSelected && resourceTypeSelected.name) || t('ndlaFilm.search.categoryFromNdla')}\n            </small>\n          </div>\n          <div>\n            <ChevronDown className=\"c-icon--22\" />\n          </div>\n        </DropdownButton>\n        {resourceTypesIsOpen && (\n          <FocusTrapReact\n            active={resourceTypesIsOpen}\n            focusTrapOptions={{\n              onDeactivate: () => {\n                this.setState({ resourceTypesIsOpen: false });\n              },\n              clickOutsideDeactivates: true,\n              escapeDeactivates: true,\n            }}>\n            <DropdownWrapper id=\"selectCategory\" offsetDropdown={offsetDropDown}>\n              <DropdownButton aria-controls={ariaControlId} type=\"button\" onClick={() => this.onSelect()}>\n                <span>{t('ndlaFilm.search.categoryFromNdla')}</span>\n              </DropdownButton>\n              {resourceTypes.map((resourceType) => (\n                <DropdownButton\n                  aria-controls={ariaControlId}\n                  type=\"button\"\n                  ref={(el) => this.createRef(el, resourceType.id)}\n                  onClick={() => this.onSelect(resourceType.id)}\n                  data-id={resourceType.id}\n                  key={resourceType.id}>\n                  <span>{resourceType.name}</span>\n                </DropdownButton>\n              ))}\n            </DropdownWrapper>\n          </FocusTrapReact>\n        )}\n      </DropdownContainer>\n    );\n  }\n}\n\nexport default withTranslation()(CategorySelect);\n"]} */"));
61
+
62
+ var DropdownWrapper = _styled("div", {
63
+ target: "e10i3sm22",
64
+ label: "DropdownWrapper"
65
+ })("top:-", function (props) {
66
+ return props.offsetDropdown * 52 + 13;
67
+ }, "px;", DropdownButton, "{border-radius:0;text-transform:0;letter-spacing:0;}display:flex;flex-direction:column;padding:$spacing--small 0;background:", colors.brand.lighter, ";border-radius:4px;left:0;right:0;animation:", zoomInSelect, " 200ms ease;box-shadow:0 0 30px rgba(", colors.black, ",0.6);position:absolute;z-index:9999;button,a{color:", colors.text.primary, ";border:0;outline:0;text-align:left;background:transparent;padding:", spacing.small, ";padding-left:", spacing.normal, ";font-weight:", fonts.weight.semibold, ";text-decoration:none;box-shadow:none;transition:background 200ms ease;&:hover,&:focus{color:", colors.brand.primary, ";background:rgba(0,0,0,0.2);}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CategorySelect.tsx"],"names":[],"mappings":"AAoEwD","file":"CategorySelect.tsx","sourcesContent":["import React, { Component } from 'react';\nimport FocusTrapReact from 'focus-trap-react';\nimport styled from '@emotion/styled';\nimport { keyframes } from '@emotion/core';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { ChevronDown } from '@ndla/icons/common';\nimport { WithTranslation, withTranslation } from 'react-i18next';\nimport { MovieResourceType } from './types';\n\nconst zoomInSelect = keyframes`\n  0% {\n    display: none;\n    opacity: 0;\n  }\n  1% {\n    display: flex;\n    transform: scale3d(0.95, 0.95, 0.95);\n    opacity: 0;\n  }\n  100% {\n    opacity: 1;\n    transform: scale3d(1, 1, 1);\n  }\n`;\n\nconst DropdownContainer = styled.div`\n  position: relative;\n  margin: 0 0 ${spacing.normal};\n`;\n\nconst DropdownButton = styled.button`\n  border-radius: 4px;\n  ${fonts.sizes('22px', '26px')};\n  border: 0;\n  text-transform: uppercase;\n  background: ${colors.ndlaFilm.filmColorBright};\n  color: ${colors.white};\n  padding: ${spacing.small} ${spacing.nsmall};\n  font-weight: ${fonts.weight.semibold};\n  display: flex;\n  align-items: center;\n  text-align: left;\n  justify-content: space-between;\n  width: 100%;\n  letter-spacing: 0.05em;\n  ${mq.range({ from: breakpoints.tablet })} {\n    padding: ${spacing.small} ${spacing.normal};\n  }\n  div:first-child {\n    ${mq.range({ until: breakpoints.tablet })} {\n      display: flex;\n      flex-direction: column;\n      small {\n        padding: 0;\n      }\n    }\n  }\n  small {\n    text-transform: none;\n    padding-left: ${spacing.small};\n    font-weight: normal;\n  }\n`;\n\ninterface DropdownWrapperProps {\n  offsetDropdown: number;\n}\n\nconst DropdownWrapper = styled.div<DropdownWrapperProps>`\n  top: -${(props) => props.offsetDropdown * 52 + 13}px;\n  ${DropdownButton} {\n    border-radius: 0;\n    text-transform: 0;\n    letter-spacing: 0;\n  }\n  display: flex;\n  flex-direction: column;\n  padding: $spacing--small 0;\n  background: ${colors.brand.lighter};\n  border-radius: 4px;\n  left: 0;\n  right: 0;\n  animation: ${zoomInSelect} 200ms ease;\n  box-shadow: 0 0 30px rgba(${colors.black}, 0.6);\n  position: absolute;\n  z-index: 9999;\n  button,\n  a {\n    color: ${colors.text.primary};\n    border: 0;\n    outline: 0;\n    text-align: left;\n    background: transparent;\n    padding: ${spacing.small};\n    padding-left: ${spacing.normal};\n    font-weight: ${fonts.weight.semibold};\n    text-decoration: none;\n    box-shadow: none;\n    transition: background 200ms ease;\n    &:hover,\n    &:focus {\n      color: ${colors.brand.primary};\n      background: rgba(0, 0, 0, 0.2);\n    }\n  }\n`;\n\ninterface Props extends WithTranslation {\n  resourceTypes: MovieResourceType[];\n  resourceTypeSelected?: MovieResourceType;\n  ariaControlId?: string;\n  onChangeResourceType: (resourceId?: string) => void;\n}\n\ninterface State {\n  resourceTypesIsOpen: boolean;\n}\nclass CategorySelect extends Component<Props, State> {\n  references: Record<string, HTMLButtonElement | null>;\n  constructor(props: Props) {\n    super(props);\n    this.state = {\n      resourceTypesIsOpen: false,\n    };\n    this.references = {};\n    this.createRef = this.createRef.bind(this);\n    this.openSelect = this.openSelect.bind(this);\n    this.onSelect = this.onSelect.bind(this);\n  }\n\n  createRef(el: HTMLButtonElement | null, name: string) {\n    this.references[name] = el;\n  }\n\n  openSelect() {\n    const { resourceTypeSelected } = this.props;\n    this.setState(\n      {\n        resourceTypesIsOpen: true,\n      },\n      () => {\n        if (resourceTypeSelected && this.references[resourceTypeSelected.id]) {\n          this.references[resourceTypeSelected.id]?.focus();\n        }\n      },\n    );\n  }\n\n  onSelect(val?: string) {\n    this.props.onChangeResourceType(val);\n    this.setState({\n      resourceTypesIsOpen: false,\n    });\n  }\n\n  render() {\n    const { resourceTypes, resourceTypeSelected, ariaControlId, t } = this.props;\n    const { resourceTypesIsOpen } = this.state;\n    const offsetDropDown = resourceTypeSelected\n      ? resourceTypes.findIndex((resource) => resource.id === resourceTypeSelected.id) + 1\n      : 0;\n\n    return (\n      <DropdownContainer className=\"u-12/12\">\n        <DropdownButton\n          aria-expanded={!resourceTypesIsOpen}\n          aria-controls=\"selectCategory\"\n          type=\"button\"\n          tabIndex={resourceTypesIsOpen ? -1 : 0}\n          onClick={this.openSelect}>\n          <div>\n            <span>{t('ndlaFilm.search.chooseCategory')}</span>\n            <small>\n              {(resourceTypeSelected && resourceTypeSelected.name) || t('ndlaFilm.search.categoryFromNdla')}\n            </small>\n          </div>\n          <div>\n            <ChevronDown className=\"c-icon--22\" />\n          </div>\n        </DropdownButton>\n        {resourceTypesIsOpen && (\n          <FocusTrapReact\n            active={resourceTypesIsOpen}\n            focusTrapOptions={{\n              onDeactivate: () => {\n                this.setState({ resourceTypesIsOpen: false });\n              },\n              clickOutsideDeactivates: true,\n              escapeDeactivates: true,\n            }}>\n            <DropdownWrapper id=\"selectCategory\" offsetDropdown={offsetDropDown}>\n              <DropdownButton aria-controls={ariaControlId} type=\"button\" onClick={() => this.onSelect()}>\n                <span>{t('ndlaFilm.search.categoryFromNdla')}</span>\n              </DropdownButton>\n              {resourceTypes.map((resourceType) => (\n                <DropdownButton\n                  aria-controls={ariaControlId}\n                  type=\"button\"\n                  ref={(el) => this.createRef(el, resourceType.id)}\n                  onClick={() => this.onSelect(resourceType.id)}\n                  data-id={resourceType.id}\n                  key={resourceType.id}>\n                  <span>{resourceType.name}</span>\n                </DropdownButton>\n              ))}\n            </DropdownWrapper>\n          </FocusTrapReact>\n        )}\n      </DropdownContainer>\n    );\n  }\n}\n\nexport default withTranslation()(CategorySelect);\n"]} */"));
37
68
 
38
69
  var CategorySelect = /*#__PURE__*/function (_Component) {
39
70
  _inherits(CategorySelect, _Component);
@@ -102,14 +133,15 @@ var CategorySelect = /*#__PURE__*/function (_Component) {
102
133
  var offsetDropDown = resourceTypeSelected ? resourceTypes.findIndex(function (resource) {
103
134
  return resource.id === resourceTypeSelected.id;
104
135
  }) + 1 : 0;
105
- return ___EmotionJSX("div", classes('dropdown-container', '', 'u-12/12'), ___EmotionJSX("button", _extends({
136
+ return ___EmotionJSX(DropdownContainer, {
137
+ className: "u-12/12"
138
+ }, ___EmotionJSX(DropdownButton, {
106
139
  "aria-expanded": !resourceTypesIsOpen,
107
140
  "aria-controls": "selectCategory",
108
- type: "button"
109
- }, classes('dropdown-button', 'toggleButton'), {
141
+ type: "button",
110
142
  tabIndex: resourceTypesIsOpen ? -1 : 0,
111
143
  onClick: this.openSelect
112
- }), ___EmotionJSX("div", null, ___EmotionJSX("span", null, t('ndlaFilm.search.chooseCategory')), ___EmotionJSX("small", null, resourceTypeSelected && resourceTypeSelected.name || t('ndlaFilm.search.categoryFromNdla'))), ___EmotionJSX("div", null, ___EmotionJSX(ChevronDown, {
144
+ }, ___EmotionJSX("div", null, ___EmotionJSX("span", null, t('ndlaFilm.search.chooseCategory')), ___EmotionJSX("small", null, resourceTypeSelected && resourceTypeSelected.name || t('ndlaFilm.search.categoryFromNdla'))), ___EmotionJSX("div", null, ___EmotionJSX(ChevronDown, {
113
145
  className: "c-icon--22"
114
146
  }))), resourceTypesIsOpen && ___EmotionJSX(FocusTrapReact, {
115
147
  active: resourceTypesIsOpen,
@@ -122,20 +154,17 @@ var CategorySelect = /*#__PURE__*/function (_Component) {
122
154
  clickOutsideDeactivates: true,
123
155
  escapeDeactivates: true
124
156
  }
125
- }, ___EmotionJSX("div", _extends({
126
- id: "selectCategory"
127
- }, classes('dropdown-wrapper'), {
128
- style: {
129
- top: "-".concat(offsetDropDown * 52 + 13, "px")
130
- }
131
- }), ___EmotionJSX("button", _extends({
157
+ }, ___EmotionJSX(DropdownWrapper, {
158
+ id: "selectCategory",
159
+ offsetDropdown: offsetDropDown
160
+ }, ___EmotionJSX(DropdownButton, {
132
161
  "aria-controls": ariaControlId,
133
162
  type: "button",
134
163
  onClick: function onClick() {
135
164
  return _this3.onSelect();
136
165
  }
137
- }, classes('dropdown-button')), ___EmotionJSX("span", null, t('ndlaFilm.search.categoryFromNdla'))), resourceTypes.map(function (resourceType) {
138
- return ___EmotionJSX("button", _extends({
166
+ }, ___EmotionJSX("span", null, t('ndlaFilm.search.categoryFromNdla'))), resourceTypes.map(function (resourceType) {
167
+ return ___EmotionJSX(DropdownButton, {
139
168
  "aria-controls": ariaControlId,
140
169
  type: "button",
141
170
  ref: function ref(el) {
@@ -143,13 +172,10 @@ var CategorySelect = /*#__PURE__*/function (_Component) {
143
172
  },
144
173
  onClick: function onClick() {
145
174
  return _this3.onSelect(resourceType.id);
146
- }
147
- }, classes('dropdown-button', {
148
- selected: !!resourceTypeSelected && resourceTypeSelected.id === resourceType.id
149
- }), {
175
+ },
150
176
  "data-id": resourceType.id,
151
177
  key: resourceType.id
152
- }), ___EmotionJSX("span", null, resourceType.name));
178
+ }, ___EmotionJSX("span", null, resourceType.name));
153
179
  }))));
154
180
  }
155
181
  }]);
@@ -1,3 +1,5 @@
1
+ import _styled from "@emotion/styled-base";
2
+
1
3
  function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
2
4
 
3
5
  /** * Copyright (c) 2016-present, NDLA.
@@ -7,14 +9,18 @@ function _extends() { _extends = Object.assign || function (target) { for (var i
7
9
  *
8
10
  */
9
11
  import React from 'react';
10
- import BEMHelper from 'react-bem-helper';
11
12
  import { Carousel } from '@ndla/carousel';
13
+ import { breakpoints, mq, spacing } from '@ndla/core';
12
14
  import FilmContentCard from './FilmContentCard';
15
+ import { StyledHeadingH1 } from './filmStyles';
13
16
  import { jsx as ___EmotionJSX } from "@emotion/core";
14
- var classes = new BEMHelper({
15
- name: 'film-movielist',
16
- prefix: 'c-'
17
- });
17
+
18
+ var StyledSection = _styled("section", {
19
+ target: "e1gotiq30",
20
+ label: "StyledSection"
21
+ })("margin-bottom:", spacing.normal, ";", mq.range({
22
+ from: breakpoints.tablet
23
+ }), "{margin-bottom:", spacing.large, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkZpbG1Nb3ZpZUxpc3QudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXlCb0MiLCJmaWxlIjoiRmlsbU1vdmllTGlzdC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKiogKiBDb3B5cmlnaHQgKGMpIDIwMTYtcHJlc2VudCwgTkRMQS5cbiAqXG4gKiBUaGlzIHNvdXJjZSBjb2RlIGlzIGxpY2Vuc2VkIHVuZGVyIHRoZSBHUEx2MyBsaWNlbnNlIGZvdW5kIGluIHRoZVxuICogTElDRU5TRSBmaWxlIGluIHRoZSByb290IGRpcmVjdG9yeSBvZiB0aGlzIHNvdXJjZSB0cmVlLlxuICpcbiAqL1xuXG5pbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgQ2Fyb3VzZWwsIENhbGN1bGF0ZWRDYXJvdXNlbFByb3BzIH0gZnJvbSAnQG5kbGEvY2Fyb3VzZWwnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgYnJlYWtwb2ludHMsIG1xLCBzcGFjaW5nIH0gZnJvbSAnQG5kbGEvY29yZSc7XG5pbXBvcnQgRmlsbUNvbnRlbnRDYXJkIGZyb20gJy4vRmlsbUNvbnRlbnRDYXJkJztcbmltcG9ydCB7IE1vdmllUmVzb3VyY2VUeXBlLCBNb3ZpZVR5cGUgfSBmcm9tICcuL3R5cGVzJztcbmltcG9ydCB7IFN0eWxlZEhlYWRpbmdIMSB9IGZyb20gJy4vZmlsbVN0eWxlcyc7XG5cbmludGVyZmFjZSBQcm9wcyB7XG4gIG1vdmllczogTW92aWVUeXBlW107XG4gIG5hbWU6IHN0cmluZztcbiAgc2xpZGVCYWNrd2FyZHNMYWJlbDogc3RyaW5nO1xuICBzbGlkZUZvcndhcmRzTGFiZWw6IHN0cmluZztcbiAgcmVzb3VyY2VUeXBlczogTW92aWVSZXNvdXJjZVR5cGVbXTtcbiAgYXV0b1NpemVkUHJvcHM6IENhbGN1bGF0ZWRDYXJvdXNlbFByb3BzO1xuICByZXNpemVUaHVtYm5haWxJbWFnZXM/OiBib29sZWFuO1xufVxuXG5jb25zdCBTdHlsZWRTZWN0aW9uID0gc3R5bGVkLnNlY3Rpb25gXG4gIG1hcmdpbi1ib3R0b206ICR7c3BhY2luZy5ub3JtYWx9O1xuICAke21xLnJhbmdlKHsgZnJvbTogYnJlYWtwb2ludHMudGFibGV0IH0pfSB7XG4gICAgbWFyZ2luLWJvdHRvbTogJHtzcGFjaW5nLmxhcmdlfTtcbiAgfVxuYDtcblxuY29uc3QgRmlsbU1vdmllTGlzdCA9ICh7XG4gIG5hbWUsXG4gIG1vdmllcyA9IFtdLFxuICBzbGlkZUJhY2t3YXJkc0xhYmVsLFxuICBzbGlkZUZvcndhcmRzTGFiZWwsXG4gIHJlc291cmNlVHlwZXMgPSBbXSxcbiAgYXV0b1NpemVkUHJvcHMsXG4gIHJlc2l6ZVRodW1ibmFpbEltYWdlcyxcbn06IFByb3BzKSA9PiAoXG4gIDxTdHlsZWRTZWN0aW9uPlxuICAgIDxTdHlsZWRIZWFkaW5nSDEgbWFyZ2luTGVmdD17YXV0b1NpemVkUHJvcHMubWFyZ2lufT57bmFtZX08L1N0eWxlZEhlYWRpbmdIMT5cbiAgICA8Q2Fyb3VzZWxcbiAgICAgIGRpc2FibGVTY3JvbGw9e2ZhbHNlfVxuICAgICAgc2xpZGVCYWNrd2FyZHNMYWJlbD17c2xpZGVCYWNrd2FyZHNMYWJlbH1cbiAgICAgIHNsaWRlRm9yd2FyZHNMYWJlbD17c2xpZGVGb3J3YXJkc0xhYmVsfVxuICAgICAgYnV0dG9uQ2xhc3M9XCJjLWZpbG0tbW92aWVsaXN0X19jYXJvdXNlbC1idXR0b25zXCJcbiAgICAgIHdyYXBwZXJDbGFzcz1cImMtZmlsbS1tb3ZpZWxpc3RfX2Nhcm91c2VsLXdyYXBwZXItYnV0dG9uc1wiXG4gICAgICBpdGVtcz17bW92aWVzLm1hcCgobW92aWUpID0+IChcbiAgICAgICAgPEZpbG1Db250ZW50Q2FyZFxuICAgICAgICAgIGtleT17bW92aWUuaWR9XG4gICAgICAgICAgbW92aWU9e21vdmllfVxuICAgICAgICAgIGNvbHVtbldpZHRoPXthdXRvU2l6ZWRQcm9wcy5jb2x1bW5XaWR0aH1cbiAgICAgICAgICByZXNvdXJjZVR5cGVzPXtyZXNvdXJjZVR5cGVzfVxuICAgICAgICAgIHJlc2l6ZVRodW1ibmFpbEltYWdlcz17cmVzaXplVGh1bWJuYWlsSW1hZ2VzfVxuICAgICAgICAvPlxuICAgICAgKSl9XG4gICAgICB7Li4uYXV0b1NpemVkUHJvcHN9XG4gICAgLz5cbiAgPC9TdHlsZWRTZWN0aW9uPlxuKTtcblxuZXhwb3J0IGRlZmF1bHQgRmlsbU1vdmllTGlzdDtcbiJdfQ== */"));
18
24
 
19
25
  var FilmMovieList = function FilmMovieList(_ref) {
20
26
  var name = _ref.name,
@@ -26,11 +32,9 @@ var FilmMovieList = function FilmMovieList(_ref) {
26
32
  resourceTypes = _ref$resourceTypes === void 0 ? [] : _ref$resourceTypes,
27
33
  autoSizedProps = _ref.autoSizedProps,
28
34
  resizeThumbnailImages = _ref.resizeThumbnailImages;
29
- return ___EmotionJSX("section", classes(), ___EmotionJSX("h1", _extends({}, classes('heading'), {
30
- style: {
31
- marginLeft: "".concat(autoSizedProps.margin, "px")
32
- }
33
- }), name), ___EmotionJSX(Carousel, _extends({
35
+ return ___EmotionJSX(StyledSection, null, ___EmotionJSX(StyledHeadingH1, {
36
+ marginLeft: autoSizedProps.margin
37
+ }, name), ___EmotionJSX(Carousel, _extends({
34
38
  disableScroll: false,
35
39
  slideBackwardsLabel: slideBackwardsLabel,
36
40
  slideForwardsLabel: slideForwardsLabel,
@@ -1,3 +1,5 @@
1
+ import _styled from "@emotion/styled-base";
2
+
1
3
  /**
2
4
  * Copyright (c) 2016-present, NDLA.
3
5
  *
@@ -6,20 +8,29 @@
6
8
  *
7
9
  */
8
10
  import React from 'react';
9
- import BEMHelper from 'react-bem-helper';
10
11
  import SafeLink from '@ndla/safelink';
11
12
  import { useTranslation } from 'react-i18next';
13
+ import { spacing, mq, breakpoints, colors } from '@ndla/core';
12
14
  import CategorySelect from './CategorySelect';
13
15
  import { OneColumn } from '..';
16
+ import { StyledHeadingH2 } from './filmStyles';
14
17
  import { jsx as ___EmotionJSX } from "@emotion/core";
15
- var classes = new BEMHelper({
16
- name: 'film-moviesearch',
17
- prefix: 'c-'
18
- });
19
- var classesMovieList = new BEMHelper({
20
- name: 'film-movielist',
21
- prefix: 'c-'
22
- });
18
+
19
+ var FilmMovieSearchContainer = _styled("div", {
20
+ target: "ebr0v6y0",
21
+ label: "FilmMovieSearchContainer"
22
+ })("margin:", spacing.normal, " 0 ", spacing.large, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkZpbG1Nb3ZpZVNlYXJjaC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBa0IyQyIsImZpbGUiOiJGaWxtTW92aWVTZWFyY2gudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMTYtcHJlc2VudCwgTkRMQS5cbiAqXG4gKiBUaGlzIHNvdXJjZSBjb2RlIGlzIGxpY2Vuc2VkIHVuZGVyIHRoZSBHUEx2MyBsaWNlbnNlIGZvdW5kIGluIHRoZVxuICogTElDRU5TRSBmaWxlIGluIHRoZSByb290IGRpcmVjdG9yeSBvZiB0aGlzIHNvdXJjZSB0cmVlLlxuICpcbiAqL1xuXG5pbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xuaW1wb3J0IFNhZmVMaW5rIGZyb20gJ0BuZGxhL3NhZmVsaW5rJztcbmltcG9ydCB7IHVzZVRyYW5zbGF0aW9uIH0gZnJvbSAncmVhY3QtaTE4bmV4dCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBzcGFjaW5nLCBtcSwgYnJlYWtwb2ludHMsIGNvbG9ycyB9IGZyb20gJ0BuZGxhL2NvcmUnO1xuaW1wb3J0IENhdGVnb3J5U2VsZWN0IGZyb20gJy4vQ2F0ZWdvcnlTZWxlY3QnO1xuaW1wb3J0IHsgTW92aWVSZXNvdXJjZVR5cGUgfSBmcm9tICcuL3R5cGVzJztcbmltcG9ydCB7IE9uZUNvbHVtbiB9IGZyb20gJy4uJztcbmltcG9ydCB7IFN0eWxlZEhlYWRpbmdIMiB9IGZyb20gJy4vZmlsbVN0eWxlcyc7XG5cbmNvbnN0IEZpbG1Nb3ZpZVNlYXJjaENvbnRhaW5lciA9IHN0eWxlZC5kaXZgXG4gIG1hcmdpbjogJHtzcGFjaW5nLm5vcm1hbH0gMCAke3NwYWNpbmcubGFyZ2V9O1xuYDtcblxuY29uc3QgVG9waWNOYXZpZ2F0aW9uID0gc3R5bGVkLmRpdmBcbiAgbWFyZ2luOiAke3NwYWNpbmcubm9ybWFsfSAwO1xuICAke21xLnJhbmdlKHsgZnJvbTogYnJlYWtwb2ludHMudGFibGV0IH0pfSB7XG4gICAgZGlzcGxheTogZmxleDtcbiAgICBhbGlnbi1pdGVtczogZmxleC1zdGFydDtcbiAgICBwYWRkaW5nOiAwICR7c3BhY2luZy5ub3JtYWx9O1xuICB9XG4gIHVsIHtcbiAgICBsaXN0LXN0eWxlLXR5cGU6IG5vbmU7XG4gICAgbGlzdC1zdHlsZS1pbWFnZTogbm9uZTtcbiAgICBkaXNwbGF5OiBmbGV4O1xuICAgIGFsaWduLWl0ZW1zOiBmbGV4LXN0YXJ0O1xuICAgIGZsZXgtd3JhcDogd3JhcDtcbiAgICBwYWRkaW5nOiAwO1xuICAgIG1hcmdpbjogJHtzcGFjaW5nLnNtYWxsfSAwO1xuICAgICR7bXEucmFuZ2UoeyBmcm9tOiBicmVha3BvaW50cy50YWJsZXQgfSl9IHtcbiAgICAgIHBhZGRpbmctbGVmdDogJHtzcGFjaW5nLm5vcm1hbH07XG4gICAgfVxuICAgIGxpIHtcbiAgICAgIHBhZGRpbmc6IDA7XG4gICAgICB3aWR0aDogMTAwJTtcbiAgICAgICR7bXEucmFuZ2UoeyBmcm9tOiBicmVha3BvaW50cy50YWJsZXQgfSl9IHtcbiAgICAgICAgd2lkdGg6IDUwJTtcbiAgICAgIH1cbiAgICAgIGEge1xuICAgICAgICBjb2xvcjogI2ZmZjtcbiAgICAgICAgJjpob3ZlcixcbiAgICAgICAgJjpmb2N1cyB7XG4gICAgICAgICAgY29sb3I6ICR7Y29sb3JzLmJyYW5kLmxpZ2h0fTtcbiAgICAgICAgfVxuICAgICAgfVxuICAgIH1cbiAgfVxuYDtcblxuaW50ZXJmYWNlIFByb3BzIHtcbiAgdG9waWNzPzogeyBpZDogc3RyaW5nOyBwYXRoOiBzdHJpbmc7IG5hbWU6IHN0cmluZyB9W107XG4gIG9uQ2hhbmdlUmVzb3VyY2VUeXBlOiAocmVzb3VyY2VUeXBlPzogc3RyaW5nKSA9PiB2b2lkO1xuICByZXNvdXJjZVR5cGVTZWxlY3RlZD86IE1vdmllUmVzb3VyY2VUeXBlO1xuICByZXNvdXJjZVR5cGVzOiBNb3ZpZVJlc291cmNlVHlwZVtdO1xuICBhcmlhQ29udHJvbElkOiBzdHJpbmc7XG59XG5cbmNvbnN0IEZpbG1Nb3ZpZVNlYXJjaCA9ICh7XG4gIHRvcGljcyA9IFtdLFxuICBvbkNoYW5nZVJlc291cmNlVHlwZSxcbiAgcmVzb3VyY2VUeXBlcyxcbiAgcmVzb3VyY2VUeXBlU2VsZWN0ZWQsXG4gIGFyaWFDb250cm9sSWQsXG59OiBQcm9wcykgPT4ge1xuICBjb25zdCB7IHQgfSA9IHVzZVRyYW5zbGF0aW9uKCk7XG4gIHJldHVybiAoXG4gICAgPEZpbG1Nb3ZpZVNlYXJjaENvbnRhaW5lcj5cbiAgICAgIDxPbmVDb2x1bW4+XG4gICAgICAgIDxUb3BpY05hdmlnYXRpb24+XG4gICAgICAgICAgPFN0eWxlZEhlYWRpbmdIMiBjbGFzc05hbWU9XCJ1LTEyLzEyIHUtNC8xMkB0YWJsZXRcIj57dCgnbmRsYUZpbG0uc3ViamVjdHNJbk1vdmllcycpfTo8L1N0eWxlZEhlYWRpbmdIMj5cbiAgICAgICAgICA8bmF2IGNsYXNzTmFtZT1cInUtMTIvMTIgdS04LzEyQHRhYmxldFwiPlxuICAgICAgICAgICAgPHVsPlxuICAgICAgICAgICAgICB7dG9waWNzLm1hcCgodG9waWMpID0+IChcbiAgICAgICAgICAgICAgICA8bGkga2V5PXt0b3BpYy5pZH0+XG4gICAgICAgICAgICAgICAgICA8U2FmZUxpbmsgdG89e3RvcGljLnBhdGh9IGtleT17dG9waWMuaWR9PlxuICAgICAgICAgICAgICAgICAgICA8c3Bhbj57dG9waWMubmFtZX08L3NwYW4+XG4gICAgICAgICAgICAgICAgICA8L1NhZmVMaW5rPlxuICAgICAgICAgICAgICAgIDwvbGk+XG4gICAgICAgICAgICAgICkpfVxuICAgICAgICAgICAgPC91bD5cbiAgICAgICAgICA8L25hdj5cbiAgICAgICAgPC9Ub3BpY05hdmlnYXRpb24+XG4gICAgICAgIDxDYXRlZ29yeVNlbGVjdFxuICAgICAgICAgIG9uQ2hhbmdlUmVzb3VyY2VUeXBlPXtvbkNoYW5nZVJlc291cmNlVHlwZX1cbiAgICAgICAgICByZXNvdXJjZVR5cGVzPXtyZXNvdXJjZVR5cGVzfVxuICAgICAgICAgIHJlc291cmNlVHlwZVNlbGVjdGVkPXtyZXNvdXJjZVR5cGVTZWxlY3RlZH1cbiAgICAgICAgICBhcmlhQ29udHJvbElkPXthcmlhQ29udHJvbElkfVxuICAgICAgICAvPlxuICAgICAgPC9PbmVDb2x1bW4+XG4gICAgPC9GaWxtTW92aWVTZWFyY2hDb250YWluZXI+XG4gICk7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBGaWxtTW92aWVTZWFyY2g7XG4iXX0= */"));
23
+
24
+ var TopicNavigation = _styled("div", {
25
+ target: "ebr0v6y1",
26
+ label: "TopicNavigation"
27
+ })("margin:", spacing.normal, " 0;", mq.range({
28
+ from: breakpoints.tablet
29
+ }), "{display:flex;align-items:flex-start;padding:0 ", spacing.normal, ";}ul{list-style-type:none;list-style-image:none;display:flex;align-items:flex-start;flex-wrap:wrap;padding:0;margin:", spacing.small, " 0;", mq.range({
30
+ from: breakpoints.tablet
31
+ }), "{padding-left:", spacing.normal, ";}li{padding:0;width:100%;", mq.range({
32
+ from: breakpoints.tablet
33
+ }), "{width:50%;}a{color:#fff;&:hover,&:focus{color:", colors.brand.light, ";}}}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkZpbG1Nb3ZpZVNlYXJjaC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBc0JrQyIsImZpbGUiOiJGaWxtTW92aWVTZWFyY2gudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMTYtcHJlc2VudCwgTkRMQS5cbiAqXG4gKiBUaGlzIHNvdXJjZSBjb2RlIGlzIGxpY2Vuc2VkIHVuZGVyIHRoZSBHUEx2MyBsaWNlbnNlIGZvdW5kIGluIHRoZVxuICogTElDRU5TRSBmaWxlIGluIHRoZSByb290IGRpcmVjdG9yeSBvZiB0aGlzIHNvdXJjZSB0cmVlLlxuICpcbiAqL1xuXG5pbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xuaW1wb3J0IFNhZmVMaW5rIGZyb20gJ0BuZGxhL3NhZmVsaW5rJztcbmltcG9ydCB7IHVzZVRyYW5zbGF0aW9uIH0gZnJvbSAncmVhY3QtaTE4bmV4dCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBzcGFjaW5nLCBtcSwgYnJlYWtwb2ludHMsIGNvbG9ycyB9IGZyb20gJ0BuZGxhL2NvcmUnO1xuaW1wb3J0IENhdGVnb3J5U2VsZWN0IGZyb20gJy4vQ2F0ZWdvcnlTZWxlY3QnO1xuaW1wb3J0IHsgTW92aWVSZXNvdXJjZVR5cGUgfSBmcm9tICcuL3R5cGVzJztcbmltcG9ydCB7IE9uZUNvbHVtbiB9IGZyb20gJy4uJztcbmltcG9ydCB7IFN0eWxlZEhlYWRpbmdIMiB9IGZyb20gJy4vZmlsbVN0eWxlcyc7XG5cbmNvbnN0IEZpbG1Nb3ZpZVNlYXJjaENvbnRhaW5lciA9IHN0eWxlZC5kaXZgXG4gIG1hcmdpbjogJHtzcGFjaW5nLm5vcm1hbH0gMCAke3NwYWNpbmcubGFyZ2V9O1xuYDtcblxuY29uc3QgVG9waWNOYXZpZ2F0aW9uID0gc3R5bGVkLmRpdmBcbiAgbWFyZ2luOiAke3NwYWNpbmcubm9ybWFsfSAwO1xuICAke21xLnJhbmdlKHsgZnJvbTogYnJlYWtwb2ludHMudGFibGV0IH0pfSB7XG4gICAgZGlzcGxheTogZmxleDtcbiAgICBhbGlnbi1pdGVtczogZmxleC1zdGFydDtcbiAgICBwYWRkaW5nOiAwICR7c3BhY2luZy5ub3JtYWx9O1xuICB9XG4gIHVsIHtcbiAgICBsaXN0LXN0eWxlLXR5cGU6IG5vbmU7XG4gICAgbGlzdC1zdHlsZS1pbWFnZTogbm9uZTtcbiAgICBkaXNwbGF5OiBmbGV4O1xuICAgIGFsaWduLWl0ZW1zOiBmbGV4LXN0YXJ0O1xuICAgIGZsZXgtd3JhcDogd3JhcDtcbiAgICBwYWRkaW5nOiAwO1xuICAgIG1hcmdpbjogJHtzcGFjaW5nLnNtYWxsfSAwO1xuICAgICR7bXEucmFuZ2UoeyBmcm9tOiBicmVha3BvaW50cy50YWJsZXQgfSl9IHtcbiAgICAgIHBhZGRpbmctbGVmdDogJHtzcGFjaW5nLm5vcm1hbH07XG4gICAgfVxuICAgIGxpIHtcbiAgICAgIHBhZGRpbmc6IDA7XG4gICAgICB3aWR0aDogMTAwJTtcbiAgICAgICR7bXEucmFuZ2UoeyBmcm9tOiBicmVha3BvaW50cy50YWJsZXQgfSl9IHtcbiAgICAgICAgd2lkdGg6IDUwJTtcbiAgICAgIH1cbiAgICAgIGEge1xuICAgICAgICBjb2xvcjogI2ZmZjtcbiAgICAgICAgJjpob3ZlcixcbiAgICAgICAgJjpmb2N1cyB7XG4gICAgICAgICAgY29sb3I6ICR7Y29sb3JzLmJyYW5kLmxpZ2h0fTtcbiAgICAgICAgfVxuICAgICAgfVxuICAgIH1cbiAgfVxuYDtcblxuaW50ZXJmYWNlIFByb3BzIHtcbiAgdG9waWNzPzogeyBpZDogc3RyaW5nOyBwYXRoOiBzdHJpbmc7IG5hbWU6IHN0cmluZyB9W107XG4gIG9uQ2hhbmdlUmVzb3VyY2VUeXBlOiAocmVzb3VyY2VUeXBlPzogc3RyaW5nKSA9PiB2b2lkO1xuICByZXNvdXJjZVR5cGVTZWxlY3RlZD86IE1vdmllUmVzb3VyY2VUeXBlO1xuICByZXNvdXJjZVR5cGVzOiBNb3ZpZVJlc291cmNlVHlwZVtdO1xuICBhcmlhQ29udHJvbElkOiBzdHJpbmc7XG59XG5cbmNvbnN0IEZpbG1Nb3ZpZVNlYXJjaCA9ICh7XG4gIHRvcGljcyA9IFtdLFxuICBvbkNoYW5nZVJlc291cmNlVHlwZSxcbiAgcmVzb3VyY2VUeXBlcyxcbiAgcmVzb3VyY2VUeXBlU2VsZWN0ZWQsXG4gIGFyaWFDb250cm9sSWQsXG59OiBQcm9wcykgPT4ge1xuICBjb25zdCB7IHQgfSA9IHVzZVRyYW5zbGF0aW9uKCk7XG4gIHJldHVybiAoXG4gICAgPEZpbG1Nb3ZpZVNlYXJjaENvbnRhaW5lcj5cbiAgICAgIDxPbmVDb2x1bW4+XG4gICAgICAgIDxUb3BpY05hdmlnYXRpb24+XG4gICAgICAgICAgPFN0eWxlZEhlYWRpbmdIMiBjbGFzc05hbWU9XCJ1LTEyLzEyIHUtNC8xMkB0YWJsZXRcIj57dCgnbmRsYUZpbG0uc3ViamVjdHNJbk1vdmllcycpfTo8L1N0eWxlZEhlYWRpbmdIMj5cbiAgICAgICAgICA8bmF2IGNsYXNzTmFtZT1cInUtMTIvMTIgdS04LzEyQHRhYmxldFwiPlxuICAgICAgICAgICAgPHVsPlxuICAgICAgICAgICAgICB7dG9waWNzLm1hcCgodG9waWMpID0+IChcbiAgICAgICAgICAgICAgICA8bGkga2V5PXt0b3BpYy5pZH0+XG4gICAgICAgICAgICAgICAgICA8U2FmZUxpbmsgdG89e3RvcGljLnBhdGh9IGtleT17dG9waWMuaWR9PlxuICAgICAgICAgICAgICAgICAgICA8c3Bhbj57dG9waWMubmFtZX08L3NwYW4+XG4gICAgICAgICAgICAgICAgICA8L1NhZmVMaW5rPlxuICAgICAgICAgICAgICAgIDwvbGk+XG4gICAgICAgICAgICAgICkpfVxuICAgICAgICAgICAgPC91bD5cbiAgICAgICAgICA8L25hdj5cbiAgICAgICAgPC9Ub3BpY05hdmlnYXRpb24+XG4gICAgICAgIDxDYXRlZ29yeVNlbGVjdFxuICAgICAgICAgIG9uQ2hhbmdlUmVzb3VyY2VUeXBlPXtvbkNoYW5nZVJlc291cmNlVHlwZX1cbiAgICAgICAgICByZXNvdXJjZVR5cGVzPXtyZXNvdXJjZVR5cGVzfVxuICAgICAgICAgIHJlc291cmNlVHlwZVNlbGVjdGVkPXtyZXNvdXJjZVR5cGVTZWxlY3RlZH1cbiAgICAgICAgICBhcmlhQ29udHJvbElkPXthcmlhQ29udHJvbElkfVxuICAgICAgICAvPlxuICAgICAgPC9PbmVDb2x1bW4+XG4gICAgPC9GaWxtTW92aWVTZWFyY2hDb250YWluZXI+XG4gICk7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBGaWxtTW92aWVTZWFyY2g7XG4iXX0= */"));
23
34
 
24
35
  var FilmMovieSearch = function FilmMovieSearch(_ref) {
25
36
  var _ref$topics = _ref.topics,
@@ -32,7 +43,9 @@ var FilmMovieSearch = function FilmMovieSearch(_ref) {
32
43
  var _useTranslation = useTranslation(),
33
44
  t = _useTranslation.t;
34
45
 
35
- return ___EmotionJSX("div", classes(''), ___EmotionJSX(OneColumn, null, ___EmotionJSX("div", classes('topic-navigation'), ___EmotionJSX("h2", classesMovieList('heading', '', 'u-12/12 u-4/12@tablet'), t('ndlaFilm.subjectsInMovies'), ":"), ___EmotionJSX("nav", {
46
+ return ___EmotionJSX(FilmMovieSearchContainer, null, ___EmotionJSX(OneColumn, null, ___EmotionJSX(TopicNavigation, null, ___EmotionJSX(StyledHeadingH2, {
47
+ className: "u-12/12 u-4/12@tablet"
48
+ }, t('ndlaFilm.subjectsInMovies'), ":"), ___EmotionJSX("nav", {
36
49
  className: "u-12/12 u-8/12@tablet"
37
50
  }, ___EmotionJSX("ul", null, topics.map(function (topic) {
38
51
  return ___EmotionJSX("li", {