@searpent/react-image-annotate 2.0.5 → 2.0.8

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 (195) hide show
  1. package/Annotator/examplePhotos.js +6976 -0
  2. package/Annotator/index.js +268 -0
  3. package/Annotator/reducers/combine-reducers.js +14 -0
  4. package/Annotator/reducers/convert-expanding-line-to-polygon.js +73 -0
  5. package/{src/Annotator → Annotator}/reducers/fix-twisted.js +3 -5
  6. package/Annotator/reducers/general-reducer.js +1152 -0
  7. package/Annotator/reducers/get-active-image.js +27 -0
  8. package/Annotator/reducers/get-implied-video-regions.js +180 -0
  9. package/Annotator/reducers/history-handler.js +38 -0
  10. package/Annotator/reducers/image-reducer.js +20 -0
  11. package/Annotator/reducers/video-reducer.js +88 -0
  12. package/ClassSelectionMenu/index.js +135 -0
  13. package/Crosshairs/index.js +53 -0
  14. package/DebugSidebarBox/index.js +20 -0
  15. package/DemoSite/Editor.js +194 -0
  16. package/DemoSite/ErrorBoundaryDialog.js +64 -0
  17. package/DemoSite/index.js +40 -0
  18. package/{src/Editor → Editor}/annotation-plugin/annotation.css +0 -0
  19. package/Editor/annotation-plugin/annotation.js +613 -0
  20. package/Editor/index.js +57 -0
  21. package/{src/Editor → Editor}/tools.js +2 -3
  22. package/FullImageSegmentationAnnotator/index.js +7 -0
  23. package/GroupSelectorSidebarBox/index.js +63 -0
  24. package/HighlightBox/index.js +99 -0
  25. package/HistorySidebarBox/index.js +71 -0
  26. package/ImageCanvas/index.js +429 -0
  27. package/ImageCanvas/region-tools.js +165 -0
  28. package/{src/ImageCanvas → ImageCanvas}/styles.js +12 -8
  29. package/ImageCanvas/use-mouse.js +180 -0
  30. package/ImageCanvas/use-project-box.js +27 -0
  31. package/ImageCanvas/use-wasd-mode.js +62 -0
  32. package/ImageMask/index.js +133 -0
  33. package/ImageMask/load-image.js +25 -0
  34. package/ImageSelectorSidebarBox/index.js +60 -0
  35. package/KeyframeTimeline/get-time-string.js +27 -0
  36. package/KeyframeTimeline/index.js +233 -0
  37. package/KeyframesSelectorSidebarBox/index.js +93 -0
  38. package/LandingPage/index.js +159 -0
  39. package/MainLayout/icon-dictionary.js +104 -0
  40. package/MainLayout/index.js +469 -0
  41. package/{src/MainLayout → MainLayout}/styles.js +6 -7
  42. package/MainLayout/types.js +0 -0
  43. package/MainLayout/use-implied-video-regions.js +13 -0
  44. package/MetadataEditorSidebarBox/index.js +126 -0
  45. package/PageSelector/index.js +69 -0
  46. package/{src/PageSelector → PageSelector}/page-selector.css +18 -0
  47. package/PointDistances/index.js +73 -0
  48. package/PreventScrollToParents/index.js +51 -0
  49. package/RegionLabel/index.js +205 -0
  50. package/{src/RegionLabel → RegionLabel}/styles.js +12 -15
  51. package/RegionSelectAndTransformBoxes/index.js +167 -0
  52. package/RegionSelectorSidebarBox/index.js +248 -0
  53. package/{src/RegionSelectorSidebarBox → RegionSelectorSidebarBox}/styles.js +13 -14
  54. package/RegionShapes/index.js +294 -0
  55. package/RegionTags/index.js +142 -0
  56. package/SettingsDialog/index.js +52 -0
  57. package/SettingsProvider/index.js +58 -0
  58. package/Shortcuts/ShortcutField.js +46 -0
  59. package/Shortcuts/index.js +133 -0
  60. package/ShortcutsManager/index.js +155 -0
  61. package/Sidebar/index.js +69 -0
  62. package/SidebarBoxContainer/index.js +93 -0
  63. package/SmallToolButton/index.js +42 -0
  64. package/TagsSidebarBox/index.js +105 -0
  65. package/TaskDescriptionSidebarBox/index.js +58 -0
  66. package/Theme/index.js +30 -0
  67. package/VideoOrImageCanvasBackground/index.js +151 -0
  68. package/colors.js +14 -0
  69. package/hooks/use-colors.js +101 -0
  70. package/hooks/use-event-callback.js +10 -0
  71. package/hooks/use-exclude-pattern.js +24 -0
  72. package/hooks/use-load-image.js +26 -0
  73. package/hooks/use-window-size.js +46 -0
  74. package/{src/hooks → hooks}/xpattern.js +1 -1
  75. package/index.js +3 -0
  76. package/lib.js +3 -0
  77. package/package.json +1 -1
  78. package/stories.js +5 -0
  79. package/{src/utils → utils}/filter-only-unique.js +1 -1
  80. package/utils/get-from-local-storage.js +7 -0
  81. package/utils/get-hotkey-help-text.js +9 -0
  82. package/utils/get-landmarks-with-transform.js +40 -0
  83. package/utils/photosToImages.js +53 -0
  84. package/utils/regions-to-blocks.js +16 -0
  85. package/utils/set-in-local-storage.js +3 -0
  86. package/.babelrc +0 -6
  87. package/.env +0 -1
  88. package/.flowconfig +0 -2
  89. package/.github/workflows/release-on-master.yml +0 -32
  90. package/.github/workflows/test.yml +0 -16
  91. package/.prettierrc +0 -3
  92. package/.releaserc.js +0 -18
  93. package/.storybook/addons.js +0 -2
  94. package/.storybook/config.js +0 -16
  95. package/LICENSE +0 -21
  96. package/public/favicon.ico +0 -0
  97. package/public/index.html +0 -38
  98. package/src/Annotator/bike-pic.png +0 -0
  99. package/src/Annotator/bike-pic2.png +0 -0
  100. package/src/Annotator/dab-keyframes.story.json +0 -1
  101. package/src/Annotator/examplePhotos.js +0 -7601
  102. package/src/Annotator/index.js +0 -291
  103. package/src/Annotator/index.story.js +0 -807
  104. package/src/Annotator/poses.story.js +0 -150
  105. package/src/Annotator/reducers/combine-reducers.js +0 -7
  106. package/src/Annotator/reducers/convert-expanding-line-to-polygon.js +0 -53
  107. package/src/Annotator/reducers/general-reducer.js +0 -996
  108. package/src/Annotator/reducers/get-active-image.js +0 -21
  109. package/src/Annotator/reducers/get-implied-video-regions.js +0 -115
  110. package/src/Annotator/reducers/history-handler.js +0 -60
  111. package/src/Annotator/reducers/image-reducer.js +0 -23
  112. package/src/Annotator/reducers/video-reducer.js +0 -85
  113. package/src/Annotator/video.story.js +0 -51
  114. package/src/ClassSelectionMenu/index.js +0 -108
  115. package/src/Crosshairs/index.js +0 -64
  116. package/src/DebugSidebarBox/index.js +0 -36
  117. package/src/DemoSite/Editor.js +0 -235
  118. package/src/DemoSite/ErrorBoundaryDialog.js +0 -34
  119. package/src/DemoSite/index.js +0 -41
  120. package/src/DemoSite/index.story.js +0 -10
  121. package/src/DemoSite/simple-segmentation-example.json +0 -572
  122. package/src/Editor/annotation-plugin/annotation.js +0 -515
  123. package/src/Editor/index.js +0 -24
  124. package/src/FullImageSegmentationAnnotator/hard1.story.jpg +0 -0
  125. package/src/FullImageSegmentationAnnotator/hard2.story.jpg +0 -0
  126. package/src/FullImageSegmentationAnnotator/hard3.story.jpg +0 -0
  127. package/src/FullImageSegmentationAnnotator/index.js +0 -7
  128. package/src/FullImageSegmentationAnnotator/index.story.js +0 -177
  129. package/src/FullImageSegmentationAnnotator/orange.story.png +0 -0
  130. package/src/GroupSelectorSidebarBox/index.js +0 -48
  131. package/src/HighlightBox/index.js +0 -143
  132. package/src/HistorySidebarBox/index.js +0 -78
  133. package/src/ImageCanvas/dancing-man.story.jpg +0 -0
  134. package/src/ImageCanvas/index.js +0 -494
  135. package/src/ImageCanvas/index.story.js +0 -314
  136. package/src/ImageCanvas/mouse_mask.story.png +0 -0
  137. package/src/ImageCanvas/region-tools.js +0 -171
  138. package/src/ImageCanvas/seves_desk.story.jpg +0 -0
  139. package/src/ImageCanvas/use-mouse.js +0 -168
  140. package/src/ImageCanvas/use-project-box.js +0 -23
  141. package/src/ImageCanvas/use-wasd-mode.js +0 -50
  142. package/src/ImageMask/index.js +0 -127
  143. package/src/ImageMask/load-image.js +0 -32
  144. package/src/ImageSelectorSidebarBox/index.js +0 -54
  145. package/src/KeyframeTimeline/get-time-string.js +0 -25
  146. package/src/KeyframeTimeline/index.js +0 -223
  147. package/src/KeyframesSelectorSidebarBox/index.js +0 -93
  148. package/src/LandingPage/content.md +0 -57
  149. package/src/LandingPage/github-markdown.css +0 -964
  150. package/src/LandingPage/index.js +0 -147
  151. package/src/MainLayout/icon-dictionary.js +0 -79
  152. package/src/MainLayout/index.js +0 -510
  153. package/src/MainLayout/index.story.js +0 -240
  154. package/src/MainLayout/types.js +0 -164
  155. package/src/MainLayout/use-implied-video-regions.js +0 -17
  156. package/src/MetadataEditorSidebarBox/index.js +0 -98
  157. package/src/PageSelector/index.js +0 -76
  158. package/src/PointDistances/index.js +0 -90
  159. package/src/PreventScrollToParents/index.js +0 -48
  160. package/src/PreventScrollToParents/index.story.js +0 -23
  161. package/src/RegionLabel/index.js +0 -222
  162. package/src/RegionSelectAndTransformBoxes/index.js +0 -234
  163. package/src/RegionSelectorSidebarBox/index.js +0 -216
  164. package/src/RegionShapes/index.js +0 -254
  165. package/src/RegionTags/index.js +0 -134
  166. package/src/SettingsDialog/index.js +0 -58
  167. package/src/SettingsProvider/index.js +0 -48
  168. package/src/Shortcuts/ShortcutField.js +0 -44
  169. package/src/Shortcuts/index.js +0 -129
  170. package/src/ShortcutsManager/index.js +0 -162
  171. package/src/Sidebar/index.js +0 -117
  172. package/src/SidebarBoxContainer/index.js +0 -93
  173. package/src/SmallToolButton/index.js +0 -57
  174. package/src/TagsSidebarBox/index.js +0 -93
  175. package/src/TaskDescriptionSidebarBox/index.js +0 -43
  176. package/src/Theme/index.js +0 -36
  177. package/src/VideoOrImageCanvasBackground/index.js +0 -170
  178. package/src/colors.js +0 -32
  179. package/src/hooks/use-colors.js +0 -74
  180. package/src/hooks/use-event-callback.js +0 -11
  181. package/src/hooks/use-exclude-pattern.js +0 -27
  182. package/src/hooks/use-load-image.js +0 -21
  183. package/src/hooks/use-window-size.js +0 -46
  184. package/src/hooks/xpattern.png +0 -0
  185. package/src/index.js +0 -18
  186. package/src/lib.js +0 -7
  187. package/src/screenshot.png +0 -0
  188. package/src/site.css +0 -5
  189. package/src/stories.js +0 -2
  190. package/src/utils/get-from-local-storage.js +0 -7
  191. package/src/utils/get-hotkey-help-text.js +0 -11
  192. package/src/utils/get-landmarks-with-transform.js +0 -23
  193. package/src/utils/photosToImages.js +0 -40
  194. package/src/utils/regions-to-blocks.js +0 -14
  195. package/src/utils/set-in-local-storage.js +0 -6
