@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/lib/ImageMeta.js CHANGED
@@ -10,17 +10,17 @@ var _core = require("@ndla/core");
10
10
  var _jsxRuntime = require("@emotion/react/jsx-runtime");
11
11
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
12
12
  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)."; } /**
13
- * Copyright (c) 2022-present, NDLA.
14
- *
15
- * This source code is licensed under the GPLv3 license found in the
16
- * LICENSE file in the root directory of this source tree.
17
- *
18
- */
19
- var StyledDiv = /*#__PURE__*/(0, _base.default)("div", {
13
+ * Copyright (c) 2022-present, NDLA.
14
+ *
15
+ * This source code is licensed under the GPLv3 license found in the
16
+ * LICENSE file in the root directory of this source tree.
17
+ *
18
+ */
19
+ const StyledDiv = /*#__PURE__*/(0, _base.default)("div", {
20
20
  target: "e171zbc01",
21
21
  label: "StyledDiv"
22
22
  })(_core.fonts.sizes('16px', 1.3), ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkltYWdlTWV0YS50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBYTRCIiwiZmlsZSI6IkltYWdlTWV0YS50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAyMi1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCBwcmV0dHlCeXRlcyBmcm9tICdwcmV0dHktYnl0ZXMnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgZm9udHMgfSBmcm9tICdAbmRsYS9jb3JlJztcbmltcG9ydCB7IElJbWFnZURpbWVuc2lvbnMgfSBmcm9tICdAbmRsYS90eXBlcy1iYWNrZW5kL2ltYWdlLWFwaSc7XG5cbmNvbnN0IFN0eWxlZERpdiA9IHN0eWxlZC5kaXZgXG4gICR7Zm9udHMuc2l6ZXMoJzE2cHgnLCAxLjMpfVxuYDtcblxuY29uc3QgU3R5bGVkU3BhbiA9IHN0eWxlZC5zcGFuYFxuICB0ZXh0LWFsaWduOiBjZW50ZXI7XG5gO1xuXG5pbnRlcmZhY2UgUHJvcHMge1xuICBjb250ZW50VHlwZTogc3RyaW5nO1xuICBmaWxlU2l6ZTogbnVtYmVyO1xuICBpbWFnZURpbWVuc2lvbnM/OiBJSW1hZ2VEaW1lbnNpb25zO1xufVxuXG5jb25zdCBJbWFnZU1ldGEgPSAoeyBjb250ZW50VHlwZSwgZmlsZVNpemUsIGltYWdlRGltZW5zaW9ucyB9OiBQcm9wcykgPT4ge1xuICBjb25zdCBkaW1lbnNpb25zID0gaW1hZ2VEaW1lbnNpb25zID8gYCAtICR7aW1hZ2VEaW1lbnNpb25zLndpZHRofXgke2ltYWdlRGltZW5zaW9ucy5oZWlnaHR9IHB4YCA6ICcnO1xuICByZXR1cm4gKFxuICAgIDxTdHlsZWREaXY+XG4gICAgICA8U3R5bGVkU3Bhbj57YCR7Y29udGVudFR5cGV9IC0gJHtwcmV0dHlCeXRlcyhmaWxlU2l6ZSl9JHtkaW1lbnNpb25zfWB9PC9TdHlsZWRTcGFuPlxuICAgIDwvU3R5bGVkRGl2PlxuICApO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgSW1hZ2VNZXRhO1xuIl19 */"));
23
- var StyledSpan = /*#__PURE__*/(0, _base.default)("span", {
23
+ const StyledSpan = /*#__PURE__*/(0, _base.default)("span", {
24
24
  target: "e171zbc00",
25
25
  label: "StyledSpan"
26
26
  })(process.env.NODE_ENV === "production" ? {
@@ -32,16 +32,17 @@ var StyledSpan = /*#__PURE__*/(0, _base.default)("span", {
32
32
  map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkltYWdlTWV0YS50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBaUI4QiIsImZpbGUiOiJJbWFnZU1ldGEudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMjItcHJlc2VudCwgTkRMQS5cbiAqXG4gKiBUaGlzIHNvdXJjZSBjb2RlIGlzIGxpY2Vuc2VkIHVuZGVyIHRoZSBHUEx2MyBsaWNlbnNlIGZvdW5kIGluIHRoZVxuICogTElDRU5TRSBmaWxlIGluIHRoZSByb290IGRpcmVjdG9yeSBvZiB0aGlzIHNvdXJjZSB0cmVlLlxuICpcbiAqL1xuXG5pbXBvcnQgcHJldHR5Qnl0ZXMgZnJvbSAncHJldHR5LWJ5dGVzJztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGZvbnRzIH0gZnJvbSAnQG5kbGEvY29yZSc7XG5pbXBvcnQgeyBJSW1hZ2VEaW1lbnNpb25zIH0gZnJvbSAnQG5kbGEvdHlwZXMtYmFja2VuZC9pbWFnZS1hcGknO1xuXG5jb25zdCBTdHlsZWREaXYgPSBzdHlsZWQuZGl2YFxuICAke2ZvbnRzLnNpemVzKCcxNnB4JywgMS4zKX1cbmA7XG5cbmNvbnN0IFN0eWxlZFNwYW4gPSBzdHlsZWQuc3BhbmBcbiAgdGV4dC1hbGlnbjogY2VudGVyO1xuYDtcblxuaW50ZXJmYWNlIFByb3BzIHtcbiAgY29udGVudFR5cGU6IHN0cmluZztcbiAgZmlsZVNpemU6IG51bWJlcjtcbiAgaW1hZ2VEaW1lbnNpb25zPzogSUltYWdlRGltZW5zaW9ucztcbn1cblxuY29uc3QgSW1hZ2VNZXRhID0gKHsgY29udGVudFR5cGUsIGZpbGVTaXplLCBpbWFnZURpbWVuc2lvbnMgfTogUHJvcHMpID0+IHtcbiAgY29uc3QgZGltZW5zaW9ucyA9IGltYWdlRGltZW5zaW9ucyA/IGAgLSAke2ltYWdlRGltZW5zaW9ucy53aWR0aH14JHtpbWFnZURpbWVuc2lvbnMuaGVpZ2h0fSBweGAgOiAnJztcbiAgcmV0dXJuIChcbiAgICA8U3R5bGVkRGl2PlxuICAgICAgPFN0eWxlZFNwYW4+e2Ake2NvbnRlbnRUeXBlfSAtICR7cHJldHR5Qnl0ZXMoZmlsZVNpemUpfSR7ZGltZW5zaW9uc31gfTwvU3R5bGVkU3Bhbj5cbiAgICA8L1N0eWxlZERpdj5cbiAgKTtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IEltYWdlTWV0YTtcbiJdfQ== */",
33
33
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
34
34
  });
35
- var ImageMeta = function ImageMeta(_ref) {
36
- var contentType = _ref.contentType,
37
- fileSize = _ref.fileSize,
38
- imageDimensions = _ref.imageDimensions;
39
- var dimensions = imageDimensions ? " - ".concat(imageDimensions.width, "x").concat(imageDimensions.height, " px") : '';
35
+ const ImageMeta = _ref => {
36
+ let {
37
+ contentType,
38
+ fileSize,
39
+ imageDimensions
40
+ } = _ref;
41
+ const dimensions = imageDimensions ? ` - ${imageDimensions.width}x${imageDimensions.height} px` : '';
40
42
  return (0, _jsxRuntime.jsx)(StyledDiv, {
41
43
  children: (0, _jsxRuntime.jsx)(StyledSpan, {
42
- children: "".concat(contentType, " - ").concat((0, _prettyBytes.default)(fileSize)).concat(dimensions)
44
+ children: `${contentType} - ${(0, _prettyBytes.default)(fileSize)}${dimensions}`
43
45
  })
44
46
  });
45
47
  };
46
- var _default = ImageMeta;
47
- exports.default = _default;
48
+ var _default = exports.default = ImageMeta;
@@ -1,6 +1,5 @@
1
1
  "use strict";
2
2
 
3
- function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
4
3
  Object.defineProperty(exports, "__esModule", {
5
4
  value: true
6
5
  });
@@ -15,26 +14,14 @@ var _common = require("@ndla/icons/common");
15
14
  var _ImageSearchResult = _interopRequireDefault(require("./ImageSearchResult"));
16
15
  var _jsxRuntime = require("@emotion/react/jsx-runtime");
17
16
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
18
- function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
19
- 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); } }
20
- function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
21
- function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return _typeof(key) === "symbol" ? key : String(key); }
22
- function _toPrimitive(input, hint) { if (_typeof(input) !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (_typeof(res) !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); }
23
- 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); }
24
- function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
25
- 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); }; }
26
- 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); }
27
- function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
28
- 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; } }
29
- function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
30
17
  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)."; } /**
