@bigbluebutton/tldraw 2.0.0-alpha.19

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (1357) hide show
  1. package/LICENSE +190 -0
  2. package/dist-cjs/index.d.ts +2954 -0
  3. package/dist-cjs/index.js +216 -0
  4. package/dist-cjs/index.js.map +7 -0
  5. package/dist-cjs/lib/Tldraw.js +136 -0
  6. package/dist-cjs/lib/Tldraw.js.map +7 -0
  7. package/dist-cjs/lib/canvas/TldrawCropHandles.js +164 -0
  8. package/dist-cjs/lib/canvas/TldrawCropHandles.js.map +7 -0
  9. package/dist-cjs/lib/canvas/TldrawHandles.js +37 -0
  10. package/dist-cjs/lib/canvas/TldrawHandles.js.map +7 -0
  11. package/dist-cjs/lib/canvas/TldrawHoveredShapeIndicator.js +42 -0
  12. package/dist-cjs/lib/canvas/TldrawHoveredShapeIndicator.js.map +7 -0
  13. package/dist-cjs/lib/canvas/TldrawScribble.js +72 -0
  14. package/dist-cjs/lib/canvas/TldrawScribble.js.map +7 -0
  15. package/dist-cjs/lib/canvas/TldrawSelectionBackground.js +44 -0
  16. package/dist-cjs/lib/canvas/TldrawSelectionBackground.js.map +7 -0
  17. package/dist-cjs/lib/canvas/TldrawSelectionForeground.js +509 -0
  18. package/dist-cjs/lib/canvas/TldrawSelectionForeground.js.map +7 -0
  19. package/dist-cjs/lib/defaultExternalContentHandlers.js +400 -0
  20. package/dist-cjs/lib/defaultExternalContentHandlers.js.map +7 -0
  21. package/dist-cjs/lib/defaultShapeTools.js +42 -0
  22. package/dist-cjs/lib/defaultShapeTools.js.map +7 -0
  23. package/dist-cjs/lib/defaultShapeUtils.js +50 -0
  24. package/dist-cjs/lib/defaultShapeUtils.js.map +7 -0
  25. package/dist-cjs/lib/defaultSideEffects.js +69 -0
  26. package/dist-cjs/lib/defaultSideEffects.js.map +7 -0
  27. package/dist-cjs/lib/defaultTools.js +30 -0
  28. package/dist-cjs/lib/defaultTools.js.map +7 -0
  29. package/dist-cjs/lib/shapes/arrow/ArrowShapeTool.js +33 -0
  30. package/dist-cjs/lib/shapes/arrow/ArrowShapeTool.js.map +7 -0
  31. package/dist-cjs/lib/shapes/arrow/ArrowShapeUtil.js +805 -0
  32. package/dist-cjs/lib/shapes/arrow/ArrowShapeUtil.js.map +7 -0
  33. package/dist-cjs/lib/shapes/arrow/components/ArrowTextLabel.js +114 -0
  34. package/dist-cjs/lib/shapes/arrow/components/ArrowTextLabel.js.map +7 -0
  35. package/dist-cjs/lib/shapes/arrow/toolStates/Idle.js +53 -0
  36. package/dist-cjs/lib/shapes/arrow/toolStates/Idle.js.map +7 -0
  37. package/dist-cjs/lib/shapes/arrow/toolStates/Pointing.js +182 -0
  38. package/dist-cjs/lib/shapes/arrow/toolStates/Pointing.js.map +7 -0
  39. package/dist-cjs/lib/shapes/bookmark/BookmarkShapeUtil.js +163 -0
  40. package/dist-cjs/lib/shapes/bookmark/BookmarkShapeUtil.js.map +7 -0
  41. package/dist-cjs/lib/shapes/draw/DrawShapeTool.js +37 -0
  42. package/dist-cjs/lib/shapes/draw/DrawShapeTool.js.map +7 -0
  43. package/dist-cjs/lib/shapes/draw/DrawShapeUtil.js +243 -0
  44. package/dist-cjs/lib/shapes/draw/DrawShapeUtil.js.map +7 -0
  45. package/dist-cjs/lib/shapes/draw/getPath.js +102 -0
  46. package/dist-cjs/lib/shapes/draw/getPath.js.map +7 -0
  47. package/dist-cjs/lib/shapes/draw/toolStates/Drawing.js +556 -0
  48. package/dist-cjs/lib/shapes/draw/toolStates/Drawing.js.map +7 -0
  49. package/dist-cjs/lib/shapes/draw/toolStates/Idle.js +37 -0
  50. package/dist-cjs/lib/shapes/draw/toolStates/Idle.js.map +7 -0
  51. package/dist-cjs/lib/shapes/embed/EmbedShapeUtil.js +192 -0
  52. package/dist-cjs/lib/shapes/embed/EmbedShapeUtil.js.map +7 -0
  53. package/dist-cjs/lib/shapes/frame/FrameShapeTool.js +66 -0
  54. package/dist-cjs/lib/shapes/frame/FrameShapeTool.js.map +7 -0
  55. package/dist-cjs/lib/shapes/frame/FrameShapeUtil.js +234 -0
  56. package/dist-cjs/lib/shapes/frame/FrameShapeUtil.js.map +7 -0
  57. package/dist-cjs/lib/shapes/frame/components/FrameHeading.js +106 -0
  58. package/dist-cjs/lib/shapes/frame/components/FrameHeading.js.map +7 -0
  59. package/dist-cjs/lib/shapes/frame/components/FrameLabelInput.js +101 -0
  60. package/dist-cjs/lib/shapes/frame/components/FrameLabelInput.js.map +7 -0
  61. package/dist-cjs/lib/shapes/geo/GeoShapeTool.js +33 -0
  62. package/dist-cjs/lib/shapes/geo/GeoShapeTool.js.map +7 -0
  63. package/dist-cjs/lib/shapes/geo/GeoShapeUtil.js +999 -0
  64. package/dist-cjs/lib/shapes/geo/GeoShapeUtil.js.map +7 -0
  65. package/dist-cjs/lib/shapes/geo/cloudOutline.js +288 -0
  66. package/dist-cjs/lib/shapes/geo/cloudOutline.js.map +7 -0
  67. package/dist-cjs/lib/shapes/geo/components/DashStyleCloud.js +124 -0
  68. package/dist-cjs/lib/shapes/geo/components/DashStyleCloud.js.map +7 -0
  69. package/dist-cjs/lib/shapes/geo/components/DashStyleEllipse.js +123 -0
  70. package/dist-cjs/lib/shapes/geo/components/DashStyleEllipse.js.map +7 -0
  71. package/dist-cjs/lib/shapes/geo/components/DashStyleOval.js +118 -0
  72. package/dist-cjs/lib/shapes/geo/components/DashStyleOval.js.map +7 -0
  73. package/dist-cjs/lib/shapes/geo/components/DashStylePolygon.js +155 -0
  74. package/dist-cjs/lib/shapes/geo/components/DashStylePolygon.js.map +7 -0
  75. package/dist-cjs/lib/shapes/geo/components/DrawStyleCloud.js +79 -0
  76. package/dist-cjs/lib/shapes/geo/components/DrawStyleCloud.js.map +7 -0
  77. package/dist-cjs/lib/shapes/geo/components/DrawStyleEllipse.js +133 -0
  78. package/dist-cjs/lib/shapes/geo/components/DrawStyleEllipse.js.map +7 -0
  79. package/dist-cjs/lib/shapes/geo/components/DrawStylePolygon.js +93 -0
  80. package/dist-cjs/lib/shapes/geo/components/DrawStylePolygon.js.map +7 -0
  81. package/dist-cjs/lib/shapes/geo/components/SolidStyleCloud.js +79 -0
  82. package/dist-cjs/lib/shapes/geo/components/SolidStyleCloud.js.map +7 -0
  83. package/dist-cjs/lib/shapes/geo/components/SolidStyleEllipse.js +84 -0
  84. package/dist-cjs/lib/shapes/geo/components/SolidStyleEllipse.js.map +7 -0
  85. package/dist-cjs/lib/shapes/geo/components/SolidStyleOval.js +99 -0
  86. package/dist-cjs/lib/shapes/geo/components/SolidStyleOval.js.map +7 -0
  87. package/dist-cjs/lib/shapes/geo/components/SolidStylePolygon.js +86 -0
  88. package/dist-cjs/lib/shapes/geo/components/SolidStylePolygon.js.map +7 -0
  89. package/dist-cjs/lib/shapes/geo/helpers.js +53 -0
  90. package/dist-cjs/lib/shapes/geo/helpers.js.map +7 -0
  91. package/dist-cjs/lib/shapes/geo/toolStates/Idle.js +53 -0
  92. package/dist-cjs/lib/shapes/geo/toolStates/Idle.js.map +7 -0
  93. package/dist-cjs/lib/shapes/geo/toolStates/Pointing.js +118 -0
  94. package/dist-cjs/lib/shapes/geo/toolStates/Pointing.js.map +7 -0
  95. package/dist-cjs/lib/shapes/highlight/HighlightShapeTool.js +37 -0
  96. package/dist-cjs/lib/shapes/highlight/HighlightShapeTool.js.map +7 -0
  97. package/dist-cjs/lib/shapes/highlight/HighlightShapeUtil.js +208 -0
  98. package/dist-cjs/lib/shapes/highlight/HighlightShapeUtil.js.map +7 -0
  99. package/dist-cjs/lib/shapes/image/ImageShapeUtil.js +262 -0
  100. package/dist-cjs/lib/shapes/image/ImageShapeUtil.js.map +7 -0
  101. package/dist-cjs/lib/shapes/line/LineShapeTool.js +33 -0
  102. package/dist-cjs/lib/shapes/line/LineShapeTool.js.map +7 -0
  103. package/dist-cjs/lib/shapes/line/LineShapeUtil.js +359 -0
  104. package/dist-cjs/lib/shapes/line/LineShapeUtil.js.map +7 -0
  105. package/dist-cjs/lib/shapes/line/components/getLinePath.js +88 -0
  106. package/dist-cjs/lib/shapes/line/components/getLinePath.js.map +7 -0
  107. package/dist-cjs/lib/shapes/line/components/svg.js +73 -0
  108. package/dist-cjs/lib/shapes/line/components/svg.js.map +7 -0
  109. package/dist-cjs/lib/shapes/line/toolStates/Idle.js +39 -0
  110. package/dist-cjs/lib/shapes/line/toolStates/Idle.js.map +7 -0
  111. package/dist-cjs/lib/shapes/line/toolStates/Pointing.js +145 -0
  112. package/dist-cjs/lib/shapes/line/toolStates/Pointing.js.map +7 -0
  113. package/dist-cjs/lib/shapes/note/NoteShapeTool.js +33 -0
  114. package/dist-cjs/lib/shapes/note/NoteShapeTool.js.map +7 -0
  115. package/dist-cjs/lib/shapes/note/NoteShapeUtil.js +205 -0
  116. package/dist-cjs/lib/shapes/note/NoteShapeUtil.js.map +7 -0
  117. package/dist-cjs/lib/shapes/note/toolStates/Idle.js +37 -0
  118. package/dist-cjs/lib/shapes/note/toolStates/Idle.js.map +7 -0
  119. package/dist-cjs/lib/shapes/note/toolStates/Pointing.js +114 -0
  120. package/dist-cjs/lib/shapes/note/toolStates/Pointing.js.map +7 -0
  121. package/dist-cjs/lib/shapes/shared/HyperlinkButton.js +65 -0
  122. package/dist-cjs/lib/shapes/shared/HyperlinkButton.js.map +7 -0
  123. package/dist-cjs/lib/shapes/shared/ShapeFill.js +117 -0
  124. package/dist-cjs/lib/shapes/shared/ShapeFill.js.map +7 -0
  125. package/dist-cjs/lib/shapes/shared/TextHelpers.js +228 -0
  126. package/dist-cjs/lib/shapes/shared/TextHelpers.js.map +7 -0
  127. package/dist-cjs/lib/shapes/shared/TextLabel.js +138 -0
  128. package/dist-cjs/lib/shapes/shared/TextLabel.js.map +7 -0
  129. package/dist-cjs/lib/shapes/shared/createTextSvgElementFromSpans.js +75 -0
  130. package/dist-cjs/lib/shapes/shared/createTextSvgElementFromSpans.js.map +7 -0
  131. package/dist-cjs/lib/shapes/shared/default-shape-constants.js +72 -0
  132. package/dist-cjs/lib/shapes/shared/default-shape-constants.js.map +7 -0
  133. package/dist-cjs/lib/shapes/shared/defaultStyleDefs.js +252 -0
  134. package/dist-cjs/lib/shapes/shared/defaultStyleDefs.js.map +7 -0
  135. package/dist-cjs/lib/shapes/shared/freehand/getStroke.js +33 -0
  136. package/dist-cjs/lib/shapes/shared/freehand/getStroke.js.map +7 -0
  137. package/dist-cjs/lib/shapes/shared/freehand/getStrokeOutlinePoints.js +175 -0
  138. package/dist-cjs/lib/shapes/shared/freehand/getStrokeOutlinePoints.js.map +7 -0
  139. package/dist-cjs/lib/shapes/shared/freehand/getStrokePoints.js +144 -0
  140. package/dist-cjs/lib/shapes/shared/freehand/getStrokePoints.js.map +7 -0
  141. package/dist-cjs/lib/shapes/shared/freehand/getStrokeRadius.js +27 -0
  142. package/dist-cjs/lib/shapes/shared/freehand/getStrokeRadius.js.map +7 -0
  143. package/dist-cjs/lib/shapes/shared/freehand/setStrokePointRadii.js +101 -0
  144. package/dist-cjs/lib/shapes/shared/freehand/setStrokePointRadii.js.map +7 -0
  145. package/dist-cjs/lib/shapes/shared/freehand/svg.js +56 -0
  146. package/dist-cjs/lib/shapes/shared/freehand/svg.js.map +7 -0
  147. package/dist-cjs/lib/shapes/shared/freehand/svgInk.js +163 -0
  148. package/dist-cjs/lib/shapes/shared/freehand/svgInk.js.map +7 -0
  149. package/dist-cjs/lib/shapes/shared/freehand/types.js +17 -0
  150. package/dist-cjs/lib/shapes/shared/freehand/types.js.map +7 -0
  151. package/dist-cjs/lib/shapes/shared/getBrowserCanvasMaxSize.js +52 -0
  152. package/dist-cjs/lib/shapes/shared/getBrowserCanvasMaxSize.js.map +7 -0
  153. package/dist-cjs/lib/shapes/shared/getPerfectDashProps.js +96 -0
  154. package/dist-cjs/lib/shapes/shared/getPerfectDashProps.js.map +7 -0
  155. package/dist-cjs/lib/shapes/shared/getTextLabelSvgElement.js +56 -0
  156. package/dist-cjs/lib/shapes/shared/getTextLabelSvgElement.js.map +7 -0
  157. package/dist-cjs/lib/shapes/shared/legacyProps.js +42 -0
  158. package/dist-cjs/lib/shapes/shared/legacyProps.js.map +7 -0
  159. package/dist-cjs/lib/shapes/shared/polygon-helpers.js +116 -0
  160. package/dist-cjs/lib/shapes/shared/polygon-helpers.js.map +7 -0
  161. package/dist-cjs/lib/shapes/shared/resizeBox.js +117 -0
  162. package/dist-cjs/lib/shapes/shared/resizeBox.js.map +7 -0
  163. package/dist-cjs/lib/shapes/shared/resizeScaled.js +48 -0
  164. package/dist-cjs/lib/shapes/shared/resizeScaled.js.map +7 -0
  165. package/dist-cjs/lib/shapes/shared/rotated-box-shadow.js +50 -0
  166. package/dist-cjs/lib/shapes/shared/rotated-box-shadow.js.map +7 -0
  167. package/dist-cjs/lib/shapes/shared/useColorSpace.js +39 -0
  168. package/dist-cjs/lib/shapes/shared/useColorSpace.js.map +7 -0
  169. package/dist-cjs/lib/shapes/shared/useEditableText.js +179 -0
  170. package/dist-cjs/lib/shapes/shared/useEditableText.js.map +7 -0
  171. package/dist-cjs/lib/shapes/shared/useForceSolid.js +29 -0
  172. package/dist-cjs/lib/shapes/shared/useForceSolid.js.map +7 -0
  173. package/dist-cjs/lib/shapes/shared/usePrefersReducedMotion.js +38 -0
  174. package/dist-cjs/lib/shapes/shared/usePrefersReducedMotion.js.map +7 -0
  175. package/dist-cjs/lib/shapes/text/TextShapeTool.js +33 -0
  176. package/dist-cjs/lib/shapes/text/TextShapeTool.js.map +7 -0
  177. package/dist-cjs/lib/shapes/text/TextShapeUtil.js +341 -0
  178. package/dist-cjs/lib/shapes/text/TextShapeUtil.js.map +7 -0
  179. package/dist-cjs/lib/shapes/text/toolStates/Idle.js +62 -0
  180. package/dist-cjs/lib/shapes/text/toolStates/Idle.js.map +7 -0
  181. package/dist-cjs/lib/shapes/text/toolStates/Pointing.js +109 -0
  182. package/dist-cjs/lib/shapes/text/toolStates/Pointing.js.map +7 -0
  183. package/dist-cjs/lib/shapes/video/VideoShapeUtil.js +202 -0
  184. package/dist-cjs/lib/shapes/video/VideoShapeUtil.js.map +7 -0
  185. package/dist-cjs/lib/tools/EraserTool/EraserTool.js +36 -0
  186. package/dist-cjs/lib/tools/EraserTool/EraserTool.js.map +7 -0
  187. package/dist-cjs/lib/tools/EraserTool/childStates/Erasing.js +111 -0
  188. package/dist-cjs/lib/tools/EraserTool/childStates/Erasing.js.map +7 -0
  189. package/dist-cjs/lib/tools/EraserTool/childStates/Idle.js +34 -0
  190. package/dist-cjs/lib/tools/EraserTool/childStates/Idle.js.map +7 -0
  191. package/dist-cjs/lib/tools/EraserTool/childStates/Pointing.js +84 -0
  192. package/dist-cjs/lib/tools/EraserTool/childStates/Pointing.js.map +7 -0
  193. package/dist-cjs/lib/tools/HandTool/HandTool.js +58 -0
  194. package/dist-cjs/lib/tools/HandTool/HandTool.js.map +7 -0
  195. package/dist-cjs/lib/tools/HandTool/childStates/Dragging.js +58 -0
  196. package/dist-cjs/lib/tools/HandTool/childStates/Dragging.js.map +7 -0
  197. package/dist-cjs/lib/tools/HandTool/childStates/Idle.js +37 -0
  198. package/dist-cjs/lib/tools/HandTool/childStates/Idle.js.map +7 -0
  199. package/dist-cjs/lib/tools/HandTool/childStates/Pointing.js +55 -0
  200. package/dist-cjs/lib/tools/HandTool/childStates/Pointing.js.map +7 -0
  201. package/dist-cjs/lib/tools/LaserTool/LaserTool.js +35 -0
  202. package/dist-cjs/lib/tools/LaserTool/LaserTool.js.map +7 -0
  203. package/dist-cjs/lib/tools/LaserTool/childStates/Idle.js +31 -0
  204. package/dist-cjs/lib/tools/LaserTool/childStates/Idle.js.map +7 -0
  205. package/dist-cjs/lib/tools/LaserTool/childStates/Lasering.js +66 -0
  206. package/dist-cjs/lib/tools/LaserTool/childStates/Lasering.js.map +7 -0
  207. package/dist-cjs/lib/tools/SelectTool/DragAndDropManager.js +100 -0
  208. package/dist-cjs/lib/tools/SelectTool/DragAndDropManager.js.map +7 -0
  209. package/dist-cjs/lib/tools/SelectTool/SelectTool.js +70 -0
  210. package/dist-cjs/lib/tools/SelectTool/SelectTool.js.map +7 -0
  211. package/dist-cjs/lib/tools/SelectTool/childStates/Brushing.js +145 -0
  212. package/dist-cjs/lib/tools/SelectTool/childStates/Brushing.js.map +7 -0
  213. package/dist-cjs/lib/tools/SelectTool/childStates/Crop/Crop.js +33 -0
  214. package/dist-cjs/lib/tools/SelectTool/childStates/Crop/Crop.js.map +7 -0
  215. package/dist-cjs/lib/tools/SelectTool/childStates/Crop/children/Idle.js +204 -0
  216. package/dist-cjs/lib/tools/SelectTool/childStates/Crop/children/Idle.js.map +7 -0
  217. package/dist-cjs/lib/tools/SelectTool/childStates/Crop/children/PointingCrop.js +39 -0
  218. package/dist-cjs/lib/tools/SelectTool/childStates/Crop/children/PointingCrop.js.map +7 -0
  219. package/dist-cjs/lib/tools/SelectTool/childStates/Crop/children/TranslatingCrop.js +101 -0
  220. package/dist-cjs/lib/tools/SelectTool/childStates/Crop/children/TranslatingCrop.js.map +7 -0
  221. package/dist-cjs/lib/tools/SelectTool/childStates/Crop/children/crop_helpers.js +58 -0
  222. package/dist-cjs/lib/tools/SelectTool/childStates/Crop/children/crop_helpers.js.map +7 -0
  223. package/dist-cjs/lib/tools/SelectTool/childStates/Crop/crop-constants.js +25 -0
  224. package/dist-cjs/lib/tools/SelectTool/childStates/Crop/crop-constants.js.map +7 -0
  225. package/dist-cjs/lib/tools/SelectTool/childStates/Cropping.js +210 -0
  226. package/dist-cjs/lib/tools/SelectTool/childStates/Cropping.js.map +7 -0
  227. package/dist-cjs/lib/tools/SelectTool/childStates/DraggingHandle.js +230 -0
  228. package/dist-cjs/lib/tools/SelectTool/childStates/DraggingHandle.js.map +7 -0
  229. package/dist-cjs/lib/tools/SelectTool/childStates/EditingShape.js +121 -0
  230. package/dist-cjs/lib/tools/SelectTool/childStates/EditingShape.js.map +7 -0
  231. package/dist-cjs/lib/tools/SelectTool/childStates/Idle.js +461 -0
  232. package/dist-cjs/lib/tools/SelectTool/childStates/Idle.js.map +7 -0
  233. package/dist-cjs/lib/tools/SelectTool/childStates/PointingCanvas.js +56 -0
  234. package/dist-cjs/lib/tools/SelectTool/childStates/PointingCanvas.js.map +7 -0
  235. package/dist-cjs/lib/tools/SelectTool/childStates/PointingCropHandle.js +89 -0
  236. package/dist-cjs/lib/tools/SelectTool/childStates/PointingCropHandle.js.map +7 -0
  237. package/dist-cjs/lib/tools/SelectTool/childStates/PointingHandle.js +67 -0
  238. package/dist-cjs/lib/tools/SelectTool/childStates/PointingHandle.js.map +7 -0
  239. package/dist-cjs/lib/tools/SelectTool/childStates/PointingResizeHandle.js +91 -0
  240. package/dist-cjs/lib/tools/SelectTool/childStates/PointingResizeHandle.js.map +7 -0
  241. package/dist-cjs/lib/tools/SelectTool/childStates/PointingRotateHandle.js +83 -0
  242. package/dist-cjs/lib/tools/SelectTool/childStates/PointingRotateHandle.js.map +7 -0
  243. package/dist-cjs/lib/tools/SelectTool/childStates/PointingSelection.js +73 -0
  244. package/dist-cjs/lib/tools/SelectTool/childStates/PointingSelection.js.map +7 -0
  245. package/dist-cjs/lib/tools/SelectTool/childStates/PointingShape.js +176 -0
  246. package/dist-cjs/lib/tools/SelectTool/childStates/PointingShape.js.map +7 -0
  247. package/dist-cjs/lib/tools/SelectTool/childStates/Resizing.js +371 -0
  248. package/dist-cjs/lib/tools/SelectTool/childStates/Resizing.js.map +7 -0
  249. package/dist-cjs/lib/tools/SelectTool/childStates/Rotating.js +148 -0
  250. package/dist-cjs/lib/tools/SelectTool/childStates/Rotating.js.map +7 -0
  251. package/dist-cjs/lib/tools/SelectTool/childStates/ScribbleBrushing.js +140 -0
  252. package/dist-cjs/lib/tools/SelectTool/childStates/ScribbleBrushing.js.map +7 -0
  253. package/dist-cjs/lib/tools/SelectTool/childStates/Translating.js +315 -0
  254. package/dist-cjs/lib/tools/SelectTool/childStates/Translating.js.map +7 -0
  255. package/dist-cjs/lib/tools/SelectTool/children/DraggingHandle.js +230 -0
  256. package/dist-cjs/lib/tools/SelectTool/children/DraggingHandle.js.map +7 -0
  257. package/dist-cjs/lib/tools/ZoomTool/ZoomTool.js +79 -0
  258. package/dist-cjs/lib/tools/ZoomTool/ZoomTool.js.map +7 -0
  259. package/dist-cjs/lib/tools/ZoomTool/childStates/Idle.js +35 -0
  260. package/dist-cjs/lib/tools/ZoomTool/childStates/Idle.js.map +7 -0
  261. package/dist-cjs/lib/tools/ZoomTool/childStates/Pointing.js +55 -0
  262. package/dist-cjs/lib/tools/ZoomTool/childStates/Pointing.js.map +7 -0
  263. package/dist-cjs/lib/tools/ZoomTool/childStates/ZoomBrushing.js +72 -0
  264. package/dist-cjs/lib/tools/ZoomTool/childStates/ZoomBrushing.js.map +7 -0
  265. package/dist-cjs/lib/tools/selection-logic/getHitShapeOnCanvasPointerDown.js +41 -0
  266. package/dist-cjs/lib/tools/selection-logic/getHitShapeOnCanvasPointerDown.js.map +7 -0
  267. package/dist-cjs/lib/tools/selection-logic/getShouldEnterCropModeOnPointerDown.js +28 -0
  268. package/dist-cjs/lib/tools/selection-logic/getShouldEnterCropModeOnPointerDown.js.map +7 -0
  269. package/dist-cjs/lib/tools/selection-logic/selectOnCanvasPointerUp.js +80 -0
  270. package/dist-cjs/lib/tools/selection-logic/selectOnCanvasPointerUp.js.map +7 -0
  271. package/dist-cjs/lib/tools/selection-logic/updateHoveredId.js +47 -0
  272. package/dist-cjs/lib/tools/selection-logic/updateHoveredId.js.map +7 -0
  273. package/dist-cjs/lib/ui/TldrawUi.js +155 -0
  274. package/dist-cjs/lib/ui/TldrawUi.js.map +7 -0
  275. package/dist-cjs/lib/ui/TldrawUiContextProvider.js +57 -0
  276. package/dist-cjs/lib/ui/TldrawUiContextProvider.js.map +7 -0
  277. package/dist-cjs/lib/ui/assetUrls.js +67 -0
  278. package/dist-cjs/lib/ui/assetUrls.js.map +7 -0
  279. package/dist-cjs/lib/ui/components/ActionsMenu.js +96 -0
  280. package/dist-cjs/lib/ui/components/ActionsMenu.js.map +7 -0
  281. package/dist-cjs/lib/ui/components/BackToContent.js +67 -0
  282. package/dist-cjs/lib/ui/components/BackToContent.js.map +7 -0
  283. package/dist-cjs/lib/ui/components/ContextMenu.js +214 -0
  284. package/dist-cjs/lib/ui/components/ContextMenu.js.map +7 -0
  285. package/dist-cjs/lib/ui/components/DebugPanel.js +334 -0
  286. package/dist-cjs/lib/ui/components/DebugPanel.js.map +7 -0
  287. package/dist-cjs/lib/ui/components/Dialogs.js +64 -0
  288. package/dist-cjs/lib/ui/components/Dialogs.js.map +7 -0
  289. package/dist-cjs/lib/ui/components/DuplicateButton.js +47 -0
  290. package/dist-cjs/lib/ui/components/DuplicateButton.js.map +7 -0
  291. package/dist-cjs/lib/ui/components/EditLinkDialog.js +161 -0
  292. package/dist-cjs/lib/ui/components/EditLinkDialog.js.map +7 -0
  293. package/dist-cjs/lib/ui/components/EmbedDialog.js +152 -0
  294. package/dist-cjs/lib/ui/components/EmbedDialog.js.map +7 -0
  295. package/dist-cjs/lib/ui/components/FollowingIndicator.js +41 -0
  296. package/dist-cjs/lib/ui/components/FollowingIndicator.js.map +7 -0
  297. package/dist-cjs/lib/ui/components/HTMLCanvas.js +66 -0
  298. package/dist-cjs/lib/ui/components/HTMLCanvas.js.map +7 -0
  299. package/dist-cjs/lib/ui/components/HelpMenu.js +116 -0
  300. package/dist-cjs/lib/ui/components/HelpMenu.js.map +7 -0
  301. package/dist-cjs/lib/ui/components/KeyboardShortcutsDialog.js +74 -0
  302. package/dist-cjs/lib/ui/components/KeyboardShortcutsDialog.js.map +7 -0
  303. package/dist-cjs/lib/ui/components/LanguageMenu.js +60 -0
  304. package/dist-cjs/lib/ui/components/LanguageMenu.js.map +7 -0
  305. package/dist-cjs/lib/ui/components/Menu.js +139 -0
  306. package/dist-cjs/lib/ui/components/Menu.js.map +7 -0
  307. package/dist-cjs/lib/ui/components/MenuZone.js +51 -0
  308. package/dist-cjs/lib/ui/components/MenuZone.js.map +7 -0
  309. package/dist-cjs/lib/ui/components/MobileStylePanel.js +69 -0
  310. package/dist-cjs/lib/ui/components/MobileStylePanel.js.map +7 -0
  311. package/dist-cjs/lib/ui/components/MoveToPageMenu.js +142 -0
  312. package/dist-cjs/lib/ui/components/MoveToPageMenu.js.map +7 -0
  313. package/dist-cjs/lib/ui/components/NavigationZone/Minimap.js +208 -0
  314. package/dist-cjs/lib/ui/components/NavigationZone/Minimap.js.map +7 -0
  315. package/dist-cjs/lib/ui/components/NavigationZone/MinimapManager.js +293 -0
  316. package/dist-cjs/lib/ui/components/NavigationZone/MinimapManager.js.map +7 -0
  317. package/dist-cjs/lib/ui/components/NavigationZone/NavigationZone.js +103 -0
  318. package/dist-cjs/lib/ui/components/NavigationZone/NavigationZone.js.map +7 -0
  319. package/dist-cjs/lib/ui/components/NavigationZone/ZoomMenu.js +118 -0
  320. package/dist-cjs/lib/ui/components/NavigationZone/ZoomMenu.js.map +7 -0
  321. package/dist-cjs/lib/ui/components/OfflineIndicator/OfflineIndicator.js +47 -0
  322. package/dist-cjs/lib/ui/components/OfflineIndicator/OfflineIndicator.js.map +7 -0
  323. package/dist-cjs/lib/ui/components/PageMenu/PageItemInput.js +63 -0
  324. package/dist-cjs/lib/ui/components/PageMenu/PageItemInput.js.map +7 -0
  325. package/dist-cjs/lib/ui/components/PageMenu/PageItemSubmenu.js +88 -0
  326. package/dist-cjs/lib/ui/components/PageMenu/PageItemSubmenu.js.map +7 -0
  327. package/dist-cjs/lib/ui/components/PageMenu/PageMenu.js +395 -0
  328. package/dist-cjs/lib/ui/components/PageMenu/PageMenu.js.map +7 -0
  329. package/dist-cjs/lib/ui/components/PageMenu/edit-pages-shared.js +45 -0
  330. package/dist-cjs/lib/ui/components/PageMenu/edit-pages-shared.js.map +7 -0
  331. package/dist-cjs/lib/ui/components/PenModeToggle.js +45 -0
  332. package/dist-cjs/lib/ui/components/PenModeToggle.js.map +7 -0
  333. package/dist-cjs/lib/ui/components/RedoButton.js +49 -0
  334. package/dist-cjs/lib/ui/components/RedoButton.js.map +7 -0
  335. package/dist-cjs/lib/ui/components/Spinner.js +41 -0
  336. package/dist-cjs/lib/ui/components/Spinner.js.map +7 -0
  337. package/dist-cjs/lib/ui/components/StopFollowing.js +45 -0
  338. package/dist-cjs/lib/ui/components/StopFollowing.js.map +7 -0
  339. package/dist-cjs/lib/ui/components/StylePanel/DoubleDropdownPicker.js +138 -0
  340. package/dist-cjs/lib/ui/components/StylePanel/DoubleDropdownPicker.js.map +7 -0
  341. package/dist-cjs/lib/ui/components/StylePanel/DropdownPicker.js +89 -0
  342. package/dist-cjs/lib/ui/components/StylePanel/DropdownPicker.js.map +7 -0
  343. package/dist-cjs/lib/ui/components/StylePanel/StylePanel.js +313 -0
  344. package/dist-cjs/lib/ui/components/StylePanel/StylePanel.js.map +7 -0
  345. package/dist-cjs/lib/ui/components/StylePanel/styles.js +119 -0
  346. package/dist-cjs/lib/ui/components/StylePanel/styles.js.map +7 -0
  347. package/dist-cjs/lib/ui/components/Toasts.js +101 -0
  348. package/dist-cjs/lib/ui/components/Toasts.js.map +7 -0
  349. package/dist-cjs/lib/ui/components/Toolbar/ToggleToolLockedButton.js +73 -0
  350. package/dist-cjs/lib/ui/components/Toolbar/ToggleToolLockedButton.js.map +7 -0
  351. package/dist-cjs/lib/ui/components/Toolbar/Toolbar.js +247 -0
  352. package/dist-cjs/lib/ui/components/Toolbar/Toolbar.js.map +7 -0
  353. package/dist-cjs/lib/ui/components/TrashButton.js +51 -0
  354. package/dist-cjs/lib/ui/components/TrashButton.js.map +7 -0
  355. package/dist-cjs/lib/ui/components/UndoButton.js +49 -0
  356. package/dist-cjs/lib/ui/components/UndoButton.js.map +7 -0
  357. package/dist-cjs/lib/ui/components/primitives/Button.js +79 -0
  358. package/dist-cjs/lib/ui/components/primitives/Button.js.map +7 -0
  359. package/dist-cjs/lib/ui/components/primitives/ButtonPicker.js +121 -0
  360. package/dist-cjs/lib/ui/components/primitives/ButtonPicker.js.map +7 -0
  361. package/dist-cjs/lib/ui/components/primitives/Dialog.js +70 -0
  362. package/dist-cjs/lib/ui/components/primitives/Dialog.js.map +7 -0
  363. package/dist-cjs/lib/ui/components/primitives/DropdownMenu.js +187 -0
  364. package/dist-cjs/lib/ui/components/primitives/DropdownMenu.js.map +7 -0
  365. package/dist-cjs/lib/ui/components/primitives/Icon.js +71 -0
  366. package/dist-cjs/lib/ui/components/primitives/Icon.js.map +7 -0
  367. package/dist-cjs/lib/ui/components/primitives/Input.js +155 -0
  368. package/dist-cjs/lib/ui/components/primitives/Input.js.map +7 -0
  369. package/dist-cjs/lib/ui/components/primitives/Kbd.js +29 -0
  370. package/dist-cjs/lib/ui/components/primitives/Kbd.js.map +7 -0
  371. package/dist-cjs/lib/ui/components/primitives/Popover.js +69 -0
  372. package/dist-cjs/lib/ui/components/primitives/Popover.js.map +7 -0
  373. package/dist-cjs/lib/ui/components/primitives/Slider.js +69 -0
  374. package/dist-cjs/lib/ui/components/primitives/Slider.js.map +7 -0
  375. package/dist-cjs/lib/ui/components/primitives/shared.js +44 -0
  376. package/dist-cjs/lib/ui/components/primitives/shared.js.map +7 -0
  377. package/dist-cjs/lib/ui/constants.js +25 -0
  378. package/dist-cjs/lib/ui/constants.js.map +7 -0
  379. package/dist-cjs/lib/ui/hooks/clipboard/pasteExcalidrawContent.js +454 -0
  380. package/dist-cjs/lib/ui/hooks/clipboard/pasteExcalidrawContent.js.map +7 -0
  381. package/dist-cjs/lib/ui/hooks/clipboard/pasteFiles.js +37 -0
  382. package/dist-cjs/lib/ui/hooks/clipboard/pasteFiles.js.map +7 -0
  383. package/dist-cjs/lib/ui/hooks/clipboard/pasteTldrawContent.js +32 -0
  384. package/dist-cjs/lib/ui/hooks/clipboard/pasteTldrawContent.js.map +7 -0
  385. package/dist-cjs/lib/ui/hooks/clipboard/pasteUrl.js +48 -0
  386. package/dist-cjs/lib/ui/hooks/clipboard/pasteUrl.js.map +7 -0
  387. package/dist-cjs/lib/ui/hooks/menuHelpers.js +172 -0
  388. package/dist-cjs/lib/ui/hooks/menuHelpers.js.map +7 -0
  389. package/dist-cjs/lib/ui/hooks/useActions.js +1152 -0
  390. package/dist-cjs/lib/ui/hooks/useActions.js.map +7 -0
  391. package/dist-cjs/lib/ui/hooks/useActionsMenuSchema.js +112 -0
  392. package/dist-cjs/lib/ui/hooks/useActionsMenuSchema.js.map +7 -0
  393. package/dist-cjs/lib/ui/hooks/useAssetUrls.js +41 -0
  394. package/dist-cjs/lib/ui/hooks/useAssetUrls.js.map +7 -0
  395. package/dist-cjs/lib/ui/hooks/useBreakpoint.js +64 -0
  396. package/dist-cjs/lib/ui/hooks/useBreakpoint.js.map +7 -0
  397. package/dist-cjs/lib/ui/hooks/useCanRedo.js +29 -0
  398. package/dist-cjs/lib/ui/hooks/useCanRedo.js.map +7 -0
  399. package/dist-cjs/lib/ui/hooks/useCanUndo.js +29 -0
  400. package/dist-cjs/lib/ui/hooks/useCanUndo.js.map +7 -0
  401. package/dist-cjs/lib/ui/hooks/useClipboardEvents.js +463 -0
  402. package/dist-cjs/lib/ui/hooks/useClipboardEvents.js.map +7 -0
  403. package/dist-cjs/lib/ui/hooks/useContextMenuSchema.js +228 -0
  404. package/dist-cjs/lib/ui/hooks/useContextMenuSchema.js.map +7 -0
  405. package/dist-cjs/lib/ui/hooks/useCopyAs.js +47 -0
  406. package/dist-cjs/lib/ui/hooks/useCopyAs.js.map +7 -0
  407. package/dist-cjs/lib/ui/hooks/useDialogsProvider.js +108 -0
  408. package/dist-cjs/lib/ui/hooks/useDialogsProvider.js.map +7 -0
  409. package/dist-cjs/lib/ui/hooks/useEditorEvents.js +43 -0
  410. package/dist-cjs/lib/ui/hooks/useEditorEvents.js.map +7 -0
  411. package/dist-cjs/lib/ui/hooks/useEventsProvider.js +47 -0
  412. package/dist-cjs/lib/ui/hooks/useEventsProvider.js.map +7 -0
  413. package/dist-cjs/lib/ui/hooks/useExportAs.js +51 -0
  414. package/dist-cjs/lib/ui/hooks/useExportAs.js.map +7 -0
  415. package/dist-cjs/lib/ui/hooks/useHasLinkShapeSelected.js +36 -0
  416. package/dist-cjs/lib/ui/hooks/useHasLinkShapeSelected.js.map +7 -0
  417. package/dist-cjs/lib/ui/hooks/useHelpMenuSchema.js +103 -0
  418. package/dist-cjs/lib/ui/hooks/useHelpMenuSchema.js.map +7 -0
  419. package/dist-cjs/lib/ui/hooks/useHighDpiCanvas.js +35 -0
  420. package/dist-cjs/lib/ui/hooks/useHighDpiCanvas.js.map +7 -0
  421. package/dist-cjs/lib/ui/hooks/useInsertMedia.js +57 -0
  422. package/dist-cjs/lib/ui/hooks/useInsertMedia.js.map +7 -0
  423. package/dist-cjs/lib/ui/hooks/useKeyboardShortcuts.js +138 -0
  424. package/dist-cjs/lib/ui/hooks/useKeyboardShortcuts.js.map +7 -0
  425. package/dist-cjs/lib/ui/hooks/useKeyboardShortcutsSchema.js +134 -0
  426. package/dist-cjs/lib/ui/hooks/useKeyboardShortcutsSchema.js.map +7 -0
  427. package/dist-cjs/lib/ui/hooks/useLocalStorageState.js +59 -0
  428. package/dist-cjs/lib/ui/hooks/useLocalStorageState.js.map +7 -0
  429. package/dist-cjs/lib/ui/hooks/useMenuIsOpen.js +74 -0
  430. package/dist-cjs/lib/ui/hooks/useMenuIsOpen.js.map +7 -0
  431. package/dist-cjs/lib/ui/hooks/useMenuSchema.js +260 -0
  432. package/dist-cjs/lib/ui/hooks/useMenuSchema.js.map +7 -0
  433. package/dist-cjs/lib/ui/hooks/useOnlyFlippableShape.js +38 -0
  434. package/dist-cjs/lib/ui/hooks/useOnlyFlippableShape.js.map +7 -0
  435. package/dist-cjs/lib/ui/hooks/usePreloadAssets.js +106 -0
  436. package/dist-cjs/lib/ui/hooks/usePreloadAssets.js.map +7 -0
  437. package/dist-cjs/lib/ui/hooks/usePreloadIcons.js +51 -0
  438. package/dist-cjs/lib/ui/hooks/usePreloadIcons.js.map +7 -0
  439. package/dist-cjs/lib/ui/hooks/usePrint.js +220 -0
  440. package/dist-cjs/lib/ui/hooks/usePrint.js.map +7 -0
  441. package/dist-cjs/lib/ui/hooks/useReadonly.js +29 -0
  442. package/dist-cjs/lib/ui/hooks/useReadonly.js.map +7 -0
  443. package/dist-cjs/lib/ui/hooks/useRevelantStyles.js +45 -0
  444. package/dist-cjs/lib/ui/hooks/useRevelantStyles.js.map +7 -0
  445. package/dist-cjs/lib/ui/hooks/useShowAutoSizeToggle.js +36 -0
  446. package/dist-cjs/lib/ui/hooks/useShowAutoSizeToggle.js.map +7 -0
  447. package/dist-cjs/lib/ui/hooks/useToastsProvider.js +53 -0
  448. package/dist-cjs/lib/ui/hooks/useToastsProvider.js.map +7 -0
  449. package/dist-cjs/lib/ui/hooks/useToolbarSchema.js +99 -0
  450. package/dist-cjs/lib/ui/hooks/useToolbarSchema.js.map +7 -0
  451. package/dist-cjs/lib/ui/hooks/useTools.js +235 -0
  452. package/dist-cjs/lib/ui/hooks/useTools.js.map +7 -0
  453. package/dist-cjs/lib/ui/hooks/useTranslation/TLUiTranslationKey.js +17 -0
  454. package/dist-cjs/lib/ui/hooks/useTranslation/TLUiTranslationKey.js.map +7 -0
  455. package/dist-cjs/lib/ui/hooks/useTranslation/defaultTranslation.js +377 -0
  456. package/dist-cjs/lib/ui/hooks/useTranslation/defaultTranslation.js.map +7 -0
  457. package/dist-cjs/lib/ui/hooks/useTranslation/translations.js +67 -0
  458. package/dist-cjs/lib/ui/hooks/useTranslation/translations.js.map +7 -0
  459. package/dist-cjs/lib/ui/hooks/useTranslation/useLanguages.js +32 -0
  460. package/dist-cjs/lib/ui/hooks/useTranslation/useLanguages.js.map +7 -0
  461. package/dist-cjs/lib/ui/hooks/useTranslation/useTranslation.js +101 -0
  462. package/dist-cjs/lib/ui/hooks/useTranslation/useTranslation.js.map +7 -0
  463. package/dist-cjs/lib/ui/icon-types.js +190 -0
  464. package/dist-cjs/lib/ui/icon-types.js.map +7 -0
  465. package/dist-cjs/lib/ui/overrides.js +178 -0
  466. package/dist-cjs/lib/ui/overrides.js.map +7 -0
  467. package/dist-cjs/lib/ui/version.js +25 -0
  468. package/dist-cjs/lib/ui/version.js.map +7 -0
  469. package/dist-cjs/lib/utils/assets/assets.js +91 -0
  470. package/dist-cjs/lib/utils/assets/assets.js.map +7 -0
  471. package/dist-cjs/lib/utils/assets/is-gif-animated.js +74 -0
  472. package/dist-cjs/lib/utils/assets/is-gif-animated.js.map +7 -0
  473. package/dist-cjs/lib/utils/assets.js +91 -0
  474. package/dist-cjs/lib/utils/assets.js.map +7 -0
  475. package/dist-cjs/lib/utils/embeds/embeds.js +85 -0
  476. package/dist-cjs/lib/utils/embeds/embeds.js.map +7 -0
  477. package/dist-cjs/lib/utils/export/copyAs.js +116 -0
  478. package/dist-cjs/lib/utils/export/copyAs.js.map +7 -0
  479. package/dist-cjs/lib/utils/export/export.js +117 -0
  480. package/dist-cjs/lib/utils/export/export.js.map +7 -0
  481. package/dist-cjs/lib/utils/export/exportAs.js +88 -0
  482. package/dist-cjs/lib/utils/export/exportAs.js.map +7 -0
  483. package/dist-cjs/lib/utils/frames/frames.js +92 -0
  484. package/dist-cjs/lib/utils/frames/frames.js.map +7 -0
  485. package/dist-cjs/lib/utils/static-assets/assetUrls.js +48 -0
  486. package/dist-cjs/lib/utils/static-assets/assetUrls.js.map +7 -0
  487. package/dist-cjs/lib/utils/text/text.js +57 -0
  488. package/dist-cjs/lib/utils/text/text.js.map +7 -0
  489. package/dist-cjs/lib/utils/tldr/buildFromV1Document.js +792 -0
  490. package/dist-cjs/lib/utils/tldr/buildFromV1Document.js.map +7 -0
  491. package/dist-cjs/lib/utils/tldr/file.js +230 -0
  492. package/dist-cjs/lib/utils/tldr/file.js.map +7 -0
  493. package/dist-esm/index.d.mts +2954 -0
  494. package/dist-esm/index.mjs +234 -0
  495. package/dist-esm/index.mjs.map +7 -0
  496. package/dist-esm/lib/Tldraw.mjs +127 -0
  497. package/dist-esm/lib/Tldraw.mjs.map +7 -0
  498. package/dist-esm/lib/canvas/TldrawCropHandles.mjs +134 -0
  499. package/dist-esm/lib/canvas/TldrawCropHandles.mjs.map +7 -0
  500. package/dist-esm/lib/canvas/TldrawHandles.mjs +17 -0
  501. package/dist-esm/lib/canvas/TldrawHandles.mjs.map +7 -0
  502. package/dist-esm/lib/canvas/TldrawHoveredShapeIndicator.mjs +26 -0
  503. package/dist-esm/lib/canvas/TldrawHoveredShapeIndicator.mjs.map +7 -0
  504. package/dist-esm/lib/canvas/TldrawScribble.mjs +42 -0
  505. package/dist-esm/lib/canvas/TldrawScribble.mjs.map +7 -0
  506. package/dist-esm/lib/canvas/TldrawSelectionBackground.mjs +28 -0
  507. package/dist-esm/lib/canvas/TldrawSelectionBackground.mjs.map +7 -0
  508. package/dist-esm/lib/canvas/TldrawSelectionForeground.mjs +487 -0
  509. package/dist-esm/lib/canvas/TldrawSelectionForeground.mjs.map +7 -0
  510. package/dist-esm/lib/defaultExternalContentHandlers.mjs +387 -0
  511. package/dist-esm/lib/defaultExternalContentHandlers.mjs.map +7 -0
  512. package/dist-esm/lib/defaultShapeTools.mjs +22 -0
  513. package/dist-esm/lib/defaultShapeTools.mjs.map +7 -0
  514. package/dist-esm/lib/defaultShapeUtils.mjs +30 -0
  515. package/dist-esm/lib/defaultShapeUtils.mjs.map +7 -0
  516. package/dist-esm/lib/defaultSideEffects.mjs +49 -0
  517. package/dist-esm/lib/defaultSideEffects.mjs.map +7 -0
  518. package/dist-esm/lib/defaultTools.mjs +10 -0
  519. package/dist-esm/lib/defaultTools.mjs.map +7 -0
  520. package/dist-esm/lib/shapes/arrow/ArrowShapeTool.mjs +13 -0
  521. package/dist-esm/lib/shapes/arrow/ArrowShapeTool.mjs.map +7 -0
  522. package/dist-esm/lib/shapes/arrow/ArrowShapeUtil.mjs +808 -0
  523. package/dist-esm/lib/shapes/arrow/ArrowShapeUtil.mjs.map +7 -0
  524. package/dist-esm/lib/shapes/arrow/components/ArrowTextLabel.mjs +84 -0
  525. package/dist-esm/lib/shapes/arrow/components/ArrowTextLabel.mjs.map +7 -0
  526. package/dist-esm/lib/shapes/arrow/toolStates/Idle.mjs +33 -0
  527. package/dist-esm/lib/shapes/arrow/toolStates/Idle.mjs.map +7 -0
  528. package/dist-esm/lib/shapes/arrow/toolStates/Pointing.mjs +162 -0
  529. package/dist-esm/lib/shapes/arrow/toolStates/Pointing.mjs.map +7 -0
  530. package/dist-esm/lib/shapes/bookmark/BookmarkShapeUtil.mjs +154 -0
  531. package/dist-esm/lib/shapes/bookmark/BookmarkShapeUtil.mjs.map +7 -0
  532. package/dist-esm/lib/shapes/draw/DrawShapeTool.mjs +17 -0
  533. package/dist-esm/lib/shapes/draw/DrawShapeTool.mjs.map +7 -0
  534. package/dist-esm/lib/shapes/draw/DrawShapeUtil.mjs +237 -0
  535. package/dist-esm/lib/shapes/draw/DrawShapeUtil.mjs.map +7 -0
  536. package/dist-esm/lib/shapes/draw/getPath.mjs +87 -0
  537. package/dist-esm/lib/shapes/draw/getPath.mjs.map +7 -0
  538. package/dist-esm/lib/shapes/draw/toolStates/Drawing.mjs +546 -0
  539. package/dist-esm/lib/shapes/draw/toolStates/Drawing.mjs.map +7 -0
  540. package/dist-esm/lib/shapes/draw/toolStates/Idle.mjs +17 -0
  541. package/dist-esm/lib/shapes/draw/toolStates/Idle.mjs.map +7 -0
  542. package/dist-esm/lib/shapes/embed/EmbedShapeUtil.mjs +181 -0
  543. package/dist-esm/lib/shapes/embed/EmbedShapeUtil.mjs.map +7 -0
  544. package/dist-esm/lib/shapes/frame/FrameShapeTool.mjs +46 -0
  545. package/dist-esm/lib/shapes/frame/FrameShapeTool.mjs.map +7 -0
  546. package/dist-esm/lib/shapes/frame/FrameShapeUtil.mjs +216 -0
  547. package/dist-esm/lib/shapes/frame/FrameShapeUtil.mjs.map +7 -0
  548. package/dist-esm/lib/shapes/frame/components/FrameHeading.mjs +93 -0
  549. package/dist-esm/lib/shapes/frame/components/FrameHeading.mjs.map +7 -0
  550. package/dist-esm/lib/shapes/frame/components/FrameLabelInput.mjs +81 -0
  551. package/dist-esm/lib/shapes/frame/components/FrameLabelInput.mjs.map +7 -0
  552. package/dist-esm/lib/shapes/geo/GeoShapeTool.mjs +13 -0
  553. package/dist-esm/lib/shapes/geo/GeoShapeTool.mjs.map +7 -0
  554. package/dist-esm/lib/shapes/geo/GeoShapeUtil.mjs +1010 -0
  555. package/dist-esm/lib/shapes/geo/GeoShapeUtil.mjs.map +7 -0
  556. package/dist-esm/lib/shapes/geo/cloudOutline.mjs +275 -0
  557. package/dist-esm/lib/shapes/geo/cloudOutline.mjs.map +7 -0
  558. package/dist-esm/lib/shapes/geo/components/DashStyleCloud.mjs +102 -0
  559. package/dist-esm/lib/shapes/geo/components/DashStyleCloud.mjs.map +7 -0
  560. package/dist-esm/lib/shapes/geo/components/DashStyleEllipse.mjs +101 -0
  561. package/dist-esm/lib/shapes/geo/components/DashStyleEllipse.mjs.map +7 -0
  562. package/dist-esm/lib/shapes/geo/components/DashStyleOval.mjs +93 -0
  563. package/dist-esm/lib/shapes/geo/components/DashStyleOval.mjs.map +7 -0
  564. package/dist-esm/lib/shapes/geo/components/DashStylePolygon.mjs +130 -0
  565. package/dist-esm/lib/shapes/geo/components/DashStylePolygon.mjs.map +7 -0
  566. package/dist-esm/lib/shapes/geo/components/DrawStyleCloud.mjs +54 -0
  567. package/dist-esm/lib/shapes/geo/components/DrawStyleCloud.mjs.map +7 -0
  568. package/dist-esm/lib/shapes/geo/components/DrawStyleEllipse.mjs +116 -0
  569. package/dist-esm/lib/shapes/geo/components/DrawStyleEllipse.mjs.map +7 -0
  570. package/dist-esm/lib/shapes/geo/components/DrawStylePolygon.mjs +68 -0
  571. package/dist-esm/lib/shapes/geo/components/DrawStylePolygon.mjs.map +7 -0
  572. package/dist-esm/lib/shapes/geo/components/SolidStyleCloud.mjs +54 -0
  573. package/dist-esm/lib/shapes/geo/components/SolidStyleCloud.mjs.map +7 -0
  574. package/dist-esm/lib/shapes/geo/components/SolidStyleEllipse.mjs +59 -0
  575. package/dist-esm/lib/shapes/geo/components/SolidStyleEllipse.mjs.map +7 -0
  576. package/dist-esm/lib/shapes/geo/components/SolidStyleOval.mjs +74 -0
  577. package/dist-esm/lib/shapes/geo/components/SolidStyleOval.mjs.map +7 -0
  578. package/dist-esm/lib/shapes/geo/components/SolidStylePolygon.mjs +61 -0
  579. package/dist-esm/lib/shapes/geo/components/SolidStylePolygon.mjs.map +7 -0
  580. package/dist-esm/lib/shapes/geo/helpers.mjs +33 -0
  581. package/dist-esm/lib/shapes/geo/helpers.mjs.map +7 -0
  582. package/dist-esm/lib/shapes/geo/toolStates/Idle.mjs +33 -0
  583. package/dist-esm/lib/shapes/geo/toolStates/Idle.mjs.map +7 -0
  584. package/dist-esm/lib/shapes/geo/toolStates/Pointing.mjs +104 -0
  585. package/dist-esm/lib/shapes/geo/toolStates/Pointing.mjs.map +7 -0
  586. package/dist-esm/lib/shapes/highlight/HighlightShapeTool.mjs +17 -0
  587. package/dist-esm/lib/shapes/highlight/HighlightShapeTool.mjs.map +7 -0
  588. package/dist-esm/lib/shapes/highlight/HighlightShapeUtil.mjs +198 -0
  589. package/dist-esm/lib/shapes/highlight/HighlightShapeUtil.mjs.map +7 -0
  590. package/dist-esm/lib/shapes/image/ImageShapeUtil.mjs +252 -0
  591. package/dist-esm/lib/shapes/image/ImageShapeUtil.mjs.map +7 -0
  592. package/dist-esm/lib/shapes/line/LineShapeTool.mjs +13 -0
  593. package/dist-esm/lib/shapes/line/LineShapeTool.mjs.map +7 -0
  594. package/dist-esm/lib/shapes/line/LineShapeUtil.mjs +357 -0
  595. package/dist-esm/lib/shapes/line/LineShapeUtil.mjs.map +7 -0
  596. package/dist-esm/lib/shapes/line/components/getLinePath.mjs +68 -0
  597. package/dist-esm/lib/shapes/line/components/getLinePath.mjs.map +7 -0
  598. package/dist-esm/lib/shapes/line/components/svg.mjs +57 -0
  599. package/dist-esm/lib/shapes/line/components/svg.mjs.map +7 -0
  600. package/dist-esm/lib/shapes/line/toolStates/Idle.mjs +19 -0
  601. package/dist-esm/lib/shapes/line/toolStates/Idle.mjs.map +7 -0
  602. package/dist-esm/lib/shapes/line/toolStates/Pointing.mjs +134 -0
  603. package/dist-esm/lib/shapes/line/toolStates/Pointing.mjs.map +7 -0
  604. package/dist-esm/lib/shapes/note/NoteShapeTool.mjs +13 -0
  605. package/dist-esm/lib/shapes/note/NoteShapeTool.mjs.map +7 -0
  606. package/dist-esm/lib/shapes/note/NoteShapeUtil.mjs +193 -0
  607. package/dist-esm/lib/shapes/note/NoteShapeUtil.mjs.map +7 -0
  608. package/dist-esm/lib/shapes/note/toolStates/Idle.mjs +17 -0
  609. package/dist-esm/lib/shapes/note/toolStates/Idle.mjs.map +7 -0
  610. package/dist-esm/lib/shapes/note/toolStates/Pointing.mjs +97 -0
  611. package/dist-esm/lib/shapes/note/toolStates/Pointing.mjs.map +7 -0
  612. package/dist-esm/lib/shapes/shared/HyperlinkButton.mjs +35 -0
  613. package/dist-esm/lib/shapes/shared/HyperlinkButton.mjs.map +7 -0
  614. package/dist-esm/lib/shapes/shared/ShapeFill.mjs +93 -0
  615. package/dist-esm/lib/shapes/shared/ShapeFill.mjs.map +7 -0
  616. package/dist-esm/lib/shapes/shared/TextHelpers.mjs +208 -0
  617. package/dist-esm/lib/shapes/shared/TextHelpers.mjs.map +7 -0
  618. package/dist-esm/lib/shapes/shared/TextLabel.mjs +112 -0
  619. package/dist-esm/lib/shapes/shared/TextLabel.mjs.map +7 -0
  620. package/dist-esm/lib/shapes/shared/createTextSvgElementFromSpans.mjs +57 -0
  621. package/dist-esm/lib/shapes/shared/createTextSvgElementFromSpans.mjs.map +7 -0
  622. package/dist-esm/lib/shapes/shared/default-shape-constants.mjs +52 -0
  623. package/dist-esm/lib/shapes/shared/default-shape-constants.mjs.map +7 -0
  624. package/dist-esm/lib/shapes/shared/defaultStyleDefs.mjs +240 -0
  625. package/dist-esm/lib/shapes/shared/defaultStyleDefs.mjs.map +7 -0
  626. package/dist-esm/lib/shapes/shared/freehand/getStroke.mjs +13 -0
  627. package/dist-esm/lib/shapes/shared/freehand/getStroke.mjs.map +7 -0
  628. package/dist-esm/lib/shapes/shared/freehand/getStrokeOutlinePoints.mjs +155 -0
  629. package/dist-esm/lib/shapes/shared/freehand/getStrokeOutlinePoints.mjs.map +7 -0
  630. package/dist-esm/lib/shapes/shared/freehand/getStrokePoints.mjs +124 -0
  631. package/dist-esm/lib/shapes/shared/freehand/getStrokePoints.mjs.map +7 -0
  632. package/dist-esm/lib/shapes/shared/freehand/getStrokeRadius.mjs +7 -0
  633. package/dist-esm/lib/shapes/shared/freehand/getStrokeRadius.mjs.map +7 -0
  634. package/dist-esm/lib/shapes/shared/freehand/setStrokePointRadii.mjs +81 -0
  635. package/dist-esm/lib/shapes/shared/freehand/setStrokePointRadii.mjs.map +7 -0
  636. package/dist-esm/lib/shapes/shared/freehand/svg.mjs +36 -0
  637. package/dist-esm/lib/shapes/shared/freehand/svg.mjs.map +7 -0
  638. package/dist-esm/lib/shapes/shared/freehand/svgInk.mjs +150 -0
  639. package/dist-esm/lib/shapes/shared/freehand/svgInk.mjs.map +7 -0
  640. package/dist-esm/lib/shapes/shared/freehand/types.mjs +1 -0
  641. package/dist-esm/lib/shapes/shared/freehand/types.mjs.map +7 -0
  642. package/dist-esm/lib/shapes/shared/getBrowserCanvasMaxSize.mjs +22 -0
  643. package/dist-esm/lib/shapes/shared/getBrowserCanvasMaxSize.mjs.map +7 -0
  644. package/dist-esm/lib/shapes/shared/getPerfectDashProps.mjs +76 -0
  645. package/dist-esm/lib/shapes/shared/getPerfectDashProps.mjs.map +7 -0
  646. package/dist-esm/lib/shapes/shared/getTextLabelSvgElement.mjs +36 -0
  647. package/dist-esm/lib/shapes/shared/getTextLabelSvgElement.mjs.map +7 -0
  648. package/dist-esm/lib/shapes/shared/legacyProps.mjs +22 -0
  649. package/dist-esm/lib/shapes/shared/legacyProps.mjs.map +7 -0
  650. package/dist-esm/lib/shapes/shared/polygon-helpers.mjs +96 -0
  651. package/dist-esm/lib/shapes/shared/polygon-helpers.mjs.map +7 -0
  652. package/dist-esm/lib/shapes/shared/resizeBox.mjs +99 -0
  653. package/dist-esm/lib/shapes/shared/resizeBox.mjs.map +7 -0
  654. package/dist-esm/lib/shapes/shared/resizeScaled.mjs +28 -0
  655. package/dist-esm/lib/shapes/shared/resizeScaled.mjs.map +7 -0
  656. package/dist-esm/lib/shapes/shared/rotated-box-shadow.mjs +30 -0
  657. package/dist-esm/lib/shapes/shared/rotated-box-shadow.mjs.map +7 -0
  658. package/dist-esm/lib/shapes/shared/useColorSpace.mjs +19 -0
  659. package/dist-esm/lib/shapes/shared/useColorSpace.mjs.map +7 -0
  660. package/dist-esm/lib/shapes/shared/useEditableText.mjs +165 -0
  661. package/dist-esm/lib/shapes/shared/useEditableText.mjs.map +7 -0
  662. package/dist-esm/lib/shapes/shared/useForceSolid.mjs +9 -0
  663. package/dist-esm/lib/shapes/shared/useForceSolid.mjs.map +7 -0
  664. package/dist-esm/lib/shapes/shared/usePrefersReducedMotion.mjs +18 -0
  665. package/dist-esm/lib/shapes/shared/usePrefersReducedMotion.mjs.map +7 -0
  666. package/dist-esm/lib/shapes/text/TextShapeTool.mjs +13 -0
  667. package/dist-esm/lib/shapes/text/TextShapeTool.mjs.map +7 -0
  668. package/dist-esm/lib/shapes/text/TextShapeUtil.mjs +334 -0
  669. package/dist-esm/lib/shapes/text/TextShapeUtil.mjs.map +7 -0
  670. package/dist-esm/lib/shapes/text/toolStates/Idle.mjs +42 -0
  671. package/dist-esm/lib/shapes/text/toolStates/Idle.mjs.map +7 -0
  672. package/dist-esm/lib/shapes/text/toolStates/Pointing.mjs +89 -0
  673. package/dist-esm/lib/shapes/text/toolStates/Pointing.mjs.map +7 -0
  674. package/dist-esm/lib/shapes/video/VideoShapeUtil.mjs +180 -0
  675. package/dist-esm/lib/shapes/video/VideoShapeUtil.mjs.map +7 -0
  676. package/dist-esm/lib/tools/EraserTool/EraserTool.mjs +16 -0
  677. package/dist-esm/lib/tools/EraserTool/EraserTool.mjs.map +7 -0
  678. package/dist-esm/lib/tools/EraserTool/childStates/Erasing.mjs +95 -0
  679. package/dist-esm/lib/tools/EraserTool/childStates/Erasing.mjs.map +7 -0
  680. package/dist-esm/lib/tools/EraserTool/childStates/Idle.mjs +14 -0
  681. package/dist-esm/lib/tools/EraserTool/childStates/Idle.mjs.map +7 -0
  682. package/dist-esm/lib/tools/EraserTool/childStates/Pointing.mjs +67 -0
  683. package/dist-esm/lib/tools/EraserTool/childStates/Pointing.mjs.map +7 -0
  684. package/dist-esm/lib/tools/HandTool/HandTool.mjs +38 -0
  685. package/dist-esm/lib/tools/HandTool/HandTool.mjs.map +7 -0
  686. package/dist-esm/lib/tools/HandTool/childStates/Dragging.mjs +38 -0
  687. package/dist-esm/lib/tools/HandTool/childStates/Dragging.mjs.map +7 -0
  688. package/dist-esm/lib/tools/HandTool/childStates/Idle.mjs +17 -0
  689. package/dist-esm/lib/tools/HandTool/childStates/Idle.mjs.map +7 -0
  690. package/dist-esm/lib/tools/HandTool/childStates/Pointing.mjs +35 -0
  691. package/dist-esm/lib/tools/HandTool/childStates/Pointing.mjs.map +7 -0
  692. package/dist-esm/lib/tools/LaserTool/LaserTool.mjs +15 -0
  693. package/dist-esm/lib/tools/LaserTool/LaserTool.mjs.map +7 -0
  694. package/dist-esm/lib/tools/LaserTool/childStates/Idle.mjs +11 -0
  695. package/dist-esm/lib/tools/LaserTool/childStates/Idle.mjs.map +7 -0
  696. package/dist-esm/lib/tools/LaserTool/childStates/Lasering.mjs +46 -0
  697. package/dist-esm/lib/tools/LaserTool/childStates/Lasering.mjs.map +7 -0
  698. package/dist-esm/lib/tools/SelectTool/DragAndDropManager.mjs +80 -0
  699. package/dist-esm/lib/tools/SelectTool/DragAndDropManager.mjs.map +7 -0
  700. package/dist-esm/lib/tools/SelectTool/SelectTool.mjs +50 -0
  701. package/dist-esm/lib/tools/SelectTool/SelectTool.mjs.map +7 -0
  702. package/dist-esm/lib/tools/SelectTool/childStates/Brushing.mjs +131 -0
  703. package/dist-esm/lib/tools/SelectTool/childStates/Brushing.mjs.map +7 -0
  704. package/dist-esm/lib/tools/SelectTool/childStates/Crop/Crop.mjs +13 -0
  705. package/dist-esm/lib/tools/SelectTool/childStates/Crop/Crop.mjs.map +7 -0
  706. package/dist-esm/lib/tools/SelectTool/childStates/Crop/children/Idle.mjs +187 -0
  707. package/dist-esm/lib/tools/SelectTool/childStates/Crop/children/Idle.mjs.map +7 -0
  708. package/dist-esm/lib/tools/SelectTool/childStates/Crop/children/PointingCrop.mjs +19 -0
  709. package/dist-esm/lib/tools/SelectTool/childStates/Crop/children/PointingCrop.mjs.map +7 -0
  710. package/dist-esm/lib/tools/SelectTool/childStates/Crop/children/TranslatingCrop.mjs +81 -0
  711. package/dist-esm/lib/tools/SelectTool/childStates/Crop/children/TranslatingCrop.mjs.map +7 -0
  712. package/dist-esm/lib/tools/SelectTool/childStates/Crop/children/crop_helpers.mjs +40 -0
  713. package/dist-esm/lib/tools/SelectTool/childStates/Crop/children/crop_helpers.mjs.map +7 -0
  714. package/dist-esm/lib/tools/SelectTool/childStates/Crop/crop-constants.mjs +5 -0
  715. package/dist-esm/lib/tools/SelectTool/childStates/Crop/crop-constants.mjs.map +7 -0
  716. package/dist-esm/lib/tools/SelectTool/childStates/Cropping.mjs +194 -0
  717. package/dist-esm/lib/tools/SelectTool/childStates/Cropping.mjs.map +7 -0
  718. package/dist-esm/lib/tools/SelectTool/childStates/DraggingHandle.mjs +217 -0
  719. package/dist-esm/lib/tools/SelectTool/childStates/DraggingHandle.mjs.map +7 -0
  720. package/dist-esm/lib/tools/SelectTool/childStates/EditingShape.mjs +103 -0
  721. package/dist-esm/lib/tools/SelectTool/childStates/EditingShape.mjs.map +7 -0
  722. package/dist-esm/lib/tools/SelectTool/childStates/Idle.mjs +447 -0
  723. package/dist-esm/lib/tools/SelectTool/childStates/Idle.mjs.map +7 -0
  724. package/dist-esm/lib/tools/SelectTool/childStates/PointingCanvas.mjs +36 -0
  725. package/dist-esm/lib/tools/SelectTool/childStates/PointingCanvas.mjs.map +7 -0
  726. package/dist-esm/lib/tools/SelectTool/childStates/PointingCropHandle.mjs +69 -0
  727. package/dist-esm/lib/tools/SelectTool/childStates/PointingCropHandle.mjs.map +7 -0
  728. package/dist-esm/lib/tools/SelectTool/childStates/PointingHandle.mjs +47 -0
  729. package/dist-esm/lib/tools/SelectTool/childStates/PointingHandle.mjs.map +7 -0
  730. package/dist-esm/lib/tools/SelectTool/childStates/PointingResizeHandle.mjs +73 -0
  731. package/dist-esm/lib/tools/SelectTool/childStates/PointingResizeHandle.mjs.map +7 -0
  732. package/dist-esm/lib/tools/SelectTool/childStates/PointingRotateHandle.mjs +63 -0
  733. package/dist-esm/lib/tools/SelectTool/childStates/PointingRotateHandle.mjs.map +7 -0
  734. package/dist-esm/lib/tools/SelectTool/childStates/PointingSelection.mjs +55 -0
  735. package/dist-esm/lib/tools/SelectTool/childStates/PointingSelection.mjs.map +7 -0
  736. package/dist-esm/lib/tools/SelectTool/childStates/PointingShape.mjs +159 -0
  737. package/dist-esm/lib/tools/SelectTool/childStates/PointingShape.mjs.map +7 -0
  738. package/dist-esm/lib/tools/SelectTool/childStates/Resizing.mjs +360 -0
  739. package/dist-esm/lib/tools/SelectTool/childStates/Resizing.mjs.map +7 -0
  740. package/dist-esm/lib/tools/SelectTool/childStates/Rotating.mjs +136 -0
  741. package/dist-esm/lib/tools/SelectTool/childStates/Rotating.mjs.map +7 -0
  742. package/dist-esm/lib/tools/SelectTool/childStates/ScribbleBrushing.mjs +125 -0
  743. package/dist-esm/lib/tools/SelectTool/childStates/ScribbleBrushing.mjs.map +7 -0
  744. package/dist-esm/lib/tools/SelectTool/childStates/Translating.mjs +302 -0
  745. package/dist-esm/lib/tools/SelectTool/childStates/Translating.mjs.map +7 -0
  746. package/dist-esm/lib/tools/SelectTool/children/DraggingHandle.mjs +217 -0
  747. package/dist-esm/lib/tools/SelectTool/children/DraggingHandle.mjs.map +7 -0
  748. package/dist-esm/lib/tools/ZoomTool/ZoomTool.mjs +61 -0
  749. package/dist-esm/lib/tools/ZoomTool/ZoomTool.mjs.map +7 -0
  750. package/dist-esm/lib/tools/ZoomTool/childStates/Idle.mjs +15 -0
  751. package/dist-esm/lib/tools/ZoomTool/childStates/Idle.mjs.map +7 -0
  752. package/dist-esm/lib/tools/ZoomTool/childStates/Pointing.mjs +35 -0
  753. package/dist-esm/lib/tools/ZoomTool/childStates/Pointing.mjs.map +7 -0
  754. package/dist-esm/lib/tools/ZoomTool/childStates/ZoomBrushing.mjs +52 -0
  755. package/dist-esm/lib/tools/ZoomTool/childStates/ZoomBrushing.mjs.map +7 -0
  756. package/dist-esm/lib/tools/selection-logic/getHitShapeOnCanvasPointerDown.mjs +21 -0
  757. package/dist-esm/lib/tools/selection-logic/getHitShapeOnCanvasPointerDown.mjs.map +7 -0
  758. package/dist-esm/lib/tools/selection-logic/getShouldEnterCropModeOnPointerDown.mjs +8 -0
  759. package/dist-esm/lib/tools/selection-logic/getShouldEnterCropModeOnPointerDown.mjs.map +7 -0
  760. package/dist-esm/lib/tools/selection-logic/selectOnCanvasPointerUp.mjs +60 -0
  761. package/dist-esm/lib/tools/selection-logic/selectOnCanvasPointerUp.mjs.map +7 -0
  762. package/dist-esm/lib/tools/selection-logic/updateHoveredId.mjs +27 -0
  763. package/dist-esm/lib/tools/selection-logic/updateHoveredId.mjs.map +7 -0
  764. package/dist-esm/lib/ui/TldrawUi.mjs +125 -0
  765. package/dist-esm/lib/ui/TldrawUi.mjs.map +7 -0
  766. package/dist-esm/lib/ui/TldrawUiContextProvider.mjs +37 -0
  767. package/dist-esm/lib/ui/TldrawUiContextProvider.mjs.map +7 -0
  768. package/dist-esm/lib/ui/assetUrls.mjs +47 -0
  769. package/dist-esm/lib/ui/assetUrls.mjs.map +7 -0
  770. package/dist-esm/lib/ui/components/ActionsMenu.mjs +66 -0
  771. package/dist-esm/lib/ui/components/ActionsMenu.mjs.map +7 -0
  772. package/dist-esm/lib/ui/components/BackToContent.mjs +47 -0
  773. package/dist-esm/lib/ui/components/BackToContent.mjs.map +7 -0
  774. package/dist-esm/lib/ui/components/ContextMenu.mjs +184 -0
  775. package/dist-esm/lib/ui/components/ContextMenu.mjs.map +7 -0
  776. package/dist-esm/lib/ui/components/DebugPanel.mjs +315 -0
  777. package/dist-esm/lib/ui/components/DebugPanel.mjs.map +7 -0
  778. package/dist-esm/lib/ui/components/Dialogs.mjs +34 -0
  779. package/dist-esm/lib/ui/components/Dialogs.mjs.map +7 -0
  780. package/dist-esm/lib/ui/components/DuplicateButton.mjs +27 -0
  781. package/dist-esm/lib/ui/components/DuplicateButton.mjs.map +7 -0
  782. package/dist-esm/lib/ui/components/EditLinkDialog.mjs +131 -0
  783. package/dist-esm/lib/ui/components/EditLinkDialog.mjs.map +7 -0
  784. package/dist-esm/lib/ui/components/EmbedDialog.mjs +122 -0
  785. package/dist-esm/lib/ui/components/EmbedDialog.mjs.map +7 -0
  786. package/dist-esm/lib/ui/components/FollowingIndicator.mjs +21 -0
  787. package/dist-esm/lib/ui/components/FollowingIndicator.mjs.map +7 -0
  788. package/dist-esm/lib/ui/components/HTMLCanvas.mjs +36 -0
  789. package/dist-esm/lib/ui/components/HTMLCanvas.mjs.map +7 -0
  790. package/dist-esm/lib/ui/components/HelpMenu.mjs +86 -0
  791. package/dist-esm/lib/ui/components/HelpMenu.mjs.map +7 -0
  792. package/dist-esm/lib/ui/components/KeyboardShortcutsDialog.mjs +44 -0
  793. package/dist-esm/lib/ui/components/KeyboardShortcutsDialog.mjs.map +7 -0
  794. package/dist-esm/lib/ui/components/LanguageMenu.mjs +30 -0
  795. package/dist-esm/lib/ui/components/LanguageMenu.mjs.map +7 -0
  796. package/dist-esm/lib/ui/components/Menu.mjs +109 -0
  797. package/dist-esm/lib/ui/components/Menu.mjs.map +7 -0
  798. package/dist-esm/lib/ui/components/MenuZone.mjs +31 -0
  799. package/dist-esm/lib/ui/components/MenuZone.mjs.map +7 -0
  800. package/dist-esm/lib/ui/components/MobileStylePanel.mjs +54 -0
  801. package/dist-esm/lib/ui/components/MobileStylePanel.mjs.map +7 -0
  802. package/dist-esm/lib/ui/components/MoveToPageMenu.mjs +112 -0
  803. package/dist-esm/lib/ui/components/MoveToPageMenu.mjs.map +7 -0
  804. package/dist-esm/lib/ui/components/NavigationZone/Minimap.mjs +191 -0
  805. package/dist-esm/lib/ui/components/NavigationZone/Minimap.mjs.map +7 -0
  806. package/dist-esm/lib/ui/components/NavigationZone/MinimapManager.mjs +279 -0
  807. package/dist-esm/lib/ui/components/NavigationZone/MinimapManager.mjs.map +7 -0
  808. package/dist-esm/lib/ui/components/NavigationZone/NavigationZone.mjs +83 -0
  809. package/dist-esm/lib/ui/components/NavigationZone/NavigationZone.mjs.map +7 -0
  810. package/dist-esm/lib/ui/components/NavigationZone/ZoomMenu.mjs +88 -0
  811. package/dist-esm/lib/ui/components/NavigationZone/ZoomMenu.mjs.map +7 -0
  812. package/dist-esm/lib/ui/components/OfflineIndicator/OfflineIndicator.mjs +17 -0
  813. package/dist-esm/lib/ui/components/OfflineIndicator/OfflineIndicator.mjs.map +7 -0
  814. package/dist-esm/lib/ui/components/PageMenu/PageItemInput.mjs +43 -0
  815. package/dist-esm/lib/ui/components/PageMenu/PageItemInput.mjs.map +7 -0
  816. package/dist-esm/lib/ui/components/PageMenu/PageItemSubmenu.mjs +58 -0
  817. package/dist-esm/lib/ui/components/PageMenu/PageItemSubmenu.mjs.map +7 -0
  818. package/dist-esm/lib/ui/components/PageMenu/PageMenu.mjs +381 -0
  819. package/dist-esm/lib/ui/components/PageMenu/PageMenu.mjs.map +7 -0
  820. package/dist-esm/lib/ui/components/PageMenu/edit-pages-shared.mjs +29 -0
  821. package/dist-esm/lib/ui/components/PageMenu/edit-pages-shared.mjs.map +7 -0
  822. package/dist-esm/lib/ui/components/PenModeToggle.mjs +25 -0
  823. package/dist-esm/lib/ui/components/PenModeToggle.mjs.map +7 -0
  824. package/dist-esm/lib/ui/components/RedoButton.mjs +29 -0
  825. package/dist-esm/lib/ui/components/RedoButton.mjs.map +7 -0
  826. package/dist-esm/lib/ui/components/Spinner.mjs +21 -0
  827. package/dist-esm/lib/ui/components/Spinner.mjs.map +7 -0
  828. package/dist-esm/lib/ui/components/StopFollowing.mjs +25 -0
  829. package/dist-esm/lib/ui/components/StopFollowing.mjs.map +7 -0
  830. package/dist-esm/lib/ui/components/StylePanel/DoubleDropdownPicker.mjs +108 -0
  831. package/dist-esm/lib/ui/components/StylePanel/DoubleDropdownPicker.mjs.map +7 -0
  832. package/dist-esm/lib/ui/components/StylePanel/DropdownPicker.mjs +59 -0
  833. package/dist-esm/lib/ui/components/StylePanel/DropdownPicker.mjs.map +7 -0
  834. package/dist-esm/lib/ui/components/StylePanel/StylePanel.mjs +297 -0
  835. package/dist-esm/lib/ui/components/StylePanel/StylePanel.mjs.map +7 -0
  836. package/dist-esm/lib/ui/components/StylePanel/styles.mjs +99 -0
  837. package/dist-esm/lib/ui/components/StylePanel/styles.mjs.map +7 -0
  838. package/dist-esm/lib/ui/components/Toasts.mjs +71 -0
  839. package/dist-esm/lib/ui/components/Toasts.mjs.map +7 -0
  840. package/dist-esm/lib/ui/components/Toolbar/ToggleToolLockedButton.mjs +43 -0
  841. package/dist-esm/lib/ui/components/Toolbar/ToggleToolLockedButton.mjs.map +7 -0
  842. package/dist-esm/lib/ui/components/Toolbar/Toolbar.mjs +217 -0
  843. package/dist-esm/lib/ui/components/Toolbar/Toolbar.mjs.map +7 -0
  844. package/dist-esm/lib/ui/components/TrashButton.mjs +31 -0
  845. package/dist-esm/lib/ui/components/TrashButton.mjs.map +7 -0
  846. package/dist-esm/lib/ui/components/UndoButton.mjs +29 -0
  847. package/dist-esm/lib/ui/components/UndoButton.mjs.map +7 -0
  848. package/dist-esm/lib/ui/components/primitives/Button.mjs +49 -0
  849. package/dist-esm/lib/ui/components/primitives/Button.mjs.map +7 -0
  850. package/dist-esm/lib/ui/components/primitives/ButtonPicker.mjs +96 -0
  851. package/dist-esm/lib/ui/components/primitives/ButtonPicker.mjs.map +7 -0
  852. package/dist-esm/lib/ui/components/primitives/Dialog.mjs +40 -0
  853. package/dist-esm/lib/ui/components/primitives/Dialog.mjs.map +7 -0
  854. package/dist-esm/lib/ui/components/primitives/DropdownMenu.mjs +157 -0
  855. package/dist-esm/lib/ui/components/primitives/DropdownMenu.mjs.map +7 -0
  856. package/dist-esm/lib/ui/components/primitives/Icon.mjs +41 -0
  857. package/dist-esm/lib/ui/components/primitives/Icon.mjs.map +7 -0
  858. package/dist-esm/lib/ui/components/primitives/Input.mjs +125 -0
  859. package/dist-esm/lib/ui/components/primitives/Input.mjs.map +7 -0
  860. package/dist-esm/lib/ui/components/primitives/Kbd.mjs +9 -0
  861. package/dist-esm/lib/ui/components/primitives/Kbd.mjs.map +7 -0
  862. package/dist-esm/lib/ui/components/primitives/Popover.mjs +39 -0
  863. package/dist-esm/lib/ui/components/primitives/Popover.mjs.map +7 -0
  864. package/dist-esm/lib/ui/components/primitives/Slider.mjs +49 -0
  865. package/dist-esm/lib/ui/components/primitives/Slider.mjs.map +7 -0
  866. package/dist-esm/lib/ui/components/primitives/shared.mjs +24 -0
  867. package/dist-esm/lib/ui/components/primitives/shared.mjs.map +7 -0
  868. package/dist-esm/lib/ui/constants.mjs +5 -0
  869. package/dist-esm/lib/ui/constants.mjs.map +7 -0
  870. package/dist-esm/lib/ui/hooks/clipboard/pasteExcalidrawContent.mjs +444 -0
  871. package/dist-esm/lib/ui/hooks/clipboard/pasteExcalidrawContent.mjs.map +7 -0
  872. package/dist-esm/lib/ui/hooks/clipboard/pasteFiles.mjs +17 -0
  873. package/dist-esm/lib/ui/hooks/clipboard/pasteFiles.mjs.map +7 -0
  874. package/dist-esm/lib/ui/hooks/clipboard/pasteTldrawContent.mjs +12 -0
  875. package/dist-esm/lib/ui/hooks/clipboard/pasteTldrawContent.mjs.map +7 -0
  876. package/dist-esm/lib/ui/hooks/clipboard/pasteUrl.mjs +28 -0
  877. package/dist-esm/lib/ui/hooks/clipboard/pasteUrl.mjs.map +7 -0
  878. package/dist-esm/lib/ui/hooks/menuHelpers.mjs +157 -0
  879. package/dist-esm/lib/ui/hooks/menuHelpers.mjs.map +7 -0
  880. package/dist-esm/lib/ui/hooks/useActions.mjs +1132 -0
  881. package/dist-esm/lib/ui/hooks/useActions.mjs.map +7 -0
  882. package/dist-esm/lib/ui/hooks/useActionsMenuSchema.mjs +87 -0
  883. package/dist-esm/lib/ui/hooks/useActionsMenuSchema.mjs.map +7 -0
  884. package/dist-esm/lib/ui/hooks/useAssetUrls.mjs +21 -0
  885. package/dist-esm/lib/ui/hooks/useAssetUrls.mjs.map +7 -0
  886. package/dist-esm/lib/ui/hooks/useBreakpoint.mjs +34 -0
  887. package/dist-esm/lib/ui/hooks/useBreakpoint.mjs.map +7 -0
  888. package/dist-esm/lib/ui/hooks/useCanRedo.mjs +9 -0
  889. package/dist-esm/lib/ui/hooks/useCanRedo.mjs.map +7 -0
  890. package/dist-esm/lib/ui/hooks/useCanUndo.mjs +9 -0
  891. package/dist-esm/lib/ui/hooks/useCanUndo.mjs.map +7 -0
  892. package/dist-esm/lib/ui/hooks/useClipboardEvents.mjs +448 -0
  893. package/dist-esm/lib/ui/hooks/useClipboardEvents.mjs.map +7 -0
  894. package/dist-esm/lib/ui/hooks/useContextMenuSchema.mjs +208 -0
  895. package/dist-esm/lib/ui/hooks/useContextMenuSchema.mjs.map +7 -0
  896. package/dist-esm/lib/ui/hooks/useCopyAs.mjs +27 -0
  897. package/dist-esm/lib/ui/hooks/useCopyAs.mjs.map +7 -0
  898. package/dist-esm/lib/ui/hooks/useDialogsProvider.mjs +88 -0
  899. package/dist-esm/lib/ui/hooks/useDialogsProvider.mjs.map +7 -0
  900. package/dist-esm/lib/ui/hooks/useEditorEvents.mjs +23 -0
  901. package/dist-esm/lib/ui/hooks/useEditorEvents.mjs.map +7 -0
  902. package/dist-esm/lib/ui/hooks/useEventsProvider.mjs +17 -0
  903. package/dist-esm/lib/ui/hooks/useEventsProvider.mjs.map +7 -0
  904. package/dist-esm/lib/ui/hooks/useExportAs.mjs +31 -0
  905. package/dist-esm/lib/ui/hooks/useExportAs.mjs.map +7 -0
  906. package/dist-esm/lib/ui/hooks/useHasLinkShapeSelected.mjs +16 -0
  907. package/dist-esm/lib/ui/hooks/useHasLinkShapeSelected.mjs.map +7 -0
  908. package/dist-esm/lib/ui/hooks/useHelpMenuSchema.mjs +73 -0
  909. package/dist-esm/lib/ui/hooks/useHelpMenuSchema.mjs.map +7 -0
  910. package/dist-esm/lib/ui/hooks/useHighDpiCanvas.mjs +15 -0
  911. package/dist-esm/lib/ui/hooks/useHighDpiCanvas.mjs.map +7 -0
  912. package/dist-esm/lib/ui/hooks/useInsertMedia.mjs +37 -0
  913. package/dist-esm/lib/ui/hooks/useInsertMedia.mjs.map +7 -0
  914. package/dist-esm/lib/ui/hooks/useKeyboardShortcuts.mjs +108 -0
  915. package/dist-esm/lib/ui/hooks/useKeyboardShortcuts.mjs.map +7 -0
  916. package/dist-esm/lib/ui/hooks/useKeyboardShortcutsSchema.mjs +104 -0
  917. package/dist-esm/lib/ui/hooks/useKeyboardShortcutsSchema.mjs.map +7 -0
  918. package/dist-esm/lib/ui/hooks/useLocalStorageState.mjs +29 -0
  919. package/dist-esm/lib/ui/hooks/useLocalStorageState.mjs.map +7 -0
  920. package/dist-esm/lib/ui/hooks/useMenuIsOpen.mjs +54 -0
  921. package/dist-esm/lib/ui/hooks/useMenuIsOpen.mjs.map +7 -0
  922. package/dist-esm/lib/ui/hooks/useMenuSchema.mjs +239 -0
  923. package/dist-esm/lib/ui/hooks/useMenuSchema.mjs.map +7 -0
  924. package/dist-esm/lib/ui/hooks/useOnlyFlippableShape.mjs +21 -0
  925. package/dist-esm/lib/ui/hooks/useOnlyFlippableShape.mjs.map +7 -0
  926. package/dist-esm/lib/ui/hooks/usePreloadAssets.mjs +86 -0
  927. package/dist-esm/lib/ui/hooks/usePreloadAssets.mjs.map +7 -0
  928. package/dist-esm/lib/ui/hooks/usePreloadIcons.mjs +31 -0
  929. package/dist-esm/lib/ui/hooks/usePreloadIcons.mjs.map +7 -0
  930. package/dist-esm/lib/ui/hooks/usePrint.mjs +200 -0
  931. package/dist-esm/lib/ui/hooks/usePrint.mjs.map +7 -0
  932. package/dist-esm/lib/ui/hooks/useReadonly.mjs +9 -0
  933. package/dist-esm/lib/ui/hooks/useReadonly.mjs.map +7 -0
  934. package/dist-esm/lib/ui/hooks/useRevelantStyles.mjs +33 -0
  935. package/dist-esm/lib/ui/hooks/useRevelantStyles.mjs.map +7 -0
  936. package/dist-esm/lib/ui/hooks/useShowAutoSizeToggle.mjs +16 -0
  937. package/dist-esm/lib/ui/hooks/useShowAutoSizeToggle.mjs.map +7 -0
  938. package/dist-esm/lib/ui/hooks/useToastsProvider.mjs +33 -0
  939. package/dist-esm/lib/ui/hooks/useToastsProvider.mjs.map +7 -0
  940. package/dist-esm/lib/ui/hooks/useToolbarSchema.mjs +69 -0
  941. package/dist-esm/lib/ui/hooks/useToolbarSchema.mjs.map +7 -0
  942. package/dist-esm/lib/ui/hooks/useTools.mjs +205 -0
  943. package/dist-esm/lib/ui/hooks/useTools.mjs.map +7 -0
  944. package/dist-esm/lib/ui/hooks/useTranslation/TLUiTranslationKey.mjs +1 -0
  945. package/dist-esm/lib/ui/hooks/useTranslation/TLUiTranslationKey.mjs.map +7 -0
  946. package/dist-esm/lib/ui/hooks/useTranslation/defaultTranslation.mjs +357 -0
  947. package/dist-esm/lib/ui/hooks/useTranslation/defaultTranslation.mjs.map +7 -0
  948. package/dist-esm/lib/ui/hooks/useTranslation/translations.mjs +47 -0
  949. package/dist-esm/lib/ui/hooks/useTranslation/translations.mjs.map +7 -0
  950. package/dist-esm/lib/ui/hooks/useTranslation/useLanguages.mjs +12 -0
  951. package/dist-esm/lib/ui/hooks/useTranslation/useLanguages.mjs.map +7 -0
  952. package/dist-esm/lib/ui/hooks/useTranslation/useTranslation.mjs +71 -0
  953. package/dist-esm/lib/ui/hooks/useTranslation/useTranslation.mjs.map +7 -0
  954. package/dist-esm/lib/ui/icon-types.mjs +170 -0
  955. package/dist-esm/lib/ui/icon-types.mjs.map +7 -0
  956. package/dist-esm/lib/ui/overrides.mjs +158 -0
  957. package/dist-esm/lib/ui/overrides.mjs.map +7 -0
  958. package/dist-esm/lib/ui/version.mjs +5 -0
  959. package/dist-esm/lib/ui/version.mjs.map +7 -0
  960. package/dist-esm/lib/utils/assets/assets.mjs +61 -0
  961. package/dist-esm/lib/utils/assets/assets.mjs.map +7 -0
  962. package/dist-esm/lib/utils/assets/is-gif-animated.mjs +54 -0
  963. package/dist-esm/lib/utils/assets/is-gif-animated.mjs.map +7 -0
  964. package/dist-esm/lib/utils/assets.mjs +61 -0
  965. package/dist-esm/lib/utils/assets.mjs.map +7 -0
  966. package/dist-esm/lib/utils/embeds/embeds.mjs +65 -0
  967. package/dist-esm/lib/utils/embeds/embeds.mjs.map +7 -0
  968. package/dist-esm/lib/utils/export/copyAs.mjs +96 -0
  969. package/dist-esm/lib/utils/export/copyAs.mjs.map +7 -0
  970. package/dist-esm/lib/utils/export/export.mjs +97 -0
  971. package/dist-esm/lib/utils/export/export.mjs.map +7 -0
  972. package/dist-esm/lib/utils/export/exportAs.mjs +68 -0
  973. package/dist-esm/lib/utils/export/exportAs.mjs.map +7 -0
  974. package/dist-esm/lib/utils/frames/frames.mjs +76 -0
  975. package/dist-esm/lib/utils/frames/frames.mjs.map +7 -0
  976. package/dist-esm/lib/utils/static-assets/assetUrls.mjs +28 -0
  977. package/dist-esm/lib/utils/static-assets/assetUrls.mjs.map +7 -0
  978. package/dist-esm/lib/utils/text/text.mjs +37 -0
  979. package/dist-esm/lib/utils/text/text.mjs.map +7 -0
  980. package/dist-esm/lib/utils/tldr/buildFromV1Document.mjs +779 -0
  981. package/dist-esm/lib/utils/tldr/buildFromV1Document.mjs.map +7 -0
  982. package/dist-esm/lib/utils/tldr/file.mjs +219 -0
  983. package/dist-esm/lib/utils/tldr/file.mjs.map +7 -0
  984. package/package.json +105 -0
  985. package/src/index.ts +174 -0
  986. package/src/lib/Tldraw.test.tsx +78 -0
  987. package/src/lib/Tldraw.tsx +179 -0
  988. package/src/lib/canvas/TldrawCropHandles.tsx +126 -0
  989. package/src/lib/canvas/TldrawHandles.tsx +15 -0
  990. package/src/lib/canvas/TldrawHoveredShapeIndicator.tsx +30 -0
  991. package/src/lib/canvas/TldrawScribble.tsx +45 -0
  992. package/src/lib/canvas/TldrawSelectionBackground.tsx +29 -0
  993. package/src/lib/canvas/TldrawSelectionForeground.tsx +526 -0
  994. package/src/lib/defaultExternalContentHandlers.ts +533 -0
  995. package/src/lib/defaultShapeTools.ts +20 -0
  996. package/src/lib/defaultShapeUtils.ts +29 -0
  997. package/src/lib/defaultSideEffects.ts +48 -0
  998. package/src/lib/defaultTools.ts +8 -0
  999. package/src/lib/shapes/arrow/ArrowShapeTool.test.ts +558 -0
  1000. package/src/lib/shapes/arrow/ArrowShapeTool.ts +12 -0
  1001. package/src/lib/shapes/arrow/ArrowShapeUtil.test.ts +595 -0
  1002. package/src/lib/shapes/arrow/ArrowShapeUtil.tsx +1036 -0
  1003. package/src/lib/shapes/arrow/components/ArrowTextLabel.tsx +87 -0
  1004. package/src/lib/shapes/arrow/toolStates/Idle.ts +37 -0
  1005. package/src/lib/shapes/arrow/toolStates/Pointing.ts +190 -0
  1006. package/src/lib/shapes/bookmark/BookmarkShapeUtil.tsx +196 -0
  1007. package/src/lib/shapes/draw/DrawShapeTool.test.ts +52 -0
  1008. package/src/lib/shapes/draw/DrawShapeTool.ts +17 -0
  1009. package/src/lib/shapes/draw/DrawShapeUtil.tsx +298 -0
  1010. package/src/lib/shapes/draw/getPath.ts +108 -0
  1011. package/src/lib/shapes/draw/toolStates/Drawing.ts +722 -0
  1012. package/src/lib/shapes/draw/toolStates/Idle.ts +17 -0
  1013. package/src/lib/shapes/embed/EmbedShapeUtil.tsx +218 -0
  1014. package/src/lib/shapes/frame/FrameShapeTool.test.ts +169 -0
  1015. package/src/lib/shapes/frame/FrameShapeTool.ts +53 -0
  1016. package/src/lib/shapes/frame/FrameShapeUtil.tsx +258 -0
  1017. package/src/lib/shapes/frame/components/FrameHeading.tsx +115 -0
  1018. package/src/lib/shapes/frame/components/FrameLabelInput.tsx +85 -0
  1019. package/src/lib/shapes/geo/GeoShapeTool.test.ts +191 -0
  1020. package/src/lib/shapes/geo/GeoShapeTool.ts +11 -0
  1021. package/src/lib/shapes/geo/GeoShapeUtil.tsx +1153 -0
  1022. package/src/lib/shapes/geo/cloudOutline.ts +391 -0
  1023. package/src/lib/shapes/geo/components/DashStyleCloud.tsx +135 -0
  1024. package/src/lib/shapes/geo/components/DashStyleEllipse.tsx +117 -0
  1025. package/src/lib/shapes/geo/components/DashStyleOval.tsx +102 -0
  1026. package/src/lib/shapes/geo/components/DashStylePolygon.tsx +152 -0
  1027. package/src/lib/shapes/geo/components/DrawStyleCloud.tsx +65 -0
  1028. package/src/lib/shapes/geo/components/DrawStyleEllipse.tsx +145 -0
  1029. package/src/lib/shapes/geo/components/DrawStylePolygon.tsx +263 -0
  1030. package/src/lib/shapes/geo/components/SolidStyleCloud.tsx +65 -0
  1031. package/src/lib/shapes/geo/components/SolidStyleEllipse.tsx +68 -0
  1032. package/src/lib/shapes/geo/components/SolidStyleOval.tsx +83 -0
  1033. package/src/lib/shapes/geo/components/SolidStylePolygon.tsx +77 -0
  1034. package/src/lib/shapes/geo/helpers.ts +34 -0
  1035. package/src/lib/shapes/geo/toolStates/Idle.ts +38 -0
  1036. package/src/lib/shapes/geo/toolStates/Pointing.ts +131 -0
  1037. package/src/lib/shapes/highlight/HighlightShapeTool.test.ts +3 -0
  1038. package/src/lib/shapes/highlight/HighlightShapeTool.ts +17 -0
  1039. package/src/lib/shapes/highlight/HighlightShapeUtil.tsx +255 -0
  1040. package/src/lib/shapes/image/ImageShapeUtil.tsx +313 -0
  1041. package/src/lib/shapes/line/LineShapeTool.test.ts +228 -0
  1042. package/src/lib/shapes/line/LineShapeTool.ts +12 -0
  1043. package/src/lib/shapes/line/LineShapeUtil.test.ts +222 -0
  1044. package/src/lib/shapes/line/LineShapeUtil.tsx +421 -0
  1045. package/src/lib/shapes/line/__snapshots__/LineShapeUtil.test.ts.snap +41 -0
  1046. package/src/lib/shapes/line/components/getLinePath.ts +91 -0
  1047. package/src/lib/shapes/line/components/svg.ts +62 -0
  1048. package/src/lib/shapes/line/toolStates/Idle.ts +20 -0
  1049. package/src/lib/shapes/line/toolStates/Pointing.ts +165 -0
  1050. package/src/lib/shapes/note/NoteShapeTool.test.ts +146 -0
  1051. package/src/lib/shapes/note/NoteShapeTool.ts +11 -0
  1052. package/src/lib/shapes/note/NoteShapeUtil.tsx +221 -0
  1053. package/src/lib/shapes/note/toolStates/Idle.ts +17 -0
  1054. package/src/lib/shapes/note/toolStates/Pointing.ts +121 -0
  1055. package/src/lib/shapes/shared/HyperlinkButton.tsx +30 -0
  1056. package/src/lib/shapes/shared/ShapeFill.tsx +113 -0
  1057. package/src/lib/shapes/shared/TextHelpers.ts +289 -0
  1058. package/src/lib/shapes/shared/TextLabel.tsx +131 -0
  1059. package/src/lib/shapes/shared/createTextSvgElementFromSpans.ts +101 -0
  1060. package/src/lib/shapes/shared/default-shape-constants.ts +57 -0
  1061. package/src/lib/shapes/shared/defaultStyleDefs.tsx +276 -0
  1062. package/src/lib/shapes/shared/freehand/getStroke.ts +23 -0
  1063. package/src/lib/shapes/shared/freehand/getStrokeOutlinePoints.ts +333 -0
  1064. package/src/lib/shapes/shared/freehand/getStrokePoints.ts +187 -0
  1065. package/src/lib/shapes/shared/freehand/getStrokeRadius.ts +13 -0
  1066. package/src/lib/shapes/shared/freehand/setStrokePointRadii.ts +127 -0
  1067. package/src/lib/shapes/shared/freehand/svg.ts +50 -0
  1068. package/src/lib/shapes/shared/freehand/svgInk.ts +195 -0
  1069. package/src/lib/shapes/shared/freehand/types.ts +49 -0
  1070. package/src/lib/shapes/shared/getBrowserCanvasMaxSize.tsx +28 -0
  1071. package/src/lib/shapes/shared/getPerfectDashProps.ts +96 -0
  1072. package/src/lib/shapes/shared/getTextLabelSvgElement.ts +42 -0
  1073. package/src/lib/shapes/shared/legacyProps.ts +25 -0
  1074. package/src/lib/shapes/shared/polygon-helpers.ts +131 -0
  1075. package/src/lib/shapes/shared/resizeBox.ts +130 -0
  1076. package/src/lib/shapes/shared/resizeScaled.ts +40 -0
  1077. package/src/lib/shapes/shared/rotated-box-shadow.ts +29 -0
  1078. package/src/lib/shapes/shared/useColorSpace.tsx +21 -0
  1079. package/src/lib/shapes/shared/useEditableText.ts +211 -0
  1080. package/src/lib/shapes/shared/useForceSolid.ts +6 -0
  1081. package/src/lib/shapes/shared/usePrefersReducedMotion.tsx +18 -0
  1082. package/src/lib/shapes/text/TextShapeTool.test.ts +157 -0
  1083. package/src/lib/shapes/text/TextShapeTool.ts +11 -0
  1084. package/src/lib/shapes/text/TextShapeUtil.tsx +401 -0
  1085. package/src/lib/shapes/text/toolStates/Idle.ts +47 -0
  1086. package/src/lib/shapes/text/toolStates/Pointing.ts +105 -0
  1087. package/src/lib/shapes/video/VideoShapeUtil.tsx +215 -0
  1088. package/src/lib/tools/EraserTool/EraserTool.ts +15 -0
  1089. package/src/lib/tools/EraserTool/childStates/Erasing.ts +131 -0
  1090. package/src/lib/tools/EraserTool/childStates/Idle.ts +13 -0
  1091. package/src/lib/tools/EraserTool/childStates/Pointing.ts +93 -0
  1092. package/src/lib/tools/HandTool/HandTool.ts +40 -0
  1093. package/src/lib/tools/HandTool/childStates/Dragging.ts +45 -0
  1094. package/src/lib/tools/HandTool/childStates/Idle.ts +17 -0
  1095. package/src/lib/tools/HandTool/childStates/Pointing.ts +39 -0
  1096. package/src/lib/tools/LaserTool/LaserTool.ts +14 -0
  1097. package/src/lib/tools/LaserTool/childStates/Idle.ts +9 -0
  1098. package/src/lib/tools/LaserTool/childStates/Lasering.ts +53 -0
  1099. package/src/lib/tools/SelectTool/DragAndDropManager.ts +112 -0
  1100. package/src/lib/tools/SelectTool/SelectTool.ts +49 -0
  1101. package/src/lib/tools/SelectTool/childStates/Brushing.ts +206 -0
  1102. package/src/lib/tools/SelectTool/childStates/Crop/Crop.ts +10 -0
  1103. package/src/lib/tools/SelectTool/childStates/Crop/children/Idle.ts +217 -0
  1104. package/src/lib/tools/SelectTool/childStates/Crop/children/PointingCrop.ts +19 -0
  1105. package/src/lib/tools/SelectTool/childStates/Crop/children/TranslatingCrop.ts +108 -0
  1106. package/src/lib/tools/SelectTool/childStates/Crop/children/crop_helpers.ts +64 -0
  1107. package/src/lib/tools/SelectTool/childStates/Crop/crop-constants.ts +2 -0
  1108. package/src/lib/tools/SelectTool/childStates/Cropping.ts +249 -0
  1109. package/src/lib/tools/SelectTool/childStates/DraggingHandle.ts +308 -0
  1110. package/src/lib/tools/SelectTool/childStates/EditingShape.ts +130 -0
  1111. package/src/lib/tools/SelectTool/childStates/Idle.ts +575 -0
  1112. package/src/lib/tools/SelectTool/childStates/PointingCanvas.ts +41 -0
  1113. package/src/lib/tools/SelectTool/childStates/PointingCropHandle.ts +83 -0
  1114. package/src/lib/tools/SelectTool/childStates/PointingHandle.ts +56 -0
  1115. package/src/lib/tools/SelectTool/childStates/PointingResizeHandle.ts +90 -0
  1116. package/src/lib/tools/SelectTool/childStates/PointingRotateHandle.ts +76 -0
  1117. package/src/lib/tools/SelectTool/childStates/PointingSelection.ts +71 -0
  1118. package/src/lib/tools/SelectTool/childStates/PointingShape.ts +218 -0
  1119. package/src/lib/tools/SelectTool/childStates/Resizing.ts +511 -0
  1120. package/src/lib/tools/SelectTool/childStates/Rotating.ts +175 -0
  1121. package/src/lib/tools/SelectTool/childStates/ScribbleBrushing.ts +167 -0
  1122. package/src/lib/tools/SelectTool/childStates/Translating.ts +418 -0
  1123. package/src/lib/tools/SelectTool/children/DraggingHandle.ts +308 -0
  1124. package/src/lib/tools/ZoomTool/ZoomTool.ts +72 -0
  1125. package/src/lib/tools/ZoomTool/childStates/Idle.ts +15 -0
  1126. package/src/lib/tools/ZoomTool/childStates/Pointing.ts +39 -0
  1127. package/src/lib/tools/ZoomTool/childStates/ZoomBrushing.ts +62 -0
  1128. package/src/lib/tools/selection-logic/getHitShapeOnCanvasPointerDown.ts +20 -0
  1129. package/src/lib/tools/selection-logic/getShouldEnterCropModeOnPointerDown.ts +10 -0
  1130. package/src/lib/tools/selection-logic/selectOnCanvasPointerUp.ts +94 -0
  1131. package/src/lib/tools/selection-logic/selection.tldr +1041 -0
  1132. package/src/lib/tools/selection-logic/updateHoveredId.ts +32 -0
  1133. package/src/lib/ui/TldrawUi.tsx +195 -0
  1134. package/src/lib/ui/TldrawUiContextProvider.tsx +99 -0
  1135. package/src/lib/ui/assetUrls.ts +57 -0
  1136. package/src/lib/ui/components/ActionsMenu.tsx +75 -0
  1137. package/src/lib/ui/components/BackToContent.tsx +55 -0
  1138. package/src/lib/ui/components/ContextMenu.tsx +234 -0
  1139. package/src/lib/ui/components/DebugPanel.tsx +355 -0
  1140. package/src/lib/ui/components/Dialogs.tsx +52 -0
  1141. package/src/lib/ui/components/DuplicateButton.tsx +23 -0
  1142. package/src/lib/ui/components/EditLinkDialog.tsx +180 -0
  1143. package/src/lib/ui/components/EmbedDialog.tsx +143 -0
  1144. package/src/lib/ui/components/FollowingIndicator.tsx +16 -0
  1145. package/src/lib/ui/components/HTMLCanvas.tsx +54 -0
  1146. package/src/lib/ui/components/HelpMenu.tsx +109 -0
  1147. package/src/lib/ui/components/KeyboardShortcutsDialog.tsx +62 -0
  1148. package/src/lib/ui/components/LanguageMenu.tsx +38 -0
  1149. package/src/lib/ui/components/Menu.tsx +129 -0
  1150. package/src/lib/ui/components/MenuZone.tsx +35 -0
  1151. package/src/lib/ui/components/MobileStylePanel.tsx +61 -0
  1152. package/src/lib/ui/components/MoveToPageMenu.tsx +104 -0
  1153. package/src/lib/ui/components/NavigationZone/Minimap.tsx +245 -0
  1154. package/src/lib/ui/components/NavigationZone/MinimapManager.ts +382 -0
  1155. package/src/lib/ui/components/NavigationZone/NavigationZone.tsx +81 -0
  1156. package/src/lib/ui/components/NavigationZone/ZoomMenu.tsx +87 -0
  1157. package/src/lib/ui/components/OfflineIndicator/OfflineIndicator.tsx +17 -0
  1158. package/src/lib/ui/components/PageMenu/PageItemInput.tsx +46 -0
  1159. package/src/lib/ui/components/PageMenu/PageItemSubmenu.tsx +86 -0
  1160. package/src/lib/ui/components/PageMenu/PageMenu.tsx +415 -0
  1161. package/src/lib/ui/components/PageMenu/edit-pages-shared.ts +32 -0
  1162. package/src/lib/ui/components/PenModeToggle.tsx +24 -0
  1163. package/src/lib/ui/components/RedoButton.tsx +26 -0
  1164. package/src/lib/ui/components/Spinner.tsx +22 -0
  1165. package/src/lib/ui/components/StopFollowing.tsx +23 -0
  1166. package/src/lib/ui/components/StylePanel/DoubleDropdownPicker.tsx +150 -0
  1167. package/src/lib/ui/components/StylePanel/DropdownPicker.tsx +76 -0
  1168. package/src/lib/ui/components/StylePanel/StylePanel.tsx +332 -0
  1169. package/src/lib/ui/components/StylePanel/styles.tsx +100 -0
  1170. package/src/lib/ui/components/Toasts.tsx +104 -0
  1171. package/src/lib/ui/components/Toolbar/ToggleToolLockedButton.tsx +45 -0
  1172. package/src/lib/ui/components/Toolbar/Toolbar.tsx +281 -0
  1173. package/src/lib/ui/components/TrashButton.tsx +28 -0
  1174. package/src/lib/ui/components/UndoButton.tsx +26 -0
  1175. package/src/lib/ui/components/primitives/Button.tsx +69 -0
  1176. package/src/lib/ui/components/primitives/ButtonPicker.tsx +128 -0
  1177. package/src/lib/ui/components/primitives/Dialog.tsx +57 -0
  1178. package/src/lib/ui/components/primitives/DropdownMenu.tsx +229 -0
  1179. package/src/lib/ui/components/primitives/Icon.tsx +55 -0
  1180. package/src/lib/ui/components/primitives/Input.tsx +165 -0
  1181. package/src/lib/ui/components/primitives/Kbd.tsx +17 -0
  1182. package/src/lib/ui/components/primitives/Popover.tsx +61 -0
  1183. package/src/lib/ui/components/primitives/Slider.tsx +62 -0
  1184. package/src/lib/ui/components/primitives/shared.ts +40 -0
  1185. package/src/lib/ui/constants.ts +2 -0
  1186. package/src/lib/ui/hooks/clipboard/pasteExcalidrawContent.ts +514 -0
  1187. package/src/lib/ui/hooks/clipboard/pasteFiles.ts +31 -0
  1188. package/src/lib/ui/hooks/clipboard/pasteTldrawContent.ts +19 -0
  1189. package/src/lib/ui/hooks/clipboard/pasteUrl.ts +44 -0
  1190. package/src/lib/ui/hooks/menuHelpers.ts +247 -0
  1191. package/src/lib/ui/hooks/useActions.tsx +1180 -0
  1192. package/src/lib/ui/hooks/useActionsMenuSchema.tsx +123 -0
  1193. package/src/lib/ui/hooks/useAssetUrls.tsx +28 -0
  1194. package/src/lib/ui/hooks/useBreakpoint.tsx +42 -0
  1195. package/src/lib/ui/hooks/useCanRedo.ts +7 -0
  1196. package/src/lib/ui/hooks/useCanUndo.ts +7 -0
  1197. package/src/lib/ui/hooks/useClipboardEvents.ts +705 -0
  1198. package/src/lib/ui/hooks/useContextMenuSchema.tsx +260 -0
  1199. package/src/lib/ui/hooks/useCopyAs.ts +26 -0
  1200. package/src/lib/ui/hooks/useDialogsProvider.tsx +128 -0
  1201. package/src/lib/ui/hooks/useEditorEvents.ts +23 -0
  1202. package/src/lib/ui/hooks/useEventsProvider.tsx +129 -0
  1203. package/src/lib/ui/hooks/useExportAs.ts +30 -0
  1204. package/src/lib/ui/hooks/useHasLinkShapeSelected.ts +17 -0
  1205. package/src/lib/ui/hooks/useHelpMenuSchema.tsx +105 -0
  1206. package/src/lib/ui/hooks/useHighDpiCanvas.ts +14 -0
  1207. package/src/lib/ui/hooks/useInsertMedia.ts +35 -0
  1208. package/src/lib/ui/hooks/useKeyboardShortcuts.ts +121 -0
  1209. package/src/lib/ui/hooks/useKeyboardShortcutsSchema.tsx +127 -0
  1210. package/src/lib/ui/hooks/useLocalStorageState.ts +30 -0
  1211. package/src/lib/ui/hooks/useMenuIsOpen.ts +73 -0
  1212. package/src/lib/ui/hooks/useMenuSchema.tsx +280 -0
  1213. package/src/lib/ui/hooks/useOnlyFlippableShape.ts +29 -0
  1214. package/src/lib/ui/hooks/usePreloadAssets.ts +120 -0
  1215. package/src/lib/ui/hooks/usePreloadIcons.ts +38 -0
  1216. package/src/lib/ui/hooks/usePrint.ts +223 -0
  1217. package/src/lib/ui/hooks/useReadonly.ts +7 -0
  1218. package/src/lib/ui/hooks/useRevelantStyles.ts +38 -0
  1219. package/src/lib/ui/hooks/useShowAutoSizeToggle.ts +17 -0
  1220. package/src/lib/ui/hooks/useToastsProvider.tsx +75 -0
  1221. package/src/lib/ui/hooks/useToolbarSchema.tsx +99 -0
  1222. package/src/lib/ui/hooks/useTools.tsx +245 -0
  1223. package/src/lib/ui/hooks/useTranslation/TLUiTranslationKey.ts +356 -0
  1224. package/src/lib/ui/hooks/useTranslation/defaultTranslation.ts +367 -0
  1225. package/src/lib/ui/hooks/useTranslation/translations.ts +74 -0
  1226. package/src/lib/ui/hooks/useTranslation/useLanguages.tsx +10 -0
  1227. package/src/lib/ui/hooks/useTranslation/useTranslation.tsx +117 -0
  1228. package/src/lib/ui/icon-types.ts +337 -0
  1229. package/src/lib/ui/overrides.ts +211 -0
  1230. package/src/lib/ui/version.ts +1 -0
  1231. package/src/lib/ui.css +1603 -0
  1232. package/src/lib/utils/assets/assets.ts +103 -0
  1233. package/src/lib/utils/assets/is-gif-animated.ts +106 -0
  1234. package/src/lib/utils/assets.ts +103 -0
  1235. package/src/lib/utils/embeds/embeds.test.ts +612 -0
  1236. package/src/lib/utils/embeds/embeds.ts +99 -0
  1237. package/src/lib/utils/export/copyAs.ts +139 -0
  1238. package/src/lib/utils/export/export.ts +128 -0
  1239. package/src/lib/utils/export/exportAs.ts +94 -0
  1240. package/src/lib/utils/frames/frames.ts +101 -0
  1241. package/src/lib/utils/static-assets/assetUrls.ts +41 -0
  1242. package/src/lib/utils/text/text.test.ts +11 -0
  1243. package/src/lib/utils/text/text.ts +59 -0
  1244. package/src/lib/utils/tldr/buildFromV1Document.ts +1171 -0
  1245. package/src/lib/utils/tldr/file.ts +303 -0
  1246. package/src/test/ClickManager.test.ts +258 -0
  1247. package/src/test/Editor.test.tsx +647 -0
  1248. package/src/test/EraserTool.test.ts +446 -0
  1249. package/src/test/HandTool.test.ts +191 -0
  1250. package/src/test/HighlightShape.test.ts +24 -0
  1251. package/src/test/LaserTool.test.ts +3 -0
  1252. package/src/test/SelectTool.test.ts +445 -0
  1253. package/src/test/TLSessionStateSnapshot.test.ts +152 -0
  1254. package/src/test/TLUserPreferences.test.ts +123 -0
  1255. package/src/test/TestEditor.test.ts +7 -0
  1256. package/src/test/TestEditor.ts +661 -0
  1257. package/src/test/TldrawEditor.test.tsx +377 -0
  1258. package/src/test/ZoomTool.test.ts +210 -0
  1259. package/src/test/__snapshots__/groups.test.ts.snap +46 -0
  1260. package/src/test/__snapshots__/resizing.test.ts.snap +43 -0
  1261. package/src/test/arrowBindingsIndex.test.tsx +295 -0
  1262. package/src/test/arrows-megabus.test.ts +652 -0
  1263. package/src/test/assets.test.ts +38 -0
  1264. package/src/test/bookmark-shapes.test.ts +141 -0
  1265. package/src/test/cleanup.test.ts +127 -0
  1266. package/src/test/commands/__snapshots__/getSvg.test.ts.snap +174 -0
  1267. package/src/test/commands/__snapshots__/packShapes.test.ts.snap +185 -0
  1268. package/src/test/commands/__snapshots__/zoomToFit.test.ts.snap +12 -0
  1269. package/src/test/commands/alignShapes.test.tsx +388 -0
  1270. package/src/test/commands/allShapesCommonBounds.test.ts +91 -0
  1271. package/src/test/commands/animateShapes.test.ts +3 -0
  1272. package/src/test/commands/animateToShape.test.ts +3 -0
  1273. package/src/test/commands/animationSpeed.test.ts +38 -0
  1274. package/src/test/commands/blur.test.ts +3 -0
  1275. package/src/test/commands/cancel.test.ts +3 -0
  1276. package/src/test/commands/centerOnPoint.test.ts +21 -0
  1277. package/src/test/commands/clipboard.test.ts +481 -0
  1278. package/src/test/commands/complete.test.ts +3 -0
  1279. package/src/test/commands/createPage.test.ts +65 -0
  1280. package/src/test/commands/createShapes.test.ts +141 -0
  1281. package/src/test/commands/deletePage.test.ts +79 -0
  1282. package/src/test/commands/deleteShapes.test.ts +113 -0
  1283. package/src/test/commands/distributeShapes.test.ts +232 -0
  1284. package/src/test/commands/duplicatePage.test.ts +55 -0
  1285. package/src/test/commands/getContent.test.ts +9 -0
  1286. package/src/test/commands/getInitialMetaForShape.test.ts +21 -0
  1287. package/src/test/commands/getSvg.test.ts +110 -0
  1288. package/src/test/commands/groupShapes.test.ts +42 -0
  1289. package/src/test/commands/guide.md +12 -0
  1290. package/src/test/commands/interrupt.test.ts +3 -0
  1291. package/src/test/commands/lockShapes.test.ts +176 -0
  1292. package/src/test/commands/moveShapesToPage.test.ts +254 -0
  1293. package/src/test/commands/nudge.test.ts +292 -0
  1294. package/src/test/commands/packShapes.test.ts +62 -0
  1295. package/src/test/commands/pageToScreen.test.ts +25 -0
  1296. package/src/test/commands/pan.test.ts +32 -0
  1297. package/src/test/commands/penmode.test.ts +27 -0
  1298. package/src/test/commands/pinch.test.ts +11 -0
  1299. package/src/test/commands/putContent.test.ts +39 -0
  1300. package/src/test/commands/reorderShapes.test.ts +950 -0
  1301. package/src/test/commands/reparentShapesById.test.ts +162 -0
  1302. package/src/test/commands/resetZoom.test.ts +30 -0
  1303. package/src/test/commands/resizeShape.test.ts +58 -0
  1304. package/src/test/commands/rotateShapes.test.ts +82 -0
  1305. package/src/test/commands/screenToPage.test.ts +246 -0
  1306. package/src/test/commands/setAppState.test.ts +9 -0
  1307. package/src/test/commands/setBrush.test.ts +38 -0
  1308. package/src/test/commands/setCurrentPage.test.ts +88 -0
  1309. package/src/test/commands/setPageState.test.ts +9 -0
  1310. package/src/test/commands/setSelectedIds.test.ts +57 -0
  1311. package/src/test/commands/setSelectedTool.test.ts +23 -0
  1312. package/src/test/commands/setSettings.test.ts +9 -0
  1313. package/src/test/commands/setStyle.test.ts +11 -0
  1314. package/src/test/commands/squash.test.ts +13 -0
  1315. package/src/test/commands/stackShapes.test.ts +227 -0
  1316. package/src/test/commands/stretch.test.tsx +245 -0
  1317. package/src/test/commands/ungroup.test.ts +17 -0
  1318. package/src/test/commands/updateShapes.test.ts +192 -0
  1319. package/src/test/commands/updateViewportPageBounds.test.ts +123 -0
  1320. package/src/test/commands/zoomIn.test.ts +43 -0
  1321. package/src/test/commands/zoomOut.test.ts +31 -0
  1322. package/src/test/commands/zoomToBounds.test.ts +50 -0
  1323. package/src/test/commands/zoomToFit.test.ts +20 -0
  1324. package/src/test/commands/zoomToSelection.test.ts +42 -0
  1325. package/src/test/cropping.test.ts +1033 -0
  1326. package/src/test/drawing.test.ts +262 -0
  1327. package/src/test/duplicate.test.ts +217 -0
  1328. package/src/test/flipShapes.test.ts +581 -0
  1329. package/src/test/frames.test.ts +995 -0
  1330. package/src/test/getShapeAtPoint.test.ts +168 -0
  1331. package/src/test/getSnapLines.ts +25 -0
  1332. package/src/test/groups.test.ts +2005 -0
  1333. package/src/test/middleMouseButtonPanning.test.ts +31 -0
  1334. package/src/test/modifiers.test.ts +36 -0
  1335. package/src/test/panning.test.ts +25 -0
  1336. package/src/test/parentsToChildrenWithIndexes.test.ts +117 -0
  1337. package/src/test/paste.test.ts +494 -0
  1338. package/src/test/renderingShapes.test.tsx +223 -0
  1339. package/src/test/resizeBox.test.ts +106 -0
  1340. package/src/test/resizing.test.ts +3901 -0
  1341. package/src/test/rotating.test.ts +321 -0
  1342. package/src/test/roundedBox.ts +13 -0
  1343. package/src/test/select.test.tsx +172 -0
  1344. package/src/test/selection-omnibus.test.ts +1710 -0
  1345. package/src/test/shapeIdsInCurrentPage.test.ts +75 -0
  1346. package/src/test/shapeutils.test.ts +204 -0
  1347. package/src/test/spacebarPanning.test.ts +50 -0
  1348. package/src/test/styles2.test.tsx +199 -0
  1349. package/src/test/styles3.test.ts +70 -0
  1350. package/src/test/test-jsx.tsx +134 -0
  1351. package/src/test/testutils/getSnapLines.ts +25 -0
  1352. package/src/test/testutils/roundedBox.ts +13 -0
  1353. package/src/test/text.test.ts +269 -0
  1354. package/src/test/translating-snapping.test.ts +584 -0
  1355. package/src/test/translating.test.ts +1829 -0
  1356. package/src/test/viewport-following.test.ts +18 -0
  1357. package/tldraw.css +3264 -0
