tldraw 3.16.0-canary.f60032f16651 → 3.16.0-canary.fa03b5a9ad13

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 (533) hide show
  1. package/dist-cjs/index.d.ts +412 -112
  2. package/dist-cjs/index.js +49 -14
  3. package/dist-cjs/index.js.map +2 -2
  4. package/dist-cjs/lib/Tldraw.js +12 -2
  5. package/dist-cjs/lib/Tldraw.js.map +2 -2
  6. package/dist-cjs/lib/canvas/TldrawScribble.js +1 -1
  7. package/dist-cjs/lib/canvas/TldrawScribble.js.map +2 -2
  8. package/dist-cjs/lib/defaultExternalContentHandlers.js +15 -4
  9. package/dist-cjs/lib/defaultExternalContentHandlers.js.map +2 -2
  10. package/dist-cjs/lib/shapes/arrow/ArrowShapeUtil.js +3 -3
  11. package/dist-cjs/lib/shapes/arrow/ArrowShapeUtil.js.map +2 -2
  12. package/dist-cjs/lib/shapes/arrow/arrow-types.js.map +1 -1
  13. package/dist-cjs/lib/shapes/arrow/arrowLabel.js +6 -0
  14. package/dist-cjs/lib/shapes/arrow/arrowLabel.js.map +3 -3
  15. package/dist-cjs/lib/shapes/arrow/arrowTargetState.js +3 -2
  16. package/dist-cjs/lib/shapes/arrow/arrowTargetState.js.map +2 -2
  17. package/dist-cjs/lib/shapes/arrow/elbow/ElbowArrowDebug.js +3 -3
  18. package/dist-cjs/lib/shapes/arrow/elbow/ElbowArrowDebug.js.map +1 -1
  19. package/dist-cjs/lib/shapes/arrow/toolStates/Pointing.js +1 -1
  20. package/dist-cjs/lib/shapes/arrow/toolStates/Pointing.js.map +2 -2
  21. package/dist-cjs/lib/shapes/bookmark/BookmarkShapeUtil.js +4 -4
  22. package/dist-cjs/lib/shapes/bookmark/BookmarkShapeUtil.js.map +2 -2
  23. package/dist-cjs/lib/shapes/draw/DrawShapeUtil.js +3 -3
  24. package/dist-cjs/lib/shapes/draw/DrawShapeUtil.js.map +2 -2
  25. package/dist-cjs/lib/shapes/embed/EmbedShapeUtil.js +1 -1
  26. package/dist-cjs/lib/shapes/embed/EmbedShapeUtil.js.map +1 -1
  27. package/dist-cjs/lib/shapes/frame/FrameShapeUtil.js +20 -13
  28. package/dist-cjs/lib/shapes/frame/FrameShapeUtil.js.map +2 -2
  29. package/dist-cjs/lib/shapes/frame/components/FrameHeading.js +1 -1
  30. package/dist-cjs/lib/shapes/frame/components/FrameHeading.js.map +2 -2
  31. package/dist-cjs/lib/shapes/frame/components/FrameLabelInput.js +8 -2
  32. package/dist-cjs/lib/shapes/frame/components/FrameLabelInput.js.map +2 -2
  33. package/dist-cjs/lib/shapes/geo/GeoShapeUtil.js +3 -2
  34. package/dist-cjs/lib/shapes/geo/GeoShapeUtil.js.map +2 -2
  35. package/dist-cjs/lib/shapes/geo/components/GeoShapeBody.js +2 -1
  36. package/dist-cjs/lib/shapes/geo/components/GeoShapeBody.js.map +2 -2
  37. package/dist-cjs/lib/shapes/highlight/HighlightShapeUtil.js +5 -1
  38. package/dist-cjs/lib/shapes/highlight/HighlightShapeUtil.js.map +2 -2
  39. package/dist-cjs/lib/shapes/image/ImageShapeUtil.js +6 -3
  40. package/dist-cjs/lib/shapes/image/ImageShapeUtil.js.map +2 -2
  41. package/dist-cjs/lib/shapes/line/LineShapeUtil.js +5 -1
  42. package/dist-cjs/lib/shapes/line/LineShapeUtil.js.map +2 -2
  43. package/dist-cjs/lib/shapes/note/NoteShapeUtil.js +6 -5
  44. package/dist-cjs/lib/shapes/note/NoteShapeUtil.js.map +2 -2
  45. package/dist-cjs/lib/shapes/shared/HyperlinkButton.js +4 -4
  46. package/dist-cjs/lib/shapes/shared/HyperlinkButton.js.map +2 -2
  47. package/dist-cjs/lib/shapes/shared/PlainTextLabel.js +1 -3
  48. package/dist-cjs/lib/shapes/shared/PlainTextLabel.js.map +2 -2
  49. package/dist-cjs/lib/shapes/shared/ShapeFill.js +4 -4
  50. package/dist-cjs/lib/shapes/shared/ShapeFill.js.map +2 -2
  51. package/dist-cjs/lib/shapes/shared/freehand/svg.js.map +2 -2
  52. package/dist-cjs/lib/shapes/shared/useEditablePlainText.js +3 -5
  53. package/dist-cjs/lib/shapes/shared/useEditablePlainText.js.map +2 -2
  54. package/dist-cjs/lib/shapes/shared/useImageOrVideoAsset.js +0 -2
  55. package/dist-cjs/lib/shapes/shared/useImageOrVideoAsset.js.map +2 -2
  56. package/dist-cjs/lib/shapes/shared/usePrefersReducedMotion.js +10 -1
  57. package/dist-cjs/lib/shapes/shared/usePrefersReducedMotion.js.map +2 -2
  58. package/dist-cjs/lib/shapes/text/PlainTextArea.js +3 -2
  59. package/dist-cjs/lib/shapes/text/PlainTextArea.js.map +2 -2
  60. package/dist-cjs/lib/shapes/text/RichTextArea.js +3 -3
  61. package/dist-cjs/lib/shapes/text/RichTextArea.js.map +2 -2
  62. package/dist-cjs/lib/shapes/text/TextShapeUtil.js +2 -2
  63. package/dist-cjs/lib/shapes/text/TextShapeUtil.js.map +2 -2
  64. package/dist-cjs/lib/shapes/video/VideoShapeUtil.js +3 -3
  65. package/dist-cjs/lib/shapes/video/VideoShapeUtil.js.map +1 -1
  66. package/dist-cjs/lib/tools/EraserTool/childStates/Erasing.js +25 -1
  67. package/dist-cjs/lib/tools/EraserTool/childStates/Erasing.js.map +2 -2
  68. package/dist-cjs/lib/tools/EraserTool/childStates/Pointing.js +12 -0
  69. package/dist-cjs/lib/tools/EraserTool/childStates/Pointing.js.map +2 -2
  70. package/dist-cjs/lib/tools/SelectTool/childStates/DraggingHandle.js +3 -1
  71. package/dist-cjs/lib/tools/SelectTool/childStates/DraggingHandle.js.map +2 -2
  72. package/dist-cjs/lib/ui/TldrawUi.js +27 -12
  73. package/dist-cjs/lib/ui/TldrawUi.js.map +3 -3
  74. package/dist-cjs/lib/ui/assetUrls.js +13 -10
  75. package/dist-cjs/lib/ui/assetUrls.js.map +2 -2
  76. package/dist-cjs/lib/ui/components/A11y.js +1 -1
  77. package/dist-cjs/lib/ui/components/A11y.js.map +2 -2
  78. package/dist-cjs/lib/ui/components/AccessibilityMenu.js +35 -0
  79. package/dist-cjs/lib/ui/components/AccessibilityMenu.js.map +7 -0
  80. package/dist-cjs/lib/ui/components/ActionsMenu/DefaultActionsMenu.js +12 -3
  81. package/dist-cjs/lib/ui/components/ActionsMenu/DefaultActionsMenu.js.map +2 -2
  82. package/dist-cjs/lib/ui/components/{FollowingIndicator.js → DefaultFollowingIndicator.js} +6 -6
  83. package/dist-cjs/lib/ui/components/DefaultFollowingIndicator.js.map +7 -0
  84. package/dist-cjs/lib/ui/components/DefaultMenuPanel.js +3 -2
  85. package/dist-cjs/lib/ui/components/DefaultMenuPanel.js.map +2 -2
  86. package/dist-cjs/lib/ui/components/KeyboardShortcutsDialog/DefaultKeyboardShortcutsDialogContent.js +6 -6
  87. package/dist-cjs/lib/ui/components/KeyboardShortcutsDialog/DefaultKeyboardShortcutsDialogContent.js.map +1 -1
  88. package/dist-cjs/lib/ui/components/LanguageMenu.js +1 -0
  89. package/dist-cjs/lib/ui/components/LanguageMenu.js.map +2 -2
  90. package/dist-cjs/lib/ui/components/MainMenu/DefaultMainMenuContent.js +3 -3
  91. package/dist-cjs/lib/ui/components/MainMenu/DefaultMainMenuContent.js.map +2 -2
  92. package/dist-cjs/lib/ui/components/Minimap/DefaultMinimap.js +2 -1
  93. package/dist-cjs/lib/ui/components/Minimap/DefaultMinimap.js.map +2 -2
  94. package/dist-cjs/lib/ui/components/Minimap/MinimapManager.js +4 -4
  95. package/dist-cjs/lib/ui/components/Minimap/MinimapManager.js.map +2 -2
  96. package/dist-cjs/lib/ui/components/MobileStylePanel.js +5 -3
  97. package/dist-cjs/lib/ui/components/MobileStylePanel.js.map +2 -2
  98. package/dist-cjs/lib/ui/components/NavigationPanel/DefaultNavigationPanel.js +1 -1
  99. package/dist-cjs/lib/ui/components/NavigationPanel/DefaultNavigationPanel.js.map +2 -2
  100. package/dist-cjs/lib/ui/components/PageMenu/DefaultPageMenu.js +3 -2
  101. package/dist-cjs/lib/ui/components/PageMenu/DefaultPageMenu.js.map +2 -2
  102. package/dist-cjs/lib/ui/components/SharePanel/PeopleMenuItem.js +3 -2
  103. package/dist-cjs/lib/ui/components/SharePanel/PeopleMenuItem.js.map +2 -2
  104. package/dist-cjs/lib/ui/components/SharePanel/UserPresenceColorPicker.js +2 -2
  105. package/dist-cjs/lib/ui/components/SharePanel/UserPresenceColorPicker.js.map +2 -2
  106. package/dist-cjs/lib/ui/components/StylePanel/DefaultStylePanel.js +11 -4
  107. package/dist-cjs/lib/ui/components/StylePanel/DefaultStylePanel.js.map +2 -2
  108. package/dist-cjs/lib/ui/components/StylePanel/DefaultStylePanelContent.js +249 -279
  109. package/dist-cjs/lib/ui/components/StylePanel/DefaultStylePanelContent.js.map +2 -2
  110. package/dist-cjs/lib/ui/components/StylePanel/StylePanelButtonPicker.js +147 -0
  111. package/dist-cjs/lib/ui/components/StylePanel/StylePanelButtonPicker.js.map +7 -0
  112. package/dist-cjs/lib/ui/components/StylePanel/StylePanelContext.js +68 -0
  113. package/dist-cjs/lib/ui/components/StylePanel/StylePanelContext.js.map +7 -0
  114. package/dist-cjs/lib/ui/components/StylePanel/{DoubleDropdownPicker.js → StylePanelDoubleDropdownPicker.js} +26 -25
  115. package/dist-cjs/lib/ui/components/StylePanel/StylePanelDoubleDropdownPicker.js.map +7 -0
  116. package/dist-cjs/lib/ui/components/StylePanel/{DropdownPicker.js → StylePanelDropdownPicker.js} +47 -43
  117. package/dist-cjs/lib/ui/components/StylePanel/StylePanelDropdownPicker.js.map +7 -0
  118. package/dist-cjs/lib/ui/components/StylePanel/StylePanelSubheading.js +28 -0
  119. package/dist-cjs/lib/ui/components/StylePanel/StylePanelSubheading.js.map +7 -0
  120. package/dist-cjs/lib/ui/components/Toolbar/AltTextEditor.js +2 -0
  121. package/dist-cjs/lib/ui/components/Toolbar/AltTextEditor.js.map +2 -2
  122. package/dist-cjs/lib/ui/components/Toolbar/DefaultImageToolbarContent.js +39 -10
  123. package/dist-cjs/lib/ui/components/Toolbar/DefaultImageToolbarContent.js.map +2 -2
  124. package/dist-cjs/lib/ui/components/Toolbar/DefaultToolbar.js +66 -21
  125. package/dist-cjs/lib/ui/components/Toolbar/DefaultToolbar.js.map +3 -3
  126. package/dist-cjs/lib/ui/components/Toolbar/DefaultVideoToolbarContent.js +15 -3
  127. package/dist-cjs/lib/ui/components/Toolbar/DefaultVideoToolbarContent.js.map +2 -2
  128. package/dist-cjs/lib/ui/components/Toolbar/LinkEditor.js +2 -1
  129. package/dist-cjs/lib/ui/components/Toolbar/LinkEditor.js.map +2 -2
  130. package/dist-cjs/lib/ui/components/Toolbar/OverflowingToolbar.js +189 -80
  131. package/dist-cjs/lib/ui/components/Toolbar/OverflowingToolbar.js.map +3 -3
  132. package/dist-cjs/lib/ui/components/Toolbar/ToggleToolLockedButton.js +10 -5
  133. package/dist-cjs/lib/ui/components/Toolbar/ToggleToolLockedButton.js.map +2 -2
  134. package/dist-cjs/lib/ui/components/menu-items.js +6 -0
  135. package/dist-cjs/lib/ui/components/menu-items.js.map +2 -2
  136. package/dist-cjs/lib/ui/components/primitives/TldrawUiContextualToolbar.js +11 -2
  137. package/dist-cjs/lib/ui/components/primitives/TldrawUiContextualToolbar.js.map +2 -2
  138. package/dist-cjs/lib/ui/components/primitives/TldrawUiInput.js +5 -3
  139. package/dist-cjs/lib/ui/components/primitives/TldrawUiInput.js.map +2 -2
  140. package/dist-cjs/lib/ui/components/primitives/TldrawUiPopover.js +3 -2
  141. package/dist-cjs/lib/ui/components/primitives/TldrawUiPopover.js.map +3 -3
  142. package/dist-cjs/lib/ui/components/primitives/TldrawUiSlider.js +18 -5
  143. package/dist-cjs/lib/ui/components/primitives/TldrawUiSlider.js.map +2 -2
  144. package/dist-cjs/lib/ui/components/primitives/TldrawUiToolbar.js +33 -7
  145. package/dist-cjs/lib/ui/components/primitives/TldrawUiToolbar.js.map +2 -2
  146. package/dist-cjs/lib/ui/components/primitives/TldrawUiTooltip.js +306 -0
  147. package/dist-cjs/lib/ui/components/primitives/TldrawUiTooltip.js.map +7 -0
  148. package/dist-cjs/lib/ui/components/primitives/layout.js +76 -0
  149. package/dist-cjs/lib/ui/components/primitives/layout.js.map +7 -0
  150. package/dist-cjs/lib/ui/components/primitives/menus/TldrawUiMenuCheckboxItem.js +3 -0
  151. package/dist-cjs/lib/ui/components/primitives/menus/TldrawUiMenuCheckboxItem.js.map +2 -2
  152. package/dist-cjs/lib/ui/components/primitives/menus/TldrawUiMenuContext.js.map +2 -2
  153. package/dist-cjs/lib/ui/components/primitives/menus/TldrawUiMenuGroup.js +25 -12
  154. package/dist-cjs/lib/ui/components/primitives/menus/TldrawUiMenuGroup.js.map +2 -2
  155. package/dist-cjs/lib/ui/components/primitives/menus/TldrawUiMenuItem.js +19 -33
  156. package/dist-cjs/lib/ui/components/primitives/menus/TldrawUiMenuItem.js.map +2 -2
  157. package/dist-cjs/lib/ui/context/TldrawUiContextProvider.js +3 -2
  158. package/dist-cjs/lib/ui/context/TldrawUiContextProvider.js.map +2 -2
  159. package/dist-cjs/lib/ui/context/actions.js +44 -10
  160. package/dist-cjs/lib/ui/context/actions.js.map +2 -2
  161. package/dist-cjs/lib/ui/context/components.js +2 -0
  162. package/dist-cjs/lib/ui/context/components.js.map +2 -2
  163. package/dist-cjs/lib/ui/context/events.js.map +2 -2
  164. package/dist-cjs/lib/ui/hooks/useClipboardEvents.js +1 -1
  165. package/dist-cjs/lib/ui/hooks/useClipboardEvents.js.map +2 -2
  166. package/dist-cjs/lib/ui/hooks/useExportAs.js +3 -2
  167. package/dist-cjs/lib/ui/hooks/useExportAs.js.map +2 -2
  168. package/dist-cjs/lib/ui/hooks/useTools.js +22 -4
  169. package/dist-cjs/lib/ui/hooks/useTools.js.map +2 -2
  170. package/dist-cjs/lib/ui/hooks/useTranslation/TLUiTranslationKey.js.map +1 -1
  171. package/dist-cjs/lib/ui/hooks/useTranslation/defaultTranslation.js +8 -1
  172. package/dist-cjs/lib/ui/hooks/useTranslation/defaultTranslation.js.map +2 -2
  173. package/dist-cjs/lib/ui/kbd-utils.js +9 -3
  174. package/dist-cjs/lib/ui/kbd-utils.js.map +2 -2
  175. package/dist-cjs/lib/ui/version.js +3 -3
  176. package/dist-cjs/lib/ui/version.js.map +1 -1
  177. package/dist-cjs/lib/utils/export/copyAs.js +1 -2
  178. package/dist-cjs/lib/utils/export/copyAs.js.map +2 -2
  179. package/dist-cjs/lib/utils/export/export.js +0 -20
  180. package/dist-cjs/lib/utils/export/export.js.map +2 -2
  181. package/dist-cjs/lib/utils/export/exportAs.js +1 -2
  182. package/dist-cjs/lib/utils/export/exportAs.js.map +2 -2
  183. package/dist-esm/index.d.mts +412 -112
  184. package/dist-esm/index.mjs +91 -29
  185. package/dist-esm/index.mjs.map +2 -2
  186. package/dist-esm/lib/Tldraw.mjs +14 -4
  187. package/dist-esm/lib/Tldraw.mjs.map +2 -2
  188. package/dist-esm/lib/canvas/TldrawScribble.mjs +1 -1
  189. package/dist-esm/lib/canvas/TldrawScribble.mjs.map +2 -2
  190. package/dist-esm/lib/defaultExternalContentHandlers.mjs +15 -4
  191. package/dist-esm/lib/defaultExternalContentHandlers.mjs.map +2 -2
  192. package/dist-esm/lib/shapes/arrow/ArrowShapeUtil.mjs +4 -3
  193. package/dist-esm/lib/shapes/arrow/ArrowShapeUtil.mjs.map +2 -2
  194. package/dist-esm/lib/shapes/arrow/arrowLabel.mjs +6 -0
  195. package/dist-esm/lib/shapes/arrow/arrowLabel.mjs.map +3 -3
  196. package/dist-esm/lib/shapes/arrow/arrowTargetState.mjs +3 -2
  197. package/dist-esm/lib/shapes/arrow/arrowTargetState.mjs.map +2 -2
  198. package/dist-esm/lib/shapes/arrow/elbow/ElbowArrowDebug.mjs +3 -3
  199. package/dist-esm/lib/shapes/arrow/elbow/ElbowArrowDebug.mjs.map +1 -1
  200. package/dist-esm/lib/shapes/arrow/toolStates/Pointing.mjs +1 -1
  201. package/dist-esm/lib/shapes/arrow/toolStates/Pointing.mjs.map +2 -2
  202. package/dist-esm/lib/shapes/bookmark/BookmarkShapeUtil.mjs +4 -5
  203. package/dist-esm/lib/shapes/bookmark/BookmarkShapeUtil.mjs.map +2 -2
  204. package/dist-esm/lib/shapes/draw/DrawShapeUtil.mjs +4 -3
  205. package/dist-esm/lib/shapes/draw/DrawShapeUtil.mjs.map +2 -2
  206. package/dist-esm/lib/shapes/embed/EmbedShapeUtil.mjs +1 -1
  207. package/dist-esm/lib/shapes/embed/EmbedShapeUtil.mjs.map +1 -1
  208. package/dist-esm/lib/shapes/frame/FrameShapeUtil.mjs +21 -13
  209. package/dist-esm/lib/shapes/frame/FrameShapeUtil.mjs.map +2 -2
  210. package/dist-esm/lib/shapes/frame/components/FrameHeading.mjs +1 -1
  211. package/dist-esm/lib/shapes/frame/components/FrameHeading.mjs.map +2 -2
  212. package/dist-esm/lib/shapes/frame/components/FrameLabelInput.mjs +9 -3
  213. package/dist-esm/lib/shapes/frame/components/FrameLabelInput.mjs.map +2 -2
  214. package/dist-esm/lib/shapes/geo/GeoShapeUtil.mjs +4 -2
  215. package/dist-esm/lib/shapes/geo/GeoShapeUtil.mjs.map +2 -2
  216. package/dist-esm/lib/shapes/geo/components/GeoShapeBody.mjs +2 -1
  217. package/dist-esm/lib/shapes/geo/components/GeoShapeBody.mjs.map +2 -2
  218. package/dist-esm/lib/shapes/highlight/HighlightShapeUtil.mjs +6 -1
  219. package/dist-esm/lib/shapes/highlight/HighlightShapeUtil.mjs.map +2 -2
  220. package/dist-esm/lib/shapes/image/ImageShapeUtil.mjs +6 -3
  221. package/dist-esm/lib/shapes/image/ImageShapeUtil.mjs.map +2 -2
  222. package/dist-esm/lib/shapes/line/LineShapeUtil.mjs +6 -1
  223. package/dist-esm/lib/shapes/line/LineShapeUtil.mjs.map +2 -2
  224. package/dist-esm/lib/shapes/note/NoteShapeUtil.mjs +7 -5
  225. package/dist-esm/lib/shapes/note/NoteShapeUtil.mjs.map +2 -2
  226. package/dist-esm/lib/shapes/shared/HyperlinkButton.mjs +5 -5
  227. package/dist-esm/lib/shapes/shared/HyperlinkButton.mjs.map +2 -2
  228. package/dist-esm/lib/shapes/shared/PlainTextLabel.mjs +1 -3
  229. package/dist-esm/lib/shapes/shared/PlainTextLabel.mjs.map +2 -2
  230. package/dist-esm/lib/shapes/shared/ShapeFill.mjs +5 -4
  231. package/dist-esm/lib/shapes/shared/ShapeFill.mjs.map +2 -2
  232. package/dist-esm/lib/shapes/shared/freehand/svg.mjs.map +2 -2
  233. package/dist-esm/lib/shapes/shared/useEditablePlainText.mjs +3 -6
  234. package/dist-esm/lib/shapes/shared/useEditablePlainText.mjs.map +2 -2
  235. package/dist-esm/lib/shapes/shared/useImageOrVideoAsset.mjs +0 -2
  236. package/dist-esm/lib/shapes/shared/useImageOrVideoAsset.mjs.map +2 -2
  237. package/dist-esm/lib/shapes/shared/usePrefersReducedMotion.mjs +10 -1
  238. package/dist-esm/lib/shapes/shared/usePrefersReducedMotion.mjs.map +2 -2
  239. package/dist-esm/lib/shapes/text/PlainTextArea.mjs +4 -3
  240. package/dist-esm/lib/shapes/text/PlainTextArea.mjs.map +2 -2
  241. package/dist-esm/lib/shapes/text/RichTextArea.mjs +3 -4
  242. package/dist-esm/lib/shapes/text/RichTextArea.mjs.map +2 -2
  243. package/dist-esm/lib/shapes/text/TextShapeUtil.mjs +3 -2
  244. package/dist-esm/lib/shapes/text/TextShapeUtil.mjs.map +2 -2
  245. package/dist-esm/lib/shapes/video/VideoShapeUtil.mjs +3 -3
  246. package/dist-esm/lib/shapes/video/VideoShapeUtil.mjs.map +1 -1
  247. package/dist-esm/lib/tools/EraserTool/childStates/Erasing.mjs +26 -1
  248. package/dist-esm/lib/tools/EraserTool/childStates/Erasing.mjs.map +2 -2
  249. package/dist-esm/lib/tools/EraserTool/childStates/Pointing.mjs +13 -0
  250. package/dist-esm/lib/tools/EraserTool/childStates/Pointing.mjs.map +2 -2
  251. package/dist-esm/lib/tools/SelectTool/childStates/DraggingHandle.mjs +3 -1
  252. package/dist-esm/lib/tools/SelectTool/childStates/DraggingHandle.mjs.map +2 -2
  253. package/dist-esm/lib/ui/TldrawUi.mjs +29 -14
  254. package/dist-esm/lib/ui/TldrawUi.mjs.map +3 -3
  255. package/dist-esm/lib/ui/assetUrls.mjs +13 -10
  256. package/dist-esm/lib/ui/assetUrls.mjs.map +2 -2
  257. package/dist-esm/lib/ui/components/A11y.mjs +1 -2
  258. package/dist-esm/lib/ui/components/A11y.mjs.map +2 -2
  259. package/dist-esm/lib/ui/components/AccessibilityMenu.mjs +19 -0
  260. package/dist-esm/lib/ui/components/AccessibilityMenu.mjs.map +7 -0
  261. package/dist-esm/lib/ui/components/ActionsMenu/DefaultActionsMenu.mjs +12 -3
  262. package/dist-esm/lib/ui/components/ActionsMenu/DefaultActionsMenu.mjs.map +2 -2
  263. package/dist-esm/lib/ui/components/{FollowingIndicator.mjs → DefaultFollowingIndicator.mjs} +3 -3
  264. package/dist-esm/lib/ui/components/DefaultFollowingIndicator.mjs.map +7 -0
  265. package/dist-esm/lib/ui/components/DefaultMenuPanel.mjs +3 -2
  266. package/dist-esm/lib/ui/components/DefaultMenuPanel.mjs.map +2 -2
  267. package/dist-esm/lib/ui/components/KeyboardShortcutsDialog/DefaultKeyboardShortcutsDialogContent.mjs +6 -6
  268. package/dist-esm/lib/ui/components/KeyboardShortcutsDialog/DefaultKeyboardShortcutsDialogContent.mjs.map +1 -1
  269. package/dist-esm/lib/ui/components/LanguageMenu.mjs +1 -0
  270. package/dist-esm/lib/ui/components/LanguageMenu.mjs.map +2 -2
  271. package/dist-esm/lib/ui/components/MainMenu/DefaultMainMenuContent.mjs +3 -5
  272. package/dist-esm/lib/ui/components/MainMenu/DefaultMainMenuContent.mjs.map +2 -2
  273. package/dist-esm/lib/ui/components/Minimap/DefaultMinimap.mjs +2 -1
  274. package/dist-esm/lib/ui/components/Minimap/DefaultMinimap.mjs.map +2 -2
  275. package/dist-esm/lib/ui/components/Minimap/MinimapManager.mjs +4 -4
  276. package/dist-esm/lib/ui/components/Minimap/MinimapManager.mjs.map +2 -2
  277. package/dist-esm/lib/ui/components/MobileStylePanel.mjs +6 -3
  278. package/dist-esm/lib/ui/components/MobileStylePanel.mjs.map +2 -2
  279. package/dist-esm/lib/ui/components/NavigationPanel/DefaultNavigationPanel.mjs +1 -1
  280. package/dist-esm/lib/ui/components/NavigationPanel/DefaultNavigationPanel.mjs.map +2 -2
  281. package/dist-esm/lib/ui/components/PageMenu/DefaultPageMenu.mjs +3 -3
  282. package/dist-esm/lib/ui/components/PageMenu/DefaultPageMenu.mjs.map +2 -2
  283. package/dist-esm/lib/ui/components/SharePanel/PeopleMenuItem.mjs +3 -2
  284. package/dist-esm/lib/ui/components/SharePanel/PeopleMenuItem.mjs.map +2 -2
  285. package/dist-esm/lib/ui/components/SharePanel/UserPresenceColorPicker.mjs +2 -2
  286. package/dist-esm/lib/ui/components/SharePanel/UserPresenceColorPicker.mjs.map +2 -2
  287. package/dist-esm/lib/ui/components/StylePanel/DefaultStylePanel.mjs +16 -5
  288. package/dist-esm/lib/ui/components/StylePanel/DefaultStylePanel.mjs.map +2 -2
  289. package/dist-esm/lib/ui/components/StylePanel/DefaultStylePanelContent.mjs +251 -283
  290. package/dist-esm/lib/ui/components/StylePanel/DefaultStylePanelContent.mjs.map +2 -2
  291. package/dist-esm/lib/ui/components/StylePanel/StylePanelButtonPicker.mjs +135 -0
  292. package/dist-esm/lib/ui/components/StylePanel/StylePanelButtonPicker.mjs.map +7 -0
  293. package/dist-esm/lib/ui/components/StylePanel/StylePanelContext.mjs +48 -0
  294. package/dist-esm/lib/ui/components/StylePanel/StylePanelContext.mjs.map +7 -0
  295. package/dist-esm/lib/ui/components/StylePanel/{DoubleDropdownPicker.mjs → StylePanelDoubleDropdownPicker.mjs} +23 -22
  296. package/dist-esm/lib/ui/components/StylePanel/StylePanelDoubleDropdownPicker.mjs.map +7 -0
  297. package/dist-esm/lib/ui/components/StylePanel/{DropdownPicker.mjs → StylePanelDropdownPicker.mjs} +44 -40
  298. package/dist-esm/lib/ui/components/StylePanel/StylePanelDropdownPicker.mjs.map +7 -0
  299. package/dist-esm/lib/ui/components/StylePanel/StylePanelSubheading.mjs +8 -0
  300. package/dist-esm/lib/ui/components/StylePanel/StylePanelSubheading.mjs.map +7 -0
  301. package/dist-esm/lib/ui/components/Toolbar/AltTextEditor.mjs +2 -0
  302. package/dist-esm/lib/ui/components/Toolbar/AltTextEditor.mjs.map +2 -2
  303. package/dist-esm/lib/ui/components/Toolbar/DefaultImageToolbarContent.mjs +39 -10
  304. package/dist-esm/lib/ui/components/Toolbar/DefaultImageToolbarContent.mjs.map +2 -2
  305. package/dist-esm/lib/ui/components/Toolbar/DefaultToolbar.mjs +56 -21
  306. package/dist-esm/lib/ui/components/Toolbar/DefaultToolbar.mjs.map +2 -2
  307. package/dist-esm/lib/ui/components/Toolbar/DefaultVideoToolbarContent.mjs +15 -3
  308. package/dist-esm/lib/ui/components/Toolbar/DefaultVideoToolbarContent.mjs.map +2 -2
  309. package/dist-esm/lib/ui/components/Toolbar/LinkEditor.mjs +2 -1
  310. package/dist-esm/lib/ui/components/Toolbar/LinkEditor.mjs.map +2 -2
  311. package/dist-esm/lib/ui/components/Toolbar/OverflowingToolbar.mjs +192 -81
  312. package/dist-esm/lib/ui/components/Toolbar/OverflowingToolbar.mjs.map +3 -3
  313. package/dist-esm/lib/ui/components/Toolbar/ToggleToolLockedButton.mjs +10 -5
  314. package/dist-esm/lib/ui/components/Toolbar/ToggleToolLockedButton.mjs.map +2 -2
  315. package/dist-esm/lib/ui/components/menu-items.mjs +6 -0
  316. package/dist-esm/lib/ui/components/menu-items.mjs.map +2 -2
  317. package/dist-esm/lib/ui/components/primitives/TldrawUiContextualToolbar.mjs +11 -3
  318. package/dist-esm/lib/ui/components/primitives/TldrawUiContextualToolbar.mjs.map +2 -2
  319. package/dist-esm/lib/ui/components/primitives/TldrawUiInput.mjs +6 -4
  320. package/dist-esm/lib/ui/components/primitives/TldrawUiInput.mjs.map +2 -2
  321. package/dist-esm/lib/ui/components/primitives/TldrawUiPopover.mjs +3 -2
  322. package/dist-esm/lib/ui/components/primitives/TldrawUiPopover.mjs.map +2 -2
  323. package/dist-esm/lib/ui/components/primitives/TldrawUiSlider.mjs +18 -5
  324. package/dist-esm/lib/ui/components/primitives/TldrawUiSlider.mjs.map +2 -2
  325. package/dist-esm/lib/ui/components/primitives/TldrawUiToolbar.mjs +33 -7
  326. package/dist-esm/lib/ui/components/primitives/TldrawUiToolbar.mjs.map +2 -2
  327. package/dist-esm/lib/ui/components/primitives/TldrawUiTooltip.mjs +284 -0
  328. package/dist-esm/lib/ui/components/primitives/TldrawUiTooltip.mjs.map +7 -0
  329. package/dist-esm/lib/ui/components/primitives/layout.mjs +46 -0
  330. package/dist-esm/lib/ui/components/primitives/layout.mjs.map +7 -0
  331. package/dist-esm/lib/ui/components/primitives/menus/TldrawUiMenuCheckboxItem.mjs +3 -0
  332. package/dist-esm/lib/ui/components/primitives/menus/TldrawUiMenuCheckboxItem.mjs.map +2 -2
  333. package/dist-esm/lib/ui/components/primitives/menus/TldrawUiMenuContext.mjs.map +2 -2
  334. package/dist-esm/lib/ui/components/primitives/menus/TldrawUiMenuGroup.mjs +25 -12
  335. package/dist-esm/lib/ui/components/primitives/menus/TldrawUiMenuGroup.mjs.map +2 -2
  336. package/dist-esm/lib/ui/components/primitives/menus/TldrawUiMenuItem.mjs +19 -33
  337. package/dist-esm/lib/ui/components/primitives/menus/TldrawUiMenuItem.mjs.map +2 -2
  338. package/dist-esm/lib/ui/context/TldrawUiContextProvider.mjs +3 -2
  339. package/dist-esm/lib/ui/context/TldrawUiContextProvider.mjs.map +2 -2
  340. package/dist-esm/lib/ui/context/actions.mjs +44 -10
  341. package/dist-esm/lib/ui/context/actions.mjs.map +2 -2
  342. package/dist-esm/lib/ui/context/components.mjs +2 -0
  343. package/dist-esm/lib/ui/context/components.mjs.map +2 -2
  344. package/dist-esm/lib/ui/context/events.mjs.map +2 -2
  345. package/dist-esm/lib/ui/hooks/useClipboardEvents.mjs +1 -2
  346. package/dist-esm/lib/ui/hooks/useClipboardEvents.mjs.map +2 -2
  347. package/dist-esm/lib/ui/hooks/useExportAs.mjs +3 -2
  348. package/dist-esm/lib/ui/hooks/useExportAs.mjs.map +2 -2
  349. package/dist-esm/lib/ui/hooks/useTools.mjs +23 -4
  350. package/dist-esm/lib/ui/hooks/useTools.mjs.map +2 -2
  351. package/dist-esm/lib/ui/hooks/useTranslation/defaultTranslation.mjs +8 -1
  352. package/dist-esm/lib/ui/hooks/useTranslation/defaultTranslation.mjs.map +2 -2
  353. package/dist-esm/lib/ui/kbd-utils.mjs +9 -3
  354. package/dist-esm/lib/ui/kbd-utils.mjs.map +2 -2
  355. package/dist-esm/lib/ui/version.mjs +3 -3
  356. package/dist-esm/lib/ui/version.mjs.map +1 -1
  357. package/dist-esm/lib/utils/export/copyAs.mjs +1 -2
  358. package/dist-esm/lib/utils/export/copyAs.mjs.map +2 -2
  359. package/dist-esm/lib/utils/export/export.mjs +0 -20
  360. package/dist-esm/lib/utils/export/export.mjs.map +2 -2
  361. package/dist-esm/lib/utils/export/exportAs.mjs +1 -2
  362. package/dist-esm/lib/utils/export/exportAs.mjs.map +2 -2
  363. package/package.json +11 -34
  364. package/src/index.ts +69 -22
  365. package/src/lib/Tldraw.tsx +15 -2
  366. package/src/lib/canvas/TldrawScribble.tsx +1 -1
  367. package/src/lib/defaultExternalContentHandlers.ts +26 -4
  368. package/src/lib/shapes/arrow/ArrowShapeOptions.test.ts +85 -14
  369. package/src/lib/shapes/arrow/ArrowShapeTool.test.ts +103 -8
  370. package/src/lib/shapes/arrow/ArrowShapeUtil.test.ts +48 -6
  371. package/src/lib/shapes/arrow/ArrowShapeUtil.tsx +4 -3
  372. package/src/lib/shapes/arrow/arrow-types.ts +3 -5
  373. package/src/lib/shapes/arrow/arrowLabel.ts +8 -0
  374. package/src/lib/shapes/arrow/arrowTargetState.ts +34 -3
  375. package/src/lib/shapes/arrow/elbow/ElbowArrowDebug.tsx +3 -3
  376. package/src/lib/shapes/arrow/toolStates/Pointing.tsx +1 -1
  377. package/src/lib/shapes/bookmark/BookmarkShapeUtil.tsx +4 -5
  378. package/src/lib/shapes/draw/DrawShapeTool.test.ts +0 -5
  379. package/src/lib/shapes/draw/DrawShapeUtil.tsx +4 -3
  380. package/src/lib/shapes/embed/EmbedShapeUtil.tsx +1 -1
  381. package/src/lib/shapes/frame/FrameShapeUtil.tsx +30 -14
  382. package/src/lib/shapes/frame/components/FrameHeading.tsx +1 -1
  383. package/src/lib/shapes/frame/components/FrameLabelInput.tsx +10 -3
  384. package/src/lib/shapes/geo/GeoShapeUtil.tsx +4 -2
  385. package/src/lib/shapes/geo/components/GeoShapeBody.tsx +2 -2
  386. package/src/lib/shapes/highlight/HighlightShapeUtil.tsx +7 -1
  387. package/src/lib/shapes/image/ImageShapeUtil.tsx +6 -3
  388. package/src/lib/shapes/line/LineShapeUtil.test.tsx +4 -3
  389. package/src/lib/shapes/line/LineShapeUtil.tsx +6 -1
  390. package/src/lib/shapes/line/__snapshots__/LineShapeUtil.test.tsx.snap +2 -2
  391. package/src/lib/shapes/note/NoteShapeUtil.tsx +10 -4
  392. package/src/lib/shapes/shared/HyperlinkButton.tsx +5 -5
  393. package/src/lib/shapes/shared/PlainTextLabel.tsx +0 -6
  394. package/src/lib/shapes/shared/ShapeFill.tsx +5 -4
  395. package/src/lib/shapes/shared/freehand/svg.ts +2 -0
  396. package/src/lib/shapes/shared/useEditablePlainText.ts +3 -10
  397. package/src/lib/shapes/shared/useImageOrVideoAsset.ts +0 -7
  398. package/src/lib/shapes/shared/usePrefersReducedMotion.tsx +11 -1
  399. package/src/lib/shapes/text/PlainTextArea.tsx +4 -3
  400. package/src/lib/shapes/text/RichTextArea.tsx +3 -4
  401. package/src/lib/shapes/text/TextShapeTool.test.ts +6 -5
  402. package/src/lib/shapes/text/TextShapeUtil.tsx +3 -2
  403. package/src/lib/shapes/video/VideoShapeUtil.tsx +3 -3
  404. package/src/lib/tools/EraserTool/childStates/Erasing.ts +34 -1
  405. package/src/lib/tools/EraserTool/childStates/Pointing.ts +20 -0
  406. package/src/lib/tools/SelectTool/childStates/DraggingHandle.tsx +6 -2
  407. package/src/lib/ui/TldrawUi.tsx +33 -12
  408. package/src/lib/ui/assetUrls.ts +13 -10
  409. package/src/lib/ui/components/A11y.tsx +1 -2
  410. package/src/lib/ui/components/AccessibilityMenu.tsx +20 -0
  411. package/src/lib/ui/components/ActionsMenu/DefaultActionsMenu.tsx +15 -3
  412. package/src/lib/ui/components/{FollowingIndicator.tsx → DefaultFollowingIndicator.tsx} +2 -1
  413. package/src/lib/ui/components/DefaultMenuPanel.tsx +4 -3
  414. package/src/lib/ui/components/KeyboardShortcutsDialog/DefaultKeyboardShortcutsDialogContent.tsx +6 -6
  415. package/src/lib/ui/components/LanguageMenu.tsx +1 -0
  416. package/src/lib/ui/components/MainMenu/DefaultMainMenuContent.tsx +4 -4
  417. package/src/lib/ui/components/Minimap/DefaultMinimap.tsx +2 -1
  418. package/src/lib/ui/components/Minimap/MinimapManager.ts +4 -4
  419. package/src/lib/ui/components/MobileStylePanel.tsx +9 -6
  420. package/src/lib/ui/components/NavigationPanel/DefaultNavigationPanel.tsx +1 -1
  421. package/src/lib/ui/components/PageMenu/DefaultPageMenu.tsx +4 -4
  422. package/src/lib/ui/components/SharePanel/PeopleMenuItem.tsx +4 -3
  423. package/src/lib/ui/components/SharePanel/UserPresenceColorPicker.tsx +3 -3
  424. package/src/lib/ui/components/StylePanel/DefaultStylePanel.tsx +28 -12
  425. package/src/lib/ui/components/StylePanel/DefaultStylePanelContent.tsx +261 -343
  426. package/src/lib/ui/components/{primitives/TldrawUiButtonPicker.tsx → StylePanel/StylePanelButtonPicker.tsx} +73 -50
  427. package/src/lib/ui/components/StylePanel/StylePanelContext.tsx +63 -0
  428. package/src/lib/ui/components/StylePanel/{DoubleDropdownPicker.tsx → StylePanelDoubleDropdownPicker.tsx} +31 -22
  429. package/src/lib/ui/components/StylePanel/StylePanelDropdownPicker.tsx +119 -0
  430. package/src/lib/ui/components/StylePanel/StylePanelSubheading.tsx +9 -0
  431. package/src/lib/ui/components/Toolbar/AltTextEditor.tsx +2 -0
  432. package/src/lib/ui/components/Toolbar/DefaultImageToolbarContent.tsx +33 -16
  433. package/src/lib/ui/components/Toolbar/DefaultToolbar.tsx +55 -23
  434. package/src/lib/ui/components/Toolbar/DefaultVideoToolbarContent.tsx +12 -4
  435. package/src/lib/ui/components/Toolbar/LinkEditor.tsx +1 -0
  436. package/src/lib/ui/components/Toolbar/OverflowingToolbar.tsx +212 -61
  437. package/src/lib/ui/components/Toolbar/ToggleToolLockedButton.tsx +21 -11
  438. package/src/lib/ui/components/menu-items.tsx +8 -0
  439. package/src/lib/ui/components/primitives/TldrawUiContextualToolbar.tsx +7 -3
  440. package/src/lib/ui/components/primitives/TldrawUiInput.tsx +6 -3
  441. package/src/lib/ui/components/primitives/TldrawUiPopover.tsx +4 -2
  442. package/src/lib/ui/components/primitives/TldrawUiSlider.tsx +52 -32
  443. package/src/lib/ui/components/primitives/TldrawUiToolbar.tsx +55 -12
  444. package/src/lib/ui/components/primitives/TldrawUiTooltip.tsx +379 -0
  445. package/src/lib/ui/components/primitives/layout.tsx +107 -0
  446. package/src/lib/ui/components/primitives/menus/TldrawUiMenuCheckboxItem.tsx +4 -0
  447. package/src/lib/ui/components/primitives/menus/TldrawUiMenuContext.tsx +0 -1
  448. package/src/lib/ui/components/primitives/menus/TldrawUiMenuGroup.tsx +29 -16
  449. package/src/lib/ui/components/primitives/menus/TldrawUiMenuItem.tsx +27 -36
  450. package/src/lib/ui/context/TldrawUiContextProvider.tsx +23 -20
  451. package/src/lib/ui/context/actions.tsx +51 -10
  452. package/src/lib/ui/context/components.tsx +3 -0
  453. package/src/lib/ui/context/events.tsx +2 -1
  454. package/src/lib/ui/hooks/useClipboardEvents.ts +1 -2
  455. package/src/lib/ui/hooks/useExportAs.ts +3 -2
  456. package/src/lib/ui/hooks/useTools.tsx +26 -4
  457. package/src/lib/ui/hooks/useTranslation/TLUiTranslationKey.ts +7 -0
  458. package/src/lib/ui/hooks/useTranslation/defaultTranslation.ts +8 -1
  459. package/src/lib/ui/kbd-utils.ts +10 -3
  460. package/src/lib/ui/version.ts +3 -3
  461. package/src/lib/ui.css +448 -294
  462. package/src/lib/utils/excalidraw/__snapshots__/putExcalidrawContent.test.tsx.snap +5 -5
  463. package/src/lib/utils/export/copyAs.ts +1 -24
  464. package/src/lib/utils/export/export.ts +0 -36
  465. package/src/lib/utils/export/exportAs.ts +1 -32
  466. package/src/lib/utils/tldr/__snapshots__/buildFromV1Document.test.ts.snap +4 -4
  467. package/src/test/A11y.test.tsx +3 -2
  468. package/src/test/ClickManager.test.ts +7 -6
  469. package/src/test/Editor.test.tsx +20 -19
  470. package/src/test/EraserTool.test.ts +184 -13
  471. package/src/test/HandTool.test.ts +10 -9
  472. package/src/test/HighlightShape.test.ts +2 -1
  473. package/src/test/SelectTool.test.ts +3 -2
  474. package/src/test/TLUserPreferences.test.ts +4 -3
  475. package/src/test/TestEditor.ts +21 -17
  476. package/src/test/TldrawEditor.test.tsx +11 -10
  477. package/src/test/ZoomTool.test.ts +7 -6
  478. package/src/test/__snapshots__/drawing.test.ts.snap +2 -2
  479. package/src/test/__snapshots__/groups.test.tsx.snap +6 -6
  480. package/src/test/__snapshots__/resizing.test.ts.snap +2 -2
  481. package/src/test/arrows-megabus.test.tsx +5 -4
  482. package/src/test/bindings.test.tsx +24 -37
  483. package/src/test/bookmark-shapes.test.ts +1 -8
  484. package/src/test/commands/__snapshots__/getSvgString.test.ts.snap +23 -7
  485. package/src/test/commands/__snapshots__/packShapes.test.ts.snap +8 -8
  486. package/src/test/commands/__snapshots__/zoomToFit.test.ts.snap +2 -2
  487. package/src/test/commands/alignShapes.test.tsx +25 -24
  488. package/src/test/commands/animationSpeed.test.ts +2 -1
  489. package/src/test/commands/centerOnPoint.test.ts +3 -2
  490. package/src/test/commands/clipboard.test.ts +3 -2
  491. package/src/test/commands/createShapes.test.ts +2 -1
  492. package/src/test/commands/deleteShapes.test.ts +2 -1
  493. package/src/test/commands/distributeShapes.test.tsx +11 -10
  494. package/src/test/commands/getSvgString.test.ts +2 -1
  495. package/src/test/commands/packShapes.test.ts +5 -4
  496. package/src/test/commands/resizeShape.test.ts +2 -1
  497. package/src/test/commands/rotateShapes.test.ts +7 -6
  498. package/src/test/commands/setCamera.test.ts +4 -3
  499. package/src/test/commands/setCurrentPage.test.ts +3 -2
  500. package/src/test/commands/stackShapes.test.ts +11 -10
  501. package/src/test/commands/stretch.test.tsx +13 -12
  502. package/src/test/createDeepLink.test.tsx +2 -1
  503. package/src/test/cropping.test.ts +3 -2
  504. package/src/test/custom-clipping.test.ts +436 -0
  505. package/src/test/drawing.test.ts +2 -1
  506. package/src/test/flipShapes.test.ts +4 -3
  507. package/src/test/frames.test.ts +40 -24
  508. package/src/test/getCulledShapes.test.tsx +74 -4
  509. package/src/test/groups.test.tsx +1 -1
  510. package/src/test/handleDeepLink.test.tsx +2 -1
  511. package/src/test/maxShapes.test.ts +3 -2
  512. package/src/test/modifiers.test.ts +5 -4
  513. package/src/test/navigation.test.ts +12 -11
  514. package/src/test/panning.test.ts +2 -1
  515. package/src/test/perf/perf.test.ts +2 -1
  516. package/src/test/registerDeepLinkListener.test.tsx +10 -9
  517. package/src/test/resizing.test.ts +39 -38
  518. package/src/test/select.test.tsx +4 -3
  519. package/src/test/selection-omnibus.test.ts +11 -10
  520. package/src/test/shapeutils.test.ts +4 -3
  521. package/src/test/translating.test.ts +9 -8
  522. package/tldraw.css +756 -584
  523. package/dist-cjs/lib/ui/components/FollowingIndicator.js.map +0 -7
  524. package/dist-cjs/lib/ui/components/StylePanel/DoubleDropdownPicker.js.map +0 -7
  525. package/dist-cjs/lib/ui/components/StylePanel/DropdownPicker.js.map +0 -7
  526. package/dist-cjs/lib/ui/components/primitives/TldrawUiButtonPicker.js +0 -142
  527. package/dist-cjs/lib/ui/components/primitives/TldrawUiButtonPicker.js.map +0 -7
  528. package/dist-esm/lib/ui/components/FollowingIndicator.mjs.map +0 -7
  529. package/dist-esm/lib/ui/components/StylePanel/DoubleDropdownPicker.mjs.map +0 -7
  530. package/dist-esm/lib/ui/components/StylePanel/DropdownPicker.mjs.map +0 -7
  531. package/dist-esm/lib/ui/components/primitives/TldrawUiButtonPicker.mjs +0 -115
  532. package/dist-esm/lib/ui/components/primitives/TldrawUiButtonPicker.mjs.map +0 -7
  533. package/src/lib/ui/components/StylePanel/DropdownPicker.tsx +0 -109