31
- * Copyright (c) 2017-present, NDLA.
32
- *
33
- * This source code is licensed under the GPLv3 license found in the
34
- * LICENSE file in the root directory of this source tree.
35
- *
36
- */
37
- var ImageSearchWrapper = /*#__PURE__*/(0, _base.default)("div", {
18
+ * Copyright (c) 2017-present, NDLA.
19
+ *
20
+ * This source code is licensed under the GPLv3 license found in the
21
+ * LICENSE file in the root directory of this source tree.
22
+ *
23
+ */
24
+ const ImageSearchWrapper = /*#__PURE__*/(0, _base.default)("div", {
38
25
  target: "ejbuzb50",
39
26
  label: "ImageSearchWrapper"
40
27
  })(".text{text-align:center;}.list-item{position:relative;float:left;height:210px;width:100%;", _core.mq.range({
@@ -74,7 +61,7 @@ var ImageSearchWrapper = /*#__PURE__*/(0, _base.default)("div", {
74
61
  }), "{.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%;}}", _core.mq.range({
75
62
  from: _core.breakpoints.wide
76
63
  }), "{.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"]} */"));
77
- var searchIconCss = process.env.NODE_ENV === "production" ? {
64
+ const searchIconCss = process.env.NODE_ENV === "production" ? {
78
65
  name: "imhgxk-searchIconCss",
79
66
  styles: "border:0;background:transparent;margin:0;padding:0;label:searchIconCss;"
80
67
  } : {
@@ -83,14 +70,10 @@ var searchIconCss = process.env.NODE_ENV === "production" ? {
83
70
  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"]} */",
84
71
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
85
72
  };
86
- var ImageSearch = /*#__PURE__*/function (_Component) {
87
- _inherits(ImageSearch, _Component);
88
- var _super = _createSuper(ImageSearch);
89
- function ImageSearch(props) {
90
- var _this;
91
- _classCallCheck(this, ImageSearch);
92
- _this = _super.call(this, props);
93
- _this.state = {
73
+ class ImageSearch extends _react.Component {
74
+ constructor(props) {
75
+ super(props);
76
+ this.state = {
94
77
  queryObject: {
95
78
  query: undefined,
96
79
  page: 1,
@@ -101,154 +84,142 @@ var ImageSearch = /*#__PURE__*/function (_Component) {
101
84
  lastPage: 0,
102
85
  searching: false
103
86
  };
104
- _this.searchImages = _this.searchImages.bind(_assertThisInitialized(_this));
105
- _this.onImageClick = _this.onImageClick.bind(_assertThisInitialized(_this));
106
- _this.onSelectImage = _this.onSelectImage.bind(_assertThisInitialized(_this));
107
- return _this;
87
+ this.searchImages = this.searchImages.bind(this);
88
+ this.onImageClick = this.onImageClick.bind(this);
89
+ this.onSelectImage = this.onSelectImage.bind(this);
108
90
  }
109
- _createClass(ImageSearch, [{
110
- key: "componentDidMount",
111
- value: function componentDidMount() {
112
- this.searchImages(this.state.queryObject);
113
- }
114
- }, {
115
- key: "onImageClick",
116
- value: function onImageClick(image) {
117
- var _this2 = this;
118
- var _this$props = this.props,
119
- onError = _this$props.onError,
120
- fetchImage = _this$props.fetchImage;
121
- var selectedImage = this.state.selectedImage;
122
- if (!selectedImage || image.id !== selectedImage.id) {
123
- fetchImage(parseInt(image.id)).then(function (result) {
124
- _this2.setState({
125
- selectedImage: result
126
- });
127
- }).catch(function (err) {
128
- onError(err);
91
+ componentDidMount() {
92
+ this.searchImages(this.state.queryObject);
93
+ }
94
+ onImageClick(image) {
95
+ const {
96
+ onError,
97
+ fetchImage
98
+ } = this.props;
99
+ const {
100
+ selectedImage
101
+ } = this.state;
102
+ if (!selectedImage || image.id !== selectedImage.id) {
103
+ fetchImage(parseInt(image.id)).then(result => {
104
+ this.setState({
105
+ selectedImage: result
129
106
  });
130
- }
131
- }
132
- }, {
133
- key: "onSelectImage",
134
- value: function onSelectImage(image, saveAsMetaImage) {
135
- var _this$props2 = this.props,
136
- onImageSelect = _this$props2.onImageSelect,
137
- checkboxAction = _this$props2.checkboxAction;
138
- this.setState({
139
- selectedImage: undefined
107
+ }).catch(err => {
108
+ onError(err);
140
109
  });
141
- onImageSelect(image);
142
- if (saveAsMetaImage) {
143
- checkboxAction && checkboxAction(image);
144
- }
145
110
  }
146
- }, {
147
- key: "searchImages",
148
- value: function searchImages(queryObject) {
149
- var _this3 = this;
150
- var _this$props3 = this.props,
151
- searchImages = _this$props3.searchImages,
152
- onError = _this$props3.onError;
111
+ }
112
+ onSelectImage(image, saveAsMetaImage) {
113
+ const {
114
+ onImageSelect,
115
+ checkboxAction
116
+ } = this.props;
117
+ this.setState({
118
+ selectedImage: undefined
119
+ });
120
+ onImageSelect(image);
121
+ if (saveAsMetaImage) {
122
+ checkboxAction && checkboxAction(image);
123
+ }
124
+ }
125
+ searchImages(queryObject) {
126
+ const {
127
+ searchImages,
128
+ onError
129
+ } = this.props;
130
+ this.setState({
131
+ searching: true
132
+ });
133
+ searchImages(queryObject.query, queryObject.page).then(result => {
153
134
  this.setState({
154
- searching: true
135
+ queryObject: {
136
+ query: queryObject.query,
137
+ pageSize: result.pageSize,
138
+ page: queryObject.page
139
+ },
140
+ images: result.results,
141
+ lastPage: Math.ceil(result.totalCount / result.pageSize),
142
+ searching: false
155
143
  });
156
- searchImages(queryObject.query, queryObject.page).then(function (result) {
157
- _this3.setState({
158
- queryObject: {
159
- query: queryObject.query,
160
- pageSize: result.pageSize,
161
- page: queryObject.page
162
- },
163
- images: result.results,
164
- lastPage: Math.ceil(result.totalCount / result.pageSize),
165
- searching: false
166
- });
167
- }).catch(function (err) {
168
- onError(err);
169
- _this3.setState({
170
- searching: false
171
- });
144
+ }).catch(err => {
145
+ onError(err);
146
+ this.setState({
147
+ searching: false
172
148
  });
173
- }
174
- }, {
175
- key: "render",
176
- value: function render() {
177
- var _this4 = this;
178
- var _this$props4 = this.props,
179
- searchPlaceholder = _this$props4.searchPlaceholder,
180
- searchButtonTitle = _this$props4.searchButtonTitle,
181
- useImageTitle = _this$props4.useImageTitle,
182
- showCheckbox = _this$props4.showCheckbox,
183
- checkboxLabel = _this$props4.checkboxLabel;
184
- var _this$state = this.state,
185
- queryObject = _this$state.queryObject,
186
- images = _this$state.images,
187
- selectedImage = _this$state.selectedImage,
188
- lastPage = _this$state.lastPage,
189
- searching = _this$state.searching,
190
- queryString = _this$state.queryString;
191
- var page = queryObject.page;
192
- var noResultsFound = !searching && images.length === 0;
193
- return (0, _jsxRuntime.jsxs)(ImageSearchWrapper, {
194
- children: [(0, _jsxRuntime.jsxs)(_forms.InputContainer, {
195
- children: [(0, _jsxRuntime.jsx)(_forms.InputV3, {
196
- placeholder: searchPlaceholder
197
- // eslint-disable-next-line jsx-a11y/no-autofocus
198
- ,
199
- autoFocus: true,
200
- value: queryString,
201
- onChange: function onChange(evt) {
202
- return _this4.setState({
203
- queryString: evt.target.value
204
- });
205
- },
206
- onKeyPress: function onKeyPress(evt) {
207
- if (evt.key === 'Enter') {
208
- evt.preventDefault();
209
- _this4.searchImages({
210
- query: queryString,
211
- page: 1
212
- });
213
- }
214
- }
215
- }), (0, _jsxRuntime.jsx)("button", {
216
- css: searchIconCss,
217
- "aria-label": searchButtonTitle,
218
- type: "button",
219
- onClick: function onClick() {
220
- _this4.searchImages({
149
+ });
150
+ }
151
+ render() {
152
+ const {
153
+ searchPlaceholder,
154
+ searchButtonTitle,
155
+ useImageTitle,
156
+ showCheckbox,
157
+ checkboxLabel
158
+ } = this.props;
159
+ const {
160
+ queryObject,
161
+ images,
162
+ selectedImage,
163
+ lastPage,
164
+ searching,
165
+ queryString
166
+ } = this.state;
167
+ const {
168
+ page
169
+ } = queryObject;
170
+ const noResultsFound = !searching && images.length === 0;
171
+ return (0, _jsxRuntime.jsxs)(ImageSearchWrapper, {
172
+ children: [(0, _jsxRuntime.jsxs)(_forms.InputContainer, {
173
+ children: [(0, _jsxRuntime.jsx)(_forms.InputV3, {
174
+ placeholder: searchPlaceholder
175
+ // eslint-disable-next-line jsx-a11y/no-autofocus
176
+ ,
177
+ autoFocus: true,
178
+ value: queryString,
179
+ onChange: evt => this.setState({
180
+ queryString: evt.target.value
181
+ }),
182
+ onKeyPress: evt => {
183
+ if (evt.key === 'Enter') {
184
+ evt.preventDefault();
185
+ this.searchImages({
221
186
  query: queryString,
222
187
  page: 1
223
188
  });
224
- },
225
- children: (0, _jsxRuntime.jsx)(_common.Search, {})
226
- })]
227
- }), noResultsFound && this.props.noResults, (0, _jsxRuntime.jsx)("div", {
228
- className: "list",
229
- children: images.map(function (image) {
230
- return (0, _jsxRuntime.jsx)(_ImageSearchResult.default, {
231
- image: image,
232
- onImageClick: _this4.onImageClick,
233
- selectedImage: selectedImage,
234
- onSelectImage: _this4.onSelectImage,
235
- useImageTitle: useImageTitle,
236
- showCheckbox: !!showCheckbox,
237
- checkboxLabel: checkboxLabel
238
- }, image.id);
239
- })
240
- }), (0, _jsxRuntime.jsx)(_pager.default, {
241
- page: page !== null && page !== void 0 ? page : 1,
242
- pathname: "",
243
- lastPage: lastPage,
244
- query: queryObject,
245
- onClick: this.searchImages,
246
- pageItemComponentClass: "button"
189
+ }
190
+ }
191
+ }), (0, _jsxRuntime.jsx)("button", {
192
+ css: searchIconCss,
193
+ "aria-label": searchButtonTitle,
194
+ type: "button",
195
+ onClick: () => {
196
+ this.searchImages({
197
+ query: queryString,
198
+ page: 1
199
+ });
200
+ },
201
+ children: (0, _jsxRuntime.jsx)(_common.Search, {})
247
202
  })]
248
- });
249
- }
250
- }]);
251
- return ImageSearch;
252
- }(_react.Component);
253
- var _default = ImageSearch;
254
- exports.default = _default;
203
+ }), noResultsFound && this.props.noResults, (0, _jsxRuntime.jsx)("div", {
204
+ className: "list",
205
+ children: images.map(image => (0, _jsxRuntime.jsx)(_ImageSearchResult.default, {
206
+ image: image,
207
+ onImageClick: this.onImageClick,
208
+ selectedImage: selectedImage,
209
+ onSelectImage: this.onSelectImage,
210
+ useImageTitle: useImageTitle,
211
+ showCheckbox: !!showCheckbox,
212
+ checkboxLabel: checkboxLabel
213
+ }, image.id))
214
+ }), (0, _jsxRuntime.jsx)(_pager.default, {
215
+ page: page ?? 1,
216
+ pathname: "",
217
+ lastPage: lastPage,
218
+ query: queryObject,
219
+ onClick: this.searchImages,
220
+ pageItemComponentClass: "button"
221
+ })]
222
+ });
223
+ }
224
+ }
225
+ var _default = exports.default = ImageSearch;
@@ -11,13 +11,13 @@ var _imageUtil = require("./util/imageUtil");
11
11
  var _jsxRuntime = require("@emotion/react/jsx-runtime");
12
12
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
13
13
  function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; } /**
14
- * Copyright (c) 2017-present, NDLA.
15
- *
16
- * This source code is licensed under the GPLv3 license found in the
17
- * LICENSE file in the root directory of this source tree.
18
- *
19
- */
20
- var StyledButton = /*#__PURE__*/(0, _base.default)(_button.ButtonV2, {
14
+ * Copyright (c) 2017-present, NDLA.
15
+ *
16
+ * This source code is licensed under the GPLv3 license found in the
17
+ * LICENSE file in the root directory of this source tree.
18
+ *
19
+ */
20
+ const StyledButton = /*#__PURE__*/(0, _base.default)(_button.ButtonV2, {
21
21
  target: "e1evho0k0",
22
22
  label: "StyledButton"
23
23
  })(process.env.NODE_ENV === "production" ? {
@@ -30,24 +30,24 @@ var StyledButton = /*#__PURE__*/(0, _base.default)(_button.ButtonV2, {
30
30
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
31
31
  });
32
32
  function ImageSearchResult(_ref) {
33
- var image = _ref.image,
34
- onImageClick = _ref.onImageClick,
35
- selectedImage = _ref.selectedImage,
36
- onSelectImage = _ref.onSelectImage,
37
- useImageTitle = _ref.useImageTitle,
38
- showCheckbox = _ref.showCheckbox,
39
- checkboxLabel = _ref.checkboxLabel;
40
- var active = selectedImage && selectedImage.id === image.id ? 'active' : '';
33
+ let {
34
+ image,
35
+ onImageClick,
36
+ selectedImage,
37
+ onSelectImage,
38
+ useImageTitle,
39
+ showCheckbox,
40
+ checkboxLabel
41
+ } = _ref;
42
+ const active = selectedImage && selectedImage.id === image.id ? 'active' : '';
41
43
  return (0, _jsxRuntime.jsxs)("div", {
42
- className: "list-item ".concat(active),
44
+ className: `list-item ${active}`,
43
45
  children: [(0, _jsxRuntime.jsx)("div", {
44
46
  className: "list-item-inner",
45
47
  children: (0, _jsxRuntime.jsxs)(StyledButton, {
46
48
  variant: "stripped",
47
49
  "data-testid": "select-image-from-list",
48
- onClick: function onClick() {
49
- return onImageClick(image);
50
- },
50
+ onClick: () => onImageClick(image),
51
51
  children: [(0, _jsxRuntime.jsx)("img", {
52
52
  role: "presentation",
53
53
  alt: "presentation",