@searpent/react-image-annotate 2.0.3 → 2.0.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (187) hide show
  1. package/.babelrc +6 -0
  2. package/.env +1 -0
  3. package/.flowconfig +2 -0
  4. package/.github/workflows/release-on-master.yml +32 -0
  5. package/.github/workflows/test.yml +16 -0
  6. package/.prettierrc +3 -0
  7. package/.releaserc.js +18 -0
  8. package/.storybook/addons.js +2 -0
  9. package/.storybook/config.js +16 -0
  10. package/LICENSE +21 -0
  11. package/package.json +4 -1
  12. package/public/favicon.ico +0 -0
  13. package/public/index.html +38 -0
  14. package/src/Annotator/bike-pic.png +0 -0
  15. package/src/Annotator/bike-pic2.png +0 -0
  16. package/src/Annotator/dab-keyframes.story.json +1 -0
  17. package/src/Annotator/examplePhotos.js +7601 -0
  18. package/src/Annotator/index.js +291 -0
  19. package/src/Annotator/index.story.js +807 -0
  20. package/src/Annotator/poses.story.js +150 -0
  21. package/src/Annotator/reducers/combine-reducers.js +7 -0
  22. package/src/Annotator/reducers/convert-expanding-line-to-polygon.js +53 -0
  23. package/{Annotator → src/Annotator}/reducers/fix-twisted.js +5 -3
  24. package/src/Annotator/reducers/general-reducer.js +996 -0
  25. package/src/Annotator/reducers/get-active-image.js +21 -0
  26. package/src/Annotator/reducers/get-implied-video-regions.js +115 -0
  27. package/src/Annotator/reducers/history-handler.js +60 -0
  28. package/src/Annotator/reducers/image-reducer.js +23 -0
  29. package/src/Annotator/reducers/video-reducer.js +85 -0
  30. package/src/Annotator/video.story.js +51 -0
  31. package/src/ClassSelectionMenu/index.js +108 -0
  32. package/src/Crosshairs/index.js +64 -0
  33. package/src/DebugSidebarBox/index.js +36 -0
  34. package/src/DemoSite/Editor.js +235 -0
  35. package/src/DemoSite/ErrorBoundaryDialog.js +34 -0
  36. package/src/DemoSite/index.js +41 -0
  37. package/src/DemoSite/index.story.js +10 -0
  38. package/src/DemoSite/simple-segmentation-example.json +572 -0
  39. package/src/Editor/annotation-plugin/annotation.css +46 -0
  40. package/src/Editor/annotation-plugin/annotation.js +515 -0
  41. package/src/Editor/index.js +24 -0
  42. package/src/Editor/tools.js +6 -0
  43. package/src/FullImageSegmentationAnnotator/hard1.story.jpg +0 -0
  44. package/src/FullImageSegmentationAnnotator/hard2.story.jpg +0 -0
  45. package/src/FullImageSegmentationAnnotator/hard3.story.jpg +0 -0
  46. package/src/FullImageSegmentationAnnotator/index.js +7 -0
  47. package/src/FullImageSegmentationAnnotator/index.story.js +177 -0
  48. package/src/FullImageSegmentationAnnotator/orange.story.png +0 -0
  49. package/src/GroupSelectorSidebarBox/index.js +48 -0
  50. package/src/HighlightBox/index.js +143 -0
  51. package/src/HistorySidebarBox/index.js +78 -0
  52. package/src/ImageCanvas/dancing-man.story.jpg +0 -0
  53. package/src/ImageCanvas/index.js +494 -0
  54. package/src/ImageCanvas/index.story.js +314 -0
  55. package/src/ImageCanvas/mouse_mask.story.png +0 -0
  56. package/src/ImageCanvas/region-tools.js +171 -0
  57. package/src/ImageCanvas/seves_desk.story.jpg +0 -0
  58. package/{ImageCanvas → src/ImageCanvas}/styles.js +8 -12
  59. package/src/ImageCanvas/use-mouse.js +168 -0
  60. package/src/ImageCanvas/use-project-box.js +23 -0
  61. package/src/ImageCanvas/use-wasd-mode.js +50 -0
  62. package/src/ImageMask/index.js +127 -0
  63. package/src/ImageMask/load-image.js +32 -0
  64. package/src/ImageSelectorSidebarBox/index.js +54 -0
  65. package/src/KeyframeTimeline/get-time-string.js +25 -0
  66. package/src/KeyframeTimeline/index.js +223 -0
  67. package/src/KeyframesSelectorSidebarBox/index.js +93 -0
  68. package/src/LandingPage/content.md +57 -0
  69. package/src/LandingPage/github-markdown.css +964 -0
  70. package/src/LandingPage/index.js +147 -0
  71. package/src/MainLayout/icon-dictionary.js +79 -0
  72. package/src/MainLayout/index.js +510 -0
  73. package/src/MainLayout/index.story.js +240 -0
  74. package/{MainLayout → src/MainLayout}/styles.js +7 -6
  75. package/src/MainLayout/types.js +164 -0
  76. package/src/MainLayout/use-implied-video-regions.js +17 -0
  77. package/src/MetadataEditorSidebarBox/index.js +98 -0
  78. package/src/PageSelector/index.js +76 -0
  79. package/src/PageSelector/page-selector.css +69 -0
  80. package/src/PointDistances/index.js +90 -0
  81. package/src/PreventScrollToParents/index.js +48 -0
  82. package/src/PreventScrollToParents/index.story.js +23 -0
  83. package/src/RegionLabel/index.js +222 -0
  84. package/{RegionLabel → src/RegionLabel}/styles.js +15 -12
  85. package/src/RegionSelectAndTransformBoxes/index.js +234 -0
  86. package/src/RegionSelectorSidebarBox/index.js +216 -0
  87. package/{RegionSelectorSidebarBox → src/RegionSelectorSidebarBox}/styles.js +14 -13
  88. package/src/RegionShapes/index.js +254 -0
  89. package/src/RegionTags/index.js +134 -0
  90. package/src/SettingsDialog/index.js +58 -0
  91. package/src/SettingsProvider/index.js +48 -0
  92. package/src/Shortcuts/ShortcutField.js +44 -0
  93. package/src/Shortcuts/index.js +129 -0
  94. package/src/ShortcutsManager/index.js +162 -0
  95. package/src/Sidebar/index.js +117 -0
  96. package/src/SidebarBoxContainer/index.js +93 -0
  97. package/src/SmallToolButton/index.js +57 -0
  98. package/src/TagsSidebarBox/index.js +93 -0
  99. package/src/TaskDescriptionSidebarBox/index.js +43 -0
  100. package/src/Theme/index.js +36 -0
  101. package/src/VideoOrImageCanvasBackground/index.js +170 -0
  102. package/src/colors.js +32 -0
  103. package/src/hooks/use-colors.js +74 -0
  104. package/src/hooks/use-event-callback.js +11 -0
  105. package/src/hooks/use-exclude-pattern.js +27 -0
  106. package/src/hooks/use-load-image.js +21 -0
  107. package/src/hooks/use-window-size.js +46 -0
  108. package/{hooks → src/hooks}/xpattern.js +1 -1
  109. package/src/hooks/xpattern.png +0 -0
  110. package/src/index.js +18 -0
  111. package/src/lib.js +7 -0
  112. package/src/screenshot.png +0 -0
  113. package/src/site.css +5 -0
  114. package/src/stories.js +2 -0
  115. package/src/utils/filter-only-unique.js +5 -0
  116. package/src/utils/get-from-local-storage.js +7 -0
  117. package/src/utils/get-hotkey-help-text.js +11 -0
  118. package/src/utils/get-landmarks-with-transform.js +23 -0
  119. package/src/utils/photosToImages.js +40 -0
  120. package/src/utils/regions-to-blocks.js +14 -0
  121. package/src/utils/set-in-local-storage.js +6 -0
  122. package/Annotator/index.js +0 -169
  123. package/Annotator/reducers/combine-reducers.js +0 -14
  124. package/Annotator/reducers/convert-expanding-line-to-polygon.js +0 -73
  125. package/Annotator/reducers/general-reducer.js +0 -1058
  126. package/Annotator/reducers/get-active-image.js +0 -27
  127. package/Annotator/reducers/get-implied-video-regions.js +0 -180
  128. package/Annotator/reducers/history-handler.js +0 -38
  129. package/Annotator/reducers/image-reducer.js +0 -20
  130. package/Annotator/reducers/video-reducer.js +0 -88
  131. package/ClassSelectionMenu/index.js +0 -135
  132. package/Crosshairs/index.js +0 -53
  133. package/DebugSidebarBox/index.js +0 -20
  134. package/DemoSite/Editor.js +0 -194
  135. package/DemoSite/ErrorBoundaryDialog.js +0 -64
  136. package/DemoSite/index.js +0 -40
  137. package/FullImageSegmentationAnnotator/index.js +0 -7
  138. package/GroupSelectorSidebarBox/index.js +0 -63
  139. package/HighlightBox/index.js +0 -99
  140. package/HistorySidebarBox/index.js +0 -71
  141. package/ImageCanvas/index.js +0 -424
  142. package/ImageCanvas/region-tools.js +0 -165
  143. package/ImageCanvas/use-mouse.js +0 -180
  144. package/ImageCanvas/use-project-box.js +0 -27
  145. package/ImageCanvas/use-wasd-mode.js +0 -62
  146. package/ImageMask/index.js +0 -133
  147. package/ImageMask/load-image.js +0 -25
  148. package/ImageSelectorSidebarBox/index.js +0 -60
  149. package/KeyframeTimeline/get-time-string.js +0 -27
  150. package/KeyframeTimeline/index.js +0 -233
  151. package/KeyframesSelectorSidebarBox/index.js +0 -93
  152. package/LandingPage/index.js +0 -159
  153. package/MainLayout/icon-dictionary.js +0 -104
  154. package/MainLayout/index.js +0 -366
  155. package/MainLayout/types.js +0 -0
  156. package/MainLayout/use-implied-video-regions.js +0 -13
  157. package/PointDistances/index.js +0 -73
  158. package/PreventScrollToParents/index.js +0 -51
  159. package/RegionLabel/index.js +0 -191
  160. package/RegionSelectAndTransformBoxes/index.js +0 -167
  161. package/RegionSelectorSidebarBox/index.js +0 -248
  162. package/RegionShapes/index.js +0 -274
  163. package/RegionTags/index.js +0 -138
  164. package/SettingsDialog/index.js +0 -52
  165. package/SettingsProvider/index.js +0 -53
  166. package/Shortcuts/ShortcutField.js +0 -46
  167. package/Shortcuts/index.js +0 -133
  168. package/ShortcutsManager/index.js +0 -155
  169. package/Sidebar/index.js +0 -69
  170. package/SidebarBoxContainer/index.js +0 -93
  171. package/SmallToolButton/index.js +0 -42
  172. package/TagsSidebarBox/index.js +0 -105
  173. package/TaskDescriptionSidebarBox/index.js +0 -58
  174. package/Theme/index.js +0 -30
  175. package/VideoOrImageCanvasBackground/index.js +0 -151
  176. package/colors.js +0 -14
  177. package/hooks/use-event-callback.js +0 -10
  178. package/hooks/use-exclude-pattern.js +0 -24
  179. package/hooks/use-load-image.js +0 -26
  180. package/hooks/use-window-size.js +0 -46
  181. package/index.js +0 -3
  182. package/lib.js +0 -3
  183. package/stories.js +0 -5
  184. package/utils/get-from-local-storage.js +0 -7
  185. package/utils/get-hotkey-help-text.js +0 -9
  186. package/utils/get-landmarks-with-transform.js +0 -40
  187. package/utils/set-in-local-storage.js +0 -3