@@ -0,0 +1,1710 @@
1
+ import { TLFrameShape, TLGeoShape, createShapeId } from '@bigbluebutton/editor'
2
+ import { TestEditor } from './TestEditor'
3
+
4
+ let editor: TestEditor
5
+
6
+ const ids = {
7
+ box1: createShapeId('box1'),
8
+ box2: createShapeId('box2'),
9
+ box3: createShapeId('box3'),
10
+ box4: createShapeId('box4'),
11
+ box5: createShapeId('box5'),
12
+ frame1: createShapeId('frame1'),
13
+ group1: createShapeId('group1'),
14
+ group2: createShapeId('group2'),
15
+ group3: createShapeId('group3'),
16
+ }
17
+
18
+ beforeEach(() => {
19
+ editor = new TestEditor()
20
+ editor.setScreenBounds({ w: 3000, h: 3000, x: 0, y: 0 })
21
+ })
22
+
23
+ it('lists a sorted shapes array correctly', () => {
24
+ editor.createShapes([
25
+ { id: ids.box1, type: 'geo' },
26
+ { id: ids.box2, type: 'geo' },
27
+ { id: ids.box3, type: 'geo' },
28
+ { id: ids.frame1, type: 'frame' },
29
+ { id: ids.box4, type: 'geo', parentId: ids.frame1 },
30
+ { id: ids.box5, type: 'geo', parentId: ids.frame1 },
31
+ ])
32
+
33
+ editor.sendBackward([ids.frame1])
34
+ editor.sendBackward([ids.frame1])
35
+
36
+ expect(editor.getCurrentPageShapesSorted().map((s) => s.id)).toEqual([
37
+ ids.box1,
38
+ ids.frame1,
39
+ ids.box4,
40
+ ids.box5,
41
+ ids.box2,
42
+ ids.box3,
43
+ ])
44
+ })
45
+
46
+ describe('Hovering shapes', () => {
47
+ beforeEach(() => {
48
+ editor.createShapes([{ id: ids.box1, type: 'geo', x: 0, y: 0, props: { w: 100, h: 100 } }])
49
+ })
50
+
51
+ it('hovers the margins of hollow shapes but not their insides', () => {
52
+ expect(editor.getHoveredShapeId()).toBe(null)
53
+ editor.pointerMove(-4, 50)
54
+ expect(editor.getHoveredShapeId()).toBe(ids.box1)
55
+ editor.pointerMove(-50, 50)
56
+ expect(editor.getHoveredShapeId()).toBe(null)
57
+ editor.pointerMove(4, 50)
58
+ expect(editor.getHoveredShapeId()).toBe(ids.box1)
59
+ editor.pointerMove(75, 75)
60
+ expect(editor.getHoveredShapeId()).toBe(null)
61
+ // does not hover the label of a geo shape when the label is empty
62
+ editor.pointerMove(50, 50)
63
+ expect(editor.getHoveredShapeId()).toBe(null)
64
+
65
+ editor.updateShape({ id: ids.box1, type: 'geo', props: { text: 'hello' } })
66
+
67
+ // oh there's text now? hover it
68
+ editor.pointerMove(50, 50)
69
+ expect(editor.getHoveredShapeId()).toBe(ids.box1)
70
+ })
71
+
72
+ it('selects a shape with a full label on pointer down', () => {
73
+ editor.updateShape({ id: ids.box1, type: 'geo', props: { text: 'hello' } })
74
+
75
+ editor.pointerMove(50, 50)
76
+ editor.pointerDown()
77
+ expect(editor.isIn('select.pointing_shape')).toBe(true)
78
+ expect(editor.getSelectedShapes().length).toBe(1)
79
+ editor.pointerUp()
80
+ expect(editor.getSelectedShapes().length).toBe(1)
81
+ expect(editor.isIn('select.idle')).toBe(true)
82
+ })
83
+
84
+ it('selects a shape with an empty label on pointer up', () => {
85
+ editor.pointerMove(50, 50)
86
+ editor.pointerDown()
87
+ expect(editor.isIn('select.pointing_canvas')).toBe(true)
88
+ expect(editor.getSelectedShapes().length).toBe(0)
89
+ editor.pointerUp()
90
+ expect(editor.isIn('select.idle')).toBe(true)
91
+ expect(editor.getSelectedShapes().length).toBe(1)
92
+ })
93
+
94
+ it('hovers the margins or inside of filled shapes', () => {
95
+ editor.updateShape({ id: ids.box1, type: 'geo', props: { fill: 'solid' } })
96
+ expect(editor.getHoveredShapeId()).toBe(null)
97
+ editor.pointerMove(-4, 50)
98
+ expect(editor.getHoveredShapeId()).toBe(ids.box1)
99
+ editor.pointerMove(-50, 50)
100
+ expect(editor.getHoveredShapeId()).toBe(null)
101
+ editor.pointerMove(4, 50)
102
+ expect(editor.getHoveredShapeId()).toBe(ids.box1)
103
+ editor.pointerMove(50, 50)
104
+ expect(editor.getHoveredShapeId()).toBe(ids.box1)
105
+ })
106
+
107
+ it('hovers the closest edge or else the highest shape', () => {
108
+ // box2 is above box1
109
+ editor.createShapes([{ id: ids.box2, type: 'geo', x: 6, y: 0, props: { w: 100, h: 100 } }])
110
+ editor.pointerMove(2, 50)
111
+ expect(editor.getHoveredShapeId()).toBe(ids.box1)
112
+ editor.pointerMove(4, 50)
113
+ expect(editor.getHoveredShapeId()).toBe(ids.box2)
114
+ editor.pointerMove(3, 50)
115
+ expect(editor.getHoveredShapeId()).toBe(ids.box2)
116
+ editor.sendToBack([ids.box2])
117
+ editor.pointerMove(3, 50) // ! does not update automatically, only on move
118
+ expect(editor.getHoveredShapeId()).toBe(ids.box1)
119
+ })
120
+ })
121
+
122
+ describe('when shape is filled', () => {
123
+ let box1: TLGeoShape
124
+ beforeEach(() => {
125
+ editor.createShapes([{ id: ids.box1, type: 'geo', props: { fill: 'solid' } }])
126
+ box1 = editor.getShape<TLGeoShape>(ids.box1)!
127
+ })
128
+
129
+ it('hits on pointer down over shape', () => {
130
+ editor.pointerMove(50, 50)
131
+ expect(editor.getHoveredShapeId()).toBe(box1.id)
132
+ editor.pointerDown()
133
+ expect(editor.getSelectedShapeIds()).toEqual([box1.id])
134
+ editor.pointerUp()
135
+ expect(editor.getSelectedShapeIds()).toEqual([box1.id])
136
+ })
137
+
138
+ it('hits on pointer down over shape margin (inside', () => {
139
+ editor.pointerMove(95, 50)
140
+ expect(editor.getHoveredShapeId()).toBe(box1.id)
141
+ editor.pointerDown()
142
+ expect(editor.getSelectedShapeIds()).toEqual([box1.id])
143
+ editor.pointerUp()
144
+ expect(editor.getSelectedShapeIds()).toEqual([box1.id])
145
+ })
146
+
147
+ it('hits on pointer down over shape margin (outside)', () => {
148
+ editor.pointerMove(104, 50)
149
+ expect(editor.getHoveredShapeId()).toBe(box1.id)
150
+ editor.pointerDown()
151
+ expect(editor.getSelectedShapeIds()).toEqual([box1.id])
152
+ editor.pointerUp()
153
+ expect(editor.getSelectedShapeIds()).toEqual([box1.id])
154
+ })
155
+
156
+ it('misses on pointer down outside of shape', () => {
157
+ editor.pointerMove(250, 50)
158
+ expect(editor.getHoveredShapeId()).toBe(null)
159
+ editor.pointerDown()
160
+ expect(editor.getSelectedShapeIds()).toEqual([])
161
+ editor.pointerUp()
162
+ expect(editor.getSelectedShapeIds()).toEqual([])
163
+ })
164
+
165
+ it('selects and drags on point inside and drag', () => {
166
+ editor.pointerMove(50, 50)
167
+ expect(editor.getHoveredShapeId()).toBe(box1.id)
168
+ editor.pointerDown()
169
+ expect(editor.getSelectedShapeIds()).toEqual([box1.id])
170
+ editor.pointerMove(55, 55)
171
+ editor.expectToBeIn('select.translating')
172
+ editor.pointerUp()
173
+ expect(editor.getSelectedShapeIds()).toEqual([box1.id])
174
+ })
175
+ })
176
+
177
+ describe('when shape is hollow', () => {
178
+ let box1: TLGeoShape
179
+ beforeEach(() => {
180
+ editor.createShapes([{ id: ids.box1, type: 'geo', props: { fill: 'none' } }])
181
+ box1 = editor.getShape<TLGeoShape>(ids.box1)!
182
+ })
183
+
184
+ it('misses on pointer down over shape, misses on pointer up', () => {
185
+ editor.pointerMove(75, 75)
186
+ expect(editor.getHoveredShapeId()).toBe(null)
187
+ editor.pointerDown()
188
+ expect(editor.getSelectedShapeIds()).toEqual([])
189
+ editor.pointerUp()
190
+ expect(editor.getSelectedShapeIds()).toEqual([])
191
+ })
192
+
193
+ it('hits on the label', () => {
194
+ editor.pointerMove(-100, -100)
195
+ expect(editor.getHoveredShapeId()).toBe(null)
196
+ expect(editor.getSelectedShapeIds()).toEqual([])
197
+ editor.pointerMove(50, 50)
198
+ // no hover over label...
199
+ expect(editor.getHoveredShapeId()).toBe(null)
200
+ expect(editor.getSelectedShapeIds()).toEqual([])
201
+ editor.pointerDown()
202
+ // will select on pointer up
203
+ expect(editor.getHoveredShapeId()).toBe(null)
204
+ expect(editor.getSelectedShapeIds()).toEqual([])
205
+ // selects on pointer up
206
+ editor.pointerUp()
207
+ expect(editor.getHoveredShapeId()).toBe(null)
208
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box1])
209
+ })
210
+
211
+ it('missed on the label when the shape is locked', () => {
212
+ editor.updateShape({ id: ids.box1, type: 'geo', isLocked: true })
213
+ editor.pointerMove(-100, -100)
214
+ expect(editor.getHoveredShapeId()).toBe(null)
215
+ expect(editor.getSelectedShapeIds()).toEqual([])
216
+ editor.pointerMove(50, 50)
217
+ // no hover over label...
218
+ expect(editor.getHoveredShapeId()).toBe(null)
219
+ expect(editor.getSelectedShapeIds()).toEqual([])
220
+ editor.pointerDown()
221
+ // will select on pointer up
222
+ expect(editor.getHoveredShapeId()).toBe(null)
223
+ expect(editor.getSelectedShapeIds()).toEqual([])
224
+ // selects on pointer up
225
+ editor.pointerUp()
226
+ expect(editor.getHoveredShapeId()).toBe(null)
227
+ expect(editor.getSelectedShapeIds()).toEqual([])
228
+ })
229
+
230
+ it('hits on pointer down over shape margin (inside)', () => {
231
+ editor.pointerMove(96, 50)
232
+ expect(editor.getHoveredShapeId()).toBe(box1.id)
233
+ editor.pointerDown()
234
+ expect(editor.getSelectedShapeIds()).toEqual([box1.id])
235
+ editor.pointerUp()
236
+ expect(editor.getSelectedShapeIds()).toEqual([box1.id])
237
+ })
238
+
239
+ it('hits on pointer down over shape margin (outside)', () => {
240
+ editor.pointerMove(104, 50)
241
+ expect(editor.getHoveredShapeId()).toBe(box1.id)
242
+ editor.pointerDown()
243
+ expect(editor.getSelectedShapeIds()).toEqual([box1.id])
244
+ editor.pointerUp()
245
+ expect(editor.getSelectedShapeIds()).toEqual([box1.id])
246
+ })
247
+
248
+ it('misses on pointer down outside of shape', () => {
249
+ editor.pointerMove(250, 50)
250
+ expect(editor.getHoveredShapeId()).toBe(null)
251
+ editor.pointerDown()
252
+ expect(editor.getSelectedShapeIds()).toEqual([])
253
+ editor.pointerUp()
254
+ expect(editor.getSelectedShapeIds()).toEqual([])
255
+ })
256
+
257
+ it('brushes on point inside and drag', () => {
258
+ editor.pointerMove(75, 75)
259
+ expect(editor.getHoveredShapeId()).toBe(null)
260
+ editor.pointerDown()
261
+ expect(editor.getSelectedShapeIds()).toEqual([])
262
+ editor.pointerMove(80, 80)
263
+ editor.expectToBeIn('select.brushing')
264
+ editor.pointerUp()
265
+ expect(editor.getSelectedShapeIds()).toEqual([])
266
+ })
267
+
268
+ it('drags draw shape child', () => {
269
+ editor
270
+ .selectAll()
271
+ .deleteShapes(editor.getSelectedShapeIds())
272
+ .setCurrentTool('draw')
273
+ .pointerMove(500, 500)
274
+ .pointerDown()
275
+ .pointerMove(501, 501)
276
+ .pointerMove(550, 550)
277
+ .pointerMove(599, 599)
278
+ .pointerMove(600, 600)
279
+ .pointerUp()
280
+ .selectAll()
281
+ .setCurrentTool('select')
282
+
283
+ expect(editor.getSelectedShapeIds().length).toBe(1)
284
+
285
+ // Not inside of the shape but inside of the selection bounds
286
+ editor.pointerMove(510, 590)
287
+ expect(editor.getHoveredShapeId()).toBe(null)
288
+
289
+ // Draw shapes have `hideSelectionBoundsBg` set to false
290
+ editor.pointerDown()
291
+ editor.expectToBeIn('select.pointing_selection')
292
+ editor.pointerUp()
293
+
294
+ editor.selectAll()
295
+ editor.rotateSelection(Math.PI)
296
+ editor.setCurrentTool('select')
297
+ editor.pointerMove(590, 510)
298
+
299
+ editor.pointerDown()
300
+ editor.expectToBeIn('select.pointing_selection')
301
+ editor.pointerUp()
302
+ })
303
+
304
+ it('does not drag arrow shape', () => {
305
+ editor
306
+ .selectAll()
307
+ .deleteShapes(editor.getSelectedShapeIds())
308
+ .setCurrentTool('arrow')
309
+ .pointerMove(500, 500)
310
+ .pointerDown()
311
+ .pointerMove(600, 600)
312
+ .pointerUp()
313
+ .selectAll()
314
+ .setCurrentTool('select')
315
+
316
+ expect(editor.getSelectedShapeIds().length).toBe(1)
317
+
318
+ // Not inside of the shape but inside of the selection bounds
319
+ editor.pointerMove(510, 590)
320
+ expect(editor.getHoveredShapeId()).toBe(null)
321
+
322
+ // Arrow shapes have `hideSelectionBoundsBg` set to true
323
+ editor.pointerDown()
324
+ editor.expectToBeIn('select.pointing_canvas')
325
+
326
+ editor.selectAll()
327
+ editor.rotateSelection(Math.PI)
328
+ editor.setCurrentTool('select')
329
+ editor.pointerMove(590, 510)
330
+
331
+ editor.pointerDown()
332
+ editor.expectToBeIn('select.pointing_canvas')
333
+ editor.pointerUp()
334
+ })
335
+
336
+ it('does not drag line shape', () => {
337
+ editor
338
+ .selectAll()
339
+ .deleteShapes(editor.getSelectedShapeIds())
340
+ .setCurrentTool('line')
341
+ .pointerMove(500, 500)
342
+ .pointerDown()
343
+ .pointerMove(600, 600)
344
+ .pointerUp()
345
+ .selectAll()
346
+ .setCurrentTool('select')
347
+
348
+ expect(editor.getSelectedShapeIds().length).toBe(1)
349
+
350
+ // Not inside of the shape but inside of the selection bounds
351
+ editor.pointerMove(510, 590)
352
+ expect(editor.getHoveredShapeId()).toBe(null)
353
+
354
+ // Line shapes have `hideSelectionBoundsBg` set to true
355
+ editor.pointerDown()
356
+ editor.expectToBeIn('select.pointing_canvas')
357
+
358
+ editor.selectAll()
359
+ editor.rotateSelection(Math.PI)
360
+ editor.setCurrentTool('select')
361
+ editor.pointerMove(590, 510)
362
+
363
+ editor.pointerDown()
364
+ editor.expectToBeIn('select.pointing_canvas')
365
+ editor.pointerUp()
366
+ })
367
+ })
368
+
369
+ describe('when shape is a frame', () => {
370
+ let frame1: TLFrameShape
371
+ beforeEach(() => {
372
+ editor.createShape<TLFrameShape>({ id: ids.frame1, type: 'frame', props: { w: 100, h: 100 } })
373
+ frame1 = editor.getShape<TLFrameShape>(ids.frame1)!
374
+ })
375
+
376
+ it('misses on pointer down over shape, hits on pointer up', () => {
377
+ editor.pointerMove(50, 50)
378
+ expect(editor.getHoveredShapeId()).toBe(null)
379
+ editor.pointerDown()
380
+ expect(editor.getSelectedShapeIds()).toEqual([])
381
+ editor.pointerUp()
382
+ expect(editor.getSelectedShapeIds()).toEqual([])
383
+ })
384
+
385
+ it('hits on pointer down over shape margin (inside)', () => {
386
+ editor.pointerMove(96, 50)
387
+ expect(editor.getHoveredShapeId()).toBe(frame1.id)
388
+ editor.pointerDown()
389
+ expect(editor.getSelectedShapeIds()).toEqual([frame1.id])
390
+ editor.pointerUp()
391
+ expect(editor.getSelectedShapeIds()).toEqual([frame1.id])
392
+ })
393
+
394
+ it('hits on pointer down over shape margin (outside)', () => {
395
+ editor.pointerMove(104, 50)
396
+ expect(editor.getHoveredShapeId()).toBe(frame1.id)
397
+ editor.pointerDown()
398
+ expect(editor.getSelectedShapeIds()).toEqual([frame1.id])
399
+ editor.pointerUp()
400
+ expect(editor.getSelectedShapeIds()).toEqual([frame1.id])
401
+ })
402
+
403
+ it('misses on pointer down outside of shape', () => {
404
+ editor.pointerMove(250, 50)
405
+ expect(editor.getHoveredShapeId()).toBe(null)
406
+ editor.pointerDown()
407
+ expect(editor.getSelectedShapeIds()).toEqual([])
408
+ editor.pointerUp()
409
+ expect(editor.getSelectedShapeIds()).toEqual([])
410
+ })
411
+
412
+ it('brushes on point inside and drag', () => {
413
+ editor.pointerMove(50, 50)
414
+ expect(editor.getHoveredShapeId()).toBe(null)
415
+ editor.pointerDown()
416
+ expect(editor.getSelectedShapeIds()).toEqual([])
417
+ editor.pointerMove(55, 55)
418
+ editor.expectToBeIn('select.brushing')
419
+ editor.pointerUp()
420
+ expect(editor.getSelectedShapeIds()).toEqual([])
421
+ })
422
+ })
423
+
424
+ describe('When a shape is behind a frame', () => {
425
+ beforeEach(() => {
426
+ editor.selectAll().deleteShapes(editor.getSelectedShapeIds())
427
+ editor.createShape<TLGeoShape>({ id: ids.box1, type: 'geo', x: 25, y: 25 })
428
+ editor.createShape<TLFrameShape>({ id: ids.frame1, type: 'frame', props: { w: 100, h: 100 } })
429
+ })
430
+
431
+ it('does not select the shape when clicked inside', () => {
432
+ editor.sendToBack([ids.box1]) // send it to back!
433
+ expect(editor.getCurrentPageShapesSorted().map((s) => s.index)).toEqual(['a1', 'a2'])
434
+ expect(editor.getCurrentPageShapesSorted().map((s) => s.id)).toEqual([ids.box1, ids.frame1])
435
+
436
+ editor.pointerMove(50, 50)
437
+ expect(editor.getHoveredShapeId()).toBe(null)
438
+ editor.pointerDown()
439
+ expect(editor.getSelectedShapeIds()).toEqual([])
440
+ editor.pointerUp()
441
+ expect(editor.getSelectedShapeIds()).toEqual([])
442
+ })
443
+
444
+ it('does not select the shape when clicked on its margin', () => {
445
+ editor.pointerMove(25, 25)
446
+ expect(editor.getHoveredShapeId()).toBe(null)
447
+ editor.pointerDown()
448
+ expect(editor.getSelectedShapeIds()).toEqual([])
449
+ editor.pointerUp()
450
+ expect(editor.getSelectedShapeIds()).toEqual([])
451
+ })
452
+ })
453
+
454
+ describe('when shape is inside of a frame', () => {
455
+ let frame1: TLFrameShape
456
+ let box1: TLGeoShape
457
+ beforeEach(() => {
458
+ editor.createShape<TLFrameShape>({ id: ids.frame1, type: 'frame', props: { w: 100, h: 100 } })
459
+ editor.createShape<TLGeoShape>({
460
+ id: ids.box1,
461
+ parentId: ids.frame1,
462
+ type: 'geo',
463
+ x: 25,
464
+ y: 25,
465
+ })
466
+ frame1 = editor.getShape<TLFrameShape>(ids.frame1)!
467
+ box1 = editor.getShape<TLGeoShape>(ids.box1)!
468
+ })
469
+
470
+ it('misses on pointer down over frame, misses on pointer up', () => {
471
+ editor.pointerMove(10, 10)
472
+ expect(editor.getHoveredShapeId()).toBe(null)
473
+ editor.pointerDown() // inside of frame1, outside of box1, outside of all margins
474
+ expect(editor.getSelectedShapeIds()).toEqual([])
475
+ editor.pointerUp()
476
+ expect(editor.getSelectedShapeIds()).toEqual([])
477
+ })
478
+
479
+ it('misses on pointer down over shape, misses on pointer up', () => {
480
+ editor.pointerMove(50, 50)
481
+ expect(editor.getHoveredShapeId()).toBe(null)
482
+ editor.pointerDown() // inside of box1 (which is empty)
483
+ expect(editor.getSelectedShapeIds()).toEqual([])
484
+ editor.pointerUp() // does not select because inside of hollow shape
485
+ expect(editor.getSelectedShapeIds()).toEqual([])
486
+ })
487
+
488
+ it('misses on pointer down over shape, hit on pointer up on the edge', () => {
489
+ editor.pointerMove(25, 25)
490
+ editor.pointerDown() // on the edge of box1 (which is empty)
491
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box1])
492
+ editor.pointerUp() // does not select because inside of hollow shape
493
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box1])
494
+ })
495
+
496
+ it('misses on pointer down over shape, misses on pointer up on the edge when locked', () => {
497
+ editor.updateShape({ id: ids.box1, type: 'geo', isLocked: true })
498
+ editor.pointerMove(25, 25)
499
+ editor.pointerDown() // on the edge of box1 (which is empty)
500
+ expect(editor.getSelectedShapeIds()).toEqual([])
501
+ editor.pointerUp() // does not select because inside of hollow shape
502
+ expect(editor.getSelectedShapeIds()).toEqual([])
503
+ })
504
+
505
+ it('misses on pointer down over shape, misses on pointer up when locked', () => {
506
+ editor.updateShape({ id: ids.box1, type: 'geo', isLocked: true })
507
+ editor.pointerMove(50, 50)
508
+ editor.pointerDown() // on the edge of box1 (which is empty)
509
+ expect(editor.getSelectedShapeIds()).toEqual([])
510
+ editor.pointerUp() // does not select because inside of hollow shape
511
+ expect(editor.getSelectedShapeIds()).toEqual([])
512
+ })
513
+
514
+ it('misses on pointer down over shape label, misses on pointer up when locked', () => {
515
+ editor.updateShape({ id: ids.box1, type: 'geo', isLocked: true })
516
+ editor.pointerMove(75, 75)
517
+ editor.pointerDown() // on the edge of box1 (which is empty)
518
+ expect(editor.getSelectedShapeIds()).toEqual([])
519
+ editor.pointerUp() // does not select because inside of hollow shape
520
+ expect(editor.getSelectedShapeIds()).toEqual([])
521
+ })
522
+
523
+ it('misses when shape is masked by frame on pointer down over shape, misses on pointer up', () => {
524
+ editor.pointerMove(110, 50)
525
+ expect(editor.getHoveredShapeId()).toBe(null)
526
+ editor.pointerDown() // inside of box1 but outside of frame1
527
+ expect(editor.getSelectedShapeIds()).toEqual([])
528
+ editor.pointerUp()
529
+ expect(editor.getSelectedShapeIds()).toEqual([])
530
+ })
531
+
532
+ it('hits frame on pointer down over shape margin (inside)', () => {
533
+ editor.pointerMove(96, 50)
534
+ expect(editor.getHoveredShapeId()).toBe(frame1.id)
535
+ editor.pointerDown() // inside of box1, in margin of frame1
536
+ expect(editor.getSelectedShapeIds()).toEqual([frame1.id])
537
+ editor.pointerUp()
538
+ expect(editor.getSelectedShapeIds()).toEqual([frame1.id])
539
+ })
540
+
541
+ it('hits frame on pointer down over shape margin where intersecting child shape margin (inside)', () => {
542
+ editor.pointerMove(96, 25)
543
+ expect(editor.getHoveredShapeId()).toBe(box1.id)
544
+ editor.pointerDown() // in margin of box1 AND frame1
545
+ expect(editor.getSelectedShapeIds()).toEqual([box1.id])
546
+ editor.pointerUp()
547
+ expect(editor.getSelectedShapeIds()).toEqual([box1.id])
548
+ })
549
+
550
+ it('hits frame on pointer down over shape margin (outside)', () => {
551
+ editor.pointerMove(104, 25)
552
+ expect(editor.getHoveredShapeId()).toBe(frame1.id)
553
+ editor.pointerDown()
554
+ expect(editor.getSelectedShapeIds()).toEqual([frame1.id])
555
+ editor.pointerUp()
556
+ expect(editor.getSelectedShapeIds()).toEqual([frame1.id])
557
+ })
558
+
559
+ it('misses on pointer down outside of shape', () => {
560
+ editor.pointerMove(250, 50)
561
+ expect(editor.getHoveredShapeId()).toBe(null)
562
+ editor.pointerDown()
563
+ expect(editor.getSelectedShapeIds()).toEqual([])
564
+ editor.pointerUp()
565
+ expect(editor.getSelectedShapeIds()).toEqual([])
566
+ })
567
+
568
+ it('brushes on point inside and drag', () => {
569
+ editor.pointerMove(50, 50)
570
+ expect(editor.getHoveredShapeId()).toBe(null)
571
+ editor.pointerDown()
572
+ expect(editor.getSelectedShapeIds()).toEqual([])
573
+ editor.pointerMove(55, 55)
574
+ editor.expectToBeIn('select.brushing')
575
+ editor.pointerUp()
576
+ expect(editor.getSelectedShapeIds()).toEqual([])
577
+ })
578
+
579
+ it('misses when shape is behind frame', () => {
580
+ editor.deleteShape(ids.box1)
581
+ editor.createShape({
582
+ id: ids.box5,
583
+ parentId: editor.getCurrentPageId(),
584
+ type: 'geo',
585
+ props: {
586
+ w: 75,
587
+ h: 75,
588
+ },
589
+ })
590
+ editor.sendToBack([ids.box5])
591
+
592
+ editor.pointerMove(50, 50)
593
+ expect(editor.getHoveredShapeId()).toBe(null)
594
+ editor.pointerDown()
595
+ expect(editor.getSelectedShapeIds()).toEqual([])
596
+ editor.pointerUp()
597
+ expect(editor.getSelectedShapeIds()).toEqual([])
598
+
599
+ editor.pointerMove(75, 75)
600
+ expect(editor.getHoveredShapeId()).toBe(null)
601
+ editor.pointerDown()
602
+ expect(editor.getSelectedShapeIds()).toEqual([])
603
+ editor.pointerUp()
604
+ expect(editor.getSelectedShapeIds()).toEqual([])
605
+ })
606
+ })
607
+
608
+ describe('when a frame has multiple children', () => {
609
+ let box1: TLGeoShape
610
+ let box2: TLGeoShape
611
+ beforeEach(() => {
612
+ editor
613
+ .createShape<TLFrameShape>({ id: ids.frame1, type: 'frame', props: { w: 100, h: 100 } })
614
+ .createShape<TLGeoShape>({
615
+ id: ids.box1,
616
+ parentId: ids.frame1,
617
+ type: 'geo',
618
+ x: 25,
619
+ y: 25,
620
+ })
621
+ .createShape<TLGeoShape>({
622
+ id: ids.box2,
623
+ parentId: ids.frame1,
624
+ type: 'geo',
625
+ x: 50,
626
+ y: 50,
627
+ props: {
628
+ w: 80,
629
+ h: 80,
630
+ },
631
+ })
632
+ box1 = editor.getShape<TLGeoShape>(ids.box1)!
633
+ box2 = editor.getShape<TLGeoShape>(ids.box2)!
634
+ })
635
+
636
+ // This is no longer the case; it will be true for arrows though
637
+
638
+ // it('selects the smaller of two overlapping hollow shapes on pointer up when both are the child of a frame', () => {
639
+ // // make box2 smaller
640
+ // editor.updateShape({ ...box2, props: { w: 99, h: 99 } })
641
+
642
+ // editor.pointerMove(64, 64)
643
+ // expect(editor.hoveredShapeId).toBe(null)
644
+ // editor.pointerDown()
645
+ // expect(editor.selectedShapeIds).toEqual([])
646
+ // editor.pointerUp()
647
+ // expect(editor.selectedShapeIds).toEqual([ids.box2])
648
+
649
+ // // make box2 bigger...
650
+ // editor.selectNone()
651
+ // editor.updateShape({ ...box2, props: { w: 101, h: 101 } })
652
+
653
+ // editor.pointerMove(64, 64)
654
+ // expect(editor.hoveredShapeId).toBe(null)
655
+ // editor.pointerDown()
656
+ // expect(editor.selectedShapeIds).toEqual([])
657
+ // editor.pointerUp()
658
+ // expect(editor.selectedShapeIds).toEqual([ids.box1])
659
+ // })
660
+
661
+ it('brush does not select a shape when brushing its masked parts', () => {
662
+ editor.pointerMove(110, 0)
663
+ expect(editor.getHoveredShapeId()).toBe(null)
664
+ editor.pointerDown()
665
+ editor.pointerMove(160, 160)
666
+ editor.expectToBeIn('select.brushing')
667
+ editor.pointerUp()
668
+ expect(editor.getSelectedShapeIds()).toEqual([])
669
+ })
670
+
671
+ it('brush selects a shape inside of the frame', () => {
672
+ editor.pointerMove(10, 10)
673
+ expect(editor.getHoveredShapeId()).toBe(null)
674
+ editor.pointerDown()
675
+ editor.pointerMove(30, 30)
676
+ editor.expectToBeIn('select.brushing')
677
+ editor.pointerUp()
678
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box1])
679
+ })
680
+
681
+ it('brush selects a shape when dragging from outside of the frame', () => {
682
+ editor.pointerMove(-50, -50)
683
+ expect(editor.getHoveredShapeId()).toBe(null)
684
+ editor.pointerDown()
685
+ editor.pointerMove(30, 30)
686
+ editor.expectToBeIn('select.brushing')
687
+ editor.pointerUp()
688
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box1])
689
+ })
690
+
691
+ it('brush selects shapes when containing them in a drag from outside of the frame', () => {
692
+ editor.updateShape({ ...box1, x: 10, y: 10, props: { w: 10, h: 10 } })
693
+ editor.updateShape({ ...box2, x: 20, y: 20, props: { w: 10, h: 10 } })
694
+
695
+ editor.pointerMove(-50, -50)
696
+ expect(editor.getHoveredShapeId()).toBe(null)
697
+ editor.pointerDown()
698
+ editor.pointerMove(99, 99)
699
+ editor.expectToBeIn('select.brushing')
700
+ editor.pointerUp()
701
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box1, ids.box2])
702
+ })
703
+
704
+ it('brush selects shapes when containing them in a drag from outside of the frame and also having the current page point outside of the frame without containing the frame', () => {
705
+ editor.updateShape({ ...box1, x: 10, y: 10, props: { w: 10, h: 10 } })
706
+ editor.updateShape({ ...box2, x: 20, y: 20, props: { w: 10, h: 10 } })
707
+
708
+ editor.pointerMove(5, -50)
709
+ expect(editor.getHoveredShapeId()).toBe(null)
710
+ editor.pointerDown()
711
+ editor.pointerMove(150, 150)
712
+ editor.expectToBeIn('select.brushing')
713
+ editor.pointerUp()
714
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box1, ids.box2])
715
+ })
716
+
717
+ it('selects only the frame when brush wraps the entire frame', () => {
718
+ editor.updateShape({ ...box1, x: 10, y: 10, props: { w: 10, h: 10 } })
719
+ editor.updateShape({ ...box2, x: 20, y: 20, props: { w: 10, h: 10 } })
720
+
721
+ editor.pointerMove(-50, -50)
722
+ expect(editor.getHoveredShapeId()).toBe(null)
723
+ editor.pointerDown()
724
+ editor.pointerMove(150, 150)
725
+ editor.expectToBeIn('select.brushing')
726
+ editor.pointerUp()
727
+ expect(editor.getSelectedShapeIds()).toEqual([ids.frame1])
728
+ })
729
+
730
+ it('selects only the frame when brush wraps the entire frame (with overlapping / masked shapes)', () => {
731
+ editor.pointerMove(-50, -50)
732
+ expect(editor.getHoveredShapeId()).toBe(null)
733
+ editor.pointerDown()
734
+ editor.pointerMove(150, 150)
735
+ editor.expectToBeIn('select.brushing')
736
+ editor.pointerUp()
737
+ expect(editor.getSelectedShapeIds()).toEqual([ids.frame1])
738
+ })
739
+ })
740
+
741
+ describe('when shape is selected', () => {
742
+ it('hits on pointer down over shape, misses on pointer up', () => {
743
+ editor.createShapes([{ id: ids.box1, type: 'geo', props: { fill: 'none' } }])
744
+ editor.select(ids.box1)
745
+ editor.pointerMove(75, 75)
746
+ expect(editor.getHoveredShapeId()).toBe(null)
747
+ editor.pointerDown()
748
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box1])
749
+ editor.pointerUp()
750
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box1])
751
+ })
752
+ })
753
+
754
+ describe('When shapes are overlapping', () => {
755
+ let box2: TLGeoShape
756
+ let box4: TLGeoShape
757
+ let box5: TLGeoShape
758
+ beforeEach(() => {
759
+ editor.createShapes<TLGeoShape>([
760
+ {
761
+ id: ids.box1,
762
+ type: 'geo',
763
+ x: 0,
764
+ y: 0,
765
+ props: {
766
+ w: 300,
767
+ h: 300,
768
+ },
769
+ },
770
+ {
771
+ id: ids.box2,
772
+ type: 'geo',
773
+ x: 50,
774
+ y: 50,
775
+ props: {
776
+ w: 100,
777
+ h: 150,
778
+ },
779
+ },
780
+ {
781
+ id: ids.box3,
782
+ type: 'geo',
783
+ x: 75,
784
+ y: 75,
785
+ props: {
786
+ w: 100,
787
+ h: 100,
788
+ },
789
+ },
790
+ {
791
+ id: ids.box4,
792
+ type: 'geo',
793
+ x: 100,
794
+ y: 25,
795
+ props: {
796
+ w: 100,
797
+ h: 100,
798
+ fill: 'solid',
799
+ },
800
+ },
801
+ {
802
+ id: ids.box5,
803
+ type: 'geo',
804
+ x: 125,
805
+ y: 0,
806
+ props: {
807
+ w: 100,
808
+ h: 100,
809
+ fill: 'solid',
810
+ },
811
+ },
812
+ ])
813
+
814
+ box2 = editor.getShape<TLGeoShape>(ids.box2)!
815
+ box4 = editor.getShape<TLGeoShape>(ids.box4)!
816
+ box5 = editor.getShape<TLGeoShape>(ids.box5)!
817
+
818
+ editor.sendToBack([ids.box4])
819
+ editor.bringToFront([ids.box5])
820
+ editor.bringToFront([ids.box2])
821
+
822
+ expect(editor.getCurrentPageShapesSorted().map((s) => s.id)).toEqual([
823
+ ids.box4, // filled
824
+ ids.box1, // hollow
825
+ ids.box3, // hollow
826
+ ids.box5, // filled
827
+ ids.box2, // hollow
828
+ ])
829
+ })
830
+
831
+ it('selects the filled shape behind the hollow shapes', () => {
832
+ editor.pointerMove(110, 90)
833
+ expect(editor.getHoveredShapeId()).toBe(box4.id)
834
+ editor.pointerDown()
835
+ expect(editor.getSelectedShapeIds()).toEqual([box4.id])
836
+ editor.pointerUp()
837
+ expect(editor.getSelectedShapeIds()).toEqual([box4.id])
838
+ })
839
+
840
+ it('selects the hollow above the filled shapes when in margin', () => {
841
+ expect(editor.getCurrentPageShapesSorted().map((s) => s.id)).toEqual([
842
+ ids.box4,
843
+ ids.box1,
844
+ ids.box3,
845
+ ids.box5,
846
+ ids.box2,
847
+ ])
848
+
849
+ editor.pointerMove(125, 50)
850
+ expect(editor.getHoveredShapeId()).toBe(box2.id)
851
+ editor.pointerDown()
852
+ expect(editor.getSelectedShapeIds()).toEqual([box2.id])
853
+ editor.pointerUp()
854
+ expect(editor.getSelectedShapeIds()).toEqual([box2.id])
855
+ })
856
+
857
+ it('selects the front-most filled shape', () => {
858
+ editor.pointerMove(175, 50)
859
+ expect(editor.getHoveredShapeId()).toBe(box5.id)
860
+ editor.pointerDown()
861
+ expect(editor.getSelectedShapeIds()).toEqual([box5.id])
862
+ editor.pointerUp()
863
+ expect(editor.getSelectedShapeIds()).toEqual([box5.id])
864
+ })
865
+
866
+ // it('selects the smallest overlapping hollow shape', () => {
867
+ // editor.pointerMove(125, 175)
868
+ // expect(editor.hoveredShapeId).toBe(null)
869
+ // editor.pointerDown()
870
+ // expect(editor.selectedShapeIds).toEqual([])
871
+ // editor.pointerUp()
872
+ // expect(editor.selectedShapeIds).toEqual([box3.id])
873
+ // editor.selectNone()
874
+ // expect(editor.hoveredShapeId).toBe(null)
875
+
876
+ // editor.pointerMove(64, 64)
877
+ // expect(editor.hoveredShapeId).toBe(null)
878
+ // editor.pointerDown()
879
+ // expect(editor.selectedShapeIds).toEqual([])
880
+ // editor.pointerUp()
881
+ // expect(editor.selectedShapeIds).toEqual([box2.id])
882
+ // editor.selectNone()
883
+
884
+ // editor.pointerMove(35, 35)
885
+ // expect(editor.hoveredShapeId).toBe(null)
886
+ // editor.pointerDown()
887
+ // expect(editor.selectedShapeIds).toEqual([])
888
+ // editor.pointerUp()
889
+ // expect(editor.selectedShapeIds).toEqual([box1.id])
890
+ // })
891
+ })
892
+
893
+ describe('Selects inside of groups', () => {
894
+ beforeEach(() => {
895
+ editor.createShapes([
896
+ { id: ids.box1, type: 'geo', x: 0, y: 0, props: { w: 100, h: 100 } },
897
+ { id: ids.box2, type: 'geo', x: 200, y: 0, props: { w: 100, h: 100, fill: 'solid' } },
898
+ ])
899
+ editor.groupShapes([ids.box1, ids.box2], ids.group1)
900
+ editor.selectNone()
901
+ })
902
+
903
+ it('cretes the group with the correct bounds', () => {
904
+ expect(editor.getShapeGeometry(ids.group1).bounds).toMatchObject({
905
+ x: 0,
906
+ y: 0,
907
+ w: 300,
908
+ h: 100,
909
+ })
910
+ })
911
+
912
+ it('does not selects the group when clicking over the group but between grouped shapes bounds', () => {
913
+ editor.pointerMove(150, 50)
914
+ expect(editor.getHoveredShapeId()).toBe(null)
915
+ editor.pointerDown()
916
+ expect(editor.getSelectedShapeIds()).toEqual([])
917
+ editor.pointerUp()
918
+ expect(editor.getSelectedShapeIds()).toEqual([])
919
+ })
920
+
921
+ it('selects on page down when over an edge of shape in th group children', () => {
922
+ editor.pointerMove(0, 50)
923
+ expect(editor.getHoveredShapeId()).toBe(ids.group1)
924
+ editor.pointerDown()
925
+ expect(editor.getSelectedShapeIds()).toEqual([ids.group1])
926
+ editor.pointerUp()
927
+ expect(editor.getSelectedShapeIds()).toEqual([ids.group1])
928
+ })
929
+
930
+ it('selects on page down when over a filled shape in group children', () => {
931
+ editor.pointerMove(250, 50)
932
+ expect(editor.getHoveredShapeId()).toBe(ids.group1)
933
+ editor.pointerDown()
934
+ expect(editor.getSelectedShapeIds()).toEqual([ids.group1])
935
+ editor.pointerUp()
936
+ expect(editor.getSelectedShapeIds()).toEqual([ids.group1])
937
+ })
938
+
939
+ it('drops selection when pointing up on the space between shapes in a group', () => {
940
+ editor.pointerMove(0, 0)
941
+ expect(editor.getHoveredShapeId()).toBe(ids.group1)
942
+ editor.pointerDown()
943
+ expect(editor.getSelectedShapeIds()).toEqual([ids.group1])
944
+ editor.pointerUp()
945
+ expect(editor.getSelectedShapeIds()).toEqual([ids.group1])
946
+
947
+ editor.pointerMove(150, 50)
948
+ expect(editor.getHoveredShapeId()).toBe(null) // the hovered shape (group1) is already selected
949
+ editor.pointerDown()
950
+ editor.expectToBeIn('select.pointing_selection')
951
+ expect(editor.getSelectedShapeIds()).toEqual([ids.group1])
952
+ editor.pointerUp()
953
+ expect(editor.getSelectedShapeIds()).toEqual([])
954
+ })
955
+
956
+ it('selects child when pointing on a filled child shape', () => {
957
+ editor.pointerMove(250, 0)
958
+ expect(editor.getHoveredShapeId()).toBe(ids.group1)
959
+ editor.pointerDown()
960
+ editor.pointerUp()
961
+ expect(editor.getSelectedShapeIds()).toEqual([ids.group1])
962
+ editor.pointerDown()
963
+ editor.expectToBeIn('select.pointing_shape')
964
+ expect(editor.getSelectedShapeIds()).toEqual([ids.group1])
965
+ editor.pointerUp()
966
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box2])
967
+ })
968
+
969
+ // it('selects child when pointing inside of a hollow child shape', () => {
970
+ // editor.pointerMove(75, 75)
971
+ // expect(editor.hoveredShapeId).toBe(null)
972
+ // editor.pointerDown()
973
+ // expect(editor.selectedShapeIds).toEqual([])
974
+ // editor.pointerUp()
975
+ // expect(editor.selectedShapeIds).toEqual([ids.group1])
976
+ // editor.pointerDown()
977
+ // editor.expectToBeIn('select.pointing_selection')
978
+ // expect(editor.selectedShapeIds).toEqual([ids.group1])
979
+ // editor.pointerUp()
980
+ // expect(editor.selectedShapeIds).toEqual([ids.box1])
981
+ // })
982
+
983
+ it('selects a solid shape in a group when double clicking it', () => {
984
+ editor.pointerMove(250, 50)
985
+ expect(editor.getHoveredShapeId()).toBe(ids.group1)
986
+ editor.doubleClick()
987
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box2])
988
+ expect(editor.getFocusedGroupId()).toBe(ids.group1)
989
+ })
990
+
991
+ it('selects a solid shape in a group when double clicking its margin', () => {
992
+ editor.pointerMove(198, 50)
993
+ expect(editor.getHoveredShapeId()).toBe(ids.group1)
994
+ editor.doubleClick()
995
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box2])
996
+ expect(editor.getFocusedGroupId()).toBe(ids.group1)
997
+ })
998
+
999
+ // it('selects a hollow shape in a group when double clicking it', () => {
1000
+ // editor.pointerMove(50, 50)
1001
+ // expect(editor.hoveredShapeId).toBe(null)
1002
+ // editor.doubleClick()
1003
+ // expect(editor.selectedShapeIds).toEqual([ids.box1])
1004
+ // expect(editor.focusedGroupId).toBe(ids.group1)
1005
+ // })
1006
+
1007
+ it('selects a hollow shape in a group when double clicking its edge', () => {
1008
+ editor.pointerMove(102, 50)
1009
+ expect(editor.getHoveredShapeId()).toBe(ids.group1)
1010
+ editor.doubleClick()
1011
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box1])
1012
+ expect(editor.getFocusedGroupId()).toBe(ids.group1)
1013
+ })
1014
+
1015
+ // it('double clicks a hollow shape when the focus layer is the shapes parent', () => {
1016
+ // editor.pointerMove(50, 50)
1017
+ // expect(editor.hoveredShapeId).toBe(null)
1018
+ // editor.doubleClick()
1019
+ // editor.doubleClick()
1020
+ // expect(editor.editingShapeId).toBe(ids.box1)
1021
+ // editor.expectToBeIn('select.editing_shape')
1022
+ // })
1023
+
1024
+ it('double clicks a solid shape to edit it when the focus layer is the shapes parent', () => {
1025
+ editor.pointerMove(250, 50)
1026
+ expect(editor.getHoveredShapeId()).toBe(ids.group1)
1027
+ editor.doubleClick()
1028
+ editor.doubleClick()
1029
+ expect(editor.getEditingShapeId()).toBe(ids.box2)
1030
+ editor.expectToBeIn('select.editing_shape')
1031
+ })
1032
+
1033
+ // it('double clicks a sibling shape to edit it when the focus layer is the shapes parent', () => {
1034
+ // editor.pointerMove(50, 50)
1035
+ // expect(editor.hoveredShapeId).toBe(null)
1036
+ // editor.doubleClick()
1037
+
1038
+ // editor.pointerMove(250, 50)
1039
+ // expect(editor.hoveredShapeId).toBe(ids.box2)
1040
+ // editor.doubleClick()
1041
+ // expect(editor.editingShapeId).toBe(ids.box2)
1042
+ // editor.expectToBeIn('select.editing_shape')
1043
+ // })
1044
+
1045
+ // it('selects a different sibling shape when editing a layer', () => {
1046
+ // editor.pointerMove(50, 50)
1047
+ // expect(editor.hoveredShapeId).toBe(null)
1048
+ // editor.doubleClick()
1049
+ // editor.doubleClick()
1050
+ // expect(editor.editingShapeId).toBe(ids.box1)
1051
+ // editor.expectToBeIn('select.editing_shape')
1052
+
1053
+ // editor.pointerMove(250, 50)
1054
+ // expect(editor.hoveredShapeId).toBe(ids.box2)
1055
+ // editor.pointerDown()
1056
+ // editor.expectToBeIn('select.pointing_shape')
1057
+ // expect(editor.editingShapeId).toBe(null)
1058
+ // expect(editor.selectedShapeIds).toEqual([ids.box2])
1059
+ // })
1060
+ })
1061
+
1062
+ describe('when selecting behind selection', () => {
1063
+ beforeEach(() => {
1064
+ editor
1065
+ .createShapes([
1066
+ { id: ids.box1, type: 'geo', x: 100, y: 0, props: { fill: 'solid' } },
1067
+ { id: ids.box2, type: 'geo', x: 0, y: 0 },
1068
+ { id: ids.box3, type: 'geo', x: 200, y: 0 },
1069
+ ])
1070
+ .select(ids.box2, ids.box3)
1071
+ })
1072
+
1073
+ it('does not select on pointer down, only on pointer up', () => {
1074
+ editor.pointerMove(175, 75)
1075
+ expect(editor.getHoveredShapeId()).toBe(ids.box1)
1076
+ editor.pointerDown() // inside of box 1
1077
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box2, ids.box3])
1078
+ editor.pointerUp()
1079
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box1])
1080
+ })
1081
+
1082
+ it('can drag the selection', () => {
1083
+ editor.pointerMove(175, 75)
1084
+ expect(editor.getHoveredShapeId()).toBe(ids.box1)
1085
+ editor.pointerDown() // inside of box 1
1086
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box2, ids.box3])
1087
+ editor.pointerMove(250, 50)
1088
+ editor.expectToBeIn('select.translating')
1089
+ editor.pointerMove(150, 50)
1090
+ editor.pointerUp()
1091
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box2, ids.box3])
1092
+ })
1093
+ })
1094
+
1095
+ describe('when shift+selecting', () => {
1096
+ beforeEach(() => {
1097
+ editor
1098
+ .createShapes([
1099
+ { id: ids.box1, type: 'geo', x: 0, y: 0 },
1100
+ { id: ids.box2, type: 'geo', x: 200, y: 0 },
1101
+ { id: ids.box3, type: 'geo', x: 400, y: 0, props: { fill: 'solid' } },
1102
+ ])
1103
+ .select(ids.box1)
1104
+ })
1105
+
1106
+ it('adds solid shape to selection on pointer down', () => {
1107
+ editor.keyDown('Shift')
1108
+ editor.pointerMove(450, 50) // inside of box 3
1109
+ expect(editor.getHoveredShapeId()).toBe(ids.box3)
1110
+ editor.pointerDown()
1111
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box1, ids.box3])
1112
+ editor.pointerUp()
1113
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box1, ids.box3])
1114
+ })
1115
+
1116
+ it('adds and removes solid shape from selection on pointer up (without causing a double click)', () => {
1117
+ editor.keyDown('Shift')
1118
+ editor.pointerMove(450, 50) // above box 3
1119
+ expect(editor.getHoveredShapeId()).toBe(ids.box3)
1120
+ editor.pointerDown()
1121
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box1, ids.box3])
1122
+ editor.pointerUp()
1123
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box1, ids.box3])
1124
+ editor.pointerDown()
1125
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box1, ids.box3])
1126
+ editor.pointerUp()
1127
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box1])
1128
+ })
1129
+
1130
+ it('adds and removes solid shape from selection on double clicks (without causing an edit by double clicks)', () => {
1131
+ editor.keyDown('Shift')
1132
+ editor.pointerMove(450, 50) // above box 3
1133
+ expect(editor.getHoveredShapeId()).toBe(ids.box3)
1134
+ editor.doubleClick()
1135
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box1, ids.box3])
1136
+ editor.doubleClick()
1137
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box1])
1138
+ })
1139
+
1140
+ it('adds how shape to selection on pointer down when pointing margin', () => {
1141
+ editor.keyDown('Shift')
1142
+ editor.pointerMove(204, 50) // inside of box 2 margin
1143
+ expect(editor.getHoveredShapeId()).toBe(ids.box2)
1144
+ editor.pointerDown()
1145
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box1, ids.box2])
1146
+ editor.pointerUp()
1147
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box1, ids.box2])
1148
+ })
1149
+
1150
+ it('adds and removes hollow shape from selection on pointer up (without causing a double click) when pointing margin', () => {
1151
+ editor.keyDown('Shift')
1152
+ editor.pointerMove(204, 50) // inside of box 2 margin
1153
+ expect(editor.getHoveredShapeId()).toBe(ids.box2)
1154
+ editor.pointerDown()
1155
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box1, ids.box2])
1156
+ editor.pointerUp()
1157
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box1, ids.box2])
1158
+ editor.pointerDown()
1159
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box1, ids.box2])
1160
+ editor.pointerUp()
1161
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box1])
1162
+ })
1163
+
1164
+ it('does not add hollow shape to selection on pointer up when in empty space', () => {
1165
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box1])
1166
+ editor.keyDown('Shift')
1167
+ editor.pointerMove(275, 75) // above box 2
1168
+ expect(editor.getHoveredShapeId()).toBe(null)
1169
+ editor.pointerDown()
1170
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box1])
1171
+ editor.pointerUp()
1172
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box1])
1173
+ })
1174
+
1175
+ it('does not add hollow shape to selection on pointer up when over the edge/label, but select on pointer up', () => {
1176
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box1])
1177
+ editor.keyDown('Shift')
1178
+ editor.pointerMove(250, 50) // above box 2's label
1179
+ expect(editor.getHoveredShapeId()).toBe(null)
1180
+ editor.pointerDown()
1181
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box1])
1182
+ editor.pointerUp()
1183
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box1, ids.box2])
1184
+ })
1185
+
1186
+ it('does not add and remove hollow shape from selection on pointer up (without causing an edit by double clicks)', () => {
1187
+ editor.keyDown('Shift')
1188
+ editor.pointerMove(275, 75) // above box 2, empty space
1189
+ expect(editor.getHoveredShapeId()).toBe(null)
1190
+ editor.pointerDown()
1191
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box1])
1192
+ editor.pointerUp()
1193
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box1])
1194
+ editor.pointerDown()
1195
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box1])
1196
+ editor.pointerUp()
1197
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box1])
1198
+ })
1199
+
1200
+ it('does not add and remove hollow shape from selection on double clicks (without causing an edit by double clicks)', () => {
1201
+ editor.keyDown('Shift')
1202
+ editor.pointerMove(275, 75) // above box 2, empty space
1203
+ expect(editor.getHoveredShapeId()).toBe(null)
1204
+ editor.doubleClick()
1205
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box1])
1206
+ editor.doubleClick()
1207
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box1])
1208
+ })
1209
+ })
1210
+
1211
+ describe('when shift+selecting a group', () => {
1212
+ beforeEach(() => {
1213
+ editor
1214
+ .createShapes([
1215
+ { id: ids.box1, type: 'geo', x: 0, y: 0 },
1216
+ { id: ids.box2, type: 'geo', x: 200, y: 0 },
1217
+ { id: ids.box3, type: 'geo', x: 400, y: 0, props: { fill: 'solid' } },
1218
+ { id: ids.box4, type: 'geo', x: 600, y: 0 },
1219
+ ])
1220
+ .groupShapes([ids.box2, ids.box3], ids.group1)
1221
+ .select(ids.box1)
1222
+ })
1223
+
1224
+ it('does not add group to selection when pointing empty space in the group', () => {
1225
+ editor.keyDown('Shift')
1226
+ editor.pointerMove(350, 50)
1227
+ expect(editor.getHoveredShapeId()).toBe(null)
1228
+ editor.pointerDown() // inside of box 2, inside of group 1
1229
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box1])
1230
+ editor.pointerUp()
1231
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box1])
1232
+ })
1233
+
1234
+ it('does not add to selection on shift + on pointer up when clicking in hollow shape', () => {
1235
+ editor.keyDown('Shift')
1236
+ editor.pointerMove(275, 75)
1237
+ expect(editor.getHoveredShapeId()).toBe(null)
1238
+ editor.pointerDown() // inside of box 2, inside of group 1
1239
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box1])
1240
+ editor.pointerUp()
1241
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box1])
1242
+ })
1243
+
1244
+ it('adds to selection on pointer down when clicking in margin', () => {
1245
+ editor.keyDown('Shift')
1246
+ editor.pointerMove(304, 50)
1247
+ expect(editor.getHoveredShapeId()).toBe(ids.group1)
1248
+ editor.pointerDown() // inside of box 2, inside of group 1
1249
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box1, ids.group1])
1250
+ editor.pointerUp()
1251
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box1, ids.group1])
1252
+ })
1253
+
1254
+ it('adds to selection on pointer down when clicking in filled', () => {
1255
+ editor.keyDown('Shift')
1256
+ editor.pointerMove(450, 50)
1257
+ expect(editor.getHoveredShapeId()).toBe(ids.group1)
1258
+ editor.pointerDown() // inside of box 2, inside of group 1
1259
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box1, ids.group1])
1260
+ editor.pointerUp()
1261
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box1, ids.group1])
1262
+ })
1263
+
1264
+ it('does not select when shift+clicking into hollow shape inside of a group', () => {
1265
+ editor.pointerMove(275, 75)
1266
+ editor.keyDown('Shift')
1267
+ expect(editor.getHoveredShapeId()).toBe(null)
1268
+ editor.pointerDown() // inside of box 2, empty space, inside of group 1
1269
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box1])
1270
+ editor.pointerUp()
1271
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box1])
1272
+ })
1273
+
1274
+ it('does not deselect on pointer up when clicking into empty space in hollow shape', () => {
1275
+ editor.keyDown('Shift')
1276
+ editor.pointerMove(275, 75)
1277
+ expect(editor.getHoveredShapeId()).toBe(null)
1278
+ editor.pointerDown() // inside of box 2, empty space, inside of group 1
1279
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box1])
1280
+ editor.pointerUp()
1281
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box1])
1282
+ editor.pointerDown()
1283
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box1])
1284
+ editor.pointerUp()
1285
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box1])
1286
+ })
1287
+ })
1288
+
1289
+ // some of these tests are adapted from the "select hollow shape on pointer up" logic, which was removed.
1290
+ // the tests may seem arbitrary but their mostly negating the logic that was introduced in that feature.
1291
+
1292
+ describe('When children / descendants of a group are selected', () => {
1293
+ beforeEach(() => {
1294
+ editor
1295
+ .createShapes([
1296
+ { id: ids.box1, type: 'geo', x: 0, y: 0 },
1297
+ { id: ids.box2, type: 'geo', x: 200, y: 0 },
1298
+ { id: ids.box3, type: 'geo', x: 400, y: 0, props: { fill: 'solid' } },
1299
+ { id: ids.box4, type: 'geo', x: 600, y: 0 },
1300
+ { id: ids.box5, type: 'geo', x: 800, y: 0 },
1301
+ ])
1302
+ .groupShapes([ids.box1, ids.box2], ids.group1)
1303
+ .groupShapes([ids.box3, ids.box4], ids.group2)
1304
+ .groupShapes([ids.group1, ids.group2], ids.group3)
1305
+ .selectNone()
1306
+ })
1307
+
1308
+ it('selects the child', () => {
1309
+ editor.select(ids.box1)
1310
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box1])
1311
+ expect(editor.getFocusedGroupId()).toBe(ids.group1)
1312
+ })
1313
+
1314
+ it('selects the children', () => {
1315
+ editor.select(ids.box1, ids.box2)
1316
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box1, ids.box2])
1317
+ expect(editor.getFocusedGroupId()).toBe(ids.group1)
1318
+ })
1319
+
1320
+ it('does not allow parents and children to be selected, picking the parent', () => {
1321
+ editor.select(ids.group1, ids.box1)
1322
+ expect(editor.getSelectedShapeIds()).toEqual([ids.group1])
1323
+ expect(editor.getFocusedGroupId()).toBe(ids.group3)
1324
+
1325
+ editor.select(ids.group1, ids.box1, ids.box2)
1326
+ expect(editor.getSelectedShapeIds()).toEqual([ids.group1])
1327
+ expect(editor.getFocusedGroupId()).toBe(ids.group3)
1328
+ })
1329
+
1330
+ it('does not allow ancestors and children to be selected, picking the ancestor', () => {
1331
+ editor.select(ids.group3, ids.box1)
1332
+ expect(editor.getSelectedShapeIds()).toEqual([ids.group3])
1333
+ expect(editor.getFocusedGroupId()).toBe(editor.getCurrentPageId())
1334
+
1335
+ editor.select(ids.group3, ids.box1, ids.box2)
1336
+ expect(editor.getSelectedShapeIds()).toEqual([ids.group3])
1337
+ expect(editor.getFocusedGroupId()).toBe(editor.getCurrentPageId())
1338
+
1339
+ editor.select(ids.group3, ids.group2, ids.box1)
1340
+ expect(editor.getSelectedShapeIds()).toEqual([ids.group3])
1341
+ expect(editor.getFocusedGroupId()).toBe(editor.getCurrentPageId())
1342
+ })
1343
+
1344
+ it('picks the highest common focus layer id', () => {
1345
+ editor.select(ids.box1, ids.box4) // child of group1, child of group 2
1346
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box1, ids.box4])
1347
+ expect(editor.getFocusedGroupId()).toBe(ids.group3)
1348
+ })
1349
+
1350
+ it('picks the highest common focus layer id', () => {
1351
+ editor.select(ids.box1, ids.box5) // child of group1 and child of the page
1352
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box1, ids.box5])
1353
+ expect(editor.getFocusedGroupId()).toBe(editor.getCurrentPageId())
1354
+ })
1355
+
1356
+ it('sets the parent to the highest common ancestor', () => {
1357
+ editor.selectNone()
1358
+ expect(editor.getFocusedGroupId()).toBe(editor.getCurrentPageId())
1359
+ editor.select(ids.group3)
1360
+ expect(editor.getFocusedGroupId()).toBe(editor.getCurrentPageId())
1361
+ editor.select(ids.group3, ids.box1)
1362
+ expect(editor.getFocusedGroupId()).toBe(editor.getCurrentPageId())
1363
+ expect(editor.getSelectedShapeIds()).toEqual([ids.group3])
1364
+ })
1365
+ })
1366
+
1367
+ describe('When pressing the enter key with groups selected', () => {
1368
+ beforeEach(() => {
1369
+ editor
1370
+ .createShapes([
1371
+ { id: ids.box1, type: 'geo', x: 0, y: 0 },
1372
+ { id: ids.box2, type: 'geo', x: 200, y: 0 },
1373
+ { id: ids.box3, type: 'geo', x: 400, y: 0, props: { fill: 'solid' } },
1374
+ { id: ids.box4, type: 'geo', x: 600, y: 0 },
1375
+ { id: ids.box5, type: 'geo', x: 800, y: 0 },
1376
+ ])
1377
+ .groupShapes([ids.box1, ids.box2], ids.group1)
1378
+ .groupShapes([ids.box3, ids.box4], ids.group2)
1379
+ })
1380
+
1381
+ it('selects the children of the groups on enter up', () => {
1382
+ editor.select(ids.group1, ids.group2)
1383
+ editor.keyDown('Enter')
1384
+ expect(editor.getSelectedShapeIds()).toEqual([ids.group1, ids.group2])
1385
+ expect(editor.getFocusedGroupId()).toBe(editor.getCurrentPageId())
1386
+ editor.keyUp('Enter')
1387
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box1, ids.box2, ids.box3, ids.box4])
1388
+ expect(editor.getFocusedGroupId()).toBe(editor.getCurrentPageId())
1389
+ })
1390
+
1391
+ it('repeats children of the groups on enter up', () => {
1392
+ editor.groupShapes([ids.group1, ids.group2], ids.group3)
1393
+ editor.select(ids.group3)
1394
+ expect(editor.getSelectedShapeIds()).toEqual([ids.group3])
1395
+ editor.keyDown('Enter').keyUp('Enter')
1396
+ expect(editor.getSelectedShapeIds()).toEqual([ids.group1, ids.group2])
1397
+ expect(editor.getFocusedGroupId()).toBe(ids.group3)
1398
+ editor.keyDown('Enter').keyUp('Enter')
1399
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box1, ids.box2, ids.box3, ids.box4])
1400
+ expect(editor.getFocusedGroupId()).toBe(ids.group3)
1401
+ })
1402
+
1403
+ it('does not select the children of the group if a non-group is also selected', () => {
1404
+ editor.select(ids.group1, ids.group2, ids.box5)
1405
+ editor.keyDown('Enter')
1406
+ expect(editor.getSelectedShapeIds()).toEqual([ids.group1, ids.group2, ids.box5])
1407
+ editor.keyUp('Enter')
1408
+ expect(editor.getSelectedShapeIds()).toEqual([ids.group1, ids.group2, ids.box5])
1409
+ })
1410
+ })
1411
+
1412
+ describe('When double clicking an editable shape', () => {
1413
+ beforeEach(() => {
1414
+ editor.createShapes([
1415
+ { id: ids.box1, type: 'geo', x: 0, y: 0 },
1416
+ {
1417
+ id: ids.box2,
1418
+ type: 'arrow',
1419
+ x: 200,
1420
+ y: 50,
1421
+ props: {
1422
+ start: { type: 'point', x: 0, y: 0 },
1423
+ end: { type: 'point', x: 100, y: 0 },
1424
+ },
1425
+ },
1426
+ ])
1427
+ })
1428
+
1429
+ it('starts editing on double click', () => {
1430
+ editor.pointerMove(50, 50).doubleClick()
1431
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box1])
1432
+ expect(editor.getEditingShapeId()).toBe(ids.box1)
1433
+ editor.expectToBeIn('select.editing_shape')
1434
+ })
1435
+
1436
+ it('does not start editing on double click if shift is down', () => {
1437
+ editor.pointerMove(50, 50).keyDown('Shift').doubleClick()
1438
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box1])
1439
+ expect(editor.getEditingShapeId()).toBe(null)
1440
+ editor.expectToBeIn('select.idle')
1441
+ })
1442
+
1443
+ it('starts editing arrow on double click', () => {
1444
+ editor.pointerMove(250, 50)
1445
+
1446
+ editor.doubleClick()
1447
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box2])
1448
+ expect(editor.getEditingShapeId()).toBe(ids.box2)
1449
+ editor.expectToBeIn('select.editing_shape')
1450
+
1451
+ editor.doubleClick()
1452
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box2])
1453
+ expect(editor.getEditingShapeId()).toBe(ids.box2)
1454
+ editor.expectToBeIn('select.editing_shape')
1455
+ })
1456
+
1457
+ it('starts editing a child of a group on triple (not double!) click', () => {
1458
+ editor.createShape({ id: ids.box2, type: 'geo', x: 300, y: 0 })
1459
+ editor.groupShapes([ids.box1, ids.box2], ids.group1)
1460
+ editor.selectNone()
1461
+ editor.pointerMove(50, 50).click() // clicks on the shape label
1462
+ expect(editor.getSelectedShapeIds()).toEqual([ids.group1])
1463
+ expect(editor.getEditingShapeId()).toBe(null)
1464
+ editor.pointerMove(50, 50).click() // clicks on the shape label
1465
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box1])
1466
+ expect(editor.getEditingShapeId()).toBe(null)
1467
+ editor.pointerMove(50, 50).click() // clicks on the shape label
1468
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box1])
1469
+ expect(editor.getEditingShapeId()).toBe(ids.box1)
1470
+ editor.expectToBeIn('select.editing_shape')
1471
+ })
1472
+ })
1473
+
1474
+ describe('shift brushes to add to the selection', () => {
1475
+ beforeEach(() => {
1476
+ editor
1477
+ .createShapes([
1478
+ { id: ids.box1, type: 'geo', x: 0, y: 0 },
1479
+ { id: ids.box2, type: 'geo', x: 200, y: 0 },
1480
+ { id: ids.box3, type: 'geo', x: 400, y: 0 },
1481
+ { id: ids.box4, type: 'geo', x: 600, y: 200 },
1482
+ ])
1483
+ .groupShapes([ids.box3, ids.box4], ids.group1)
1484
+ })
1485
+
1486
+ it('does not select when brushing into margin', () => {
1487
+ editor.pointerMove(-50, -50)
1488
+ editor.pointerDown()
1489
+ editor.pointerMove(-1, -1)
1490
+ expect(editor.getSelectedShapeIds()).toEqual([])
1491
+ })
1492
+
1493
+ it('selects when brushing into shape edge', () => {
1494
+ editor.pointerMove(-50, -50)
1495
+ editor.pointerDown()
1496
+ editor.pointerMove(1, 1)
1497
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box1])
1498
+ })
1499
+
1500
+ it('selects when wrapping shape', () => {
1501
+ editor.pointerMove(-50, -50)
1502
+ editor.pointerDown()
1503
+ editor.pointerMove(101, 101)
1504
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box1])
1505
+ })
1506
+
1507
+ it('does not select when brushing into shape edge when holding control', () => {
1508
+ editor.pointerMove(-50, -50)
1509
+ editor.keyDown('Control')
1510
+ editor.pointerDown()
1511
+ editor.pointerMove(1, 1)
1512
+ expect(editor.getSelectedShapeIds()).toEqual([])
1513
+ })
1514
+
1515
+ it('selects when wrapping shape when holding control', () => {
1516
+ editor.pointerMove(-50, -50)
1517
+ editor.keyDown('Control')
1518
+ editor.pointerDown()
1519
+ editor.pointerMove(101, 101)
1520
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box1])
1521
+ })
1522
+
1523
+ it('does not select a group when colliding only with the groups bounds', () => {
1524
+ editor.pointerMove(650, -50)
1525
+ editor.pointerDown()
1526
+ editor.pointerMove(600, 50)
1527
+ expect(editor.getSelectedShapeIds()).toEqual([])
1528
+ })
1529
+
1530
+ it('selects a group when colliding with the groups child shape', () => {
1531
+ editor.pointerMove(650, -50)
1532
+ editor.pointerDown()
1533
+ editor.pointerMove(600, 250)
1534
+ expect(editor.getSelectedShapeIds()).toEqual([ids.group1])
1535
+ })
1536
+
1537
+ it('adds to selection when shift + brushing into shape', () => {
1538
+ editor.select(ids.box2)
1539
+ editor.pointerMove(-50, -50)
1540
+ editor.keyDown('Shift')
1541
+ editor.pointerDown()
1542
+ editor.pointerMove(1, 1)
1543
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box2, ids.box1])
1544
+ editor.keyUp('Shift')
1545
+ // there's a timer here—we should keep the shift mode until the timer expires
1546
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box2, ids.box1])
1547
+ jest.advanceTimersByTime(500)
1548
+ // once the timer expires, we should be back in regular mode
1549
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box1])
1550
+ editor.keyDown('Shift')
1551
+ // there's no timer on key down, so go right into shift mode again
1552
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box2, ids.box1])
1553
+ })
1554
+ })
1555
+
1556
+ describe('scribble brushes to add to the selection', () => {
1557
+ beforeEach(() => {
1558
+ editor.createShapes([
1559
+ { id: ids.box1, type: 'geo', x: 0, y: 0 },
1560
+ { id: ids.box2, type: 'geo', x: 200, y: 0 },
1561
+ { id: ids.box3, type: 'geo', x: 400, y: 0 },
1562
+ { id: ids.box4, type: 'geo', x: 600, y: 200 },
1563
+ ])
1564
+ })
1565
+
1566
+ it('does not select when scribbling into margin', () => {
1567
+ editor.pointerMove(-50, -50)
1568
+ editor.keyDown('Alt')
1569
+ editor.pointerDown()
1570
+ editor.pointerMove(-1, -1)
1571
+ editor.expectToBeIn('select.scribble_brushing')
1572
+ expect(editor.getSelectedShapeIds()).toEqual([])
1573
+ })
1574
+
1575
+ it('selects when scribbling into shape edge', () => {
1576
+ editor.pointerMove(-50, -50)
1577
+ editor.keyDown('Alt')
1578
+ editor.pointerDown()
1579
+ editor.pointerMove(1, 1)
1580
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box1])
1581
+ })
1582
+
1583
+ it('selects when scribbling through shape', () => {
1584
+ editor.pointerMove(-50, -50)
1585
+ editor.keyDown('Alt')
1586
+ editor.pointerDown()
1587
+ editor.pointerMove(101, 101)
1588
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box1])
1589
+ })
1590
+
1591
+ it('does not select a group when scribble is colliding only with the groups bounds', () => {
1592
+ editor.pointerMove(650, -50)
1593
+ editor.keyDown('Alt')
1594
+ editor.pointerDown()
1595
+ editor.pointerMove(600, 50)
1596
+ expect(editor.getSelectedShapeIds()).toEqual([])
1597
+ })
1598
+
1599
+ it('selects a group when scribble is colliding with the groups child shape', () => {
1600
+ editor.groupShapes([ids.box3, ids.box4], ids.group1)
1601
+ editor.pointerMove(650, -50)
1602
+ editor.keyDown('Alt')
1603
+ editor.pointerDown()
1604
+ editor.pointerMove(600, 250)
1605
+ expect(editor.getSelectedShapeIds()).toEqual([ids.group1])
1606
+ })
1607
+
1608
+ it('adds to selection when shift + scribbling into shape', () => {
1609
+ editor.select(ids.box2)
1610
+ editor.pointerMove(-50, -50)
1611
+ editor.keyDown('Alt')
1612
+ editor.keyDown('Shift')
1613
+ editor.pointerDown()
1614
+ editor.pointerMove(50, 50)
1615
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box1, ids.box2])
1616
+ editor.keyUp('Shift')
1617
+ jest.advanceTimersByTime(500)
1618
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box1])
1619
+ editor.keyDown('Shift')
1620
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box1, ids.box2])
1621
+ })
1622
+
1623
+ it('selects when switching between moves', () => {
1624
+ editor.ungroupShapes([ids.group1]) // ungroup boxes 3 and 4
1625
+ editor.pointerMove(650, 0)
1626
+ editor.keyDown('Alt') // scribble
1627
+ editor.pointerDown()
1628
+ editor.pointerMove(650, 250) // into box 4
1629
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box4])
1630
+ editor.pointerMove(450, 250) // below box 3
1631
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box4])
1632
+ editor.keyUp('Alt') // scribble
1633
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box4]) // still in timer
1634
+ jest.advanceTimersByTime(1000) // let timer expire
1635
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box3, ids.box4]) // brushed!
1636
+ editor.keyDown('Alt') // scribble
1637
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box4]) // back to brushed only
1638
+ editor.pointerMove(450, 240) // below box 3
1639
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box4]) // back to brushed only
1640
+ })
1641
+ })
1642
+
1643
+ describe('creating text on double click', () => {
1644
+ it('creates text on double click', () => {
1645
+ editor.doubleClick()
1646
+ expect(editor.getCurrentPageShapes().length).toBe(1)
1647
+ editor.pointerMove(0, 100)
1648
+ editor.click()
1649
+ })
1650
+ })
1651
+
1652
+ it.todo('maybe? does not select a hollow closed shape that contains the viewport?')
1653
+ it.todo('maybe? does not select a hollow closed shape if the negative distance is more than X?')
1654
+ it.todo(
1655
+ 'maybe? does not edit a hollow geo shape when double clicking inside of it unless it already has a label OR the double click is in the middle of the shape'
1656
+ )
1657
+
1658
+ it('selects one of the selected shapes on pointer up', () => {
1659
+ editor.createShapes([
1660
+ { id: ids.box1, type: 'geo' },
1661
+ { id: ids.box2, type: 'geo', x: 300 },
1662
+ ])
1663
+ editor.selectAll()
1664
+ editor.pointerMove(96, 50)
1665
+ editor.pointerDown()
1666
+ editor.pointerUp()
1667
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box1])
1668
+ })
1669
+
1670
+ describe('right clicking', () => {
1671
+ it('selects on right click', () => {
1672
+ editor.createShapes([{ id: ids.box1, type: 'geo' }])
1673
+ expect(editor.getSelectedShapeIds()).toEqual([])
1674
+ editor.pointerMove(4, 4)
1675
+ editor.pointerDown(4, 4, { target: 'canvas', button: 2 })
1676
+ editor.pointerUp()
1677
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box1])
1678
+ })
1679
+
1680
+ it('keeps selection when right-clicking a selection background', () => {
1681
+ editor.createShapes([{ id: ids.box1, type: 'geo' }])
1682
+ editor.selectAll()
1683
+ editor.pointerMove(30, 30)
1684
+ editor.pointerDown(30, 30, { target: 'canvas', button: 2 })
1685
+ editor.pointerUp()
1686
+ expect(editor.getSelectedShapeIds()).toEqual([ids.box1])
1687
+ })
1688
+
1689
+ it('keeps selection when right-clicking a selection background', () => {
1690
+ editor
1691
+ .selectAll()
1692
+ .deleteShapes(editor.getSelectedShapeIds())
1693
+ .setCurrentTool('arrow')
1694
+ .pointerMove(500, 500)
1695
+ .pointerDown()
1696
+ .pointerMove(600, 600)
1697
+ .pointerUp()
1698
+ .selectAll()
1699
+ .setCurrentTool('select')
1700
+
1701
+ expect(editor.getSelectedShapeIds().length).toBe(1)
1702
+
1703
+ // Not inside of the shape but inside of the selection bounds
1704
+ editor.pointerMove(510, 590)
1705
+ expect(editor.getHoveredShapeId()).toBe(null)
1706
+ editor.pointerDown(30, 30, { target: 'canvas', button: 2 })
1707
+ editor.pointerUp()
1708
+ expect(editor.getSelectedShapeIds()).toEqual([])
1709
+ })
1710
+ })