@@ -1,147 +0,0 @@
1
- // @flow
2
-
3
- import React from "react"
4
- import Button from "@mui/material/Button"
5
- import { styled } from "@mui/material/styles"
6
- import { createTheme, ThemeProvider } from "@mui/material/styles"
7
- import * as colors from "@mui/material/colors"
8
- import Grid from "@mui/material/Grid"
9
- import Markdown from "react-markdown"
10
- import GitHubButton from "react-github-btn"
11
- import "./github-markdown.css"
12
- import raw from "raw.macro"
13
- import { Prism as SyntaxHighlighter } from "react-syntax-highlighter"
14
- import { docco } from "react-syntax-highlighter/dist/cjs/languages/hljs/javascript"
15
-
16
- const contentMd = raw("./content.md")
17
- const theme = createTheme()
18
- const RootContainer = styled("div")(({ theme }) => ({
19
- display: "flex",
20
- flexDirection: "column",
21
- alignItems: "center",
22
- }))
23
- const ContentContainer = styled("div")(({ theme }) => ({
24
- width: "100%",
25
- boxSizing: "border-box",
26
- display: "flex",
27
- flexDirection: "column",
28
- maxWidth: 1200,
29
- }))
30
- const Header = styled("div")(({ theme }) => ({
31
- width: "100%",
32
- display: "flex",
33
- justifyContent: "center",
34
- backgroundColor: colors.blue[600],
35
- padding: 8,
36
- boxSizing: "border-box",
37
- }))
38
- const HeaderButton = styled(Button)(({ theme }) => ({
39
- color: "white",
40
- margin: 8,
41
- padding: 16,
42
- paddingLeft: 24,
43
- paddingRight: 24,
44
- }))
45
- const Hero = styled("div")(({ theme }) => ({
46
- display: "flex",
47
- justifyContent: "center",
48
- width: "100%",
49
- backgroundColor: colors.blue[500],
50
- padding: 16,
51
- color: "white",
52
- boxSizing: "border-box",
53
- }))
54
- const HeroMain = styled("div")(({ theme }) => ({
55
- fontSize: 48,
56
- fontWeight: "bold",
57
- paddingTop: 64,
58
- textShadow: "0px 1px 5px rgba(0,0,0,0.3)",
59
- }))
60
- const HeroSub = styled("div")(({ theme }) => ({
61
- paddingTop: 32,
62
- lineHeight: 1.5,
63
- fontSize: 24,
64
- textShadow: "0px 1px 3px rgba(0,0,0,0.2)",
65
- }))
66
- const HeroButtons = styled("div")(({ theme }) => ({
67
- paddingTop: 32,
68
- paddingBottom: 48,
69
- }))
70
- const Section = styled("div")(({ theme }) => ({
71
- display: "flex",
72
- padding: 16,
73
- paddingTop: 32,
74
- flexDirection: "column",
75
- }))
76
-
77
- const CodeBlock = ({ language, value }) => {
78
- return (
79
- <SyntaxHighlighter language={language} style={docco}>
80
- {value}
81
- </SyntaxHighlighter>
82
- )
83
- }
84
-
85
- function flatten(text, child) {
86
- return typeof child === "string"
87
- ? text + child
88
- : React.Children.toArray(child.props.children).reduce(flatten, text)
89
- }
90
-
91
- function HeadingRenderer(props) {
92
- var children = React.Children.toArray(props.children)
93
- var text = children.reduce(flatten, "")
94
- var slug = text.toLowerCase().replace(/\W/g, "-")
95
- return React.createElement("h" + props.level, { id: slug }, props.children)
96
- }
97
-
98
- const LandingPage = () => {
99
- return (
100
- <ThemeProvider theme={theme}>
101
- <RootContainer>
102
- <Header id="about">
103
- <ContentContainer style={{ flexDirection: "row", flexGrow: 1 }}>
104
- <HeaderButton href="#features">Features</HeaderButton>
105
- <HeaderButton href="#usage">Usage</HeaderButton>
106
- <HeaderButton href="#props">Props</HeaderButton>
107
- <HeaderButton href="./demo">Demo Playground</HeaderButton>
108
- </ContentContainer>
109
- </Header>
110
- <Hero>
111
- <ContentContainer>
112
- <HeroMain>React Image Annotate</HeroMain>
113
- <HeroSub>
114
- Powerful React component for image annotations with bounding
115
- boxes, tagging, classification, multiple images and polygon
116
- segmentation.
117
- </HeroSub>
118
- <HeroButtons>
119
- <GitHubButton
120
- href="https://github.com/waoai/react-image-annotate"
121
- data-size="large"
122
- data-show-count="true"
123
- aria-label="Star waoai/react-image-annotate on GitHub"
124
- >
125
- Star
126
- </GitHubButton>
127
- </HeroButtons>
128
- </ContentContainer>
129
- </Hero>
130
- <ContentContainer className="markdown-body">
131
- <Section className="markdown-body">
132
- <Markdown
133
- escapeHtml={false}
134
- source={contentMd}
135
- renderers={{
136
- code: CodeBlock,
137
- heading: HeadingRenderer,
138
- }}
139
- />
140
- </Section>
141
- </ContentContainer>
142
- </RootContainer>
143
- </ThemeProvider>
144
- )
145
- }
146
-
147
- export default LandingPage
@@ -1,79 +0,0 @@
1
- // @flow
2
-
3
- import React from "react"
4
- import { FontAwesomeIcon } from "@fortawesome/react-fontawesome"
5
- import {
6
- faArrowsAlt,
7
- faMousePointer,
8
- faExpandArrowsAlt,
9
- faGripLines,
10
- faTag,
11
- faPaintBrush,
12
- faCrosshairs,
13
- faDrawPolygon,
14
- faVectorSquare,
15
- faHandPaper,
16
- faSearch,
17
- faMask,
18
- faEdit,
19
- faChartLine,
20
- } from "@fortawesome/free-solid-svg-icons"
21
- import FullscreenIcon from "@mui/icons-material/Fullscreen"
22
- import AccessibilityNewIcon from "@mui/icons-material/AccessibilityNew"
23
-
24
- const faStyle = { marginTop: 4, width: 16, height: 16, marginBottom: 4 }
25
-
26
- export const iconDictionary = {
27
- select: () => (
28
- <FontAwesomeIcon
29
- style={faStyle}
30
- size="xs"
31
- fixedWidth
32
- icon={faMousePointer}
33
- />
34
- ),
35
- pan: () => (
36
- <FontAwesomeIcon style={faStyle} size="xs" fixedWidth icon={faHandPaper} />
37
- ),
38
- zoom: () => (
39
- <FontAwesomeIcon style={faStyle} size="xs" fixedWidth icon={faSearch} />
40
- ),
41
- "show-tags": () => (
42
- <FontAwesomeIcon style={faStyle} size="xs" fixedWidth icon={faTag} />
43
- ),
44
- "create-point": () => (
45
- <FontAwesomeIcon style={faStyle} size="xs" fixedWidth icon={faCrosshairs} />
46
- ),
47
- "create-box": () => (
48
- <FontAwesomeIcon
49
- style={faStyle}
50
- size="xs"
51
- fixedWidth
52
- icon={faVectorSquare}
53
- />
54
- ),
55
- "create-polygon": () => (
56
- <FontAwesomeIcon
57
- style={faStyle}
58
- size="xs"
59
- fixedWidth
60
- icon={faDrawPolygon}
61
- />
62
- ),
63
- "create-expanding-line": () => (
64
- <FontAwesomeIcon style={faStyle} size="xs" fixedWidth icon={faGripLines} />
65
- ),
66
- "create-line": () => (
67
- <FontAwesomeIcon style={faStyle} size="xs" fixedWidth icon={faChartLine} />
68
- ),
69
- "show-mask": () => (
70
- <FontAwesomeIcon style={faStyle} size="xs" fixedWidth icon={faMask} />
71
- ),
72
- "modify-allowed-area": () => (
73
- <FontAwesomeIcon style={faStyle} size="xs" fixedWidth icon={faEdit} />
74
- ),
75
- "create-keypoints": AccessibilityNewIcon,
76
- window: FullscreenIcon,
77
- }
78
-
79
- export default iconDictionary