@ndla/image-search 6.0.124 → 6.0.126

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.
package/es/ImageMeta.js CHANGED
@@ -11,11 +11,11 @@ function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringif
11
11
  import prettyBytes from 'pretty-bytes';
12
12
  import { fonts } from '@ndla/core';
13
13
  import { jsx as _jsx } from "@emotion/react/jsx-runtime";
14
- var StyledDiv = /*#__PURE__*/_styled("div", {
14
+ const StyledDiv = /*#__PURE__*/_styled("div", {
15
15
  target: "e171zbc01",
16
16
  label: "StyledDiv"
17
17
  })(fonts.sizes('16px', 1.3), ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkltYWdlTWV0YS50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBYTRCIiwiZmlsZSI6IkltYWdlTWV0YS50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAyMi1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCBwcmV0dHlCeXRlcyBmcm9tICdwcmV0dHktYnl0ZXMnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgZm9udHMgfSBmcm9tICdAbmRsYS9jb3JlJztcbmltcG9ydCB7IElJbWFnZURpbWVuc2lvbnMgfSBmcm9tICdAbmRsYS90eXBlcy1iYWNrZW5kL2ltYWdlLWFwaSc7XG5cbmNvbnN0IFN0eWxlZERpdiA9IHN0eWxlZC5kaXZgXG4gICR7Zm9udHMuc2l6ZXMoJzE2cHgnLCAxLjMpfVxuYDtcblxuY29uc3QgU3R5bGVkU3BhbiA9IHN0eWxlZC5zcGFuYFxuICB0ZXh0LWFsaWduOiBjZW50ZXI7XG5gO1xuXG5pbnRlcmZhY2UgUHJvcHMge1xuICBjb250ZW50VHlwZTogc3RyaW5nO1xuICBmaWxlU2l6ZTogbnVtYmVyO1xuICBpbWFnZURpbWVuc2lvbnM/OiBJSW1hZ2VEaW1lbnNpb25zO1xufVxuXG5jb25zdCBJbWFnZU1ldGEgPSAoeyBjb250ZW50VHlwZSwgZmlsZVNpemUsIGltYWdlRGltZW5zaW9ucyB9OiBQcm9wcykgPT4ge1xuICBjb25zdCBkaW1lbnNpb25zID0gaW1hZ2VEaW1lbnNpb25zID8gYCAtICR7aW1hZ2VEaW1lbnNpb25zLndpZHRofXgke2ltYWdlRGltZW5zaW9ucy5oZWlnaHR9IHB4YCA6ICcnO1xuICByZXR1cm4gKFxuICAgIDxTdHlsZWREaXY+XG4gICAgICA8U3R5bGVkU3Bhbj57YCR7Y29udGVudFR5cGV9IC0gJHtwcmV0dHlCeXRlcyhmaWxlU2l6ZSl9JHtkaW1lbnNpb25zfWB9PC9TdHlsZWRTcGFuPlxuICAgIDwvU3R5bGVkRGl2PlxuICApO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgSW1hZ2VNZXRhO1xuIl19 */"));
18
- var StyledSpan = /*#__PURE__*/_styled("span", {
18
+ const StyledSpan = /*#__PURE__*/_styled("span", {
19
19
  target: "e171zbc00",
20
20
  label: "StyledSpan"
21
21
  })(process.env.NODE_ENV === "production" ? {
@@ -27,14 +27,16 @@ var StyledSpan = /*#__PURE__*/_styled("span", {
27
27
  map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkltYWdlTWV0YS50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBaUI4QiIsImZpbGUiOiJJbWFnZU1ldGEudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMjItcHJlc2VudCwgTkRMQS5cbiAqXG4gKiBUaGlzIHNvdXJjZSBjb2RlIGlzIGxpY2Vuc2VkIHVuZGVyIHRoZSBHUEx2MyBsaWNlbnNlIGZvdW5kIGluIHRoZVxuICogTElDRU5TRSBmaWxlIGluIHRoZSByb290IGRpcmVjdG9yeSBvZiB0aGlzIHNvdXJjZSB0cmVlLlxuICpcbiAqL1xuXG5pbXBvcnQgcHJldHR5Qnl0ZXMgZnJvbSAncHJldHR5LWJ5dGVzJztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGZvbnRzIH0gZnJvbSAnQG5kbGEvY29yZSc7XG5pbXBvcnQgeyBJSW1hZ2VEaW1lbnNpb25zIH0gZnJvbSAnQG5kbGEvdHlwZXMtYmFja2VuZC9pbWFnZS1hcGknO1xuXG5jb25zdCBTdHlsZWREaXYgPSBzdHlsZWQuZGl2YFxuICAke2ZvbnRzLnNpemVzKCcxNnB4JywgMS4zKX1cbmA7XG5cbmNvbnN0IFN0eWxlZFNwYW4gPSBzdHlsZWQuc3BhbmBcbiAgdGV4dC1hbGlnbjogY2VudGVyO1xuYDtcblxuaW50ZXJmYWNlIFByb3BzIHtcbiAgY29udGVudFR5cGU6IHN0cmluZztcbiAgZmlsZVNpemU6IG51bWJlcjtcbiAgaW1hZ2VEaW1lbnNpb25zPzogSUltYWdlRGltZW5zaW9ucztcbn1cblxuY29uc3QgSW1hZ2VNZXRhID0gKHsgY29udGVudFR5cGUsIGZpbGVTaXplLCBpbWFnZURpbWVuc2lvbnMgfTogUHJvcHMpID0+IHtcbiAgY29uc3QgZGltZW5zaW9ucyA9IGltYWdlRGltZW5zaW9ucyA/IGAgLSAke2ltYWdlRGltZW5zaW9ucy53aWR0aH14JHtpbWFnZURpbWVuc2lvbnMuaGVpZ2h0fSBweGAgOiAnJztcbiAgcmV0dXJuIChcbiAgICA8U3R5bGVkRGl2PlxuICAgICAgPFN0eWxlZFNwYW4+e2Ake2NvbnRlbnRUeXBlfSAtICR7cHJldHR5Qnl0ZXMoZmlsZVNpemUpfSR7ZGltZW5zaW9uc31gfTwvU3R5bGVkU3Bhbj5cbiAgICA8L1N0eWxlZERpdj5cbiAgKTtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IEltYWdlTWV0YTtcbiJdfQ== */",
28
28
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
29
29
  });
30
- var ImageMeta = function ImageMeta(_ref) {
31
- var contentType = _ref.contentType,
32
- fileSize = _ref.fileSize,
33
- imageDimensions = _ref.imageDimensions;
34
- var dimensions = imageDimensions ? " - ".concat(imageDimensions.width, "x").concat(imageDimensions.height, " px") : '';
30
+ const ImageMeta = _ref => {
31
+ let {
32
+ contentType,
33
+ fileSize,
34
+ imageDimensions
35
+ } = _ref;
36
+ const dimensions = imageDimensions ? ` - ${imageDimensions.width}x${imageDimensions.height} px` : '';
35
37
  return _jsx(StyledDiv, {
36
38
  children: _jsx(StyledSpan, {
37
- children: "".concat(contentType, " - ").concat(prettyBytes(fileSize)).concat(dimensions)
39
+ children: `${contentType} - ${prettyBytes(fileSize)}${dimensions}`
38
40
  })
39
41
  });
40
42
  };
package/es/ImageSearch.js CHANGED
@@ -1,17 +1,4 @@
1
- function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
2
1
  import _styled from "@emotion/styled/base";
3
- function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
4
- function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, _toPropertyKey(descriptor.key), descriptor); } }
5
- function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
6
- function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return _typeof(key) === "symbol" ? key : String(key); }
7
- function _toPrimitive(input, hint) { if (_typeof(input) !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (_typeof(res) !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); }
8
- function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); Object.defineProperty(subClass, "prototype", { writable: false }); if (superClass) _setPrototypeOf(subClass, superClass); }
9
- function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
10
- function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
11
- function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } else if (call !== void 0) { throw new TypeError("Derived constructors may only return object or undefined"); } return _assertThisInitialized(self); }
12
- function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
13
- function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
14
- function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
15
2
  function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
16
3
  /**
17
4
  * Copyright (c) 2017-present, NDLA.
@@ -30,7 +17,7 @@ import { Search as SearchIcon } from '@ndla/icons/common';
30
17
  import ImageSearchResult from './ImageSearchResult';
31
18
  import { jsx as _jsx } from "@emotion/react/jsx-runtime";
32
19
  import { jsxs as _jsxs } from "@emotion/react/jsx-runtime";
33
- var ImageSearchWrapper = /*#__PURE__*/_styled("div", {
20
+ const ImageSearchWrapper = /*#__PURE__*/_styled("div", {
34
21
  target: "ejbuzb50",
35
22
  label: "ImageSearchWrapper"
36
23
  })(".text{text-align:center;}.list-item{position:relative;float:left;height:210px;width:100%;", mq.range({
@@ -70,7 +57,7 @@ var ImageSearchWrapper = /*#__PURE__*/_styled("div", {
70
57
  }), "{.list-item .image-preview{width:400%;}.list-item:nth-of-type(4n - 2) .image-preview{margin-left:-100%;}.list-item:nth-of-type(4n - 1) .image-preview{margin-left:-200%;}.list-item:nth-of-type(4n) .image-preview{margin-left:-300%;}}", mq.range({
71
58
  from: breakpoints.wide
72
59
  }), "{.list-item .image-preview{width:500%;}.list-item:nth-of-type(5n - 3) .image-preview{margin-left:-100%;}.list-item:nth-of-type(5n - 2) .image-preview{margin-left:-200%;}.list-item:nth-of-type(5n - 1) .image-preview{margin-left:-300%;}.list-item:nth-of-type(5n) .image-preview{margin-left:-400%;}}@keyframes fadeInSearchPreview{0%{display:none;opacity:0;}1%{opacity:0;display:flex;transform:translateY(-20px);}100%{opacity:1;transform:translateY(0px);}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ImageSearch.tsx"],"names":[],"mappings":"AAkBqC","file":"ImageSearch.tsx","sourcesContent":["/**\n * Copyright (c) 2017-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 { ChangeEvent, Component, ReactNode, KeyboardEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport { fonts, colors, spacing, mq, breakpoints } from '@ndla/core';\nimport Pager from '@ndla/pager';\nimport { IImageMetaInformationV3, ISearchResultV3, ISearchParams } from '@ndla/types-backend/image-api';\nimport { InputContainer, InputV3 } from '@ndla/forms';\nimport { Search as SearchIcon } from '@ndla/icons/common';\nimport ImageSearchResult from './ImageSearchResult';\n\nconst ImageSearchWrapper = styled.div`\n  .text {\n    text-align: center;\n  }\n  .list-item {\n    position: relative;\n    float: left;\n    height: 210px;\n    width: 100%;\n    ${mq.range({ from: breakpoints.tablet })} {\n      width: 50%;\n    }\n    ${mq.range({ from: breakpoints.tabletWide })} {\n      width: 33.3%;\n    }\n    ${mq.range({ from: breakpoints.desktop })} {\n      width: 25%;\n    }\n    ${mq.range({ from: breakpoints.wide })} {\n      width: 20%;\n    }\n    &.active {\n      height: inherit;\n    }\n  }\n\n  .list {\n    display: flex;\n    align-items: stretch;\n    flex-flow: row wrap;\n    position: relative;\n    margin-left: -${spacing.small};\n    margin-right: -${spacing.small};\n    margin-top: ${spacing.normal};\n  }\n\n  .list-item-inner {\n    padding: ${spacing.small};\n    text-align: center;\n    height: 210px;\n\n    .list-item-title {\n      margin: ${spacing.xsmall} 0;\n      ${fonts.sizes('14px', 1.2)};\n      overflow: hidden;\n      text-overflow: ellipsis;\n      display: -webkit-box;\n      -webkit-box-orient: vertical;\n      -webkit-line-clamp: 3;\n      max-height: ${spacing.large};\n    }\n  }\n\n  .list-item-inner img {\n    max-height: 135px;\n    max-width: 100%;\n    border: 2px solid white;\n    transition: border-color 100ms ease;\n  }\n\n  .list-item-inner:hover {\n    img {\n      border: 2px solid ${colors.brand.primary};\n    }\n  }\n\n  .list-item-inner > .list-item-inner img {\n    border: 2px solid ${colors.brand.primary};\n  }\n\n  .list-item.active > .list-item-inner::after {\n    animation: fadeInSearchPreview 300ms ease;\n    top: 190px;\n    left: 50%;\n    border: solid transparent;\n    content: ' ';\n    height: 0;\n    width: 0;\n    position: absolute;\n    pointer-events: none;\n    border-color: rgba(136, 183, 213, 0);\n    border-bottom-color: ${colors.brand.lighter};\n    border-width: ${spacing.normal};\n    margin-left: -${spacing.normal};\n  }\n\n  .image-preview {\n    animation: fadeInSearchPreview 300ms ease;\n    position: relative;\n    width: 100%;\n    ${mq.range({ from: breakpoints.tablet, until: breakpoints.tabletWide })} {\n      width: 200%;\n    }\n    ${mq.range({ from: breakpoints.tabletWide, until: breakpoints.desktop })} {\n      width: 300%;\n    }\n    ${mq.range({ from: breakpoints.desktop, until: breakpoints.wide })} {\n      width: 400%;\n    }\n    ${mq.range({ from: breakpoints.wide })} {\n      width: 500%;\n    }\n    background-color: ${colors.brand.lighter};\n    border-radius: 2px;\n    margin: 20px 0;\n    display: flex;\n    align-items: flex-start;\n    justify-content: flex-start;\n\n    ${mq.range({ until: breakpoints.mobileWide })} {\n      display: block;\n    }\n\n    .image {\n      max-width: 50%;\n      padding: ${spacing.small};\n      ${mq.range({ until: breakpoints.mobileWide })} {\n        width: 100%;\n      }\n    }\n\n    .info {\n      ${fonts.sizes('16px', 1.3)}\n    }\n\n    .image img {\n      max-width: 100%;\n      max-height: 300px;\n    }\n\n    .information {\n      width: 50%;\n      padding: calc(${spacing.normal} - ${spacing.xsmall}) ${spacing.normal} ${spacing.normal} ${spacing.small};\n      word-break: initial;\n      ${mq.range({ until: breakpoints.mobileWide })} {\n        width: 100%;\n        padding: 0 ${spacing.small} ${spacing.normal};\n      }\n    }\n\n    .information > * {\n      margin-top: ${spacing.small};\n    }\n\n    .title {\n      padding-top: 0;\n      margin: 0;\n      line-height: 1.3;\n    }\n    .text--left {\n      width: 20%;\n      display: inline-block;\n    }\n\n    .text--right {\n      width: 80%;\n      display: inline-block;\n    }\n    .tags > b {\n      display: block;\n      margin-bottom: ${spacing.normal};\n    }\n\n    .tags > .tag_item {\n      font-weight: ${fonts.weight.semibold};\n      margin-right: ${spacing.xsmall};\n      margin-bottom: ${spacing.xsmall};\n      display: inline-block;\n      ${fonts.sizes('16px', 1.3)}\n    }\n\n    .tags > .tag_item:hover {\n      text-decoration: none;\n    }\n\n    .clear {\n      clear: both;\n    }\n\n    width: 100%;\n  }\n  ${mq.range({ from: breakpoints.tablet, until: breakpoints.tabletWide })} {\n    .list-item .image-preview {\n      width: 200%;\n    }\n    .list-item:nth-of-type(2n) .image-preview {\n      margin-left: -100%;\n    }\n  }\n  ${mq.range({ from: breakpoints.tabletWide, until: breakpoints.desktop })} {\n    .list-item .image-preview {\n      width: 300%;\n    }\n    .list-item:nth-of-type(3n - 1) .image-preview {\n      margin-left: -100%;\n    }\n    .list-item:nth-of-type(3n) .image-preview {\n      margin-left: -200%;\n    }\n  }\n  ${mq.range({ from: breakpoints.desktop, until: breakpoints.wide })} {\n    .list-item .image-preview {\n      width: 400%;\n    }\n    .list-item:nth-of-type(4n - 2) .image-preview {\n      margin-left: -100%;\n    }\n    .list-item:nth-of-type(4n - 1) .image-preview {\n      margin-left: -200%;\n    }\n    .list-item:nth-of-type(4n) .image-preview {\n      margin-left: -300%;\n    }\n  }\n  ${mq.range({ from: breakpoints.wide })} {\n    .list-item .image-preview {\n      width: 500%;\n    }\n    .list-item:nth-of-type(5n - 3) .image-preview {\n      margin-left: -100%;\n    }\n    .list-item:nth-of-type(5n - 2) .image-preview {\n      margin-left: -200%;\n    }\n    .list-item:nth-of-type(5n - 1) .image-preview {\n      margin-left: -300%;\n    }\n    .list-item:nth-of-type(5n) .image-preview {\n      margin-left: -400%;\n    }\n  }\n\n  @keyframes fadeInSearchPreview {\n    0% {\n      display: none;\n      opacity: 0;\n    }\n    1% {\n      opacity: 0;\n      display: flex;\n      transform: translateY(-20px);\n    }\n    100% {\n      opacity: 1;\n      transform: translateY(0px);\n    }\n  }\n`;\n\nconst searchIconCss = css`\n  border: 0;\n  background: transparent;\n  margin: 0;\n  padding: 0;\n`;\n\ninterface Props {\n  onImageSelect: (image: IImageMetaInformationV3) => void;\n  searchImages: (query: string | undefined, page: number | undefined) => Promise<ISearchResultV3>;\n  fetchImage: (id: number) => Promise<IImageMetaInformationV3>;\n  onError: (err: any) => void;\n  searchPlaceholder: string;\n  searchButtonTitle: string;\n  locale: string;\n  useImageTitle: string;\n  noResults?: ReactNode;\n  checkboxAction?: (image: IImageMetaInformationV3) => void;\n  showCheckbox?: boolean;\n  checkboxLabel?: string;\n}\n\ninterface State {\n  queryObject: ISearchParams;\n  images: IImageMetaInformationV3[];\n  selectedImage?: IImageMetaInformationV3;\n  lastPage: number;\n  searching: boolean;\n  queryString?: string;\n}\nclass ImageSearch extends Component<Props, State> {\n  constructor(props: Props) {\n    super(props);\n    this.state = {\n      queryObject: {\n        query: undefined,\n        page: 1,\n        pageSize: 16,\n      },\n      images: [],\n      selectedImage: undefined,\n      lastPage: 0,\n      searching: false,\n    };\n\n    this.searchImages = this.searchImages.bind(this);\n    this.onImageClick = this.onImageClick.bind(this);\n    this.onSelectImage = this.onSelectImage.bind(this);\n  }\n\n  componentDidMount() {\n    this.searchImages(this.state.queryObject);\n  }\n\n  onImageClick(image: IImageMetaInformationV3) {\n    const { onError, fetchImage } = this.props;\n    const { selectedImage } = this.state;\n    if (!selectedImage || image.id !== selectedImage.id) {\n      fetchImage(parseInt(image.id))\n        .then((result) => {\n          this.setState({ selectedImage: result });\n        })\n        .catch((err) => {\n          onError(err);\n        });\n    }\n  }\n\n  onSelectImage(image: IImageMetaInformationV3, saveAsMetaImage: boolean) {\n    const { onImageSelect, checkboxAction } = this.props;\n    this.setState({ selectedImage: undefined });\n    onImageSelect(image);\n    if (saveAsMetaImage) {\n      checkboxAction && checkboxAction(image);\n    }\n  }\n\n  searchImages(queryObject: ISearchParams) {\n    const { searchImages, onError } = this.props;\n    this.setState({ searching: true });\n    searchImages(queryObject.query, queryObject.page)\n      .then((result) => {\n        this.setState({\n          queryObject: {\n            query: queryObject.query,\n            pageSize: result.pageSize,\n            page: queryObject.page,\n          },\n          images: result.results,\n          lastPage: Math.ceil(result.totalCount / result.pageSize),\n          searching: false,\n        });\n      })\n      .catch((err) => {\n        onError(err);\n        this.setState({ searching: false });\n      });\n  }\n\n  render() {\n    const { searchPlaceholder, searchButtonTitle, useImageTitle, showCheckbox, checkboxLabel } = this.props;\n\n    const { queryObject, images, selectedImage, lastPage, searching, queryString } = this.state;\n\n    const { page } = queryObject;\n    const noResultsFound = !searching && images.length === 0;\n\n    return (\n      <ImageSearchWrapper>\n        <InputContainer>\n          <InputV3\n            placeholder={searchPlaceholder}\n            // eslint-disable-next-line jsx-a11y/no-autofocus\n            autoFocus\n            value={queryString}\n            onChange={(evt: ChangeEvent<HTMLInputElement>) => this.setState({ queryString: evt.target.value })}\n            onKeyPress={(evt: KeyboardEvent<HTMLInputElement>) => {\n              if (evt.key === 'Enter') {\n                evt.preventDefault();\n                this.searchImages({ query: queryString, page: 1 });\n              }\n            }}\n          />\n          <button\n            css={searchIconCss}\n            aria-label={searchButtonTitle}\n            type=\"button\"\n            onClick={() => {\n              this.searchImages({ query: queryString, page: 1 });\n            }}\n          >\n            <SearchIcon />\n          </button>\n        </InputContainer>\n        {noResultsFound && this.props.noResults}\n        <div className=\"list\">\n          {images.map((image) => (\n            <ImageSearchResult\n              key={image.id}\n              image={image}\n              onImageClick={this.onImageClick}\n              selectedImage={selectedImage}\n              onSelectImage={this.onSelectImage}\n              useImageTitle={useImageTitle}\n              showCheckbox={!!showCheckbox}\n              checkboxLabel={checkboxLabel}\n            />\n          ))}\n        </div>\n        <Pager\n          page={page ?? 1}\n          pathname=\"\"\n          lastPage={lastPage}\n          query={queryObject}\n          onClick={this.searchImages}\n          pageItemComponentClass=\"button\"\n        />\n      </ImageSearchWrapper>\n    );\n  }\n}\n\nexport default ImageSearch;\n"]} */"));
73
- var searchIconCss = process.env.NODE_ENV === "production" ? {
60
+ const searchIconCss = process.env.NODE_ENV === "production" ? {
74
61
  name: "imhgxk-searchIconCss",
75
62
  styles: "border:0;background:transparent;margin:0;padding:0;label:searchIconCss;"
76
63
  } : {
@@ -79,14 +66,10 @@ var searchIconCss = process.env.NODE_ENV === "production" ? {
79
66
  map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ImageSearch.tsx"],"names":[],"mappings":"AA2QyB","file":"ImageSearch.tsx","sourcesContent":["/**\n * Copyright (c) 2017-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 { ChangeEvent, Component, ReactNode, KeyboardEvent } from 'react';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport { fonts, colors, spacing, mq, breakpoints } from '@ndla/core';\nimport Pager from '@ndla/pager';\nimport { IImageMetaInformationV3, ISearchResultV3, ISearchParams } from '@ndla/types-backend/image-api';\nimport { InputContainer, InputV3 } from '@ndla/forms';\nimport { Search as SearchIcon } from '@ndla/icons/common';\nimport ImageSearchResult from './ImageSearchResult';\n\nconst ImageSearchWrapper = styled.div`\n  .text {\n    text-align: center;\n  }\n  .list-item {\n    position: relative;\n    float: left;\n    height: 210px;\n    width: 100%;\n    ${mq.range({ from: breakpoints.tablet })} {\n      width: 50%;\n    }\n    ${mq.range({ from: breakpoints.tabletWide })} {\n      width: 33.3%;\n    }\n    ${mq.range({ from: breakpoints.desktop })} {\n      width: 25%;\n    }\n    ${mq.range({ from: breakpoints.wide })} {\n      width: 20%;\n    }\n    &.active {\n      height: inherit;\n    }\n  }\n\n  .list {\n    display: flex;\n    align-items: stretch;\n    flex-flow: row wrap;\n    position: relative;\n    margin-left: -${spacing.small};\n    margin-right: -${spacing.small};\n    margin-top: ${spacing.normal};\n  }\n\n  .list-item-inner {\n    padding: ${spacing.small};\n    text-align: center;\n    height: 210px;\n\n    .list-item-title {\n      margin: ${spacing.xsmall} 0;\n      ${fonts.sizes('14px', 1.2)};\n      overflow: hidden;\n      text-overflow: ellipsis;\n      display: -webkit-box;\n      -webkit-box-orient: vertical;\n      -webkit-line-clamp: 3;\n      max-height: ${spacing.large};\n    }\n  }\n\n  .list-item-inner img {\n    max-height: 135px;\n    max-width: 100%;\n    border: 2px solid white;\n    transition: border-color 100ms ease;\n  }\n\n  .list-item-inner:hover {\n    img {\n      border: 2px solid ${colors.brand.primary};\n    }\n  }\n\n  .list-item-inner > .list-item-inner img {\n    border: 2px solid ${colors.brand.primary};\n  }\n\n  .list-item.active > .list-item-inner::after {\n    animation: fadeInSearchPreview 300ms ease;\n    top: 190px;\n    left: 50%;\n    border: solid transparent;\n    content: ' ';\n    height: 0;\n    width: 0;\n    position: absolute;\n    pointer-events: none;\n    border-color: rgba(136, 183, 213, 0);\n    border-bottom-color: ${colors.brand.lighter};\n    border-width: ${spacing.normal};\n    margin-left: -${spacing.normal};\n  }\n\n  .image-preview {\n    animation: fadeInSearchPreview 300ms ease;\n    position: relative;\n    width: 100%;\n    ${mq.range({ from: breakpoints.tablet, until: breakpoints.tabletWide })} {\n      width: 200%;\n    }\n    ${mq.range({ from: breakpoints.tabletWide, until: breakpoints.desktop })} {\n      width: 300%;\n    }\n    ${mq.range({ from: breakpoints.desktop, until: breakpoints.wide })} {\n      width: 400%;\n    }\n    ${mq.range({ from: breakpoints.wide })} {\n      width: 500%;\n    }\n    background-color: ${colors.brand.lighter};\n    border-radius: 2px;\n    margin: 20px 0;\n    display: flex;\n    align-items: flex-start;\n    justify-content: flex-start;\n\n    ${mq.range({ until: breakpoints.mobileWide })} {\n      display: block;\n    }\n\n    .image {\n      max-width: 50%;\n      padding: ${spacing.small};\n      ${mq.range({ until: breakpoints.mobileWide })} {\n        width: 100%;\n      }\n    }\n\n    .info {\n      ${fonts.sizes('16px', 1.3)}\n    }\n\n    .image img {\n      max-width: 100%;\n      max-height: 300px;\n    }\n\n    .information {\n      width: 50%;\n      padding: calc(${spacing.normal} - ${spacing.xsmall}) ${spacing.normal} ${spacing.normal} ${spacing.small};\n      word-break: initial;\n      ${mq.range({ until: breakpoints.mobileWide })} {\n        width: 100%;\n        padding: 0 ${spacing.small} ${spacing.normal};\n      }\n    }\n\n    .information > * {\n      margin-top: ${spacing.small};\n    }\n\n    .title {\n      padding-top: 0;\n      margin: 0;\n      line-height: 1.3;\n    }\n    .text--left {\n      width: 20%;\n      display: inline-block;\n    }\n\n    .text--right {\n      width: 80%;\n      display: inline-block;\n    }\n    .tags > b {\n      display: block;\n      margin-bottom: ${spacing.normal};\n    }\n\n    .tags > .tag_item {\n      font-weight: ${fonts.weight.semibold};\n      margin-right: ${spacing.xsmall};\n      margin-bottom: ${spacing.xsmall};\n      display: inline-block;\n      ${fonts.sizes('16px', 1.3)}\n    }\n\n    .tags > .tag_item:hover {\n      text-decoration: none;\n    }\n\n    .clear {\n      clear: both;\n    }\n\n    width: 100%;\n  }\n  ${mq.range({ from: breakpoints.tablet, until: breakpoints.tabletWide })} {\n    .list-item .image-preview {\n      width: 200%;\n    }\n    .list-item:nth-of-type(2n) .image-preview {\n      margin-left: -100%;\n    }\n  }\n  ${mq.range({ from: breakpoints.tabletWide, until: breakpoints.desktop })} {\n    .list-item .image-preview {\n      width: 300%;\n    }\n    .list-item:nth-of-type(3n - 1) .image-preview {\n      margin-left: -100%;\n    }\n    .list-item:nth-of-type(3n) .image-preview {\n      margin-left: -200%;\n    }\n  }\n  ${mq.range({ from: breakpoints.desktop, until: breakpoints.wide })} {\n    .list-item .image-preview {\n      width: 400%;\n    }\n    .list-item:nth-of-type(4n - 2) .image-preview {\n      margin-left: -100%;\n    }\n    .list-item:nth-of-type(4n - 1) .image-preview {\n      margin-left: -200%;\n    }\n    .list-item:nth-of-type(4n) .image-preview {\n      margin-left: -300%;\n    }\n  }\n  ${mq.range({ from: breakpoints.wide })} {\n    .list-item .image-preview {\n      width: 500%;\n    }\n    .list-item:nth-of-type(5n - 3) .image-preview {\n      margin-left: -100%;\n    }\n    .list-item:nth-of-type(5n - 2) .image-preview {\n      margin-left: -200%;\n    }\n    .list-item:nth-of-type(5n - 1) .image-preview {\n      margin-left: -300%;\n    }\n    .list-item:nth-of-type(5n) .image-preview {\n      margin-left: -400%;\n    }\n  }\n\n  @keyframes fadeInSearchPreview {\n    0% {\n      display: none;\n      opacity: 0;\n    }\n    1% {\n      opacity: 0;\n      display: flex;\n      transform: translateY(-20px);\n    }\n    100% {\n      opacity: 1;\n      transform: translateY(0px);\n    }\n  }\n`;\n\nconst searchIconCss = css`\n  border: 0;\n  background: transparent;\n  margin: 0;\n  padding: 0;\n`;\n\ninterface Props {\n  onImageSelect: (image: IImageMetaInformationV3) => void;\n  searchImages: (query: string | undefined, page: number | undefined) => Promise<ISearchResultV3>;\n  fetchImage: (id: number) => Promise<IImageMetaInformationV3>;\n  onError: (err: any) => void;\n  searchPlaceholder: string;\n  searchButtonTitle: string;\n  locale: string;\n  useImageTitle: string;\n  noResults?: ReactNode;\n  checkboxAction?: (image: IImageMetaInformationV3) => void;\n  showCheckbox?: boolean;\n  checkboxLabel?: string;\n}\n\ninterface State {\n  queryObject: ISearchParams;\n  images: IImageMetaInformationV3[];\n  selectedImage?: IImageMetaInformationV3;\n  lastPage: number;\n  searching: boolean;\n  queryString?: string;\n}\nclass ImageSearch extends Component<Props, State> {\n  constructor(props: Props) {\n    super(props);\n    this.state = {\n      queryObject: {\n        query: undefined,\n        page: 1,\n        pageSize: 16,\n      },\n      images: [],\n      selectedImage: undefined,\n      lastPage: 0,\n      searching: false,\n    };\n\n    this.searchImages = this.searchImages.bind(this);\n    this.onImageClick = this.onImageClick.bind(this);\n    this.onSelectImage = this.onSelectImage.bind(this);\n  }\n\n  componentDidMount() {\n    this.searchImages(this.state.queryObject);\n  }\n\n  onImageClick(image: IImageMetaInformationV3) {\n    const { onError, fetchImage } = this.props;\n    const { selectedImage } = this.state;\n    if (!selectedImage || image.id !== selectedImage.id) {\n      fetchImage(parseInt(image.id))\n        .then((result) => {\n          this.setState({ selectedImage: result });\n        })\n        .catch((err) => {\n          onError(err);\n        });\n    }\n  }\n\n  onSelectImage(image: IImageMetaInformationV3, saveAsMetaImage: boolean) {\n    const { onImageSelect, checkboxAction } = this.props;\n    this.setState({ selectedImage: undefined });\n    onImageSelect(image);\n    if (saveAsMetaImage) {\n      checkboxAction && checkboxAction(image);\n    }\n  }\n\n  searchImages(queryObject: ISearchParams) {\n    const { searchImages, onError } = this.props;\n    this.setState({ searching: true });\n    searchImages(queryObject.query, queryObject.page)\n      .then((result) => {\n        this.setState({\n          queryObject: {\n            query: queryObject.query,\n            pageSize: result.pageSize,\n            page: queryObject.page,\n          },\n          images: result.results,\n          lastPage: Math.ceil(result.totalCount / result.pageSize),\n          searching: false,\n        });\n      })\n      .catch((err) => {\n        onError(err);\n        this.setState({ searching: false });\n      });\n  }\n\n  render() {\n    const { searchPlaceholder, searchButtonTitle, useImageTitle, showCheckbox, checkboxLabel } = this.props;\n\n    const { queryObject, images, selectedImage, lastPage, searching, queryString } = this.state;\n\n    const { page } = queryObject;\n    const noResultsFound = !searching && images.length === 0;\n\n    return (\n      <ImageSearchWrapper>\n        <InputContainer>\n          <InputV3\n            placeholder={searchPlaceholder}\n            // eslint-disable-next-line jsx-a11y/no-autofocus\n            autoFocus\n            value={queryString}\n            onChange={(evt: ChangeEvent<HTMLInputElement>) => this.setState({ queryString: evt.target.value })}\n            onKeyPress={(evt: KeyboardEvent<HTMLInputElement>) => {\n              if (evt.key === 'Enter') {\n                evt.preventDefault();\n                this.searchImages({ query: queryString, page: 1 });\n              }\n            }}\n          />\n          <button\n            css={searchIconCss}\n            aria-label={searchButtonTitle}\n            type=\"button\"\n            onClick={() => {\n              this.searchImages({ query: queryString, page: 1 });\n            }}\n          >\n            <SearchIcon />\n          </button>\n        </InputContainer>\n        {noResultsFound && this.props.noResults}\n        <div className=\"list\">\n          {images.map((image) => (\n            <ImageSearchResult\n              key={image.id}\n              image={image}\n              onImageClick={this.onImageClick}\n              selectedImage={selectedImage}\n              onSelectImage={this.onSelectImage}\n              useImageTitle={useImageTitle}\n              showCheckbox={!!showCheckbox}\n              checkboxLabel={checkboxLabel}\n            />\n          ))}\n        </div>\n        <Pager\n          page={page ?? 1}\n          pathname=\"\"\n          lastPage={lastPage}\n          query={queryObject}\n          onClick={this.searchImages}\n          pageItemComponentClass=\"button\"\n        />\n      </ImageSearchWrapper>\n    );\n  }\n}\n\nexport default ImageSearch;\n"]} */",
80
67
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
81
68
  };
82
- var ImageSearch = /*#__PURE__*/function (_Component) {
83
- _inherits(ImageSearch, _Component);
84
- var _super = _createSuper(ImageSearch);
85
- function ImageSearch(props) {
86
- var _this;
87
- _classCallCheck(this, ImageSearch);
88
- _this = _super.call(this, props);
89
- _this.state = {
69
+ class ImageSearch extends Component {
70
+ constructor(props) {
71
+ super(props);
72
+ this.state = {
90
73
  queryObject: {
91
74
  query: undefined,
92
75
  page: 1,
@@ -97,153 +80,142 @@ var ImageSearch = /*#__PURE__*/function (_Component) {
97
80
  lastPage: 0,
98
81
  searching: false
99
82
  };
100
- _this.searchImages = _this.searchImages.bind(_assertThisInitialized(_this));
101
- _this.onImageClick = _this.onImageClick.bind(_assertThisInitialized(_this));
102
- _this.onSelectImage = _this.onSelectImage.bind(_assertThisInitialized(_this));
103
- return _this;
83
+ this.searchImages = this.searchImages.bind(this);
84
+ this.onImageClick = this.onImageClick.bind(this);
85
+ this.onSelectImage = this.onSelectImage.bind(this);
104
86
  }
105
- _createClass(ImageSearch, [{
106
- key: "componentDidMount",
107
- value: function componentDidMount() {
108
- this.searchImages(this.state.queryObject);
109
- }
110
- }, {
111
- key: "onImageClick",
112
- value: function onImageClick(image) {
113
- var _this2 = this;
114
- var _this$props = this.props,
115
- onError = _this$props.onError,
116
- fetchImage = _this$props.fetchImage;
117
- var selectedImage = this.state.selectedImage;
118
- if (!selectedImage || image.id !== selectedImage.id) {
119
- fetchImage(parseInt(image.id)).then(function (result) {
120
- _this2.setState({
121
- selectedImage: result
122
- });
123
- }).catch(function (err) {
124
- onError(err);
87
+ componentDidMount() {
88
+ this.searchImages(this.state.queryObject);
89
+ }
90
+ onImageClick(image) {
91
+ const {
92
+ onError,
93
+ fetchImage
94
+ } = this.props;
95
+ const {
96
+ selectedImage
97
+ } = this.state;
98
+ if (!selectedImage || image.id !== selectedImage.id) {
99
+ fetchImage(parseInt(image.id)).then(result => {
100
+ this.setState({
101
+ selectedImage: result
125
102
  });
126
- }
127
- }
128
- }, {
129
- key: "onSelectImage",
130
- value: function onSelectImage(image, saveAsMetaImage) {
131
- var _this$props2 = this.props,
132
- onImageSelect = _this$props2.onImageSelect,
133
- checkboxAction = _this$props2.checkboxAction;
134
- this.setState({
135
- selectedImage: undefined
103
+ }).catch(err => {
104
+ onError(err);
136
105
  });
137
- onImageSelect(image);
138
- if (saveAsMetaImage) {
139
- checkboxAction && checkboxAction(image);
140
- }
141
106
  }
142
- }, {
143
- key: "searchImages",
144
- value: function searchImages(queryObject) {
145
- var _this3 = this;
146
- var _this$props3 = this.props,
147
- searchImages = _this$props3.searchImages,
148
- onError = _this$props3.onError;
107
+ }
108
+ onSelectImage(image, saveAsMetaImage) {
109
+ const {
110
+ onImageSelect,
111
+ checkboxAction
112
+ } = this.props;
113
+ this.setState({
114
+ selectedImage: undefined
115
+ });
116
+ onImageSelect(image);
117
+ if (saveAsMetaImage) {
118
+ checkboxAction && checkboxAction(image);
119
+ }
120
+ }
121
+ searchImages(queryObject) {
122
+ const {
123
+ searchImages,
124
+ onError
125
+ } = this.props;
126
+ this.setState({
127
+ searching: true
128
+ });
129
+ searchImages(queryObject.query, queryObject.page).then(result => {
149
130
  this.setState({
150
- searching: true
131
+ queryObject: {
132
+ query: queryObject.query,
133
+ pageSize: result.pageSize,
134
+ page: queryObject.page
135
+ },
136
+ images: result.results,
137
+ lastPage: Math.ceil(result.totalCount / result.pageSize),
138
+ searching: false
151
139
  });
152
- searchImages(queryObject.query, queryObject.page).then(function (result) {
153
- _this3.setState({
154
- queryObject: {
155
- query: queryObject.query,
156
- pageSize: result.pageSize,
157
- page: queryObject.page
158
- },
159
- images: result.results,
160
- lastPage: Math.ceil(result.totalCount / result.pageSize),
161
- searching: false
162
- });
163
- }).catch(function (err) {
164
- onError(err);
165
- _this3.setState({
166
- searching: false
167
- });
140
+ }).catch(err => {
141
+ onError(err);
142
+ this.setState({
143
+ searching: false
168
144
  });
169
- }
170
- }, {
171
- key: "render",
172
- value: function render() {
173
- var _this4 = this;
174
- var _this$props4 = this.props,
175
- searchPlaceholder = _this$props4.searchPlaceholder,
176
- searchButtonTitle = _this$props4.searchButtonTitle,
177
- useImageTitle = _this$props4.useImageTitle,
178
- showCheckbox = _this$props4.showCheckbox,
179
- checkboxLabel = _this$props4.checkboxLabel;
180
- var _this$state = this.state,
181
- queryObject = _this$state.queryObject,
182
- images = _this$state.images,
183
- selectedImage = _this$state.selectedImage,
184
- lastPage = _this$state.lastPage,
185
- searching = _this$state.searching,
186
- queryString = _this$state.queryString;
187
- var page = queryObject.page;
188
- var noResultsFound = !searching && images.length === 0;
189
- return _jsxs(ImageSearchWrapper, {
190
- children: [_jsxs(InputContainer, {
191
- children: [_jsx(InputV3, {
192
- placeholder: searchPlaceholder
193
- // eslint-disable-next-line jsx-a11y/no-autofocus
194
- ,
195
- autoFocus: true,
196
- value: queryString,
197
- onChange: function onChange(evt) {
198
- return _this4.setState({
199
- queryString: evt.target.value
200
- });
201
- },
202
- onKeyPress: function onKeyPress(evt) {
203
- if (evt.key === 'Enter') {
204
- evt.preventDefault();
205
- _this4.searchImages({
206
- query: queryString,
207
- page: 1
208
- });
209
- }
210
- }
211
- }), _jsx("button", {
212
- css: searchIconCss,
213
- "aria-label": searchButtonTitle,
214
- type: "button",
215
- onClick: function onClick() {
216
- _this4.searchImages({
145
+ });
146
+ }
147
+ render() {
148
+ const {
149
+ searchPlaceholder,
150
+ searchButtonTitle,
151
+ useImageTitle,
152
+ showCheckbox,
153
+ checkboxLabel
154
+ } = this.props;
155
+ const {
156
+ queryObject,
157
+ images,
158
+ selectedImage,
159
+ lastPage,
160
+ searching,
161
+ queryString
162
+ } = this.state;
163
+ const {
164
+ page
165
+ } = queryObject;
166
+ const noResultsFound = !searching && images.length === 0;
167
+ return _jsxs(ImageSearchWrapper, {
168
+ children: [_jsxs(InputContainer, {
169
+ children: [_jsx(InputV3, {
170
+ placeholder: searchPlaceholder
171
+ // eslint-disable-next-line jsx-a11y/no-autofocus
172
+ ,
173
+ autoFocus: true,
174
+ value: queryString,
175
+ onChange: evt => this.setState({
176
+ queryString: evt.target.value
177
+ }),
178
+ onKeyPress: evt => {
179
+ if (evt.key === 'Enter') {
180
+ evt.preventDefault();
181
+ this.searchImages({
217
182
  query: queryString,
218
183
  page: 1
219
184
  });
220
- },
221
- children: _jsx(SearchIcon, {})
222
- })]
223
- }), noResultsFound && this.props.noResults, _jsx("div", {
224
- className: "list",
225
- children: images.map(function (image) {
226
- return _jsx(ImageSearchResult, {
227
- image: image,
228
- onImageClick: _this4.onImageClick,
229
- selectedImage: selectedImage,
230
- onSelectImage: _this4.onSelectImage,
231
- useImageTitle: useImageTitle,
232
- showCheckbox: !!showCheckbox,
233
- checkboxLabel: checkboxLabel
234
- }, image.id);
235
- })
236
- }), _jsx(Pager, {
237
- page: page !== null && page !== void 0 ? page : 1,
238
- pathname: "",
239
- lastPage: lastPage,
240
- query: queryObject,
241
- onClick: this.searchImages,
242
- pageItemComponentClass: "button"
185
+ }
186
+ }
187
+ }), _jsx("button", {
188
+ css: searchIconCss,
189
+ "aria-label": searchButtonTitle,
190
+ type: "button",
191
+ onClick: () => {
192
+ this.searchImages({
193
+ query: queryString,
194
+ page: 1
195
+ });
196
+ },
197
+ children: _jsx(SearchIcon, {})
243
198
  })]
244
- });
245
- }
246
- }]);
247
- return ImageSearch;
248
- }(Component);
199
+ }), noResultsFound && this.props.noResults, _jsx("div", {
200
+ className: "list",
201
+ children: images.map(image => _jsx(ImageSearchResult, {
202
+ image: image,
203
+ onImageClick: this.onImageClick,
204
+ selectedImage: selectedImage,
205
+ onSelectImage: this.onSelectImage,
206
+ useImageTitle: useImageTitle,
207
+ showCheckbox: !!showCheckbox,
208
+ checkboxLabel: checkboxLabel
209
+ }, image.id))
210
+ }), _jsx(Pager, {
211
+ page: page ?? 1,
212
+ pathname: "",
213
+ lastPage: lastPage,
214
+ query: queryObject,
215
+ onClick: this.searchImages,
216
+ pageItemComponentClass: "button"
217
+ })]
218
+ });
219
+ }
220
+ }
249
221
  export default ImageSearch;
@@ -13,7 +13,7 @@ import PreviewImage from './PreviewImage';
13
13
  import { getPreviewSrcSets } from './util/imageUtil';
14
14
  import { jsx as _jsx } from "@emotion/react/jsx-runtime";
15
15
  import { jsxs as _jsxs } from "@emotion/react/jsx-runtime";
16
- var StyledButton = /*#__PURE__*/_styled(ButtonV2, {
16
+ const StyledButton = /*#__PURE__*/_styled(ButtonV2, {
17
17
  target: "e1evho0k0",
18
18
  label: "StyledButton"
19
19
  })(process.env.NODE_ENV === "production" ? {
@@ -26,24 +26,24 @@ var StyledButton = /*#__PURE__*/_styled(ButtonV2, {
26
26
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
27
27
  });
28
28
  export default function ImageSearchResult(_ref) {
29
- var image = _ref.image,
30
- onImageClick = _ref.onImageClick,
31
- selectedImage = _ref.selectedImage,
32
- onSelectImage = _ref.onSelectImage,
33
- useImageTitle = _ref.useImageTitle,
34
- showCheckbox = _ref.showCheckbox,
35
- checkboxLabel = _ref.checkboxLabel;
36
- var active = selectedImage && selectedImage.id === image.id ? 'active' : '';
29
+ let {
30
+ image,
31
+ onImageClick,
32
+ selectedImage,
33
+ onSelectImage,
34
+ useImageTitle,
35
+ showCheckbox,
36
+ checkboxLabel
37
+ } = _ref;
38
+ const active = selectedImage && selectedImage.id === image.id ? 'active' : '';
37
39
  return _jsxs("div", {
38
- className: "list-item ".concat(active),
40
+ className: `list-item ${active}`,
39
41
  children: [_jsx("div", {
40
42
  className: "list-item-inner",
41
43
  children: _jsxs(StyledButton, {
42
44
  variant: "stripped",
43
45
  "data-testid": "select-image-from-list",
44
- onClick: function onClick() {
45
- return onImageClick(image);
46
- },
46
+ onClick: () => onImageClick(image),
47
47
  children: [_jsx("img", {
48
48
  role: "presentation",
49
49
  alt: "presentation",
@@ -1,9 +1,3 @@
1
- function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
2
- 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."); }
3
- 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); }
4
- function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }
5
- function _iterableToArrayLimit(arr, i) { var _i = null == arr ? null : "undefined" != typeof Symbol && arr[Symbol.iterator] || arr["@@iterator"]; if (null != _i) { var _s, _e, _x, _r, _arr = [], _n = !0, _d = !1; try { if (_x = (_i = _i.call(arr)).next, 0 === i) { if (Object(_i) !== _i) return; _n = !1; } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0); } catch (err) { _d = !0, _e = err; } finally { try { if (!_n && null != _i.return && (_r = _i.return(), Object(_r) !== _r)) return; } finally { if (_d) throw _e; } } return _arr; } }
6
- function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
7
1
  /**
8
2
  * Copyright (c) 2017-present, NDLA.
9
3
  *
@@ -21,23 +15,22 @@ import { getSrcSets } from './util/imageUtil';
21
15
  import ImageMeta from './ImageMeta';
22
16
  import { jsx as _jsx } from "@emotion/react/jsx-runtime";
23
17
  import { jsxs as _jsxs } from "@emotion/react/jsx-runtime";
24
- var PreviewImage = function PreviewImage(_ref) {
25
- var _image$tags$tags, _image$title$title, _image$alttext$alttex, _image$caption$captio;
26
- var image = _ref.image,
27
- onSelectImage = _ref.onSelectImage,
28
- useImageTitle = _ref.useImageTitle,
29
- showCheckbox = _ref.showCheckbox,
30
- checkboxLabel = _ref.checkboxLabel;
31
- var _useTranslation = useTranslation(),
32
- t = _useTranslation.t;
33
- var _useState = useState(false),
34
- _useState2 = _slicedToArray(_useState, 2),
35
- saveAsMetaImage = _useState2[0],
36
- setSaveAsMetaImage = _useState2[1];
37
- var tags = (_image$tags$tags = image.tags.tags) !== null && _image$tags$tags !== void 0 ? _image$tags$tags : [];
38
- var title = (_image$title$title = image.title.title) !== null && _image$title$title !== void 0 ? _image$title$title : '';
39
- var altText = (_image$alttext$alttex = image.alttext.alttext) !== null && _image$alttext$alttex !== void 0 ? _image$alttext$alttex : '';
40
- var caption = (_image$caption$captio = image.caption.caption) !== null && _image$caption$captio !== void 0 ? _image$caption$captio : '';
18
+ const PreviewImage = _ref => {
19
+ let {
20
+ image,
21
+ onSelectImage,
22
+ useImageTitle,
23
+ showCheckbox,
24
+ checkboxLabel
25
+ } = _ref;
26
+ const {
27
+ t
28
+ } = useTranslation();
29
+ const [saveAsMetaImage, setSaveAsMetaImage] = useState(false);
30
+ const tags = image.tags.tags ?? [];
31
+ const title = image.title.title ?? '';
32
+ const altText = image.alttext.alttext ?? '';
33
+ const caption = image.caption.caption ?? '';
41
34
  return _jsxs("div", {
42
35
  className: "image-preview",
43
36
  children: [_jsx("div", {
@@ -59,9 +52,7 @@ var PreviewImage = function PreviewImage(_ref) {
59
52
  className: "copyright-author",
60
53
  children: _jsx("span", {
61
54
  className: "text",
62
- children: image.copyright.creators.map(function (creator) {
63
- return creator.name;
64
- }).join(', ')
55
+ children: image.copyright.creators.map(creator => creator.name).join(', ')
65
56
  })
66
57
  }) : null, _jsx("div", {
67
58
  className: "info",
@@ -73,19 +64,19 @@ var PreviewImage = function PreviewImage(_ref) {
73
64
  className: "info",
74
65
  children: _jsx("span", {
75
66
  className: "text",
76
- children: "".concat(t('image.caption'), ": ").concat(caption)
67
+ children: `${t('image.caption')}: ${caption}`
77
68
  })
78
69
  }), _jsx("div", {
79
70
  className: "info",
80
71
  children: _jsx("span", {
81
72
  className: "text",
82
- children: "".concat(t('image.altText'), ": ").concat(altText)
73
+ children: `${t('image.altText')}: ${altText}`
83
74
  })
84
75
  }), _jsx("div", {
85
76
  className: "info",
86
77
  children: _jsx("span", {
87
78
  className: "text",
88
- children: "".concat(t('image.modelReleased.label'), ": ").concat(t('image.modelReleased.' + image.modelRelease))
79
+ children: `${t('image.modelReleased.label')}: ${t('image.modelReleased.' + image.modelRelease)}`
89
80
  })
90
81
  }), _jsx(ImageMeta, {
91
82
  contentType: image.image.contentType,
@@ -93,27 +84,19 @@ var PreviewImage = function PreviewImage(_ref) {
93
84
  imageDimensions: image.image.dimensions
94
85
  }), _jsx("div", {
95
86
  className: "tags",
96
- children: tags.map(function (tag) {
97
- return _jsx("span", {
98
- className: "tag_item",
99
- children: "#".concat(tag)
100
- }, uuid());
101
- })
87
+ children: tags.map(tag => _jsx("span", {
88
+ className: "tag_item",
89
+ children: `#${tag}`
90
+ }, uuid()))
102
91
  }), _jsx(ButtonV2, {
103
92
  "data-testid": "use-image",
104
- onClick: function onClick() {
105
- return onSelectImage(image, saveAsMetaImage);
106
- },
93
+ onClick: () => onSelectImage(image, saveAsMetaImage),
107
94
  children: useImageTitle
108
95
  }), showCheckbox && _jsx("div", {
109
96
  children: _jsx(CheckboxItem, {
110
97
  label: checkboxLabel,
111
98
  checked: saveAsMetaImage,
112
- onChange: function onChange() {
113
- return setSaveAsMetaImage(function (prev) {
114
- return !prev;
115
- });
116
- }
99
+ onChange: () => setSaveAsMetaImage(prev => !prev)
117
100
  })
118
101
  })]
119
102
  }), _jsx("div", {
@@ -9,9 +9,5 @@
9
9
  /* - Source sets for gallery search is retina-display optimized
10
10
  - Based on: https://www.smashingmagazine.com/2014/05/responsive-images-done-right-guide-picture-srcset/ */
11
11
 
12
- export var getSrcSets = function getSrcSets(imageUrl) {
13
- return ["".concat(imageUrl, "?width=1440 1440w"), "".concat(imageUrl, "?width=1120 1120w"), "".concat(imageUrl, "?width=1000 1000w"), "".concat(imageUrl, "?width=960 960w"), "".concat(imageUrl, "?width=800 800w"), "".concat(imageUrl, "?width=640 640w"), "".concat(imageUrl, "?width=480 480w"), "".concat(imageUrl, "?width=320 320w")].join(', ');
14
- };
15
- export var getPreviewSrcSets = function getPreviewSrcSets(imageUrl) {
16
- return ["".concat(imageUrl, "?width=480 3x"), "".concat(imageUrl, "?width=320 2x"), "".concat(imageUrl, "?width=160 1x")].join(', ');
17
- };
12
+ export const getSrcSets = imageUrl => [`${imageUrl}?width=1440 1440w`, `${imageUrl}?width=1120 1120w`, `${imageUrl}?width=1000 1000w`, `${imageUrl}?width=960 960w`, `${imageUrl}?width=800 800w`, `${imageUrl}?width=640 640w`, `${imageUrl}?width=480 480w`, `${imageUrl}?width=320 320w`].join(', ');
13
+ export const getPreviewSrcSets = imageUrl => [`${imageUrl}?width=480 3x`, `${imageUrl}?width=320 2x`, `${imageUrl}?width=160 1x`].join(', ');