cd-aichat 1.0.0

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 (356) hide show
  1. package/README.md +188 -0
  2. package/dist/ailogo.png +0 -0
  3. package/dist/cd-aichat.css +1 -0
  4. package/dist/cd-aichat.es.js +32223 -0
  5. package/dist/cd-aichat.umd.js +279 -0
  6. package/dist/index.css +1 -0
  7. package/package.json +61 -0
  8. package/src/ailogo.png +0 -0
  9. package/src/components/AiChat.test.js +538 -0
  10. package/src/components/AiChat.vue +2206 -0
  11. package/src/components/AiChatWidget.test.js +312 -0
  12. package/src/components/AiChatWidget.vue +963 -0
  13. package/src/components/BurnAfterReadDialog.test.js +121 -0
  14. package/src/components/BurnAfterReadDialog.vue +511 -0
  15. package/src/components/BurnAfterReadMessage.test.js +188 -0
  16. package/src/components/BurnAfterReadMessage.vue +193 -0
  17. package/src/components/BurnIndicator.test.js +101 -0
  18. package/src/components/BurnIndicator.vue +164 -0
  19. package/src/components/ChatWindow.vue +0 -0
  20. package/src/components/MentionList.vue +163 -0
  21. package/src/components/ResourceList.vue +194 -0
  22. package/src/components/RichTextEditor.vue +437 -0
  23. package/src/components/ScheduledSendDialog.vue +476 -0
  24. package/src/components/ScreenshotOverlay.vue +78 -0
  25. package/src/components/SendButtonGroup.test.js +174 -0
  26. package/src/components/SendButtonGroup.vue +166 -0
  27. package/src/components/UserDrawer.vue +0 -0
  28. package/src/components/screenshot/ScreenshotsBackground/getBoundsByPoints.ts +41 -0
  29. package/src/components/screenshot/ScreenshotsBackground/index.scss +27 -0
  30. package/src/components/screenshot/ScreenshotsBackground/index.tsx +145 -0
  31. package/src/components/screenshot/ScreenshotsButton/index.scss +29 -0
  32. package/src/components/screenshot/ScreenshotsButton/index.tsx +58 -0
  33. package/src/components/screenshot/ScreenshotsCanvas/getBoundsByPoints.ts +55 -0
  34. package/src/components/screenshot/ScreenshotsCanvas/getPoints.ts +60 -0
  35. package/src/components/screenshot/ScreenshotsCanvas/index.scss +84 -0
  36. package/src/components/screenshot/ScreenshotsCanvas/index.tsx +277 -0
  37. package/src/components/screenshot/ScreenshotsCanvas/isPointInDraw.ts +35 -0
  38. package/src/components/screenshot/ScreenshotsColor/index.scss +45 -0
  39. package/src/components/screenshot/ScreenshotsColor/index.tsx +39 -0
  40. package/src/components/screenshot/ScreenshotsContext.ts +56 -0
  41. package/src/components/screenshot/ScreenshotsMagnifier/index.scss +61 -0
  42. package/src/components/screenshot/ScreenshotsMagnifier/index.tsx +126 -0
  43. package/src/components/screenshot/ScreenshotsOperations/index.scss +25 -0
  44. package/src/components/screenshot/ScreenshotsOperations/index.tsx +118 -0
  45. package/src/components/screenshot/ScreenshotsOption/index.scss +50 -0
  46. package/src/components/screenshot/ScreenshotsOption/index.tsx +150 -0
  47. package/src/components/screenshot/ScreenshotsSize/index.scss +28 -0
  48. package/src/components/screenshot/ScreenshotsSize/index.tsx +41 -0
  49. package/src/components/screenshot/ScreenshotsSizeColor/index.scss +8 -0
  50. package/src/components/screenshot/ScreenshotsSizeColor/index.tsx +25 -0
  51. package/src/components/screenshot/ScreenshotsTextarea/calculateNodeSize.ts +117 -0
  52. package/src/components/screenshot/ScreenshotsTextarea/index.scss +19 -0
  53. package/src/components/screenshot/ScreenshotsTextarea/index.tsx +96 -0
  54. package/src/components/screenshot/composeImage.ts +57 -0
  55. package/src/components/screenshot/exports.ts +4 -0
  56. package/src/components/screenshot/hooks/useBounds.ts +35 -0
  57. package/src/components/screenshot/hooks/useCall.ts +17 -0
  58. package/src/components/screenshot/hooks/useCanvasContextRef.ts +8 -0
  59. package/src/components/screenshot/hooks/useCanvasMousedown.ts +13 -0
  60. package/src/components/screenshot/hooks/useCanvasMousemove.ts +13 -0
  61. package/src/components/screenshot/hooks/useCanvasMouseup.ts +13 -0
  62. package/src/components/screenshot/hooks/useCursor.ts +34 -0
  63. package/src/components/screenshot/hooks/useDispatcher.ts +8 -0
  64. package/src/components/screenshot/hooks/useDrawSelect.ts +16 -0
  65. package/src/components/screenshot/hooks/useEmiter.ts +61 -0
  66. package/src/components/screenshot/hooks/useHistory.ts +160 -0
  67. package/src/components/screenshot/hooks/useLang.ts +8 -0
  68. package/src/components/screenshot/hooks/useOperation.ts +37 -0
  69. package/src/components/screenshot/hooks/useReset.ts +26 -0
  70. package/src/components/screenshot/hooks/useStore.ts +8 -0
  71. package/src/components/screenshot/icons/iconfont.scss +88 -0
  72. package/src/components/screenshot/icons/iconfont.ttf +0 -0
  73. package/src/components/screenshot/icons/iconfont.woff +0 -0
  74. package/src/components/screenshot/icons/iconfont.woff2 +0 -0
  75. package/src/components/screenshot/index.tsx +169 -0
  76. package/src/components/screenshot/operations/Arrow/draw.ts +56 -0
  77. package/src/components/screenshot/operations/Arrow/index.tsx +193 -0
  78. package/src/components/screenshot/operations/Brush/draw.ts +45 -0
  79. package/src/components/screenshot/operations/Brush/index.tsx +169 -0
  80. package/src/components/screenshot/operations/Cancel/index.tsx +18 -0
  81. package/src/components/screenshot/operations/Ellipse/draw.ts +96 -0
  82. package/src/components/screenshot/operations/Ellipse/index.tsx +245 -0
  83. package/src/components/screenshot/operations/Mosaic/index.tsx +223 -0
  84. package/src/components/screenshot/operations/Ok/index.tsx +37 -0
  85. package/src/components/screenshot/operations/Pin/index.tsx +37 -0
  86. package/src/components/screenshot/operations/Rectangle/draw.ts +80 -0
  87. package/src/components/screenshot/operations/Rectangle/index.tsx +245 -0
  88. package/src/components/screenshot/operations/Redo/index.tsx +22 -0
  89. package/src/components/screenshot/operations/Save/index.tsx +37 -0
  90. package/src/components/screenshot/operations/Scan/index.tsx +46 -0
  91. package/src/components/screenshot/operations/Search/index.tsx +39 -0
  92. package/src/components/screenshot/operations/Text/index.tsx +307 -0
  93. package/src/components/screenshot/operations/Undo/index.tsx +22 -0
  94. package/src/components/screenshot/operations/index.ts +34 -0
  95. package/src/components/screenshot/operations/utils.ts +34 -0
  96. package/src/components/screenshot/screenshots.scss +13 -0
  97. package/src/components/screenshot/types.ts +53 -0
  98. package/src/components/screenshot/useGetLoadedImage.ts +29 -0
  99. package/src/components/screenshot/var.scss +107 -0
  100. package/src/components/screenshot/zh_CN.ts +37 -0
  101. package/src/emoji/100.gif +0 -0
  102. package/src/emoji/101.gif +0 -0
  103. package/src/emoji/102.gif +0 -0
  104. package/src/emoji/103.gif +0 -0
  105. package/src/emoji/104.gif +0 -0
  106. package/src/emoji/105.gif +0 -0
  107. package/src/emoji/106.gif +0 -0
  108. package/src/emoji/107.gif +0 -0
  109. package/src/emoji/108.gif +0 -0
  110. package/src/emoji/109.gif +0 -0
  111. package/src/emoji/110.gif +0 -0
  112. package/src/emoji/111.gif +0 -0
  113. package/src/emoji/112.gif +0 -0
  114. package/src/emoji/113.gif +0 -0
  115. package/src/emoji/114.gif +0 -0
  116. package/src/emoji/115.gif +0 -0
  117. package/src/emoji/116.gif +0 -0
  118. package/src/emoji/117.gif +0 -0
  119. package/src/emoji/118.gif +0 -0
  120. package/src/emoji/119.gif +0 -0
  121. package/src/emoji/120.gif +0 -0
  122. package/src/emoji/121.gif +0 -0
  123. package/src/emoji/122.gif +0 -0
  124. package/src/emoji/123.gif +0 -0
  125. package/src/emoji/124.gif +0 -0
  126. package/src/emoji/125.gif +0 -0
  127. package/src/emoji/126.gif +0 -0
  128. package/src/emoji/127.gif +0 -0
  129. package/src/emoji/128.gif +0 -0
  130. package/src/emoji/129.gif +0 -0
  131. package/src/emoji/130.gif +0 -0
  132. package/src/emoji/131.gif +0 -0
  133. package/src/emoji/132.gif +0 -0
  134. package/src/emoji/133.gif +0 -0
  135. package/src/emoji/134.gif +0 -0
  136. package/src/emoji/135.gif +0 -0
  137. package/src/emoji/136.gif +0 -0
  138. package/src/emoji/137.gif +0 -0
  139. package/src/emoji/138.gif +0 -0
  140. package/src/emoji/139.gif +0 -0
  141. package/src/emoji/140.gif +0 -0
  142. package/src/emoji/141.gif +0 -0
  143. package/src/emoji/142.gif +0 -0
  144. package/src/emoji/143.gif +0 -0
  145. package/src/emoji/144.gif +0 -0
  146. package/src/emoji/145.gif +0 -0
  147. package/src/emoji/146.gif +0 -0
  148. package/src/emoji/147.gif +0 -0
  149. package/src/emoji/148.gif +0 -0
  150. package/src/emoji/149.gif +0 -0
  151. package/src/emoji/150.gif +0 -0
  152. package/src/emoji/151.gif +0 -0
  153. package/src/emoji/152.gif +0 -0
  154. package/src/emoji/153.gif +0 -0
  155. package/src/emoji/154.gif +0 -0
  156. package/src/emoji/155.gif +0 -0
  157. package/src/emoji/156.gif +0 -0
  158. package/src/emoji/157.gif +0 -0
  159. package/src/emoji/158.gif +0 -0
  160. package/src/emoji/159.gif +0 -0
  161. package/src/emoji/160.gif +0 -0
  162. package/src/emoji/161.gif +0 -0
  163. package/src/emoji/162.gif +0 -0
  164. package/src/emoji/163.gif +0 -0
  165. package/src/emoji/164.gif +0 -0
  166. package/src/emoji/165.gif +0 -0
  167. package/src/emoji/166.gif +0 -0
  168. package/src/emoji/167.gif +0 -0
  169. package/src/emoji/168.gif +0 -0
  170. package/src/emoji/169.gif +0 -0
  171. package/src/emoji/170.gif +0 -0
  172. package/src/emoji/171.gif +0 -0
  173. package/src/emoji/172.gif +0 -0
  174. package/src/emoji/173.gif +0 -0
  175. package/src/emoji/174.gif +0 -0
  176. package/src/emoji/175.gif +0 -0
  177. package/src/emoji/176.gif +0 -0
  178. package/src/emoji/177.gif +0 -0
  179. package/src/emoji/178.gif +0 -0
  180. package/src/emoji/179.gif +0 -0
  181. package/src/emoji/180.gif +0 -0
  182. package/src/emoji/181.gif +0 -0
  183. package/src/emoji/182.gif +0 -0
  184. package/src/emoji/183.gif +0 -0
  185. package/src/emoji/184.gif +0 -0
  186. package/src/emoji/185.gif +0 -0
  187. package/src/emoji/186.gif +0 -0
  188. package/src/emoji/187.gif +0 -0
  189. package/src/emoji/188.gif +0 -0
  190. package/src/emoji/189.gif +0 -0
  191. package/src/emoji/190.gif +0 -0
  192. package/src/emoji/191.gif +0 -0
  193. package/src/emoji/192.gif +0 -0
  194. package/src/emoji/193.gif +0 -0
  195. package/src/emoji/194.gif +0 -0
  196. package/src/emoji/195.gif +0 -0
  197. package/src/emoji/196.gif +0 -0
  198. package/src/emoji/197.gif +0 -0
  199. package/src/emoji/198.gif +0 -0
  200. package/src/emoji/199.gif +0 -0
  201. package/src/emoji/200.png +0 -0
  202. package/src/emoji/201.png +0 -0
  203. package/src/emoji/202.png +0 -0
  204. package/src/emoji/203.png +0 -0
  205. package/src/emoji/204.png +0 -0
  206. package/src/emoji/205.png +0 -0
  207. package/src/emoji/206.png +0 -0
  208. package/src/emoji/207.png +0 -0
  209. package/src/emoji/208.png +0 -0
  210. package/src/emoji/209.png +0 -0
  211. package/src/emoji/210.png +0 -0
  212. package/src/emoji/211.png +0 -0
  213. package/src/emoji/212.png +0 -0
  214. package/src/emoji/213.png +0 -0
  215. package/src/emoji/214.png +0 -0
  216. package/src/emoji/215.png +0 -0
  217. package/src/emoji/216.png +0 -0
  218. package/src/emoji/217.png +0 -0
  219. package/src/emoji/218.png +0 -0
  220. package/src/emoji/219.png +0 -0
  221. package/src/emoji2/101--Streamline-The-Team.png +0 -0
  222. package/src/emoji2/128--Streamline-The-Team.png +0 -0
  223. package/src/emoji2/134--Streamline-The-Team.png +0 -0
  224. package/src/emoji2/173--Streamline-The-Team.png +0 -0
  225. package/src/emoji2/Airplane--Streamline-Emoji.svg +24 -0
  226. package/src/emoji2/Alien--Streamline-Emoji.svg +21 -0
  227. package/src/emoji2/Amazed-Face--Streamline-Emoji.svg +16 -0
  228. package/src/emoji2/Amusing-Face--Streamline-Emoji.svg +20 -0
  229. package/src/emoji2/Anguished-Face--Streamline-Emoji.svg +19 -0
  230. package/src/emoji2/Anxious-Face--Streamline-Emoji.svg +17 -0
  231. package/src/emoji2/Astonished-Face--Streamline-Emoji.svg +20 -0
  232. package/src/emoji2/Backhand-Index-Pointing-Down-1--Streamline-Emoji.svg +12 -0
  233. package/src/emoji2/Backhand-Index-Pointing-Left-1--Streamline-Emoji.svg +13 -0
  234. package/src/emoji2/Backhand-Index-Pointing-Right-1--Streamline-Emoji.svg +13 -0
  235. package/src/emoji2/Backhand-Index-Pointing-Up-1--Streamline-Emoji.svg +14 -0
  236. package/src/emoji2/Bar-Chart--Streamline-Emoji.svg +22 -0
  237. package/src/emoji2/Beaming-Face-With-Smiling-Eyes--Streamline-Emoji.svg +20 -0
  238. package/src/emoji2/Boy-1--Streamline-Emoji.svg +17 -0
  239. package/src/emoji2/Boy-2--Streamline-Emoji.svg +17 -0
  240. package/src/emoji2/Boy-3--Streamline-Emoji.svg +17 -0
  241. package/src/emoji2/Broken-Heart--Streamline-Emoji.svg +12 -0
  242. package/src/emoji2/Clapping-Hands-1--Streamline-Emoji.svg +23 -0
  243. package/src/emoji2/Clinking-Glasses-2--Streamline-Emoji.svg +43 -0
  244. package/src/emoji2/Confounded-Face--Streamline-Emoji.svg +17 -0
  245. package/src/emoji2/Confused-Face--Streamline-Emoji.svg +15 -0
  246. package/src/emoji2/Construction-Worker--Streamline-Emoji.svg +21 -0
  247. package/src/emoji2/Couple-With-Heart-Woman-Man-1--Streamline-Emoji.svg +40 -0
  248. package/src/emoji2/Couple-With-Heart-Woman-Man-2--Streamline-Emoji.svg +40 -0
  249. package/src/emoji2/Cowboy-Hat-Face--Streamline-Emoji.svg +22 -0
  250. package/src/emoji2/Crazy-Face--Streamline-Emoji.svg +25 -0
  251. package/src/emoji2/Crossed-Fingers-1--Streamline-Emoji.svg +25 -0
  252. package/src/emoji2/Crown--Streamline-Emoji.svg +35 -0
  253. package/src/emoji2/Crying-Face--Streamline-Emoji.svg +26 -0
  254. package/src/emoji2/Delivery-Truck--Streamline-Emoji.svg +31 -0
  255. package/src/emoji2/Determined-Face--Streamline-Emoji.svg +25 -0
  256. package/src/emoji2/Disappointed-Face--Streamline-Emoji.svg +15 -0
  257. package/src/emoji2/Dizzy-Face--Streamline-Emoji.svg +20 -0
  258. package/src/emoji2/Downcast-Face-With-Sweat--Streamline-Emoji.svg +18 -0
  259. package/src/emoji2/Drooling-Face-1--Streamline-Emoji.svg +19 -0
  260. package/src/emoji2/Drooling-Face-2--Streamline-Emoji.svg +18 -0
  261. package/src/emoji2/Ear--Streamline-Emoji.svg +14 -0
  262. package/src/emoji2/Exclamation-Mark--Streamline-Emoji.svg +12 -0
  263. package/src/emoji2/Exploding-Head--Streamline-Emoji.svg +24 -0
  264. package/src/emoji2/Expressionless-Face--Streamline-Emoji.svg +15 -0
  265. package/src/emoji2/Face-Blowing-A-Kiss--Streamline-Emoji.svg +18 -0
  266. package/src/emoji2/Face-Savoring-Food--Streamline-Emoji.svg +18 -0
  267. package/src/emoji2/Face-Screaming-In-Fear--Streamline-Emoji.svg +18 -0
  268. package/src/emoji2/Face-Vomiting--Streamline-Emoji.svg +28 -0
  269. package/src/emoji2/Face-With-Head-Bandage--Streamline-Emoji.svg +25 -0
  270. package/src/emoji2/Face-With-Medical-Mask--Streamline-Emoji.svg +23 -0
  271. package/src/emoji2/Face-With-Monocle--Streamline-Emoji.svg +26 -0
  272. package/src/emoji2/Face-With-Raised-Eyebrow--Streamline-Emoji.svg +17 -0
  273. package/src/emoji2/Face-With-Rolling-Eyes--Streamline-Emoji.svg +17 -0
  274. package/src/emoji2/Face-With-Steam-From-Nose--Streamline-Emoji.svg +19 -0
  275. package/src/emoji2/Face-With-Symbols-On-Mouth--Streamline-Emoji.svg +22 -0
  276. package/src/emoji2/Face-With-Tears-Of-Joy--Streamline-Emoji.svg +34 -0
  277. package/src/emoji2/Face-With-Thermometer--Streamline-Emoji.svg +31 -0
  278. package/src/emoji2/Face-With-Tongue--Streamline-Emoji.svg +18 -0
  279. package/src/emoji2/Face-Without-Mouth--Streamline-Emoji.svg +14 -0
  280. package/src/emoji2/Fearful-Face--Streamline-Emoji.svg +18 -0
  281. package/src/emoji2/Flexed-Biceps-1--Streamline-Emoji.svg +13 -0
  282. package/src/emoji2/Flushed-Face--Streamline-Emoji.svg +19 -0
  283. package/src/emoji2/Folded-Hands-1--Streamline-Emoji.svg +29 -0
  284. package/src/emoji2/Frowning-Face--Streamline-Emoji.svg +15 -0
  285. package/src/emoji2/Fuel-Pump--Streamline-Emoji.svg +30 -0
  286. package/src/emoji2/Girl-1--Streamline-Emoji.svg +23 -0
  287. package/src/emoji2/Glasses-1--Streamline-Emoji.svg +27 -0
  288. package/src/emoji2/Grimacing-Face--Streamline-Emoji.svg +19 -0
  289. package/src/emoji2/Grinning-Cat-Face--Streamline-Emoji.svg +32 -0
  290. package/src/emoji2/Grinning-Face--Streamline-Emoji.svg +16 -0
  291. package/src/emoji2/Grinning-Face-With-Sweat--Streamline-Emoji.svg +19 -0
  292. package/src/emoji2/Grinning-Squinting-Face--Streamline-Emoji.svg +16 -0
  293. package/src/emoji2/Hand-With-Fingers-Splayed-1--Streamline-Emoji.svg +14 -0
  294. package/src/emoji2/Heart-Suit--Streamline-Emoji.svg +9 -0
  295. package/src/emoji2/Hushed-Face-1--Streamline-Emoji.svg +17 -0
  296. package/src/emoji2/Hushed-Face-2--Streamline-Emoji.svg +15 -0
  297. package/src/emoji2/Index-Pointing-Up-1--Streamline-Emoji.svg +17 -0
  298. package/src/emoji2/Kissing-Face-With-Closed-Eyes--Streamline-Emoji.svg +18 -0
  299. package/src/emoji2/Loudly-Crying-Face--Streamline-Emoji.svg +16 -0
  300. package/src/emoji2/Lying-Face--Streamline-Emoji.svg +15 -0
  301. package/src/emoji2/Man-1--Streamline-Emoji.svg +17 -0
  302. package/src/emoji2/Man-Facepalming-1--Streamline-Emoji.svg +21 -0
  303. package/src/emoji2/Man-Gesturing-No-1--Streamline-Emoji.svg +34 -0
  304. package/src/emoji2/Man-Gesturing-Ok-1--Streamline-Emoji.svg +25 -0
  305. package/src/emoji2/Man-Health-Worker-1--Streamline-Emoji.svg +41 -0
  306. package/src/emoji2/Man-Raising-Hand-1--Streamline-Emoji.svg +26 -0
  307. package/src/emoji2/Man-Shrugging-1--Streamline-Emoji.svg +31 -0
  308. package/src/emoji2/Money-Mouth-Face-2--Streamline-Emoji.svg +30 -0
  309. package/src/emoji2/Mouth--Streamline-Emoji.svg +12 -0
  310. package/src/emoji2/Nauseated-Face-2--Streamline-Emoji.svg +19 -0
  311. package/src/emoji2/Neutral-Face--Streamline-Emoji.svg +15 -0
  312. package/src/emoji2/Ok-Hand-1--Streamline-Emoji.svg +14 -0
  313. package/src/emoji2/Old-Man-1--Streamline-Emoji.svg +27 -0
  314. package/src/emoji2/Old-Woman-1--Streamline-Emoji.svg +23 -0
  315. package/src/emoji2/Oncoming-Fist-1--Streamline-Emoji.svg +15 -0
  316. package/src/emoji2/Person-Wearing-Turban-2--Streamline-Emoji.svg +20 -0
  317. package/src/emoji2/Pile-Of-Poo--Streamline-Emoji.svg +15 -0
  318. package/src/emoji2/Police-Car-Light--Streamline-Emoji.svg +26 -0
  319. package/src/emoji2/Rocket--Streamline-Emoji.svg +32 -0
  320. package/src/emoji2/Sailboat--Streamline-Emoji.svg +18 -0
  321. package/src/emoji2/Shaved-Ice--Streamline-Emoji.svg +21 -0
  322. package/src/emoji2/Shortcake-2--Streamline-Emoji.svg +18 -0
  323. package/src/emoji2/Shushing-Face--Streamline-Emoji.svg +21 -0
  324. package/src/emoji2/Sign-Of-The-Horns-1--Streamline-Emoji.svg +19 -0
  325. package/src/emoji2/Sleeping-Face--Streamline-Emoji.svg +21 -0
  326. package/src/emoji2/Slightly-Smiling-Face--Streamline-Emoji.svg +15 -0
  327. package/src/emoji2/Smiling-Face-With-Halo--Streamline-Emoji.svg +20 -0
  328. package/src/emoji2/Smiling-Face-With-Heart-Eyes--Streamline-Emoji.svg +21 -0
  329. package/src/emoji2/Smirking-Face--Streamline-Emoji.svg +17 -0
  330. package/src/emoji2/Sun-With-Face--Streamline-Emoji.svg +24 -0
  331. package/src/emoji2/Thumbs-Down-1--Streamline-Emoji.svg +20 -0
  332. package/src/emoji2/Thumbs-Up-1--Streamline-Emoji.svg +19 -0
  333. package/src/emoji2/Winking-Face--Streamline-Emoji.svg +18 -0
  334. package/src/emoji2/Woman-Gesturing-No-1--Streamline-Emoji.svg +34 -0
  335. package/src/emoji2/Woman-Gesturing-Ok-2--Streamline-Emoji.svg +25 -0
  336. package/src/emoji2/Woman-Raising-Hand-1--Streamline-Emoji.svg +26 -0
  337. package/src/emoji2/Womans-Sandal--Streamline-Emoji.svg +13 -0
  338. package/src/emoji2/Worried-Face--Streamline-Emoji.svg +17 -0
  339. package/src/emoji2/Writing-Hand-1--Streamline-Emoji.svg +17 -0
  340. package/src/emoji2/Zipper-Mouth-Face--Streamline-Emoji.svg +21 -0
  341. package/src/index.js +19 -0
  342. package/src/services/burn-after-read-service.js +313 -0
  343. package/src/services/burn-after-read-service.test.js +325 -0
  344. package/src/services/dify-api.js +338 -0
  345. package/src/services/dify-api.test.js +376 -0
  346. package/src/services/scheduled-send-service.js +311 -0
  347. package/src/services/scheduled-send-service.test.js +317 -0
  348. package/src/styles/index.css +2368 -0
  349. package/src/utils/emoji.js +125 -0
  350. package/src/utils/emojiData.js +267 -0
  351. package/src/utils/eventEmitter.js +114 -0
  352. package/src/utils/state.js +224 -0
  353. package/src/utils/state.test.js +198 -0
  354. package/src/utils/storage.js +122 -0
  355. package/src/utils/storage.test.js +162 -0
  356. package/src/utils/validation.js +249 -0