@@ -0,0 +1,40 @@
1
+ function labelAndTextFromResultText(resultText) {
2
+ if (!resultText) { return {} }
3
+ const parsedResultText = JSON.parse(resultText);
4
+ const label = parsedResultText[0].label;
5
+ const text = parsedResultText[0].text;
6
+ return { label, text }
7
+ }
8
+
9
+ function modelResultsToRegions(modelResults) {
10
+ return modelResults.map(r => {
11
+ const { label, text } = labelAndTextFromResultText(r.text);
12
+ return {
13
+ id: r.id,
14
+ type: "box",
15
+ visible: true,
16
+ cls: label,
17
+ highlighted: false,
18
+ groupHighlighted: false,
19
+ x: r.box.X1,
20
+ y: r.box.Y1,
21
+ w: r.box.X2 - r.box.X1,
22
+ h: r.box.Y2 - r.box.Y1,
23
+ groupId: r.groupId,
24
+ text: text,
25
+ }
26
+ })
27
+ }
28
+
29
+ function photosToImages(photos) {
30
+ return photos.map(photo => ({
31
+ id: photo.id,
32
+ src: photo.fullsize.key,
33
+ thumbnail: photo.thumbnail.key,
34
+ name: photo.fullsize.key,
35
+ regions: modelResultsToRegions(photo.modelResults.v1.filter(mr => mr.name === 'extraction-engine')[0].results),
36
+ metadata: photo.metadata
37
+ }))
38
+ }
39
+
40
+ export default photosToImages;
@@ -0,0 +1,14 @@
1
+ function regionsToBlocks(regions) {
2
+ return regions.map(r => ({
3
+ id: r.id,
4
+ type: "annotation",
5
+ data: {
6
+ text: r.text || '',
7
+ labelName: r.cls,
8
+ groupColor: r.groupColor,
9
+ groupId: r.groupId
10
+ }
11
+ }))
12
+ }
13
+
14
+ export default regionsToBlocks;
@@ -0,0 +1,6 @@
1
+ export default (key, val) => {
2
+ window.localStorage.setItem(
3
+ `__REACT_IMAGE_ANNOTATE_${key}`,
4
+ JSON.stringify(val)
5
+ )
6
+ }
@@ -1,169 +0,0 @@
1
- import _objectSpread from "@babel/runtime/helpers/esm/objectSpread";
2
- import _slicedToArray from "@babel/runtime/helpers/esm/slicedToArray";
3
- import React, { useEffect, useReducer } from "react";
4
- import makeImmutable, { without } from "seamless-immutable";
5
- import MainLayout from "../MainLayout";
6
- import SettingsProvider from "../SettingsProvider";
7
- import combineReducers from "./reducers/combine-reducers.js";
8
- import generalReducer from "./reducers/general-reducer.js";
9
- import getFromLocalStorage from "../utils/get-from-local-storage";
10
- import historyHandler from "./reducers/history-handler.js";
11
- import imageReducer from "./reducers/image-reducer.js";
12
- import useEventCallback from "use-event-callback";
13
- import videoReducer from "./reducers/video-reducer.js";
14
- export var Annotator = function Annotator(_ref) {
15
- var images = _ref.images,
16
- allowedArea = _ref.allowedArea,
17
- _ref$selectedImage = _ref.selectedImage,
18
- selectedImage = _ref$selectedImage === void 0 ? images && images.length > 0 ? 0 : undefined : _ref$selectedImage,
19
- showPointDistances = _ref.showPointDistances,
20
- pointDistancePrecision = _ref.pointDistancePrecision,
21
- _ref$showTags = _ref.showTags,
22
- showTags = _ref$showTags === void 0 ? getFromLocalStorage("showTags", true) : _ref$showTags,
23
- _ref$enabledTools = _ref.enabledTools,
24
- enabledTools = _ref$enabledTools === void 0 ? ["select", "create-point", "create-box", "create-polygon", "create-line", "create-expanding-line", "show-mask"] : _ref$enabledTools,
25
- _ref$selectedTool = _ref.selectedTool,
26
- selectedTool = _ref$selectedTool === void 0 ? "select" : _ref$selectedTool,
27
- _ref$regionTagList = _ref.regionTagList,
28
- regionTagList = _ref$regionTagList === void 0 ? [] : _ref$regionTagList,
29
- _ref$regionClsList = _ref.regionClsList,
30
- regionClsList = _ref$regionClsList === void 0 ? [] : _ref$regionClsList,
31
- _ref$imageTagList = _ref.imageTagList,
32
- imageTagList = _ref$imageTagList === void 0 ? [] : _ref$imageTagList,
33
- _ref$imageClsList = _ref.imageClsList,
34
- imageClsList = _ref$imageClsList === void 0 ? [] : _ref$imageClsList,
35
- _ref$keyframes = _ref.keyframes,
36
- keyframes = _ref$keyframes === void 0 ? {} : _ref$keyframes,
37
- _ref$taskDescription = _ref.taskDescription,
38
- taskDescription = _ref$taskDescription === void 0 ? "" : _ref$taskDescription,
39
- _ref$fullImageSegment = _ref.fullImageSegmentationMode,
40
- fullImageSegmentationMode = _ref$fullImageSegment === void 0 ? false : _ref$fullImageSegment,
41
- RegionEditLabel = _ref.RegionEditLabel,
42
- videoSrc = _ref.videoSrc,
43
- _ref$videoTime = _ref.videoTime,
44
- videoTime = _ref$videoTime === void 0 ? 0 : _ref$videoTime,
45
- videoName = _ref.videoName,
46
- onExit = _ref.onExit,
47
- onNextImage = _ref.onNextImage,
48
- onPrevImage = _ref.onPrevImage,
49
- keypointDefinitions = _ref.keypointDefinitions,
50
- _ref$autoSegmentation = _ref.autoSegmentationOptions,
51
- autoSegmentationOptions = _ref$autoSegmentation === void 0 ? {
52
- type: "autoseg"
53
- } : _ref$autoSegmentation,
54
- hideHeader = _ref.hideHeader,
55
- hideHeaderText = _ref.hideHeaderText,
56
- hideNext = _ref.hideNext,
57
- hidePrev = _ref.hidePrev,
58
- hideClone = _ref.hideClone,
59
- hideSettings = _ref.hideSettings,
60
- hideFullScreen = _ref.hideFullScreen,
61
- hideSave = _ref.hideSave,
62
- allowComments = _ref.allowComments,
63
- onImagesChange = _ref.onImagesChange,
64
- groups = _ref.groups,
65
- onGroupSelect = _ref.onGroupSelect,
66
- selectedGroupId = _ref.selectedGroupId,
67
- hideHistory = _ref.hideHistory;
68
-
69
- if (typeof selectedImage === "string") {
70
- selectedImage = (images || []).findIndex(function (img) {
71
- return img.src === selectedImage;
72
- });
73
- if (selectedImage === -1) selectedImage = undefined;
74
- }
75
-
76
- var annotationType = images ? "image" : "video";
77
-
78
- var _useReducer = useReducer(historyHandler(combineReducers(annotationType === "image" ? imageReducer : videoReducer, generalReducer)), makeImmutable(_objectSpread({
79
- annotationType: annotationType,
80
- showTags: showTags,
81
- allowedArea: allowedArea,
82
- showPointDistances: showPointDistances,
83
- pointDistancePrecision: pointDistancePrecision,
84
- selectedTool: selectedTool,
85
- fullImageSegmentationMode: fullImageSegmentationMode,
86
- autoSegmentationOptions: autoSegmentationOptions,
87
- mode: null,
88
- taskDescription: taskDescription,
89
- showMask: true,
90
- labelImages: imageClsList.length > 0 || imageTagList.length > 0,
91
- regionClsList: regionClsList,
92
- regionTagList: regionTagList,
93
- imageClsList: imageClsList,
94
- imageTagList: imageTagList,
95
- currentVideoTime: videoTime,
96
- enabledTools: enabledTools,
97
- history: [],
98
- videoName: videoName,
99
- keypointDefinitions: keypointDefinitions,
100
- allowComments: allowComments
101
- }, annotationType === "image" ? {
102
- selectedImage: selectedImage,
103
- images: images,
104
- selectedImageFrameTime: images && images.length > 0 ? images[0].frameTime : undefined
105
- } : {
106
- videoSrc: videoSrc,
107
- keyframes: keyframes
108
- }))),
109
- _useReducer2 = _slicedToArray(_useReducer, 2),
110
- state = _useReducer2[0],
111
- dispatchToReducer = _useReducer2[1];
112
-
113
- var dispatch = useEventCallback(function (action) {
114
- if (action.type === "HEADER_BUTTON_CLICKED") {
115
- if (["Exit", "Done", "Save", "Complete"].includes(action.buttonName)) {
116
- return onExit(without(state, "history"));
117
- } else if (action.buttonName === "Next" && onNextImage) {
118
- return onNextImage(without(state, "history"));
119
- } else if (action.buttonName === "Prev" && onPrevImage) {
120
- return onPrevImage(without(state, "history"));
121
- }
122
- }
123
-
124
- dispatchToReducer(action);
125
- });
126
- var onRegionClassAdded = useEventCallback(function (cls) {
127
- dispatchToReducer({
128
- type: "ON_CLS_ADDED",
129
- cls: cls
130
- });
131
- });
132
- useEffect(function () {
133
- if (onImagesChange) {
134
- onImagesChange({
135
- selectedImage: selectedImage,
136
- images: state.images
137
- });
138
- }
139
-
140
- if (selectedImage === undefined) return;
141
- dispatchToReducer({
142
- type: "SELECT_IMAGE",
143
- imageIndex: selectedImage,
144
- image: state.images[selectedImage]
145
- });
146
- }, [onImagesChange, selectedImage, state.images]);
147
- if (!images && !videoSrc) return 'Missing required prop "images" or "videoSrc"';
148
- return React.createElement(SettingsProvider, null, React.createElement(MainLayout, {
149
- RegionEditLabel: RegionEditLabel,
150
- alwaysShowNextButton: Boolean(onNextImage),
151
- alwaysShowPrevButton: Boolean(onPrevImage),
152
- state: state,
153
- dispatch: dispatch,
154
- onRegionClassAdded: onRegionClassAdded,
155
- hideHeader: hideHeader,
156
- hideHeaderText: hideHeaderText,
157
- hideNext: hideNext,
158
- hidePrev: hidePrev,
159
- hideClone: hideClone,
160
- hideSettings: hideSettings,
161
- hideFullScreen: hideFullScreen,
162
- hideSave: hideSave,
163
- groups: groups,
164
- onGroupSelect: onGroupSelect,
165
- selectedGroupId: selectedGroupId,
166
- hideHistory: hideHistory
167
- }));
168
- };
169
- export default Annotator;
@@ -1,14 +0,0 @@
1
- export default (function () {
2
- for (var _len = arguments.length, reducers = new Array(_len), _key = 0; _key < _len; _key++) {
3
- reducers[_key] = arguments[_key];
4
- }
5
-
6
- return function (state, action) {
7
- for (var _i = 0, _reducers = reducers; _i < _reducers.length; _i++) {
8
- var reducer = _reducers[_i];
9
- state = reducer(state, action);
10
- }
11
-
12
- return state;
13
- };
14
- });
@@ -1,73 +0,0 @@
1
- import _objectSpread from "@babel/runtime/helpers/esm/objectSpread";
2
- import _slicedToArray from "@babel/runtime/helpers/esm/slicedToArray";
3
-
4
- function clamp(num, min, max) {
5
- return num <= min ? min : num >= max ? max : num;
6
- }
7
-
8
- export default (function (expandingLine) {
9
- var expandingWidth = expandingLine.expandingWidth || 0.005;
10
- var pointPairs = expandingLine.points.map(function (_ref, i) {
11
- var x = _ref.x,
12
- y = _ref.y,
13
- angle = _ref.angle,
14
- width = _ref.width;
15
-
16
- if (!angle) {
17
- var n = expandingLine.points[clamp(i + 1, 0, expandingLine.points.length - 1)];
18
- var p = expandingLine.points[clamp(i - 1, 0, expandingLine.points.length - 1)];
19
- angle = Math.atan2(p.x - n.x, p.y - n.y) + Math.PI / 2;
20
- }
21
-
22
- var dx = Math.sin(angle) * (width || expandingWidth) / 2;
23
- var dy = Math.cos(angle) * (width || expandingWidth) / 2;
24
- return [{
25
- x: x + dx,
26
- y: y + dy
27
- }, {
28
- x: x - dx,
29
- y: y - dy
30
- }];
31
- });
32
- var firstSection = pointPairs.map(function (_ref2) {
33
- var _ref3 = _slicedToArray(_ref2, 2),
34
- p1 = _ref3[0],
35
- p2 = _ref3[1];
36
-
37
- return p1;
38
- });
39
- var secondSection = pointPairs.map(function (_ref4) {
40
- var _ref5 = _slicedToArray(_ref4, 2),
41
- p1 = _ref5[0],
42
- p2 = _ref5[1];
43
-
44
- return p2;
45
- }).asMutable();
46
- secondSection.reverse();
47
- var newPoints = firstSection.concat(secondSection).map(function (_ref6) {
48
- var x = _ref6.x,
49
- y = _ref6.y;
50
- return [x, y];
51
- });
52
- return _objectSpread({}, expandingLine, {
53
- type: "polygon",
54
- open: false,
55
- points: newPoints,
56
- unfinished: undefined,
57
- candidatePoint: undefined // let { expandingWidth = 0.005, points } = region
58
- // expandingWidth = points.slice(-1)[0].width || expandingWidth
59
- // const lastPoint = points.slice(-1)[0]
60
- // return (
61
- // <>
62
- // <polygon
63
- // points={
64
- // .map((p) => `${p.x * iw} ${p.y * ih}`)
65
- // .join(" ")}
66
- // return {
67
- // ...expandingLine,
68
- // unfinished: undefined,
69
- // candidatePoint: undefined,
70
- // }
71
-
72
- });
73
- });