@ndla/image-search 6.0.123 → 6.0.125
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 +10 -8
- package/es/ImageSearch.js +133 -161
- package/es/ImageSearchResult.js +13 -13
- package/es/PreviewImage.js +26 -43
- package/es/util/imageUtil.js +2 -6
- package/lib/ImageMeta.js +17 -16
- package/lib/ImageSearch.js +140 -169
- package/lib/ImageSearchResult.js +19 -19
- package/lib/PreviewImage.js +35 -51
- package/lib/index.js +2 -3
- package/lib/util/imageUtil.js +2 -6
- package/package.json +12 -7
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
|
-
|
|
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
|
-
|
|
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
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
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:
|
|
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
|
-
|
|
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
|
-
|
|
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
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
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
|
-
|
|
101
|
-
|
|
102
|
-
|
|
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
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
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
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
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
|
-
|
|
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
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
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
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
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
|
-
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
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
|
-
|
|
248
|
-
|
|
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;
|
package/es/ImageSearchResult.js
CHANGED
|
@@ -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
|
-
|
|
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
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
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:
|
|
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:
|
|
45
|
-
return onImageClick(image);
|
|
46
|
-
},
|
|
46
|
+
onClick: () => onImageClick(image),
|
|
47
47
|
children: [_jsx("img", {
|
|
48
48
|
role: "presentation",
|
|
49
49
|
alt: "presentation",
|
package/es/PreviewImage.js
CHANGED
|
@@ -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
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
onSelectImage
|
|
28
|
-
useImageTitle
|
|
29
|
-
showCheckbox
|
|
30
|
-
checkboxLabel
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
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(
|
|
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:
|
|
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:
|
|
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:
|
|
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(
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
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:
|
|
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:
|
|
113
|
-
return setSaveAsMetaImage(function (prev) {
|
|
114
|
-
return !prev;
|
|
115
|
-
});
|
|
116
|
-
}
|
|
99
|
+
onChange: () => setSaveAsMetaImage(prev => !prev)
|
|
117
100
|
})
|
|
118
101
|
})]
|
|
119
102
|
}), _jsx("div", {
|
package/es/util/imageUtil.js
CHANGED
|
@@ -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
|
|
13
|
-
|
|
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(', ');
|