@@ -0,0 +1,4 @@
1
+ export type { Bounds } from "./types";
2
+ export type { Lang } from "./zh_CN";
3
+ export { default } from "./";
4
+ export type { ScreenshotsProps } from "./";
@@ -0,0 +1,35 @@
1
+ import { useCallback } from 'react'
2
+ import { Bounds } from '../types'
3
+ import useDispatcher from './useDispatcher'
4
+ import useStore from './useStore'
5
+
6
+ export interface BoundsDispatcher {
7
+ set: (bounds: Bounds) => void
8
+ reset: () => void
9
+ }
10
+
11
+ export type BoundsValueDispatcher = [Bounds | null, BoundsDispatcher]
12
+
13
+ export default function useBounds (): BoundsValueDispatcher {
14
+ const { bounds } = useStore()
15
+ const { setBounds } = useDispatcher()
16
+
17
+ const set = useCallback(
18
+ (bounds: Bounds) => {
19
+ setBounds?.(bounds)
20
+ },
21
+ [setBounds]
22
+ )
23
+
24
+ const reset = useCallback(() => {
25
+ setBounds?.(null)
26
+ }, [setBounds])
27
+
28
+ return [
29
+ bounds,
30
+ {
31
+ set,
32
+ reset
33
+ }
34
+ ]
35
+ }
@@ -0,0 +1,17 @@
1
+ import { useCallback } from 'react'
2
+ import useDispatcher from './useDispatcher'
3
+
4
+ export type CallDispatcher = <T extends unknown[]>(funcName: string, ...args: T) => void
5
+
6
+ export default function useCall (): CallDispatcher {
7
+ const dispatcher = useDispatcher()
8
+
9
+ const call = useCallback(
10
+ <T extends unknown[]>(funcName: string, ...args: T) => {
11
+ dispatcher.call?.(funcName, ...args)
12
+ },
13
+ [dispatcher]
14
+ )
15
+
16
+ return call
17
+ }
@@ -0,0 +1,8 @@
1
+ import useStore from './useStore'
2
+ import { CanvasContextRef } from '../types'
3
+
4
+ export default function useCanvasContextRef (): CanvasContextRef {
5
+ const { canvasContextRef } = useStore()
6
+
7
+ return canvasContextRef
8
+ }
@@ -0,0 +1,13 @@
1
+ import { useEffect } from 'react'
2
+ import useEmiter from '../hooks/useEmiter'
3
+
4
+ export default function useCanvasMousedown (onMousedown: (e: MouseEvent) => unknown): void {
5
+ const emiter = useEmiter()
6
+
7
+ useEffect(() => {
8
+ emiter.on('mousedown', onMousedown)
9
+ return () => {
10
+ emiter.off('mousedown', onMousedown)
11
+ }
12
+ }, [onMousedown, emiter])
13
+ }
@@ -0,0 +1,13 @@
1
+ import { useEffect } from 'react'
2
+ import useEmiter from '../hooks/useEmiter'
3
+
4
+ export default function useCanvasMousemove (onMousemove: (e: MouseEvent) => unknown): void {
5
+ const emiter = useEmiter()
6
+
7
+ useEffect(() => {
8
+ emiter.on('mousemove', onMousemove)
9
+ return () => {
10
+ emiter.off('mousemove', onMousemove)
11
+ }
12
+ }, [onMousemove, emiter])
13
+ }
@@ -0,0 +1,13 @@
1
+ import { useEffect } from 'react'
2
+ import useEmiter from '../hooks/useEmiter'
3
+
4
+ export default function useCanvasMouseup (onMouseup: (e: MouseEvent) => unknown): void {
5
+ const emiter = useEmiter()
6
+
7
+ useEffect(() => {
8
+ emiter.on('mouseup', onMouseup)
9
+ return () => {
10
+ emiter.off('mouseup', onMouseup)
11
+ }
12
+ }, [onMouseup, emiter])
13
+ }
@@ -0,0 +1,34 @@
1
+ import { useCallback } from 'react'
2
+ import useDispatcher from './useDispatcher'
3
+ import useStore from './useStore'
4
+
5
+ export interface CursorDispatcher {
6
+ set: (cursor: string) => void;
7
+ reset: () => void;
8
+ }
9
+
10
+ export type CursorValueDispatcher = [string | undefined, CursorDispatcher];
11
+
12
+ export default function useCursor (): CursorValueDispatcher {
13
+ const { cursor } = useStore()
14
+ const { setCursor } = useDispatcher()
15
+
16
+ const set = useCallback(
17
+ (cursor: string) => {
18
+ setCursor?.(cursor)
19
+ },
20
+ [setCursor]
21
+ )
22
+
23
+ const reset = useCallback(() => {
24
+ setCursor?.('move')
25
+ }, [setCursor])
26
+
27
+ return [
28
+ cursor,
29
+ {
30
+ set,
31
+ reset
32
+ }
33
+ ]
34
+ }
@@ -0,0 +1,8 @@
1
+ import { useContext } from 'react'
2
+ import ScreenshotsContext, { ScreenshotsContextDispatcher } from '../ScreenshotsContext'
3
+
4
+ export default function useDispatcher (): ScreenshotsContextDispatcher {
5
+ const { dispatcher } = useContext(ScreenshotsContext)
6
+
7
+ return dispatcher
8
+ }
@@ -0,0 +1,16 @@
1
+ import { useEffect } from 'react'
2
+ import useEmiter from '../hooks/useEmiter'
3
+ import { HistoryItemSource } from '../types'
4
+
5
+ export default function useDrawSelect (
6
+ onDrawSelect: (action: HistoryItemSource<unknown, unknown>, e: MouseEvent) => unknown
7
+ ): void {
8
+ const emiter = useEmiter()
9
+
10
+ useEffect(() => {
11
+ emiter.on('drawselect', onDrawSelect)
12
+ return () => {
13
+ emiter.off('drawselect', onDrawSelect)
14
+ }
15
+ }, [onDrawSelect, emiter])
16
+ }
@@ -0,0 +1,61 @@
1
+ import { useCallback } from 'react'
2
+ import { EmiterListener } from '../types'
3
+ import useStore from './useStore'
4
+
5
+ export interface EmiterDispatcher {
6
+ on: (event: string, listener: EmiterListener) => void
7
+ off: (event: string, listener: EmiterListener) => void
8
+ emit: (event: string, ...args: unknown[]) => void
9
+ reset: () => void
10
+ }
11
+
12
+ export default function useEmiter (): EmiterDispatcher {
13
+ const { emiterRef } = useStore()
14
+
15
+ const on = useCallback(
16
+ (event: string, listener: EmiterListener) => {
17
+ const emiter = emiterRef.current
18
+ if (Array.isArray(emiter[event])) {
19
+ emiter[event].push(listener)
20
+ } else {
21
+ emiter[event] = [listener]
22
+ }
23
+ },
24
+ [emiterRef]
25
+ )
26
+
27
+ const off = useCallback(
28
+ (event: string, listener: EmiterListener) => {
29
+ const emiter = emiterRef.current
30
+ if (Array.isArray(emiter[event])) {
31
+ const index = emiter[event].findIndex(item => item === listener)
32
+ if (index !== -1) {
33
+ emiter[event].splice(index, 1)
34
+ }
35
+ }
36
+ },
37
+ [emiterRef]
38
+ )
39
+
40
+ const emit = useCallback(
41
+ (event: string, ...args: unknown[]) => {
42
+ const emiter = emiterRef.current
43
+
44
+ if (Array.isArray(emiter[event])) {
45
+ emiter[event].forEach(listener => listener(...args))
46
+ }
47
+ },
48
+ [emiterRef]
49
+ )
50
+
51
+ const reset = useCallback(() => {
52
+ emiterRef.current = {}
53
+ }, [emiterRef])
54
+
55
+ return {
56
+ on,
57
+ off,
58
+ emit,
59
+ reset
60
+ }
61
+ }
@@ -0,0 +1,160 @@
1
+ import { useCallback } from 'react'
2
+ import { History, HistoryItem, HistoryItemType } from '../types'
3
+ import useDispatcher from './useDispatcher'
4
+ import useStore from './useStore'
5
+
6
+ export interface HistoryValue extends History {
7
+ top?: HistoryItem<unknown, unknown>
8
+ }
9
+
10
+ export interface HistoryDispatcher {
11
+ push: <S, E>(action: HistoryItem<S, E>) => void
12
+ pop: () => void
13
+ undo: () => void
14
+ redo: () => void
15
+ set: (history: History) => void
16
+ select: <S, E>(action: HistoryItem<S, E>) => void
17
+ clearSelect: () => void
18
+ reset: () => void
19
+ }
20
+
21
+ export type HistoryValueDispatcher = [HistoryValue, HistoryDispatcher]
22
+
23
+ export default function useHistory (): HistoryValueDispatcher {
24
+ const { history } = useStore()
25
+ const { setHistory } = useDispatcher()
26
+
27
+ const push = useCallback(
28
+ <S, E>(action: HistoryItem<S, E>) => {
29
+ const { index, stack } = history
30
+
31
+ stack.forEach(item => {
32
+ if (item.type === HistoryItemType.Source) {
33
+ item.isSelected = false
34
+ }
35
+ })
36
+
37
+ if (action.type === HistoryItemType.Source) {
38
+ action.isSelected = true
39
+ } else if (action.type === HistoryItemType.Edit) {
40
+ action.source.isSelected = true
41
+ }
42
+
43
+ stack.splice(index + 1)
44
+ stack.push(action)
45
+
46
+ setHistory?.({
47
+ index: stack.length - 1,
48
+ stack
49
+ })
50
+ },
51
+ [history, setHistory]
52
+ )
53
+
54
+ const pop = useCallback(() => {
55
+ const { stack } = history
56
+
57
+ stack.pop()
58
+
59
+ setHistory?.({
60
+ index: stack.length - 1,
61
+ stack
62
+ })
63
+ }, [history, setHistory])
64
+
65
+ const undo = useCallback(() => {
66
+ const { index, stack } = history
67
+
68
+ const item = stack[index]
69
+
70
+ if (item) {
71
+ if (item.type === HistoryItemType.Source) {
72
+ item.isSelected = false
73
+ } else if (item.type === HistoryItemType.Edit) {
74
+ item.source.editHistory.pop()
75
+ }
76
+ }
77
+
78
+ setHistory?.({
79
+ index: index <= 0 ? -1 : index - 1,
80
+ stack
81
+ })
82
+ }, [history, setHistory])
83
+
84
+ const redo = useCallback(() => {
85
+ const { index, stack } = history
86
+
87
+ const item = stack[index + 1]
88
+
89
+ if (item) {
90
+ if (item.type === HistoryItemType.Source) {
91
+ item.isSelected = false
92
+ } else if (item.type === HistoryItemType.Edit) {
93
+ item.source.editHistory.push(item)
94
+ }
95
+ }
96
+
97
+ setHistory?.({
98
+ index: index >= stack.length - 1 ? stack.length - 1 : index + 1,
99
+ stack
100
+ })
101
+ }, [history, setHistory])
102
+
103
+ const set = useCallback(
104
+ (history: History) => {
105
+ setHistory?.({ ...history })
106
+ },
107
+ [setHistory]
108
+ )
109
+
110
+ const select = useCallback(
111
+ <S, E>(action: HistoryItem<S, E>) => {
112
+ history.stack.forEach(item => {
113
+ if (item.type === HistoryItemType.Source) {
114
+ if (item === action) {
115
+ item.isSelected = true
116
+ } else {
117
+ item.isSelected = false
118
+ }
119
+ }
120
+ })
121
+ setHistory?.({ ...history })
122
+ },
123
+ [history, setHistory]
124
+ )
125
+
126
+ const clearSelect = useCallback(() => {
127
+ history.stack.forEach(item => {
128
+ if (item.type === HistoryItemType.Source) {
129
+ item.isSelected = false
130
+ }
131
+ })
132
+
133
+ setHistory?.({ ...history })
134
+ }, [history, setHistory])
135
+
136
+ const reset = useCallback(() => {
137
+ setHistory?.({
138
+ index: -1,
139
+ stack: []
140
+ })
141
+ }, [setHistory])
142
+
143
+ return [
144
+ {
145
+ index: history.index,
146
+ stack: history.stack,
147
+ top: history.stack.slice(history.index, history.index + 1)[0]
148
+ },
149
+ {
150
+ push,
151
+ pop,
152
+ undo,
153
+ redo,
154
+ set,
155
+ select,
156
+ clearSelect,
157
+ reset
158
+ }
159
+ ]
160
+ }
@@ -0,0 +1,8 @@
1
+ import { Lang } from '../zh_CN'
2
+ import useStore from './useStore'
3
+
4
+ export default function useLang (): Lang {
5
+ const { lang } = useStore()
6
+
7
+ return lang
8
+ }
@@ -0,0 +1,37 @@
1
+ import { useCallback } from 'react'
2
+ import useDispatcher from './useDispatcher'
3
+ import useStore from './useStore'
4
+
5
+ export interface OperationDispatcher {
6
+ set: (operation: string) => void;
7
+ reset: () => void;
8
+ }
9
+
10
+ export type OperationValueDispatcher = [
11
+ string | undefined,
12
+ OperationDispatcher
13
+ ];
14
+
15
+ export default function useOperation (): OperationValueDispatcher {
16
+ const { operation } = useStore()
17
+ const { setOperation } = useDispatcher()
18
+
19
+ const set = useCallback(
20
+ (operation: string) => {
21
+ setOperation?.(operation)
22
+ },
23
+ [setOperation]
24
+ )
25
+
26
+ const reset = useCallback(() => {
27
+ setOperation?.(undefined)
28
+ }, [setOperation])
29
+
30
+ return [
31
+ operation,
32
+ {
33
+ set,
34
+ reset
35
+ }
36
+ ]
37
+ }
@@ -0,0 +1,26 @@
1
+ import { useCallback } from 'react'
2
+ import useBounds from './useBounds'
3
+ import useCursor from './useCursor'
4
+ import useEmiter from './useEmiter'
5
+ import useHistory from './useHistory'
6
+ import useOperation from './useOperation'
7
+
8
+ export type ResetDispatcher = () => void
9
+
10
+ export default function useReset (): ResetDispatcher {
11
+ const emiter = useEmiter()
12
+ const [, boundsDispatcher] = useBounds()
13
+ const [, cursorDispatcher] = useCursor()
14
+ const [, historyDispatcher] = useHistory()
15
+ const [, operatioDispatcher] = useOperation()
16
+
17
+ const reset = useCallback(() => {
18
+ emiter.reset()
19
+ historyDispatcher.reset()
20
+ boundsDispatcher.reset()
21
+ cursorDispatcher.reset()
22
+ operatioDispatcher.reset()
23
+ }, [emiter, historyDispatcher, boundsDispatcher, cursorDispatcher, operatioDispatcher])
24
+
25
+ return reset
26
+ }
@@ -0,0 +1,8 @@
1
+ import { useContext } from 'react'
2
+ import ScreenshotsContext, { ScreenshotsContextStore } from '../ScreenshotsContext'
3
+
4
+ export default function useStore (): ScreenshotsContextStore {
5
+ const { store } = useContext(ScreenshotsContext)
6
+
7
+ return store
8
+ }
@@ -0,0 +1,88 @@
1
+ @font-face {
2
+ font-family: 'screenshots-icon'; /* Project id 572327 */
3
+ src: url('iconfont.woff2') format('woff2'), url('iconfont.woff') format('woff'),
4
+ url('iconfont.ttf') format('truetype');
5
+ }
6
+
7
+ [class^='icon-'],
8
+ [class*=' icon-'] {
9
+ font-family: 'screenshots-icon' !important;
10
+ font-style: normal;
11
+ line-height: 1;
12
+ -webkit-font-smoothing: antialiased;
13
+ -moz-osx-font-smoothing: grayscale;
14
+ }
15
+
16
+ .icon-ok:before {
17
+ content: '\e001';
18
+ }
19
+
20
+ .icon-cancel:before {
21
+ content: '\e002';
22
+ }
23
+
24
+ .icon-save:before {
25
+ content: '\e003';
26
+ }
27
+
28
+ .icon-redo:before {
29
+ content: '\e004';
30
+ }
31
+
32
+ .icon-undo:before {
33
+ content: '\e005';
34
+ }
35
+
36
+ .icon-mosaic:before {
37
+ content: '\e006';
38
+ }
39
+
40
+ .icon-text:before {
41
+ content: '\e007';
42
+ }
43
+
44
+ .icon-brush:before {
45
+ content: '\e008';
46
+ }
47
+
48
+ .icon-arrow:before {
49
+ content: '\e009';
50
+ }
51
+
52
+ .icon-ellipse:before {
53
+ content: '\e00a';
54
+ }
55
+
56
+ .icon-rectangle:before {
57
+ content: '\e00b';
58
+ }
59
+
60
+ .icon-scan:before {
61
+ content: '';
62
+ background: transparent url(/imgs/svg/scan.svg) no-repeat 0px 0px;
63
+ background-size: 22px;
64
+ background-position: center;
65
+ width: 35px;
66
+ height: 35px;
67
+ display: inline-block;
68
+ }
69
+
70
+ .icon-search:before {
71
+ content: '';
72
+ background: transparent url(/imgs/svg/search.svg) no-repeat 0px 0px;
73
+ background-size: 22px;
74
+ background-position: center;
75
+ width: 35px;
76
+ height: 35px;
77
+ display: inline-block;
78
+ }
79
+
80
+ .icon-pin:before {
81
+ content: '';
82
+ background: transparent url(/imgs/svg/pin.svg) no-repeat 0px 0px;
83
+ background-size: 22px;
84
+ background-position: center;
85
+ width: 35px;
86
+ height: 35px;
87
+ display: inline-block;
88
+ }