package/src/index.ts CHANGED
@@ -22,8 +22,20 @@ export {
22
22
  } from './lib/shapes/shared/PathBuilder'
23
23
  export { usePrefersReducedMotion } from './lib/shapes/shared/usePrefersReducedMotion'
24
24
  export { DefaultA11yAnnouncer, useSelectedShapesAnnouncer } from './lib/ui/components/A11y'
25
+ export { AccessibilityMenu } from './lib/ui/components/AccessibilityMenu'
25
26
  export { ColorSchemeMenu } from './lib/ui/components/ColorSchemeMenu'
27
+ export { DefaultFollowingIndicator } from './lib/ui/components/DefaultFollowingIndicator'
26
28
  export { DefaultDialogs } from './lib/ui/components/Dialogs'
29
+ export {
30
+ TldrawUiColumn,
31
+ TldrawUiGrid,
32
+ TldrawUiOrientationProvider,
33
+ TldrawUiRow,
34
+ useTldrawUiOrientation,
35
+ type TldrawUiOrientationContext,
36
+ type TldrawUiOrientationProviderProps,
37
+ type TLUiLayoutProps,
38
+ } from './lib/ui/components/primitives/layout'
27
39
  export {
28
40
  TldrawUiMenuActionCheckboxItem,
29
41
  type TLUiMenuActionCheckboxItemProps,
@@ -74,6 +86,7 @@ export {
74
86
  defaultHandleExternalUrlContent,
75
87
  getAssetInfo,
76
88
  getMediaAssetInfoPartial,
89
+ notifyIfFileNotAllowed,
77
90
  registerDefaultExternalContentHandlers,
78
91
  type TLDefaultExternalContentHandlerOpts,
79
92
  type TLExternalContentProps,
@@ -93,6 +106,13 @@ export {
93
106
  } from './lib/shapes/arrow/arrow-types'
94
107
  export { ArrowShapeTool } from './lib/shapes/arrow/ArrowShapeTool'
95
108
  export { ArrowShapeUtil } from './lib/shapes/arrow/ArrowShapeUtil'
109
+ export {
110
+ clearArrowTargetState,
111
+ getArrowTargetState,
112
+ updateArrowTargetState,
113
+ type ArrowTargetState,
114
+ type UpdateArrowTargetStateOpts,
115
+ } from './lib/shapes/arrow/arrowTargetState'
96
116
  export {
97
117
  type ElbowArrowBox,
98
118
  type ElbowArrowBoxEdges,
@@ -155,11 +175,10 @@ export {
155
175
  type TLDefaultFont,
156
176
  type TLDefaultFonts,
157
177
  } from './lib/shapes/shared/defaultFonts'
158
- export {
159
- PlainTextLabel,
160
- TextLabel,
161
- type PlainTextLabelProps,
162
- } from './lib/shapes/shared/PlainTextLabel'
178
+ export { getStrokePoints } from './lib/shapes/shared/freehand/getStrokePoints'
179
+ export { getSvgPathFromStrokePoints } from './lib/shapes/shared/freehand/svg'
180
+ export { type StrokeOptions, type StrokePoint } from './lib/shapes/shared/freehand/types'
181
+ export { PlainTextLabel, type PlainTextLabelProps } from './lib/shapes/shared/PlainTextLabel'
163
182
  export {
164
183
  RichTextLabel,
165
184
  RichTextSVG,
@@ -167,10 +186,9 @@ export {
167
186
  type RichTextSVGProps,
168
187
  } from './lib/shapes/shared/RichTextLabel'
169
188
  export { useDefaultColorTheme } from './lib/shapes/shared/useDefaultColorTheme'
170
- export { useEditablePlainText, useEditableText } from './lib/shapes/shared/useEditablePlainText'
189
+ export { useEditablePlainText } from './lib/shapes/shared/useEditablePlainText'
171
190
  export { useEditableRichText } from './lib/shapes/shared/useEditableRichText'
172
191
  export {
173
- useAsset,
174
192
  useImageOrVideoAsset,
175
193
  type UseImageOrVideoAssetOptions,
176
194
  } from './lib/shapes/shared/useImageOrVideoAsset'
@@ -294,6 +312,7 @@ export {
294
312
  ToggleSnapModeItem,
295
313
  ToggleToolLockItem,
296
314
  ToggleTransparentBgMenuItem,
315
+ ToggleUiLabelsItem,
297
316
  ToggleWrapModeItem,
298
317
  UngroupMenuItem,
299
318
  UnlockAllMenuItem,
@@ -348,10 +367,6 @@ export {
348
367
  TldrawUiMenuSubmenu,
349
368
  type TLUiMenuSubmenuProps,
350
369
  } from './lib/ui/components/primitives/menus/TldrawUiMenuSubmenu'
351
- export {
352
- TldrawUiButtonPicker,
353
- type TLUiButtonPickerProps,
354
- } from './lib/ui/components/primitives/TldrawUiButtonPicker'
355
370
  export {
356
371
  TldrawUiContextualToolbar,
357
372
  type TLUiContextualToolbarProps,
@@ -412,6 +427,12 @@ export {
412
427
  type TLUiToolbarToggleGroupProps,
413
428
  type TLUiToolbarToggleItemProps,
414
429
  } from './lib/ui/components/primitives/TldrawUiToolbar'
430
+ export {
431
+ TldrawUiTooltip,
432
+ TldrawUiTooltipProvider,
433
+ type TldrawUiTooltipProps,
434
+ type TldrawUiTooltipProviderProps,
435
+ } from './lib/ui/components/primitives/TldrawUiTooltip'
415
436
  export {
416
437
  DefaultQuickActions,
417
438
  type TLUiQuickActionsProps,
@@ -425,17 +446,44 @@ export {
425
446
  type TLUiStylePanelProps,
426
447
  } from './lib/ui/components/StylePanel/DefaultStylePanel'
427
448
  export {
428
- ArrowheadStylePickerSet,
429
- CommonStylePickerSet,
430
449
  DefaultStylePanelContent,
431
- GeoStylePickerSet,
432
- OpacitySlider,
433
- SplineStylePickerSet,
434
- TextStylePickerSet,
435
- type StylePickerSetProps,
436
- type ThemeStylePickerSetProps,
437
- type TLUiStylePanelContentProps,
450
+ StylePanelArrowheadPicker,
451
+ StylePanelArrowKindPicker,
452
+ StylePanelColorPicker,
453
+ StylePanelDashPicker,
454
+ StylePanelFillPicker,
455
+ StylePanelFontPicker,
456
+ StylePanelGeoShapePicker,
457
+ StylePanelLabelAlignPicker,
458
+ StylePanelOpacityPicker,
459
+ StylePanelSection,
460
+ StylePanelSizePicker,
461
+ StylePanelSplinePicker,
462
+ StylePanelTextAlignPicker,
463
+ type StylePanelSectionProps,
438
464
  } from './lib/ui/components/StylePanel/DefaultStylePanelContent'
465
+ export {
466
+ StylePanelButtonPicker,
467
+ type StylePanelButtonPickerProps,
468
+ } from './lib/ui/components/StylePanel/StylePanelButtonPicker'
469
+ export {
470
+ StylePanelContextProvider,
471
+ useStylePanelContext,
472
+ type StylePanelContext,
473
+ type StylePanelContextProviderProps,
474
+ } from './lib/ui/components/StylePanel/StylePanelContext'
475
+ export {
476
+ StylePanelDoubleDropdownPicker,
477
+ type StylePanelDoubleDropdownPickerProps,
478
+ } from './lib/ui/components/StylePanel/StylePanelDoubleDropdownPicker'
479
+ export {
480
+ StylePanelDropdownPicker,
481
+ type StylePanelDropdownPickerProps,
482
+ } from './lib/ui/components/StylePanel/StylePanelDropdownPicker'
483
+ export {
484
+ StylePanelSubheading,
485
+ type StylePanelSubheadingProps,
486
+ } from './lib/ui/components/StylePanel/StylePanelSubheading'
439
487
  export {
440
488
  DefaultImageToolbar,
441
489
  type TLUiImageToolbarProps,
@@ -607,13 +655,12 @@ export {
607
655
  } from './lib/ui/hooks/useTranslation/useTranslation'
608
656
  export { type TLUiIconType } from './lib/ui/icon-types'
609
657
  export { useDefaultHelpers, type TLUiOverrideHelpers, type TLUiOverrides } from './lib/ui/overrides'
610
- export { TldrawUi, type TldrawUiProps } from './lib/ui/TldrawUi'
658
+ export { TldrawUi, TldrawUiInFrontOfTheCanvas, type TldrawUiProps } from './lib/ui/TldrawUi'
611
659
  export { containBoxSize, downsizeImage, type BoxWidthHeight } from './lib/utils/assets/assets'
612
660
  export { preloadFont, type TLTypeFace } from './lib/utils/assets/preload-font'
613
661
  export { getEmbedInfo, type TLEmbedResult } from './lib/utils/embeds/embeds'
614
662
  export { putExcalidrawContent } from './lib/utils/excalidraw/putExcalidrawContent'
615
663
  export { copyAs, type CopyAsOptions, type TLCopyType } from './lib/utils/export/copyAs'
616
- export { exportToBlob } from './lib/utils/export/export'
617
664
  export { downloadFile, exportAs, type ExportAsOptions } from './lib/utils/export/exportAs'
618
665
  export { fitFrameToContent, removeFrame } from './lib/utils/frames/frames'
619
666
  export {
@@ -33,7 +33,7 @@ import { registerDefaultSideEffects } from './defaultSideEffects'
33
33
  import { defaultTools } from './defaultTools'
34
34
  import { EmbedShapeUtil } from './shapes/embed/EmbedShapeUtil'
35
35
  import { allDefaultFontFaces } from './shapes/shared/defaultFonts'
36
- import { TldrawUi, TldrawUiProps } from './ui/TldrawUi'
36
+ import { TldrawUi, TldrawUiInFrontOfTheCanvas, TldrawUiProps } from './ui/TldrawUi'
37
37
  import { TLUiAssetUrlOverrides, useDefaultUiAssetUrlsWithOverrides } from './ui/assetUrls'
38
38
  import { LoadingScreen } from './ui/components/LoadingScreen'
39
39
  import { Spinner } from './ui/components/Spinner'
@@ -118,6 +118,18 @@ export function Tldraw(props: TldrawProps) {
118
118
 
119
119
  const _components = useShallowObjectIdentity(components)
120
120
 
121
+ const CustomInFrontOfTheCanvas = components?.InFrontOfTheCanvas
122
+ const InFrontOfTheCanvas = useMemo(() => {
123
+ if (rest.hideUi) return CustomInFrontOfTheCanvas ?? null
124
+ if (!CustomInFrontOfTheCanvas) return TldrawUiInFrontOfTheCanvas
125
+
126
+ return () => (
127
+ <>
128
+ <TldrawUiInFrontOfTheCanvas />
129
+ <CustomInFrontOfTheCanvas />
130
+ </>
131
+ )
132
+ }, [rest.hideUi, CustomInFrontOfTheCanvas])
121
133
  const componentsWithDefault = useMemo(
122
134
  () => ({
123
135
  Scribble: TldrawScribble,
@@ -129,8 +141,9 @@ export function Tldraw(props: TldrawProps) {
129
141
  Spinner,
130
142
  LoadingScreen,
131
143
  ..._components,
144
+ InFrontOfTheCanvas,
132
145
  }),
133
- [_components]
146
+ [_components, InFrontOfTheCanvas]
134
147
  )
135
148
 
136
149
  const _shapeUtils = useShallowArrayIdentity(shapeUtils)
@@ -31,7 +31,7 @@ export function TldrawScribble({ scribble, zoom, color, opacity, className }: TL
31
31
  <path
32
32
  className="tl-scribble"
33
33
  d={d}
34
- fill={color ?? `var(--color-${scribble.color})`}
34
+ fill={color ?? `var(--tl-color-${scribble.color})`}
35
35
  opacity={opacity ?? scribble.opacity}
36
36
  />
37
37
  </svg>
@@ -144,7 +144,7 @@ export async function defaultHandleExternalFileAsset(
144
144
  { file, assetId }: TLFileExternalAsset,
145
145
  options: TLDefaultExternalContentHandlerOpts
146
146
  ) {
147
- const isSuccess = runFileChecks(file, options)
147
+ const isSuccess = notifyIfFileNotAllowed(file, options)
148
148
  if (!isSuccess) assert(false, 'File checks failed')
149
149
 
150
150
  const assetInfo = await getAssetInfo(file, options, assetId)
@@ -161,7 +161,7 @@ export async function defaultHandleExternalFileReplaceContent(
161
161
  { file, shapeId, isImage }: TLFileReplaceExternalContent,
162
162
  options: TLDefaultExternalContentHandlerOpts
163
163
  ) {
164
- const isSuccess = runFileChecks(file, options)
164
+ const isSuccess = notifyIfFileNotAllowed(file, options)
165
165
  if (!isSuccess) assert(false, 'File checks failed')
166
166
 
167
167
  const shape = editor.getShape(shapeId)
@@ -399,7 +399,7 @@ export async function defaultHandleExternalFileContent(
399
399
  file: File
400
400
  }[] = []
401
401
  for (const file of files) {
402
- const isSuccess = runFileChecks(file, options)
402
+ const isSuccess = notifyIfFileNotAllowed(file, options)
403
403
  if (!isSuccess) continue
404
404
 
405
405
  const assetInfo = await getAssetInfo(file, options)
@@ -873,7 +873,15 @@ export function createEmptyBookmarkShape(
873
873
  return editor.getShape(partial.id) as TLBookmarkShape
874
874
  }
875
875
 
876
- function runFileChecks(file: File, options: TLDefaultExternalContentHandlerOpts) {
876
+ /**
877
+ * Checks if a file is allowed to be uploaded. If it is not, it will show a toast explaining why to the user.
878
+ *
879
+ * @param file - The file to check
880
+ * @param options - The options for the external content handler
881
+ * @returns True if the file is allowed, false otherwise
882
+ * @public
883
+ */
884
+ export function notifyIfFileNotAllowed(file: File, options: TLDefaultExternalContentHandlerOpts) {
877
885
  const {
878
886
  acceptedImageMimeTypes = DEFAULT_SUPPORTED_IMAGE_TYPES,
879
887
  acceptedVideoMimeTypes = DEFAULT_SUPPORT_VIDEO_TYPES,
@@ -893,8 +901,22 @@ function runFileChecks(file: File, options: TLDefaultExternalContentHandlerOpts)
893
901
  }
894
902
 
895
903
  if (file.size > maxAssetSize) {
904
+ const formatBytes = (bytes: number): string => {
905
+ if (bytes === 0) return '0 bytes'
906
+
907
+ const units = ['bytes', 'KB', 'MB', 'GB', 'TB', 'PB']
908
+ const base = 1024
909
+ const unitIndex = Math.floor(Math.log(bytes) / Math.log(base))
910
+
911
+ const value = bytes / Math.pow(base, unitIndex)
912
+ const formatted = value % 1 === 0 ? value.toString() : value.toFixed(1)
913
+
914
+ return `${formatted} ${units[unitIndex]}`
915
+ }
916
+
896
917
  toasts.addToast({
897
918
  title: msg('assets.files.size-too-big'),
919
+ description: msg('assets.files.maximum-size').replace('{size}', formatBytes(maxAssetSize)),
898
920
  severity: 'error',
899
921
  })
900
922
  return false
@@ -1,4 +1,5 @@
1
1
  import { TLArrowShape, createShapeId } from '@tldraw/editor'
2
+ import { vi } from 'vitest'
2
3
  import { TestEditor } from '../../../test/TestEditor'
3
4
  import { ArrowShapeUtil } from './ArrowShapeUtil'
4
5
  import { updateArrowTargetState } from './arrowTargetState'
@@ -12,7 +13,7 @@ const ids = {
12
13
  arrow1: createShapeId('arrow1'),
13
14
  }
14
15
 
15
- jest.useFakeTimers()
16
+ vi.useFakeTimers()
16
17
 
17
18
  window.requestAnimationFrame = function requestAnimationFrame(cb) {
18
19
  return setTimeout(cb, 1000 / 60)
@@ -46,13 +47,21 @@ describe('ArrowShapeOptions', () => {
46
47
  it('should have correct default shouldBeExact behavior (alt key)', () => {
47
48
  const util = editor.getShapeUtil<ArrowShapeUtil>('arrow')
48
49
 
49
- // Test without alt key
50
+ // Test without alt key, not precise
50
51
  editor.inputs.altKey = false
51
- expect(util.options.shouldBeExact(editor)).toBe(false)
52
+ expect(util.options.shouldBeExact(editor, false)).toBe(false)
52
53
 
53
- // Test with alt key
54
+ // Test without alt key, precise
55
+ editor.inputs.altKey = false
56
+ expect(util.options.shouldBeExact(editor, true)).toBe(false)
57
+
58
+ // Test with alt key, not precise
59
+ editor.inputs.altKey = true
60
+ expect(util.options.shouldBeExact(editor, false)).toBe(true)
61
+
62
+ // Test with alt key, precise
54
63
  editor.inputs.altKey = true
55
- expect(util.options.shouldBeExact(editor)).toBe(true)
64
+ expect(util.options.shouldBeExact(editor, true)).toBe(true)
56
65
  })
57
66
 
58
67
  it('should have correct default shouldIgnoreTargets behavior (ctrl key)', () => {
@@ -185,7 +194,7 @@ describe('ArrowShapeOptions', () => {
185
194
  class CustomArrowShapeUtil extends ArrowShapeUtil {
186
195
  override options = {
187
196
  ...baseUtil.options,
188
- shouldBeExact: (editor: any) => editor.inputs.shiftKey, // Use shift instead of alt
197
+ shouldBeExact: (editor: any, _isPrecise: boolean) => editor.inputs.shiftKey, // Use shift instead of alt
189
198
  }
190
199
  }
191
200
 
@@ -194,12 +203,14 @@ describe('ArrowShapeOptions', () => {
194
203
  // Test with shift key
195
204
  editor.inputs.shiftKey = true
196
205
  editor.inputs.altKey = false
197
- expect(customUtil.options.shouldBeExact(editor)).toBe(true)
206
+ expect(customUtil.options.shouldBeExact(editor, false)).toBe(true)
207
+ expect(customUtil.options.shouldBeExact(editor, true)).toBe(true)
198
208
 
199
209
  // Test without shift key
200
210
  editor.inputs.shiftKey = false
201
211
  editor.inputs.altKey = true // Alt key should not matter for custom implementation
202
- expect(customUtil.options.shouldBeExact(editor)).toBe(false)
212
+ expect(customUtil.options.shouldBeExact(editor, false)).toBe(false)
213
+ expect(customUtil.options.shouldBeExact(editor, true)).toBe(false)
203
214
  })
204
215
 
205
216
  it('should allow customizing shouldIgnoreTargets behavior', () => {
@@ -231,9 +242,9 @@ describe('ArrowShapeOptions', () => {
231
242
  class CustomArrowShapeUtil extends ArrowShapeUtil {
232
243
  override options = {
233
244
  ...baseUtil.options,
234
- shouldBeExact: (editor: any) => {
235
- // Custom logic: exact when both alt and shift are pressed
236
- return editor.inputs.altKey && editor.inputs.shiftKey
245
+ shouldBeExact: (editor: any, isPrecise: boolean) => {
246
+ // Custom logic: exact when both alt and shift are pressed, and only if precise
247
+ return editor.inputs.altKey && editor.inputs.shiftKey && isPrecise
237
248
  },
238
249
  shouldIgnoreTargets: (editor: any) => {
239
250
  // Custom logic: ignore targets when any modifier key is pressed
@@ -244,15 +255,20 @@ describe('ArrowShapeOptions', () => {
244
255
 
245
256
  const customUtil = new CustomArrowShapeUtil(editor)
246
257
 
247
- // Test shouldBeExact with both keys
258
+ // Test shouldBeExact with both keys and precise
248
259
  editor.inputs.altKey = true
249
260
  editor.inputs.shiftKey = true
250
- expect(customUtil.options.shouldBeExact(editor)).toBe(true)
261
+ expect(customUtil.options.shouldBeExact(editor, true)).toBe(true)
262
+
263
+ // Test shouldBeExact with both keys but not precise
264
+ editor.inputs.altKey = true
265
+ editor.inputs.shiftKey = true
266
+ expect(customUtil.options.shouldBeExact(editor, false)).toBe(false)
251
267
 
252
268
  // Test shouldBeExact with only one key
253
269
  editor.inputs.altKey = true
254
270
  editor.inputs.shiftKey = false
255
- expect(customUtil.options.shouldBeExact(editor)).toBe(false)
271
+ expect(customUtil.options.shouldBeExact(editor, true)).toBe(false)
256
272
 
257
273
  // Test shouldIgnoreTargets with any key
258
274
  editor.inputs.altKey = false
@@ -282,6 +298,61 @@ describe('ArrowShapeOptions', () => {
282
298
  expect(editor.getCurrentToolId()).toBe('arrow')
283
299
  })
284
300
 
301
+ it('should allow custom shouldBeExact logic based on isPrecise - example from arrow precise-exact', () => {
302
+ // This replicates the logic from the arrows-precise-exact example
303
+ const baseUtil = editor.getShapeUtil<ArrowShapeUtil>('arrow')
304
+ class ExampleArrowShapeUtil extends ArrowShapeUtil {
305
+ override options = {
306
+ ...baseUtil.options,
307
+ shouldBeExact: (_editor: any, isPrecise: boolean) => isPrecise,
308
+ }
309
+ }
310
+
311
+ // Replace the util temporarily for testing
312
+ const customUtil = new ExampleArrowShapeUtil(editor)
313
+ const originalShouldBeExact = baseUtil.options.shouldBeExact
314
+ baseUtil.options.shouldBeExact = customUtil.options.shouldBeExact
315
+
316
+ try {
317
+ editor.setCurrentTool('arrow')
318
+ editor.inputs.ctrlKey = false // Allow binding
319
+
320
+ // Set up fast pointer velocity to ensure precise remains false
321
+ editor.inputs.pointerVelocity = { x: 2, y: 2, len: () => 2.8 } as any
322
+
323
+ const targetState = updateArrowTargetState({
324
+ editor,
325
+ pointInPageSpace: { x: 150, y: 150 },
326
+ arrow: undefined,
327
+ isPrecise: true, // Input precise
328
+ currentBinding: undefined,
329
+ oppositeBinding: undefined,
330
+ })
331
+
332
+ // With the custom logic, precise arrows should be exact
333
+ expect(targetState?.isExact).toBe(true)
334
+ expect(targetState?.isPrecise).toBe(true)
335
+
336
+ // Test with non-precise movement (and fast velocity to avoid auto-precise)
337
+ const nonPreciseTargetState = updateArrowTargetState({
338
+ editor,
339
+ pointInPageSpace: { x: 150, y: 150 },
340
+ arrow: undefined,
341
+ isPrecise: false, // Not precise
342
+ currentBinding: undefined,
343
+ oppositeBinding: undefined,
344
+ })
345
+
346
+ // Non-precise arrows should not be exact with this custom logic,
347
+ // but they might still become precise due to internal logic
348
+ // The key test is that shouldBeExact gets the final computed precise value
349
+ expect(nonPreciseTargetState).toBeDefined()
350
+ } finally {
351
+ // Restore original function
352
+ baseUtil.options.shouldBeExact = originalShouldBeExact
353
+ }
354
+ })
355
+
285
356
  it('should respect shouldIgnoreTargets when starting arrow creation', () => {
286
357
  editor.setCurrentTool('arrow')
287
358
 
@@ -1,5 +1,8 @@
1
1
  import { IndexKey, TLArrowShape, TLShapeId, Vec, createShapeId } from '@tldraw/editor'
2
+ import { vi } from 'vitest'
2
3
  import { TestEditor } from '../../../test/TestEditor'
4
+ import { defaultShapeUtils } from '../../defaultShapeUtils'
5
+ import { ArrowShapeUtil } from './ArrowShapeUtil'
3
6
  import { getArrowTargetState } from './arrowTargetState'
4
7
  import { getArrowBindings } from './shared'
5
8
 
@@ -13,7 +16,7 @@ global.cancelAnimationFrame = function cancelAnimationFrame(id) {
13
16
  clearTimeout(id)
14
17
  }
15
18
 
16
- jest.useFakeTimers()
19
+ vi.useFakeTimers()
17
20
 
18
21
  const ids = {
19
22
  box1: createShapeId('box1'),
@@ -25,8 +28,8 @@ function bindings(id: TLShapeId) {
25
28
  return getArrowBindings(editor, editor.getShape(id) as TLArrowShape)
26
29
  }
27
30
 
28
- beforeEach(() => {
29
- editor = new TestEditor()
31
+ function init(opts?: ConstructorParameters<typeof TestEditor>[0]) {
32
+ editor = new TestEditor(opts)
30
33
  editor
31
34
  .selectAll()
32
35
  .deleteShapes(editor.getSelectedShapeIds())
@@ -35,7 +38,9 @@ beforeEach(() => {
35
38
  { id: ids.box2, type: 'geo', x: 300, y: 300, props: { w: 100, h: 100 } },
36
39
  { id: ids.box3, type: 'geo', x: 350, y: 350, props: { w: 50, h: 50 } }, // overlapping box2, but smaller!
37
40
  ])
38
- })
41
+ }
42
+
43
+ beforeEach(init)
39
44
 
40
45
  it('enters the arrow state', () => {
41
46
  editor.setCurrentTool('arrow')
@@ -242,7 +247,7 @@ describe('When pointing an end shape', () => {
242
247
  },
243
248
  })
244
249
 
245
- jest.advanceTimersByTime(1000)
250
+ vi.advanceTimersByTime(1000)
246
251
 
247
252
  arrow = editor.getCurrentPageShapes()[editor.getCurrentPageShapes().length - 1]
248
253
 
@@ -306,7 +311,7 @@ describe('When pointing an end shape', () => {
306
311
  })
307
312
 
308
313
  // Give time for the velocity to die down
309
- jest.advanceTimersByTime(1000)
314
+ vi.advanceTimersByTime(1000)
310
315
 
311
316
  arrow = editor.getCurrentPageShapes()[editor.getCurrentPageShapes().length - 1]
312
317
 
@@ -568,12 +573,102 @@ describe('reparenting issue', () => {
568
573
  const arrow1BoundIndex = editor.getShape(arrow1Id)!.index
569
574
  const arrow2BoundIndex = editor.getShape(arrow2Id)!.index
570
575
  expect(arrow1BoundIndex).toBe('a1V')
571
- expect(arrow2BoundIndex).toBe('a1F')
576
+ expect(arrow2BoundIndex).toBe('a1G')
572
577
 
573
578
  // nudge everything around and make sure we all stay in the right order
574
579
  editor.selectAll().nudgeShapes(editor.getSelectedShapeIds(), { x: -1, y: 0 })
575
580
  expect(editor.getShape(arrow1Id)!.index).toBe('a1V')
576
- expect(editor.getShape(arrow2Id)!.index).toBe('a1F')
581
+ expect(editor.getShape(arrow2Id)!.index).toBe('a1G')
582
+ })
583
+ })
584
+
585
+ describe('precision timeout configuration', () => {
586
+ it('uses a timeout when dragging arrow handles', () => {
587
+ // Create an arrow first
588
+
589
+ editor.setCurrentTool('arrow').pointerDown(0, 0)
590
+ // Use high velocity to avoid precise mode immediately
591
+ editor.inputs.pointerVelocity = new Vec(1, 1)
592
+ editor.pointerMove(100, 100)
593
+
594
+ const arrow = editor.getCurrentPageShapes()[
595
+ editor.getCurrentPageShapes().length - 1
596
+ ] as TLArrowShape
597
+
598
+ editor.expectToBeIn('select.dragging_handle')
599
+
600
+ expect(bindings(arrow.id)).toMatchObject({
601
+ end: {
602
+ toId: ids.box1,
603
+ props: {
604
+ isPrecise: false,
605
+ },
606
+ },
607
+ })
608
+
609
+ vi.advanceTimersByTime(1000)
610
+
611
+ expect(bindings(arrow.id)).toMatchObject({
612
+ end: {
613
+ toId: ids.box1,
614
+ props: {
615
+ isPrecise: true,
616
+ },
617
+ },
618
+ })
619
+ })
620
+
621
+ it('allows configuring the pointingPreciseTimeout', () => {
622
+ init({
623
+ shapeUtils: [
624
+ ...defaultShapeUtils.map((s) =>
625
+ s.type === 'arrow' ? ArrowShapeUtil.configure({ pointingPreciseTimeout: 2000 }) : s
626
+ ),
627
+ ],
628
+ })
629
+ // Create an arrow first
630
+
631
+ editor.setCurrentTool('arrow').pointerDown(0, 0)
632
+ // Use high velocity to avoid precise mode immediately
633
+ editor.inputs.pointerVelocity = new Vec(1, 1)
634
+ editor.pointerMove(100, 100)
635
+
636
+ const arrow = editor.getCurrentPageShapes()[
637
+ editor.getCurrentPageShapes().length - 1
638
+ ] as TLArrowShape
639
+
640
+ editor.expectToBeIn('select.dragging_handle')
641
+
642
+ expect(bindings(arrow.id)).toMatchObject({
643
+ end: {
644
+ toId: ids.box1,
645
+ props: {
646
+ isPrecise: false,
647
+ },
648
+ },
649
+ })
650
+
651
+ vi.advanceTimersByTime(1000)
652
+
653
+ expect(bindings(arrow.id)).toMatchObject({
654
+ end: {
655
+ toId: ids.box1,
656
+ props: {
657
+ isPrecise: false,
658
+ },
659
+ },
660
+ })
661
+
662
+ vi.advanceTimersByTime(1000)
663
+
664
+ expect(bindings(arrow.id)).toMatchObject({
665
+ end: {
666
+ toId: ids.box1,
667
+ props: {
668
+ isPrecise: true,
669
+ },
670
+ },
671
+ })
577
672
  })
578
673
  })
579
674