@searpent/react-image-annotate 2.0.18 → 2.0.19

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.
@@ -786,10 +786,10 @@ var examplePhotos = [{
786
786
  }, {
787
787
  "id": "431fc636-d6d1-4e20-a35b-cc7a201c1833",
788
788
  "fullsize": {
789
- "key": "https://www.gannett-cdn.com/presto/2022/01/12/NJDN/8088720b-446d-4693-be62-4dfdf1c3046f-DailyNewsSaturday.jpg?width=660&height=1253&fit=crop&format=pjpg&auto=webp"
789
+ "key": "https://images.pexels.com/photos/167699/pexels-photo-167699.jpeg?auto=compress&cs=tinysrgb&w=1260&h=750&dpr=2"
790
790
  },
791
791
  "thumbnail": {
792
- "key": "https://www.gannett-cdn.com/presto/2022/01/12/NJDN/8088720b-446d-4693-be62-4dfdf1c3046f-DailyNewsSaturday.jpg?width=660&height=1253&fit=crop&format=pjpg&auto=webp"
792
+ "key": "https://images.pexels.com/photos/167699/pexels-photo-167699.jpeg?auto=compress&cs=tinysrgb&w=1260&h=750&dpr=2"
793
793
  },
794
794
  "modelResults": {
795
795
  "v1": [{
@@ -1,7 +1,21 @@
1
1
  import _slicedToArray from "@babel/runtime/helpers/esm/slicedToArray";
2
2
  import React, { useState } from 'react';
3
3
  import classnames from "classnames";
4
- import './page-selector.css';
4
+ import './page-selector.css'; // {
5
+ // showMetadata && (
6
+ // <div className="page-thumbnail__metadata">
7
+ // <h5>Metadata</h5>
8
+ // {
9
+ // page?.metadata?.map(({ key, value }) => (
10
+ // <div key={key}>
11
+ // <label htmlFor={key}>{key}</label>
12
+ // <input id={key} type="text" value={value} onChange={(e) => onMetadataChange({ name: key, value: e.target.value, imageIndex: idx })} />
13
+ // </div>
14
+ // ))
15
+ // }
16
+ // </div>
17
+ // )
18
+ // }
5
19
 
6
20
  function PageThumbnail(_ref) {
7
21
  var src = _ref.src,
@@ -17,12 +31,13 @@ function PageThumbnail(_ref) {
17
31
  onClick: onClick
18
32
  }, React.createElement("img", {
19
33
  src: src,
20
- alt: ""
21
- }), pageNumber !== undefined && React.createElement("div", {
34
+ alt: "",
35
+ className: "page-thumbnail-image"
36
+ }), React.createElement("div", {
22
37
  className: "page-number-wrapper"
23
- }, React.createElement("span", {
38
+ }, pageNumber !== undefined && React.createElement("span", {
24
39
  className: "page-number"
25
- }, pageNumber)));
40
+ }, pageNumber)), " */");
26
41
  }
27
42
 
28
43
  function PageSelector(_ref2) {
@@ -44,11 +59,41 @@ function PageSelector(_ref2) {
44
59
  'page-selector--opened': showMetadata
45
60
  })
46
61
  }, React.createElement("div", {
62
+ className: "top-buttons"
63
+ }, React.createElement("button", {
64
+ onClick: onRecalc,
65
+ disabled: !recalcActive,
66
+ className: "info"
67
+ }, "Recalc"), React.createElement("button", {
68
+ onClick: onSave,
69
+ disabled: !saveActive,
70
+ className: "success"
71
+ }, "Save"), React.createElement("div", {
72
+ className: "show-metadata-wrapper"
73
+ }, React.createElement("label", {
74
+ className: "switch mr-2"
75
+ }, React.createElement("input", {
76
+ id: "show-metadata",
77
+ type: "checkbox",
78
+ value: showMetadata,
79
+ onChange: function onChange() {
80
+ return setShowMetadata(function (prev) {
81
+ return !prev;
82
+ });
83
+ }
84
+ }), React.createElement("span", {
85
+ className: "slider round"
86
+ })), React.createElement("label", null, "Metadata"))), React.createElement("div", {
47
87
  className: "pages"
48
88
  }, pages.map(function (page, idx) {
49
- return React.createElement("div", {
50
- className: "page-thumbnail__wrapper"
51
- }, "This is thumbnail ", page.id);
89
+ return React.createElement(PageThumbnail, {
90
+ key: "".concat(page.id),
91
+ src: page.src,
92
+ isActive: page.isActive,
93
+ onClick: function onClick() {
94
+ return onPageClick(idx);
95
+ }
96
+ });
52
97
  })));
53
98
  }
54
99
 
@@ -1,35 +1,38 @@
1
1
  .page-selector {
2
2
  height: 100vh;
3
3
  overflow-y: scroll;
4
- /* max-width: 10%; */
5
- transition: max-width .5s;
4
+ width: 240px;
5
+ transition: width .5s;
6
6
  }
7
7
 
8
8
  .page-selector--opened {
9
- /* max-width: 20%; */
9
+ width: 520px;
10
10
  }
11
11
 
12
12
  .pages {
13
13
  list-style: none;
14
- }
15
-
16
- .page-thumbnail__wrapper {
17
14
  display: flex;
18
- flex-direction: row;
19
- align-items: flex-start;
20
- background-color: #2dce89;
21
- /* width: 240px; */
22
- width: 480px;
15
+ flex-direction: column;
16
+ align-items: center;
17
+ width: 100%;
23
18
  }
24
19
 
25
20
  .page-thumbnail {
26
- /* width: 300px; */
21
+ height: 140px;
22
+ width: 100px;
27
23
  margin-bottom: 1rem;
28
24
  border-radius: .25rem !important;
29
25
  overflow: hidden;
30
26
  filter: grayscale(1);
31
27
  transition: transform .2s;
32
- opacity: .5;
28
+ transition: width .2s;
29
+ opacity: .75;
30
+ overflow: hidden;
31
+ border: 1px solid #8898aa;
32
+ }
33
+
34
+ .page-selector--opened .page-thumbnail {
35
+ width: 240px;
33
36
  }
34
37
 
35
38
  .page-thumbnail:hover {
@@ -45,8 +48,11 @@
45
48
  opacity: 1;
46
49
  }
47
50
 
48
- .page-thumbnail img {
51
+ .page-thumbnail-image {
49
52
  width: 100%;
53
+ height: 100%;
54
+ object-fit: cover;
55
+ object-position: top;
50
56
  }
51
57
 
52
58
  .page-thumbnail__metadata {
@@ -198,4 +204,16 @@ input:checked+.slider:before {
198
204
 
199
205
  .mr-2 {
200
206
  margin-right: 1rem;
207
+ }
208
+
209
+ .thumbnail-metadata {
210
+ background-color: #2dce89;
211
+ overflow-y: scroll;
212
+ display: grid;
213
+ grid-template-columns: 1fr 1fr;
214
+ row-gap: .5rem;
215
+ }
216
+
217
+ .thumbnail-metadata label {
218
+ font-size: 12px;
201
219
  }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@searpent/react-image-annotate",
3
- "version": "2.0.18",
3
+ "version": "2.0.19",
4
4
  "dependencies": {
5
5
  "@editorjs/editorjs": "^2.25.0",
6
6
  "@editorjs/paragraph": "^2.8.0",