@searpent/react-image-annotate 2.0.0 → 2.0.3

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 (174) hide show
  1. package/Annotator/index.js +169 -0
  2. package/Annotator/reducers/combine-reducers.js +14 -0
  3. package/Annotator/reducers/convert-expanding-line-to-polygon.js +73 -0
  4. package/{src/Annotator → Annotator}/reducers/fix-twisted.js +3 -5
  5. package/Annotator/reducers/general-reducer.js +1058 -0
  6. package/Annotator/reducers/get-active-image.js +27 -0
  7. package/Annotator/reducers/get-implied-video-regions.js +180 -0
  8. package/Annotator/reducers/history-handler.js +38 -0
  9. package/Annotator/reducers/image-reducer.js +20 -0
  10. package/Annotator/reducers/video-reducer.js +88 -0
  11. package/ClassSelectionMenu/index.js +135 -0
  12. package/Crosshairs/index.js +53 -0
  13. package/DebugSidebarBox/index.js +20 -0
  14. package/DemoSite/Editor.js +194 -0
  15. package/DemoSite/ErrorBoundaryDialog.js +64 -0
  16. package/DemoSite/index.js +40 -0
  17. package/FullImageSegmentationAnnotator/index.js +7 -0
  18. package/GroupSelectorSidebarBox/index.js +63 -0
  19. package/HighlightBox/index.js +99 -0
  20. package/HistorySidebarBox/index.js +71 -0
  21. package/ImageCanvas/index.js +424 -0
  22. package/ImageCanvas/region-tools.js +165 -0
  23. package/{src/ImageCanvas → ImageCanvas}/styles.js +12 -8
  24. package/ImageCanvas/use-mouse.js +180 -0
  25. package/ImageCanvas/use-project-box.js +27 -0
  26. package/ImageCanvas/use-wasd-mode.js +62 -0
  27. package/ImageMask/index.js +133 -0
  28. package/ImageMask/load-image.js +25 -0
  29. package/ImageSelectorSidebarBox/index.js +60 -0
  30. package/KeyframeTimeline/get-time-string.js +27 -0
  31. package/KeyframeTimeline/index.js +233 -0
  32. package/KeyframesSelectorSidebarBox/index.js +93 -0
  33. package/LandingPage/index.js +159 -0
  34. package/MainLayout/icon-dictionary.js +104 -0
  35. package/MainLayout/index.js +366 -0
  36. package/{src/MainLayout → MainLayout}/styles.js +6 -7
  37. package/MainLayout/types.js +0 -0
  38. package/MainLayout/use-implied-video-regions.js +13 -0
  39. package/PointDistances/index.js +73 -0
  40. package/PreventScrollToParents/index.js +51 -0
  41. package/RegionLabel/index.js +191 -0
  42. package/{src/RegionLabel → RegionLabel}/styles.js +12 -15
  43. package/RegionSelectAndTransformBoxes/index.js +167 -0
  44. package/RegionSelectorSidebarBox/index.js +248 -0
  45. package/{src/RegionSelectorSidebarBox → RegionSelectorSidebarBox}/styles.js +13 -14
  46. package/RegionShapes/index.js +274 -0
  47. package/RegionTags/index.js +138 -0
  48. package/SettingsDialog/index.js +52 -0
  49. package/SettingsProvider/index.js +53 -0
  50. package/Shortcuts/ShortcutField.js +46 -0
  51. package/Shortcuts/index.js +133 -0
  52. package/ShortcutsManager/index.js +155 -0
  53. package/Sidebar/index.js +69 -0
  54. package/SidebarBoxContainer/index.js +93 -0
  55. package/SmallToolButton/index.js +42 -0
  56. package/TagsSidebarBox/index.js +105 -0
  57. package/TaskDescriptionSidebarBox/index.js +58 -0
  58. package/Theme/index.js +30 -0
  59. package/VideoOrImageCanvasBackground/index.js +151 -0
  60. package/colors.js +14 -0
  61. package/hooks/use-event-callback.js +10 -0
  62. package/hooks/use-exclude-pattern.js +24 -0
  63. package/hooks/use-load-image.js +26 -0
  64. package/hooks/use-window-size.js +46 -0
  65. package/{src/hooks → hooks}/xpattern.js +1 -1
  66. package/index.js +3 -0
  67. package/lib.js +3 -0
  68. package/package.json +1 -1
  69. package/stories.js +5 -0
  70. package/utils/get-from-local-storage.js +7 -0
  71. package/utils/get-hotkey-help-text.js +9 -0
  72. package/utils/get-landmarks-with-transform.js +40 -0
  73. package/utils/set-in-local-storage.js +3 -0
  74. package/.babelrc +0 -6
  75. package/.env +0 -1
  76. package/.flowconfig +0 -2
  77. package/.github/workflows/release-on-master.yml +0 -32
  78. package/.github/workflows/test.yml +0 -16
  79. package/.prettierrc +0 -3
  80. package/.releaserc.js +0 -18
  81. package/.storybook/addons.js +0 -2
  82. package/.storybook/config.js +0 -16
  83. package/LICENSE +0 -21
  84. package/public/favicon.ico +0 -0
  85. package/public/index.html +0 -38
  86. package/src/Annotator/bike-pic.png +0 -0
  87. package/src/Annotator/bike-pic2.png +0 -0
  88. package/src/Annotator/dab-keyframes.story.json +0 -1
  89. package/src/Annotator/index.js +0 -206
  90. package/src/Annotator/index.story.js +0 -727
  91. package/src/Annotator/poses.story.js +0 -150
  92. package/src/Annotator/reducers/combine-reducers.js +0 -7
  93. package/src/Annotator/reducers/convert-expanding-line-to-polygon.js +0 -53
  94. package/src/Annotator/reducers/general-reducer.js +0 -914
  95. package/src/Annotator/reducers/get-active-image.js +0 -21
  96. package/src/Annotator/reducers/get-implied-video-regions.js +0 -115
  97. package/src/Annotator/reducers/history-handler.js +0 -60
  98. package/src/Annotator/reducers/image-reducer.js +0 -23
  99. package/src/Annotator/reducers/video-reducer.js +0 -85
  100. package/src/Annotator/video.story.js +0 -51
  101. package/src/ClassSelectionMenu/index.js +0 -108
  102. package/src/Crosshairs/index.js +0 -64
  103. package/src/DebugSidebarBox/index.js +0 -36
  104. package/src/DemoSite/Editor.js +0 -235
  105. package/src/DemoSite/ErrorBoundaryDialog.js +0 -34
  106. package/src/DemoSite/index.js +0 -41
  107. package/src/DemoSite/index.story.js +0 -10
  108. package/src/DemoSite/simple-segmentation-example.json +0 -572
  109. package/src/FullImageSegmentationAnnotator/hard1.story.jpg +0 -0
  110. package/src/FullImageSegmentationAnnotator/hard2.story.jpg +0 -0
  111. package/src/FullImageSegmentationAnnotator/hard3.story.jpg +0 -0
  112. package/src/FullImageSegmentationAnnotator/index.js +0 -7
  113. package/src/FullImageSegmentationAnnotator/index.story.js +0 -177
  114. package/src/FullImageSegmentationAnnotator/orange.story.png +0 -0
  115. package/src/HighlightBox/index.js +0 -143
  116. package/src/HistorySidebarBox/index.js +0 -78
  117. package/src/ImageCanvas/dancing-man.story.jpg +0 -0
  118. package/src/ImageCanvas/index.js +0 -488
  119. package/src/ImageCanvas/index.story.js +0 -214
  120. package/src/ImageCanvas/mouse_mask.story.png +0 -0
  121. package/src/ImageCanvas/region-tools.js +0 -171
  122. package/src/ImageCanvas/seves_desk.story.jpg +0 -0
  123. package/src/ImageCanvas/use-mouse.js +0 -168
  124. package/src/ImageCanvas/use-project-box.js +0 -23
  125. package/src/ImageCanvas/use-wasd-mode.js +0 -50
  126. package/src/ImageMask/index.js +0 -127
  127. package/src/ImageMask/load-image.js +0 -32
  128. package/src/ImageSelectorSidebarBox/index.js +0 -54
  129. package/src/KeyframeTimeline/get-time-string.js +0 -25
  130. package/src/KeyframeTimeline/index.js +0 -223
  131. package/src/KeyframesSelectorSidebarBox/index.js +0 -93
  132. package/src/LandingPage/content.md +0 -57
  133. package/src/LandingPage/github-markdown.css +0 -964
  134. package/src/LandingPage/index.js +0 -147
  135. package/src/MainLayout/icon-dictionary.js +0 -79
  136. package/src/MainLayout/index.js +0 -420
  137. package/src/MainLayout/index.story.js +0 -240
  138. package/src/MainLayout/types.js +0 -156
  139. package/src/MainLayout/use-implied-video-regions.js +0 -17
  140. package/src/PointDistances/index.js +0 -90
  141. package/src/PreventScrollToParents/index.js +0 -48
  142. package/src/PreventScrollToParents/index.story.js +0 -23
  143. package/src/RegionLabel/index.js +0 -201
  144. package/src/RegionSelectAndTransformBoxes/index.js +0 -234
  145. package/src/RegionSelectorSidebarBox/index.js +0 -216
  146. package/src/RegionShapes/index.js +0 -236
  147. package/src/RegionTags/index.js +0 -130
  148. package/src/SettingsDialog/index.js +0 -58
  149. package/src/SettingsProvider/index.js +0 -44
  150. package/src/Shortcuts/ShortcutField.js +0 -44
  151. package/src/Shortcuts/index.js +0 -129
  152. package/src/ShortcutsManager/index.js +0 -162
  153. package/src/Sidebar/index.js +0 -117
  154. package/src/SidebarBoxContainer/index.js +0 -93
  155. package/src/SmallToolButton/index.js +0 -57
  156. package/src/TagsSidebarBox/index.js +0 -93
  157. package/src/TaskDescriptionSidebarBox/index.js +0 -43
  158. package/src/Theme/index.js +0 -36
  159. package/src/VideoOrImageCanvasBackground/index.js +0 -170
  160. package/src/colors.js +0 -32
  161. package/src/hooks/use-event-callback.js +0 -11
  162. package/src/hooks/use-exclude-pattern.js +0 -27
  163. package/src/hooks/use-load-image.js +0 -21
  164. package/src/hooks/use-window-size.js +0 -46
  165. package/src/hooks/xpattern.png +0 -0
  166. package/src/index.js +0 -18
  167. package/src/lib.js +0 -7
  168. package/src/screenshot.png +0 -0
  169. package/src/site.css +0 -5
  170. package/src/stories.js +0 -2
  171. package/src/utils/get-from-local-storage.js +0 -7
  172. package/src/utils/get-hotkey-help-text.js +0 -11
  173. package/src/utils/get-landmarks-with-transform.js +0 -23
  174. package/src/utils/set-in-local-storage.js +0 -6
@@ -0,0 +1,169 @@
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;
@@ -0,0 +1,14 @@
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
+ });
@@ -0,0 +1,73 @@
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
+ });
@@ -1,6 +1,4 @@
1
- // @flow
2
-
3
- export default (pointsWithAngles) => {
1
+ export default (function (pointsWithAngles) {
4
2
  // Adjacent angles should not have an angular distance of more than Math.PI
5
- return pointsWithAngles
6
- }
3
+ return pointsWithAngles;
4
+ });