tldraw 3.16.0-canary.ed8bd30c0f28 → 3.16.0-canary.f20b7a478e22

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 (525) hide show
  1. package/dist-cjs/index.d.ts +359 -109
  2. package/dist-cjs/index.js +46 -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/arrowLabel.js +6 -0
  13. package/dist-cjs/lib/shapes/arrow/arrowLabel.js.map +3 -3
  14. package/dist-cjs/lib/shapes/arrow/arrowTargetState.js +1 -1
  15. package/dist-cjs/lib/shapes/arrow/arrowTargetState.js.map +2 -2
  16. package/dist-cjs/lib/shapes/arrow/elbow/ElbowArrowDebug.js +3 -3
  17. package/dist-cjs/lib/shapes/arrow/elbow/ElbowArrowDebug.js.map +1 -1
  18. package/dist-cjs/lib/shapes/bookmark/BookmarkShapeUtil.js +4 -4
  19. package/dist-cjs/lib/shapes/bookmark/BookmarkShapeUtil.js.map +2 -2
  20. package/dist-cjs/lib/shapes/draw/DrawShapeUtil.js +3 -3
  21. package/dist-cjs/lib/shapes/draw/DrawShapeUtil.js.map +2 -2
  22. package/dist-cjs/lib/shapes/embed/EmbedShapeUtil.js +1 -1
  23. package/dist-cjs/lib/shapes/embed/EmbedShapeUtil.js.map +1 -1
  24. package/dist-cjs/lib/shapes/frame/FrameShapeUtil.js +20 -13
  25. package/dist-cjs/lib/shapes/frame/FrameShapeUtil.js.map +2 -2
  26. package/dist-cjs/lib/shapes/frame/components/FrameHeading.js +1 -1
  27. package/dist-cjs/lib/shapes/frame/components/FrameHeading.js.map +2 -2
  28. package/dist-cjs/lib/shapes/frame/components/FrameLabelInput.js +2 -2
  29. package/dist-cjs/lib/shapes/frame/components/FrameLabelInput.js.map +2 -2
  30. package/dist-cjs/lib/shapes/geo/GeoShapeUtil.js +3 -2
  31. package/dist-cjs/lib/shapes/geo/GeoShapeUtil.js.map +2 -2
  32. package/dist-cjs/lib/shapes/geo/components/GeoShapeBody.js +2 -1
  33. package/dist-cjs/lib/shapes/geo/components/GeoShapeBody.js.map +2 -2
  34. package/dist-cjs/lib/shapes/highlight/HighlightShapeUtil.js +5 -1
  35. package/dist-cjs/lib/shapes/highlight/HighlightShapeUtil.js.map +2 -2
  36. package/dist-cjs/lib/shapes/image/ImageShapeUtil.js +6 -3
  37. package/dist-cjs/lib/shapes/image/ImageShapeUtil.js.map +2 -2
  38. package/dist-cjs/lib/shapes/line/LineShapeUtil.js +5 -1
  39. package/dist-cjs/lib/shapes/line/LineShapeUtil.js.map +2 -2
  40. package/dist-cjs/lib/shapes/note/NoteShapeUtil.js +6 -5
  41. package/dist-cjs/lib/shapes/note/NoteShapeUtil.js.map +2 -2
  42. package/dist-cjs/lib/shapes/shared/HyperlinkButton.js +4 -4
  43. package/dist-cjs/lib/shapes/shared/HyperlinkButton.js.map +2 -2
  44. package/dist-cjs/lib/shapes/shared/PlainTextLabel.js +1 -3
  45. package/dist-cjs/lib/shapes/shared/PlainTextLabel.js.map +2 -2
  46. package/dist-cjs/lib/shapes/shared/ShapeFill.js +4 -4
  47. package/dist-cjs/lib/shapes/shared/ShapeFill.js.map +2 -2
  48. package/dist-cjs/lib/shapes/shared/freehand/svg.js.map +2 -2
  49. package/dist-cjs/lib/shapes/shared/useEditablePlainText.js +3 -4
  50. package/dist-cjs/lib/shapes/shared/useEditablePlainText.js.map +2 -2
  51. package/dist-cjs/lib/shapes/shared/useImageOrVideoAsset.js +0 -2
  52. package/dist-cjs/lib/shapes/shared/useImageOrVideoAsset.js.map +2 -2
  53. package/dist-cjs/lib/shapes/shared/usePrefersReducedMotion.js +10 -1
  54. package/dist-cjs/lib/shapes/shared/usePrefersReducedMotion.js.map +2 -2
  55. package/dist-cjs/lib/shapes/text/PlainTextArea.js +2 -2
  56. package/dist-cjs/lib/shapes/text/PlainTextArea.js.map +2 -2
  57. package/dist-cjs/lib/shapes/text/RichTextArea.js +3 -3
  58. package/dist-cjs/lib/shapes/text/RichTextArea.js.map +2 -2
  59. package/dist-cjs/lib/shapes/text/TextShapeUtil.js +2 -2
  60. package/dist-cjs/lib/shapes/text/TextShapeUtil.js.map +2 -2
  61. package/dist-cjs/lib/shapes/video/VideoShapeUtil.js +3 -3
  62. package/dist-cjs/lib/shapes/video/VideoShapeUtil.js.map +1 -1
  63. package/dist-cjs/lib/tools/EraserTool/childStates/Erasing.js +25 -1
  64. package/dist-cjs/lib/tools/EraserTool/childStates/Erasing.js.map +2 -2
  65. package/dist-cjs/lib/tools/EraserTool/childStates/Pointing.js +12 -0
  66. package/dist-cjs/lib/tools/EraserTool/childStates/Pointing.js.map +2 -2
  67. package/dist-cjs/lib/tools/SelectTool/childStates/Translating.js.map +2 -2
  68. package/dist-cjs/lib/ui/TldrawUi.js +27 -12
  69. package/dist-cjs/lib/ui/TldrawUi.js.map +3 -3
  70. package/dist-cjs/lib/ui/assetUrls.js +13 -10
  71. package/dist-cjs/lib/ui/assetUrls.js.map +2 -2
  72. package/dist-cjs/lib/ui/components/A11y.js +1 -1
  73. package/dist-cjs/lib/ui/components/A11y.js.map +2 -2
  74. package/dist-cjs/lib/ui/components/AccessibilityMenu.js +35 -0
  75. package/dist-cjs/lib/ui/components/AccessibilityMenu.js.map +7 -0
  76. package/dist-cjs/lib/ui/components/ActionsMenu/DefaultActionsMenu.js +12 -3
  77. package/dist-cjs/lib/ui/components/ActionsMenu/DefaultActionsMenu.js.map +2 -2
  78. package/dist-cjs/lib/ui/components/{FollowingIndicator.js → DefaultFollowingIndicator.js} +6 -6
  79. package/dist-cjs/lib/ui/components/DefaultFollowingIndicator.js.map +7 -0
  80. package/dist-cjs/lib/ui/components/DefaultMenuPanel.js +3 -2
  81. package/dist-cjs/lib/ui/components/DefaultMenuPanel.js.map +2 -2
  82. package/dist-cjs/lib/ui/components/KeyboardShortcutsDialog/DefaultKeyboardShortcutsDialogContent.js +6 -6
  83. package/dist-cjs/lib/ui/components/KeyboardShortcutsDialog/DefaultKeyboardShortcutsDialogContent.js.map +1 -1
  84. package/dist-cjs/lib/ui/components/LanguageMenu.js +1 -0
  85. package/dist-cjs/lib/ui/components/LanguageMenu.js.map +2 -2
  86. package/dist-cjs/lib/ui/components/MainMenu/DefaultMainMenuContent.js +3 -3
  87. package/dist-cjs/lib/ui/components/MainMenu/DefaultMainMenuContent.js.map +2 -2
  88. package/dist-cjs/lib/ui/components/Minimap/DefaultMinimap.js +1 -0
  89. package/dist-cjs/lib/ui/components/Minimap/DefaultMinimap.js.map +2 -2
  90. package/dist-cjs/lib/ui/components/Minimap/MinimapManager.js +4 -4
  91. package/dist-cjs/lib/ui/components/Minimap/MinimapManager.js.map +2 -2
  92. package/dist-cjs/lib/ui/components/MobileStylePanel.js +5 -3
  93. package/dist-cjs/lib/ui/components/MobileStylePanel.js.map +2 -2
  94. package/dist-cjs/lib/ui/components/NavigationPanel/DefaultNavigationPanel.js +1 -1
  95. package/dist-cjs/lib/ui/components/NavigationPanel/DefaultNavigationPanel.js.map +2 -2
  96. package/dist-cjs/lib/ui/components/PageMenu/DefaultPageMenu.js +3 -2
  97. package/dist-cjs/lib/ui/components/PageMenu/DefaultPageMenu.js.map +2 -2
  98. package/dist-cjs/lib/ui/components/SharePanel/PeopleMenuItem.js +3 -2
  99. package/dist-cjs/lib/ui/components/SharePanel/PeopleMenuItem.js.map +2 -2
  100. package/dist-cjs/lib/ui/components/SharePanel/UserPresenceColorPicker.js +2 -2
  101. package/dist-cjs/lib/ui/components/SharePanel/UserPresenceColorPicker.js.map +2 -2
  102. package/dist-cjs/lib/ui/components/StylePanel/DefaultStylePanel.js +11 -4
  103. package/dist-cjs/lib/ui/components/StylePanel/DefaultStylePanel.js.map +2 -2
  104. package/dist-cjs/lib/ui/components/StylePanel/DefaultStylePanelContent.js +249 -279
  105. package/dist-cjs/lib/ui/components/StylePanel/DefaultStylePanelContent.js.map +2 -2
  106. package/dist-cjs/lib/ui/components/StylePanel/StylePanelButtonPicker.js +147 -0
  107. package/dist-cjs/lib/ui/components/StylePanel/StylePanelButtonPicker.js.map +7 -0
  108. package/dist-cjs/lib/ui/components/StylePanel/StylePanelContext.js +68 -0
  109. package/dist-cjs/lib/ui/components/StylePanel/StylePanelContext.js.map +7 -0
  110. package/dist-cjs/lib/ui/components/StylePanel/{DoubleDropdownPicker.js → StylePanelDoubleDropdownPicker.js} +26 -25
  111. package/dist-cjs/lib/ui/components/StylePanel/StylePanelDoubleDropdownPicker.js.map +7 -0
  112. package/dist-cjs/lib/ui/components/StylePanel/{DropdownPicker.js → StylePanelDropdownPicker.js} +47 -43
  113. package/dist-cjs/lib/ui/components/StylePanel/StylePanelDropdownPicker.js.map +7 -0
  114. package/dist-cjs/lib/ui/components/StylePanel/StylePanelSubheading.js +28 -0
  115. package/dist-cjs/lib/ui/components/StylePanel/StylePanelSubheading.js.map +7 -0
  116. package/dist-cjs/lib/ui/components/Toolbar/AltTextEditor.js +2 -0
  117. package/dist-cjs/lib/ui/components/Toolbar/AltTextEditor.js.map +2 -2
  118. package/dist-cjs/lib/ui/components/Toolbar/DefaultImageToolbarContent.js +39 -10
  119. package/dist-cjs/lib/ui/components/Toolbar/DefaultImageToolbarContent.js.map +2 -2
  120. package/dist-cjs/lib/ui/components/Toolbar/DefaultToolbar.js +66 -21
  121. package/dist-cjs/lib/ui/components/Toolbar/DefaultToolbar.js.map +3 -3
  122. package/dist-cjs/lib/ui/components/Toolbar/DefaultVideoToolbarContent.js +15 -3
  123. package/dist-cjs/lib/ui/components/Toolbar/DefaultVideoToolbarContent.js.map +2 -2
  124. package/dist-cjs/lib/ui/components/Toolbar/LinkEditor.js +2 -1
  125. package/dist-cjs/lib/ui/components/Toolbar/LinkEditor.js.map +2 -2
  126. package/dist-cjs/lib/ui/components/Toolbar/OverflowingToolbar.js +189 -80
  127. package/dist-cjs/lib/ui/components/Toolbar/OverflowingToolbar.js.map +3 -3
  128. package/dist-cjs/lib/ui/components/Toolbar/ToggleToolLockedButton.js +10 -5
  129. package/dist-cjs/lib/ui/components/Toolbar/ToggleToolLockedButton.js.map +2 -2
  130. package/dist-cjs/lib/ui/components/menu-items.js +6 -0
  131. package/dist-cjs/lib/ui/components/menu-items.js.map +2 -2
  132. package/dist-cjs/lib/ui/components/primitives/TldrawUiContextualToolbar.js +11 -2
  133. package/dist-cjs/lib/ui/components/primitives/TldrawUiContextualToolbar.js.map +2 -2
  134. package/dist-cjs/lib/ui/components/primitives/TldrawUiInput.js +5 -3
  135. package/dist-cjs/lib/ui/components/primitives/TldrawUiInput.js.map +2 -2
  136. package/dist-cjs/lib/ui/components/primitives/TldrawUiPopover.js +3 -2
  137. package/dist-cjs/lib/ui/components/primitives/TldrawUiPopover.js.map +3 -3
  138. package/dist-cjs/lib/ui/components/primitives/TldrawUiSlider.js +18 -5
  139. package/dist-cjs/lib/ui/components/primitives/TldrawUiSlider.js.map +2 -2
  140. package/dist-cjs/lib/ui/components/primitives/TldrawUiToolbar.js +33 -7
  141. package/dist-cjs/lib/ui/components/primitives/TldrawUiToolbar.js.map +2 -2
  142. package/dist-cjs/lib/ui/components/primitives/TldrawUiTooltip.js +306 -0
  143. package/dist-cjs/lib/ui/components/primitives/TldrawUiTooltip.js.map +7 -0
  144. package/dist-cjs/lib/ui/components/primitives/layout.js +76 -0
  145. package/dist-cjs/lib/ui/components/primitives/layout.js.map +7 -0
  146. package/dist-cjs/lib/ui/components/primitives/menus/TldrawUiMenuCheckboxItem.js +3 -0
  147. package/dist-cjs/lib/ui/components/primitives/menus/TldrawUiMenuCheckboxItem.js.map +2 -2
  148. package/dist-cjs/lib/ui/components/primitives/menus/TldrawUiMenuContext.js.map +2 -2
  149. package/dist-cjs/lib/ui/components/primitives/menus/TldrawUiMenuGroup.js +25 -12
  150. package/dist-cjs/lib/ui/components/primitives/menus/TldrawUiMenuGroup.js.map +2 -2
  151. package/dist-cjs/lib/ui/components/primitives/menus/TldrawUiMenuItem.js +154 -20
  152. package/dist-cjs/lib/ui/components/primitives/menus/TldrawUiMenuItem.js.map +2 -2
  153. package/dist-cjs/lib/ui/context/TldrawUiContextProvider.js +3 -2
  154. package/dist-cjs/lib/ui/context/TldrawUiContextProvider.js.map +2 -2
  155. package/dist-cjs/lib/ui/context/actions.js +44 -10
  156. package/dist-cjs/lib/ui/context/actions.js.map +2 -2
  157. package/dist-cjs/lib/ui/context/components.js +2 -0
  158. package/dist-cjs/lib/ui/context/components.js.map +2 -2
  159. package/dist-cjs/lib/ui/context/events.js.map +2 -2
  160. package/dist-cjs/lib/ui/hooks/useClipboardEvents.js +1 -1
  161. package/dist-cjs/lib/ui/hooks/useClipboardEvents.js.map +2 -2
  162. package/dist-cjs/lib/ui/hooks/useExportAs.js +3 -2
  163. package/dist-cjs/lib/ui/hooks/useExportAs.js.map +2 -2
  164. package/dist-cjs/lib/ui/hooks/useTools.js +94 -9
  165. package/dist-cjs/lib/ui/hooks/useTools.js.map +2 -2
  166. package/dist-cjs/lib/ui/hooks/useTranslation/TLUiTranslationKey.js.map +1 -1
  167. package/dist-cjs/lib/ui/hooks/useTranslation/defaultTranslation.js +8 -1
  168. package/dist-cjs/lib/ui/hooks/useTranslation/defaultTranslation.js.map +2 -2
  169. package/dist-cjs/lib/ui/kbd-utils.js +9 -3
  170. package/dist-cjs/lib/ui/kbd-utils.js.map +2 -2
  171. package/dist-cjs/lib/ui/version.js +3 -3
  172. package/dist-cjs/lib/ui/version.js.map +1 -1
  173. package/dist-cjs/lib/utils/export/copyAs.js +1 -2
  174. package/dist-cjs/lib/utils/export/copyAs.js.map +2 -2
  175. package/dist-cjs/lib/utils/export/export.js +0 -20
  176. package/dist-cjs/lib/utils/export/export.js.map +2 -2
  177. package/dist-cjs/lib/utils/export/exportAs.js +1 -2
  178. package/dist-cjs/lib/utils/export/exportAs.js.map +2 -2
  179. package/dist-esm/index.d.mts +359 -109
  180. package/dist-esm/index.mjs +85 -29
  181. package/dist-esm/index.mjs.map +2 -2
  182. package/dist-esm/lib/Tldraw.mjs +14 -4
  183. package/dist-esm/lib/Tldraw.mjs.map +2 -2
  184. package/dist-esm/lib/canvas/TldrawScribble.mjs +1 -1
  185. package/dist-esm/lib/canvas/TldrawScribble.mjs.map +2 -2
  186. package/dist-esm/lib/defaultExternalContentHandlers.mjs +15 -4
  187. package/dist-esm/lib/defaultExternalContentHandlers.mjs.map +2 -2
  188. package/dist-esm/lib/shapes/arrow/ArrowShapeUtil.mjs +4 -3
  189. package/dist-esm/lib/shapes/arrow/ArrowShapeUtil.mjs.map +2 -2
  190. package/dist-esm/lib/shapes/arrow/arrowLabel.mjs +6 -0
  191. package/dist-esm/lib/shapes/arrow/arrowLabel.mjs.map +3 -3
  192. package/dist-esm/lib/shapes/arrow/arrowTargetState.mjs +1 -1
  193. package/dist-esm/lib/shapes/arrow/arrowTargetState.mjs.map +2 -2
  194. package/dist-esm/lib/shapes/arrow/elbow/ElbowArrowDebug.mjs +3 -3
  195. package/dist-esm/lib/shapes/arrow/elbow/ElbowArrowDebug.mjs.map +1 -1
  196. package/dist-esm/lib/shapes/bookmark/BookmarkShapeUtil.mjs +5 -5
  197. package/dist-esm/lib/shapes/bookmark/BookmarkShapeUtil.mjs.map +2 -2
  198. package/dist-esm/lib/shapes/draw/DrawShapeUtil.mjs +4 -3
  199. package/dist-esm/lib/shapes/draw/DrawShapeUtil.mjs.map +2 -2
  200. package/dist-esm/lib/shapes/embed/EmbedShapeUtil.mjs +1 -1
  201. package/dist-esm/lib/shapes/embed/EmbedShapeUtil.mjs.map +1 -1
  202. package/dist-esm/lib/shapes/frame/FrameShapeUtil.mjs +21 -13
  203. package/dist-esm/lib/shapes/frame/FrameShapeUtil.mjs.map +2 -2
  204. package/dist-esm/lib/shapes/frame/components/FrameHeading.mjs +1 -1
  205. package/dist-esm/lib/shapes/frame/components/FrameHeading.mjs.map +2 -2
  206. package/dist-esm/lib/shapes/frame/components/FrameLabelInput.mjs +3 -3
  207. package/dist-esm/lib/shapes/frame/components/FrameLabelInput.mjs.map +2 -2
  208. package/dist-esm/lib/shapes/geo/GeoShapeUtil.mjs +4 -2
  209. package/dist-esm/lib/shapes/geo/GeoShapeUtil.mjs.map +2 -2
  210. package/dist-esm/lib/shapes/geo/components/GeoShapeBody.mjs +2 -1
  211. package/dist-esm/lib/shapes/geo/components/GeoShapeBody.mjs.map +2 -2
  212. package/dist-esm/lib/shapes/highlight/HighlightShapeUtil.mjs +6 -1
  213. package/dist-esm/lib/shapes/highlight/HighlightShapeUtil.mjs.map +2 -2
  214. package/dist-esm/lib/shapes/image/ImageShapeUtil.mjs +6 -3
  215. package/dist-esm/lib/shapes/image/ImageShapeUtil.mjs.map +2 -2
  216. package/dist-esm/lib/shapes/line/LineShapeUtil.mjs +6 -1
  217. package/dist-esm/lib/shapes/line/LineShapeUtil.mjs.map +2 -2
  218. package/dist-esm/lib/shapes/note/NoteShapeUtil.mjs +7 -5
  219. package/dist-esm/lib/shapes/note/NoteShapeUtil.mjs.map +2 -2
  220. package/dist-esm/lib/shapes/shared/HyperlinkButton.mjs +5 -5
  221. package/dist-esm/lib/shapes/shared/HyperlinkButton.mjs.map +2 -2
  222. package/dist-esm/lib/shapes/shared/PlainTextLabel.mjs +1 -3
  223. package/dist-esm/lib/shapes/shared/PlainTextLabel.mjs.map +2 -2
  224. package/dist-esm/lib/shapes/shared/ShapeFill.mjs +5 -4
  225. package/dist-esm/lib/shapes/shared/ShapeFill.mjs.map +2 -2
  226. package/dist-esm/lib/shapes/shared/freehand/svg.mjs.map +2 -2
  227. package/dist-esm/lib/shapes/shared/useEditablePlainText.mjs +4 -5
  228. package/dist-esm/lib/shapes/shared/useEditablePlainText.mjs.map +2 -2
  229. package/dist-esm/lib/shapes/shared/useImageOrVideoAsset.mjs +0 -2
  230. package/dist-esm/lib/shapes/shared/useImageOrVideoAsset.mjs.map +2 -2
  231. package/dist-esm/lib/shapes/shared/usePrefersReducedMotion.mjs +10 -1
  232. package/dist-esm/lib/shapes/shared/usePrefersReducedMotion.mjs.map +2 -2
  233. package/dist-esm/lib/shapes/text/PlainTextArea.mjs +3 -3
  234. package/dist-esm/lib/shapes/text/PlainTextArea.mjs.map +2 -2
  235. package/dist-esm/lib/shapes/text/RichTextArea.mjs +3 -4
  236. package/dist-esm/lib/shapes/text/RichTextArea.mjs.map +2 -2
  237. package/dist-esm/lib/shapes/text/TextShapeUtil.mjs +3 -2
  238. package/dist-esm/lib/shapes/text/TextShapeUtil.mjs.map +2 -2
  239. package/dist-esm/lib/shapes/video/VideoShapeUtil.mjs +3 -3
  240. package/dist-esm/lib/shapes/video/VideoShapeUtil.mjs.map +1 -1
  241. package/dist-esm/lib/tools/EraserTool/childStates/Erasing.mjs +26 -1
  242. package/dist-esm/lib/tools/EraserTool/childStates/Erasing.mjs.map +2 -2
  243. package/dist-esm/lib/tools/EraserTool/childStates/Pointing.mjs +13 -0
  244. package/dist-esm/lib/tools/EraserTool/childStates/Pointing.mjs.map +2 -2
  245. package/dist-esm/lib/tools/SelectTool/childStates/Translating.mjs.map +2 -2
  246. package/dist-esm/lib/ui/TldrawUi.mjs +29 -14
  247. package/dist-esm/lib/ui/TldrawUi.mjs.map +3 -3
  248. package/dist-esm/lib/ui/assetUrls.mjs +13 -10
  249. package/dist-esm/lib/ui/assetUrls.mjs.map +2 -2
  250. package/dist-esm/lib/ui/components/A11y.mjs +2 -2
  251. package/dist-esm/lib/ui/components/A11y.mjs.map +2 -2
  252. package/dist-esm/lib/ui/components/AccessibilityMenu.mjs +19 -0
  253. package/dist-esm/lib/ui/components/AccessibilityMenu.mjs.map +7 -0
  254. package/dist-esm/lib/ui/components/ActionsMenu/DefaultActionsMenu.mjs +12 -3
  255. package/dist-esm/lib/ui/components/ActionsMenu/DefaultActionsMenu.mjs.map +2 -2
  256. package/dist-esm/lib/ui/components/{FollowingIndicator.mjs → DefaultFollowingIndicator.mjs} +3 -3
  257. package/dist-esm/lib/ui/components/DefaultFollowingIndicator.mjs.map +7 -0
  258. package/dist-esm/lib/ui/components/DefaultMenuPanel.mjs +3 -2
  259. package/dist-esm/lib/ui/components/DefaultMenuPanel.mjs.map +2 -2
  260. package/dist-esm/lib/ui/components/KeyboardShortcutsDialog/DefaultKeyboardShortcutsDialogContent.mjs +6 -6
  261. package/dist-esm/lib/ui/components/KeyboardShortcutsDialog/DefaultKeyboardShortcutsDialogContent.mjs.map +1 -1
  262. package/dist-esm/lib/ui/components/LanguageMenu.mjs +1 -0
  263. package/dist-esm/lib/ui/components/LanguageMenu.mjs.map +2 -2
  264. package/dist-esm/lib/ui/components/MainMenu/DefaultMainMenuContent.mjs +3 -5
  265. package/dist-esm/lib/ui/components/MainMenu/DefaultMainMenuContent.mjs.map +2 -2
  266. package/dist-esm/lib/ui/components/Minimap/DefaultMinimap.mjs +1 -0
  267. package/dist-esm/lib/ui/components/Minimap/DefaultMinimap.mjs.map +2 -2
  268. package/dist-esm/lib/ui/components/Minimap/MinimapManager.mjs +4 -4
  269. package/dist-esm/lib/ui/components/Minimap/MinimapManager.mjs.map +2 -2
  270. package/dist-esm/lib/ui/components/MobileStylePanel.mjs +6 -3
  271. package/dist-esm/lib/ui/components/MobileStylePanel.mjs.map +2 -2
  272. package/dist-esm/lib/ui/components/NavigationPanel/DefaultNavigationPanel.mjs +1 -1
  273. package/dist-esm/lib/ui/components/NavigationPanel/DefaultNavigationPanel.mjs.map +2 -2
  274. package/dist-esm/lib/ui/components/PageMenu/DefaultPageMenu.mjs +4 -3
  275. package/dist-esm/lib/ui/components/PageMenu/DefaultPageMenu.mjs.map +2 -2
  276. package/dist-esm/lib/ui/components/SharePanel/PeopleMenuItem.mjs +3 -2
  277. package/dist-esm/lib/ui/components/SharePanel/PeopleMenuItem.mjs.map +2 -2
  278. package/dist-esm/lib/ui/components/SharePanel/UserPresenceColorPicker.mjs +2 -2
  279. package/dist-esm/lib/ui/components/SharePanel/UserPresenceColorPicker.mjs.map +2 -2
  280. package/dist-esm/lib/ui/components/StylePanel/DefaultStylePanel.mjs +16 -5
  281. package/dist-esm/lib/ui/components/StylePanel/DefaultStylePanel.mjs.map +2 -2
  282. package/dist-esm/lib/ui/components/StylePanel/DefaultStylePanelContent.mjs +251 -283
  283. package/dist-esm/lib/ui/components/StylePanel/DefaultStylePanelContent.mjs.map +2 -2
  284. package/dist-esm/lib/ui/components/StylePanel/StylePanelButtonPicker.mjs +135 -0
  285. package/dist-esm/lib/ui/components/StylePanel/StylePanelButtonPicker.mjs.map +7 -0
  286. package/dist-esm/lib/ui/components/StylePanel/StylePanelContext.mjs +48 -0
  287. package/dist-esm/lib/ui/components/StylePanel/StylePanelContext.mjs.map +7 -0
  288. package/dist-esm/lib/ui/components/StylePanel/{DoubleDropdownPicker.mjs → StylePanelDoubleDropdownPicker.mjs} +23 -22
  289. package/dist-esm/lib/ui/components/StylePanel/StylePanelDoubleDropdownPicker.mjs.map +7 -0
  290. package/dist-esm/lib/ui/components/StylePanel/{DropdownPicker.mjs → StylePanelDropdownPicker.mjs} +44 -40
  291. package/dist-esm/lib/ui/components/StylePanel/StylePanelDropdownPicker.mjs.map +7 -0
  292. package/dist-esm/lib/ui/components/StylePanel/StylePanelSubheading.mjs +8 -0
  293. package/dist-esm/lib/ui/components/StylePanel/StylePanelSubheading.mjs.map +7 -0
  294. package/dist-esm/lib/ui/components/Toolbar/AltTextEditor.mjs +2 -0
  295. package/dist-esm/lib/ui/components/Toolbar/AltTextEditor.mjs.map +2 -2
  296. package/dist-esm/lib/ui/components/Toolbar/DefaultImageToolbarContent.mjs +39 -10
  297. package/dist-esm/lib/ui/components/Toolbar/DefaultImageToolbarContent.mjs.map +2 -2
  298. package/dist-esm/lib/ui/components/Toolbar/DefaultToolbar.mjs +56 -21
  299. package/dist-esm/lib/ui/components/Toolbar/DefaultToolbar.mjs.map +2 -2
  300. package/dist-esm/lib/ui/components/Toolbar/DefaultVideoToolbarContent.mjs +15 -3
  301. package/dist-esm/lib/ui/components/Toolbar/DefaultVideoToolbarContent.mjs.map +2 -2
  302. package/dist-esm/lib/ui/components/Toolbar/LinkEditor.mjs +2 -1
  303. package/dist-esm/lib/ui/components/Toolbar/LinkEditor.mjs.map +2 -2
  304. package/dist-esm/lib/ui/components/Toolbar/OverflowingToolbar.mjs +192 -81
  305. package/dist-esm/lib/ui/components/Toolbar/OverflowingToolbar.mjs.map +3 -3
  306. package/dist-esm/lib/ui/components/Toolbar/ToggleToolLockedButton.mjs +10 -5
  307. package/dist-esm/lib/ui/components/Toolbar/ToggleToolLockedButton.mjs.map +2 -2
  308. package/dist-esm/lib/ui/components/menu-items.mjs +6 -0
  309. package/dist-esm/lib/ui/components/menu-items.mjs.map +2 -2
  310. package/dist-esm/lib/ui/components/primitives/TldrawUiContextualToolbar.mjs +12 -3
  311. package/dist-esm/lib/ui/components/primitives/TldrawUiContextualToolbar.mjs.map +2 -2
  312. package/dist-esm/lib/ui/components/primitives/TldrawUiInput.mjs +6 -4
  313. package/dist-esm/lib/ui/components/primitives/TldrawUiInput.mjs.map +2 -2
  314. package/dist-esm/lib/ui/components/primitives/TldrawUiPopover.mjs +3 -2
  315. package/dist-esm/lib/ui/components/primitives/TldrawUiPopover.mjs.map +2 -2
  316. package/dist-esm/lib/ui/components/primitives/TldrawUiSlider.mjs +18 -5
  317. package/dist-esm/lib/ui/components/primitives/TldrawUiSlider.mjs.map +2 -2
  318. package/dist-esm/lib/ui/components/primitives/TldrawUiToolbar.mjs +33 -7
  319. package/dist-esm/lib/ui/components/primitives/TldrawUiToolbar.mjs.map +2 -2
  320. package/dist-esm/lib/ui/components/primitives/TldrawUiTooltip.mjs +284 -0
  321. package/dist-esm/lib/ui/components/primitives/TldrawUiTooltip.mjs.map +7 -0
  322. package/dist-esm/lib/ui/components/primitives/layout.mjs +46 -0
  323. package/dist-esm/lib/ui/components/primitives/layout.mjs.map +7 -0
  324. package/dist-esm/lib/ui/components/primitives/menus/TldrawUiMenuCheckboxItem.mjs +3 -0
  325. package/dist-esm/lib/ui/components/primitives/menus/TldrawUiMenuCheckboxItem.mjs.map +2 -2
  326. package/dist-esm/lib/ui/components/primitives/menus/TldrawUiMenuContext.mjs.map +2 -2
  327. package/dist-esm/lib/ui/components/primitives/menus/TldrawUiMenuGroup.mjs +25 -12
  328. package/dist-esm/lib/ui/components/primitives/menus/TldrawUiMenuGroup.mjs.map +2 -2
  329. package/dist-esm/lib/ui/components/primitives/menus/TldrawUiMenuItem.mjs +162 -22
  330. package/dist-esm/lib/ui/components/primitives/menus/TldrawUiMenuItem.mjs.map +2 -2
  331. package/dist-esm/lib/ui/context/TldrawUiContextProvider.mjs +3 -2
  332. package/dist-esm/lib/ui/context/TldrawUiContextProvider.mjs.map +2 -2
  333. package/dist-esm/lib/ui/context/actions.mjs +44 -10
  334. package/dist-esm/lib/ui/context/actions.mjs.map +2 -2
  335. package/dist-esm/lib/ui/context/components.mjs +2 -0
  336. package/dist-esm/lib/ui/context/components.mjs.map +2 -2
  337. package/dist-esm/lib/ui/context/events.mjs.map +2 -2
  338. package/dist-esm/lib/ui/hooks/useClipboardEvents.mjs +2 -2
  339. package/dist-esm/lib/ui/hooks/useClipboardEvents.mjs.map +2 -2
  340. package/dist-esm/lib/ui/hooks/useExportAs.mjs +3 -2
  341. package/dist-esm/lib/ui/hooks/useExportAs.mjs.map +2 -2
  342. package/dist-esm/lib/ui/hooks/useTools.mjs +102 -10
  343. package/dist-esm/lib/ui/hooks/useTools.mjs.map +2 -2
  344. package/dist-esm/lib/ui/hooks/useTranslation/defaultTranslation.mjs +8 -1
  345. package/dist-esm/lib/ui/hooks/useTranslation/defaultTranslation.mjs.map +2 -2
  346. package/dist-esm/lib/ui/kbd-utils.mjs +9 -3
  347. package/dist-esm/lib/ui/kbd-utils.mjs.map +2 -2
  348. package/dist-esm/lib/ui/version.mjs +3 -3
  349. package/dist-esm/lib/ui/version.mjs.map +1 -1
  350. package/dist-esm/lib/utils/export/copyAs.mjs +1 -2
  351. package/dist-esm/lib/utils/export/copyAs.mjs.map +2 -2
  352. package/dist-esm/lib/utils/export/export.mjs +0 -20
  353. package/dist-esm/lib/utils/export/export.mjs.map +2 -2
  354. package/dist-esm/lib/utils/export/exportAs.mjs +1 -2
  355. package/dist-esm/lib/utils/export/exportAs.mjs.map +2 -2
  356. package/package.json +11 -34
  357. package/src/index.ts +64 -22
  358. package/src/lib/Tldraw.tsx +15 -2
  359. package/src/lib/canvas/TldrawScribble.tsx +1 -1
  360. package/src/lib/defaultExternalContentHandlers.ts +26 -4
  361. package/src/lib/shapes/arrow/ArrowShapeOptions.test.ts +2 -1
  362. package/src/lib/shapes/arrow/ArrowShapeTool.test.ts +6 -5
  363. package/src/lib/shapes/arrow/ArrowShapeUtil.test.ts +48 -6
  364. package/src/lib/shapes/arrow/ArrowShapeUtil.tsx +4 -3
  365. package/src/lib/shapes/arrow/arrowLabel.ts +8 -0
  366. package/src/lib/shapes/arrow/arrowTargetState.ts +2 -1
  367. package/src/lib/shapes/arrow/elbow/ElbowArrowDebug.tsx +3 -3
  368. package/src/lib/shapes/bookmark/BookmarkShapeUtil.tsx +5 -5
  369. package/src/lib/shapes/draw/DrawShapeTool.test.ts +0 -5
  370. package/src/lib/shapes/draw/DrawShapeUtil.tsx +4 -3
  371. package/src/lib/shapes/embed/EmbedShapeUtil.tsx +1 -1
  372. package/src/lib/shapes/frame/FrameShapeUtil.tsx +30 -14
  373. package/src/lib/shapes/frame/components/FrameHeading.tsx +1 -1
  374. package/src/lib/shapes/frame/components/FrameLabelInput.tsx +3 -3
  375. package/src/lib/shapes/geo/GeoShapeUtil.tsx +4 -2
  376. package/src/lib/shapes/geo/components/GeoShapeBody.tsx +2 -2
  377. package/src/lib/shapes/highlight/HighlightShapeUtil.tsx +7 -1
  378. package/src/lib/shapes/image/ImageShapeUtil.tsx +6 -3
  379. package/src/lib/shapes/line/LineShapeUtil.test.tsx +4 -3
  380. package/src/lib/shapes/line/LineShapeUtil.tsx +6 -1
  381. package/src/lib/shapes/line/__snapshots__/LineShapeUtil.test.tsx.snap +2 -2
  382. package/src/lib/shapes/note/NoteShapeUtil.tsx +10 -4
  383. package/src/lib/shapes/shared/HyperlinkButton.tsx +5 -5
  384. package/src/lib/shapes/shared/PlainTextLabel.tsx +0 -6
  385. package/src/lib/shapes/shared/ShapeFill.tsx +5 -4
  386. package/src/lib/shapes/shared/freehand/svg.ts +2 -0
  387. package/src/lib/shapes/shared/useEditablePlainText.ts +5 -9
  388. package/src/lib/shapes/shared/useImageOrVideoAsset.ts +0 -7
  389. package/src/lib/shapes/shared/usePrefersReducedMotion.tsx +11 -1
  390. package/src/lib/shapes/text/PlainTextArea.tsx +3 -3
  391. package/src/lib/shapes/text/RichTextArea.tsx +3 -4
  392. package/src/lib/shapes/text/TextShapeTool.test.ts +6 -5
  393. package/src/lib/shapes/text/TextShapeUtil.tsx +3 -2
  394. package/src/lib/shapes/video/VideoShapeUtil.tsx +3 -3
  395. package/src/lib/tools/EraserTool/childStates/Erasing.ts +34 -1
  396. package/src/lib/tools/EraserTool/childStates/Pointing.ts +20 -0
  397. package/src/lib/tools/SelectTool/childStates/Translating.ts +0 -1
  398. package/src/lib/ui/TldrawUi.tsx +33 -12
  399. package/src/lib/ui/assetUrls.ts +13 -10
  400. package/src/lib/ui/components/A11y.tsx +2 -2
  401. package/src/lib/ui/components/AccessibilityMenu.tsx +20 -0
  402. package/src/lib/ui/components/ActionsMenu/DefaultActionsMenu.tsx +15 -3
  403. package/src/lib/ui/components/{FollowingIndicator.tsx → DefaultFollowingIndicator.tsx} +2 -1
  404. package/src/lib/ui/components/DefaultMenuPanel.tsx +4 -3
  405. package/src/lib/ui/components/KeyboardShortcutsDialog/DefaultKeyboardShortcutsDialogContent.tsx +6 -6
  406. package/src/lib/ui/components/LanguageMenu.tsx +1 -0
  407. package/src/lib/ui/components/MainMenu/DefaultMainMenuContent.tsx +4 -4
  408. package/src/lib/ui/components/Minimap/DefaultMinimap.tsx +1 -0
  409. package/src/lib/ui/components/Minimap/MinimapManager.ts +4 -4
  410. package/src/lib/ui/components/MobileStylePanel.tsx +9 -6
  411. package/src/lib/ui/components/NavigationPanel/DefaultNavigationPanel.tsx +1 -1
  412. package/src/lib/ui/components/PageMenu/DefaultPageMenu.tsx +5 -4
  413. package/src/lib/ui/components/SharePanel/PeopleMenuItem.tsx +4 -3
  414. package/src/lib/ui/components/SharePanel/UserPresenceColorPicker.tsx +3 -3
  415. package/src/lib/ui/components/StylePanel/DefaultStylePanel.tsx +28 -12
  416. package/src/lib/ui/components/StylePanel/DefaultStylePanelContent.tsx +261 -343
  417. package/src/lib/ui/components/{primitives/TldrawUiButtonPicker.tsx → StylePanel/StylePanelButtonPicker.tsx} +73 -50
  418. package/src/lib/ui/components/StylePanel/StylePanelContext.tsx +63 -0
  419. package/src/lib/ui/components/StylePanel/{DoubleDropdownPicker.tsx → StylePanelDoubleDropdownPicker.tsx} +31 -22
  420. package/src/lib/ui/components/StylePanel/StylePanelDropdownPicker.tsx +119 -0
  421. package/src/lib/ui/components/StylePanel/StylePanelSubheading.tsx +9 -0
  422. package/src/lib/ui/components/Toolbar/AltTextEditor.tsx +2 -0
  423. package/src/lib/ui/components/Toolbar/DefaultImageToolbarContent.tsx +33 -16
  424. package/src/lib/ui/components/Toolbar/DefaultToolbar.tsx +55 -23
  425. package/src/lib/ui/components/Toolbar/DefaultVideoToolbarContent.tsx +12 -4
  426. package/src/lib/ui/components/Toolbar/LinkEditor.tsx +1 -0
  427. package/src/lib/ui/components/Toolbar/OverflowingToolbar.tsx +212 -61
  428. package/src/lib/ui/components/Toolbar/ToggleToolLockedButton.tsx +21 -11
  429. package/src/lib/ui/components/menu-items.tsx +8 -0
  430. package/src/lib/ui/components/primitives/TldrawUiContextualToolbar.tsx +8 -3
  431. package/src/lib/ui/components/primitives/TldrawUiInput.tsx +6 -3
  432. package/src/lib/ui/components/primitives/TldrawUiPopover.tsx +4 -2
  433. package/src/lib/ui/components/primitives/TldrawUiSlider.tsx +52 -32
  434. package/src/lib/ui/components/primitives/TldrawUiToolbar.tsx +55 -12
  435. package/src/lib/ui/components/primitives/TldrawUiTooltip.tsx +379 -0
  436. package/src/lib/ui/components/primitives/layout.tsx +107 -0
  437. package/src/lib/ui/components/primitives/menus/TldrawUiMenuCheckboxItem.tsx +4 -0
  438. package/src/lib/ui/components/primitives/menus/TldrawUiMenuContext.tsx +0 -1
  439. package/src/lib/ui/components/primitives/menus/TldrawUiMenuGroup.tsx +29 -16
  440. package/src/lib/ui/components/primitives/menus/TldrawUiMenuItem.tsx +221 -19
  441. package/src/lib/ui/context/TldrawUiContextProvider.tsx +23 -20
  442. package/src/lib/ui/context/actions.tsx +51 -10
  443. package/src/lib/ui/context/components.tsx +3 -0
  444. package/src/lib/ui/context/events.tsx +3 -1
  445. package/src/lib/ui/hooks/useClipboardEvents.ts +2 -2
  446. package/src/lib/ui/hooks/useExportAs.ts +3 -2
  447. package/src/lib/ui/hooks/useTools.tsx +140 -10
  448. package/src/lib/ui/hooks/useTranslation/TLUiTranslationKey.ts +7 -0
  449. package/src/lib/ui/hooks/useTranslation/defaultTranslation.ts +8 -1
  450. package/src/lib/ui/kbd-utils.ts +10 -3
  451. package/src/lib/ui/version.ts +3 -3
  452. package/src/lib/ui.css +434 -293
  453. package/src/lib/utils/excalidraw/__snapshots__/putExcalidrawContent.test.tsx.snap +5 -5
  454. package/src/lib/utils/export/copyAs.ts +1 -24
  455. package/src/lib/utils/export/export.ts +0 -36
  456. package/src/lib/utils/export/exportAs.ts +1 -32
  457. package/src/lib/utils/tldr/__snapshots__/buildFromV1Document.test.ts.snap +4 -4
  458. package/src/test/A11y.test.tsx +3 -2
  459. package/src/test/ClickManager.test.ts +7 -6
  460. package/src/test/Editor.test.tsx +20 -19
  461. package/src/test/EraserTool.test.ts +184 -13
  462. package/src/test/HandTool.test.ts +10 -9
  463. package/src/test/HighlightShape.test.ts +2 -1
  464. package/src/test/SelectTool.test.ts +3 -2
  465. package/src/test/TLUserPreferences.test.ts +4 -3
  466. package/src/test/TestEditor.ts +13 -15
  467. package/src/test/TldrawEditor.test.tsx +11 -10
  468. package/src/test/ZoomTool.test.ts +7 -6
  469. package/src/test/__snapshots__/drawing.test.ts.snap +2 -2
  470. package/src/test/__snapshots__/groups.test.tsx.snap +6 -6
  471. package/src/test/__snapshots__/resizing.test.ts.snap +2 -2
  472. package/src/test/arrows-megabus.test.tsx +17 -10
  473. package/src/test/bindings.test.tsx +24 -37
  474. package/src/test/bookmark-shapes.test.ts +1 -8
  475. package/src/test/commands/__snapshots__/getSvgString.test.ts.snap +23 -7
  476. package/src/test/commands/__snapshots__/packShapes.test.ts.snap +8 -8
  477. package/src/test/commands/__snapshots__/zoomToFit.test.ts.snap +2 -2
  478. package/src/test/commands/alignShapes.test.tsx +25 -24
  479. package/src/test/commands/animationSpeed.test.ts +2 -1
  480. package/src/test/commands/centerOnPoint.test.ts +3 -2
  481. package/src/test/commands/clipboard.test.ts +3 -2
  482. package/src/test/commands/createShapes.test.ts +2 -1
  483. package/src/test/commands/deleteShapes.test.ts +2 -1
  484. package/src/test/commands/distributeShapes.test.tsx +11 -10
  485. package/src/test/commands/getSvgString.test.ts +2 -1
  486. package/src/test/commands/packShapes.test.ts +5 -4
  487. package/src/test/commands/resizeShape.test.ts +2 -1
  488. package/src/test/commands/rotateShapes.test.ts +7 -6
  489. package/src/test/commands/setCamera.test.ts +4 -3
  490. package/src/test/commands/setCurrentPage.test.ts +3 -2
  491. package/src/test/commands/stackShapes.test.ts +11 -10
  492. package/src/test/commands/stretch.test.tsx +13 -12
  493. package/src/test/createDeepLink.test.tsx +2 -1
  494. package/src/test/cropping.test.ts +3 -2
  495. package/src/test/custom-clipping.test.ts +436 -0
  496. package/src/test/drawing.test.ts +2 -1
  497. package/src/test/flipShapes.test.ts +4 -3
  498. package/src/test/frames.test.ts +25 -24
  499. package/src/test/getCulledShapes.test.tsx +74 -4
  500. package/src/test/groups.test.tsx +1 -1
  501. package/src/test/handleDeepLink.test.tsx +2 -1
  502. package/src/test/inner-outer-margin.test.ts +315 -0
  503. package/src/test/maxShapes.test.ts +3 -2
  504. package/src/test/modifiers.test.ts +5 -4
  505. package/src/test/navigation.test.ts +12 -11
  506. package/src/test/panning.test.ts +2 -1
  507. package/src/test/perf/perf.test.ts +2 -1
  508. package/src/test/registerDeepLinkListener.test.tsx +10 -9
  509. package/src/test/resizing.test.ts +39 -38
  510. package/src/test/select.test.tsx +4 -3
  511. package/src/test/selection-omnibus.test.ts +11 -10
  512. package/src/test/shapeutils.test.ts +4 -3
  513. package/src/test/translating.test.ts +9 -8
  514. package/tldraw.css +742 -583
  515. package/dist-cjs/lib/ui/components/FollowingIndicator.js.map +0 -7
  516. package/dist-cjs/lib/ui/components/StylePanel/DoubleDropdownPicker.js.map +0 -7
  517. package/dist-cjs/lib/ui/components/StylePanel/DropdownPicker.js.map +0 -7
  518. package/dist-cjs/lib/ui/components/primitives/TldrawUiButtonPicker.js +0 -142
  519. package/dist-cjs/lib/ui/components/primitives/TldrawUiButtonPicker.js.map +0 -7
  520. package/dist-esm/lib/ui/components/FollowingIndicator.mjs.map +0 -7
  521. package/dist-esm/lib/ui/components/StylePanel/DoubleDropdownPicker.mjs.map +0 -7
  522. package/dist-esm/lib/ui/components/StylePanel/DropdownPicker.mjs.map +0 -7
  523. package/dist-esm/lib/ui/components/primitives/TldrawUiButtonPicker.mjs +0 -115
  524. package/dist-esm/lib/ui/components/primitives/TldrawUiButtonPicker.mjs.map +0 -7
  525. 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,
@@ -155,11 +168,10 @@ export {
155
168
  type TLDefaultFont,
156
169
  type TLDefaultFonts,
157
170
  } from './lib/shapes/shared/defaultFonts'
158
- export {
159
- PlainTextLabel,
160
- TextLabel,
161
- type PlainTextLabelProps,
162
- } from './lib/shapes/shared/PlainTextLabel'
171
+ export { getStrokePoints } from './lib/shapes/shared/freehand/getStrokePoints'
172
+ export { getSvgPathFromStrokePoints } from './lib/shapes/shared/freehand/svg'
173
+ export { type StrokeOptions, type StrokePoint } from './lib/shapes/shared/freehand/types'
174
+ export { PlainTextLabel, type PlainTextLabelProps } from './lib/shapes/shared/PlainTextLabel'
163
175
  export {
164
176
  RichTextLabel,
165
177
  RichTextSVG,
@@ -167,10 +179,9 @@ export {
167
179
  type RichTextSVGProps,
168
180
  } from './lib/shapes/shared/RichTextLabel'
169
181
  export { useDefaultColorTheme } from './lib/shapes/shared/useDefaultColorTheme'
170
- export { useEditablePlainText, useEditableText } from './lib/shapes/shared/useEditablePlainText'
182
+ export { useEditablePlainText } from './lib/shapes/shared/useEditablePlainText'
171
183
  export { useEditableRichText } from './lib/shapes/shared/useEditableRichText'
172
184
  export {
173
- useAsset,
174
185
  useImageOrVideoAsset,
175
186
  type UseImageOrVideoAssetOptions,
176
187
  } from './lib/shapes/shared/useImageOrVideoAsset'
@@ -294,6 +305,7 @@ export {
294
305
  ToggleSnapModeItem,
295
306
  ToggleToolLockItem,
296
307
  ToggleTransparentBgMenuItem,
308
+ ToggleUiLabelsItem,
297
309
  ToggleWrapModeItem,
298
310
  UngroupMenuItem,
299
311
  UnlockAllMenuItem,
@@ -348,10 +360,6 @@ export {
348
360
  TldrawUiMenuSubmenu,
349
361
  type TLUiMenuSubmenuProps,
350
362
  } from './lib/ui/components/primitives/menus/TldrawUiMenuSubmenu'
351
- export {
352
- TldrawUiButtonPicker,
353
- type TLUiButtonPickerProps,
354
- } from './lib/ui/components/primitives/TldrawUiButtonPicker'
355
363
  export {
356
364
  TldrawUiContextualToolbar,
357
365
  type TLUiContextualToolbarProps,
@@ -412,6 +420,12 @@ export {
412
420
  type TLUiToolbarToggleGroupProps,
413
421
  type TLUiToolbarToggleItemProps,
414
422
  } from './lib/ui/components/primitives/TldrawUiToolbar'
423
+ export {
424
+ TldrawUiTooltip,
425
+ TldrawUiTooltipProvider,
426
+ type TldrawUiTooltipProps,
427
+ type TldrawUiTooltipProviderProps,
428
+ } from './lib/ui/components/primitives/TldrawUiTooltip'
415
429
  export {
416
430
  DefaultQuickActions,
417
431
  type TLUiQuickActionsProps,
@@ -425,17 +439,44 @@ export {
425
439
  type TLUiStylePanelProps,
426
440
  } from './lib/ui/components/StylePanel/DefaultStylePanel'
427
441
  export {
428
- ArrowheadStylePickerSet,
429
- CommonStylePickerSet,
430
442
  DefaultStylePanelContent,
431
- GeoStylePickerSet,
432
- OpacitySlider,
433
- SplineStylePickerSet,
434
- TextStylePickerSet,
435
- type StylePickerSetProps,
436
- type ThemeStylePickerSetProps,
437
- type TLUiStylePanelContentProps,
443
+ StylePanelArrowheadPicker,
444
+ StylePanelArrowKindPicker,
445
+ StylePanelColorPicker,
446
+ StylePanelDashPicker,
447
+ StylePanelFillPicker,
448
+ StylePanelFontPicker,
449
+ StylePanelGeoShapePicker,
450
+ StylePanelLabelAlignPicker,
451
+ StylePanelOpacityPicker,
452
+ StylePanelSection,
453
+ StylePanelSizePicker,
454
+ StylePanelSplinePicker,
455
+ StylePanelTextAlignPicker,
456
+ type StylePanelSectionProps,
438
457
  } from './lib/ui/components/StylePanel/DefaultStylePanelContent'
458
+ export {
459
+ StylePanelButtonPicker,
460
+ type StylePanelButtonPickerProps,
461
+ } from './lib/ui/components/StylePanel/StylePanelButtonPicker'
462
+ export {
463
+ StylePanelContextProvider,
464
+ useStylePanelContext,
465
+ type StylePanelContext,
466
+ type StylePanelContextProviderProps,
467
+ } from './lib/ui/components/StylePanel/StylePanelContext'
468
+ export {
469
+ StylePanelDoubleDropdownPicker,
470
+ type StylePanelDoubleDropdownPickerProps,
471
+ } from './lib/ui/components/StylePanel/StylePanelDoubleDropdownPicker'
472
+ export {
473
+ StylePanelDropdownPicker,
474
+ type StylePanelDropdownPickerProps,
475
+ } from './lib/ui/components/StylePanel/StylePanelDropdownPicker'
476
+ export {
477
+ StylePanelSubheading,
478
+ type StylePanelSubheadingProps,
479
+ } from './lib/ui/components/StylePanel/StylePanelSubheading'
439
480
  export {
440
481
  DefaultImageToolbar,
441
482
  type TLUiImageToolbarProps,
@@ -590,7 +631,9 @@ export { useMenuIsOpen } from './lib/ui/hooks/useMenuIsOpen'
590
631
  export { useReadonly } from './lib/ui/hooks/useReadonly'
591
632
  export { useRelevantStyles } from './lib/ui/hooks/useRelevantStyles'
592
633
  export {
634
+ onDragFromToolbarToCreateShape,
593
635
  useTools,
636
+ type OnDragFromToolbarToCreateShapesOpts,
594
637
  type TLUiToolItem,
595
638
  type TLUiToolsContextType,
596
639
  type TLUiToolsProviderProps,
@@ -605,13 +648,12 @@ export {
605
648
  } from './lib/ui/hooks/useTranslation/useTranslation'
606
649
  export { type TLUiIconType } from './lib/ui/icon-types'
607
650
  export { useDefaultHelpers, type TLUiOverrideHelpers, type TLUiOverrides } from './lib/ui/overrides'
608
- export { TldrawUi, type TldrawUiProps } from './lib/ui/TldrawUi'
651
+ export { TldrawUi, TldrawUiInFrontOfTheCanvas, type TldrawUiProps } from './lib/ui/TldrawUi'
609
652
  export { containBoxSize, downsizeImage, type BoxWidthHeight } from './lib/utils/assets/assets'
610
653
  export { preloadFont, type TLTypeFace } from './lib/utils/assets/preload-font'
611
654
  export { getEmbedInfo, type TLEmbedResult } from './lib/utils/embeds/embeds'
612
655
  export { putExcalidrawContent } from './lib/utils/excalidraw/putExcalidrawContent'
613
656
  export { copyAs, type CopyAsOptions, type TLCopyType } from './lib/utils/export/copyAs'
614
- export { exportToBlob } from './lib/utils/export/export'
615
657
  export { downloadFile, exportAs, type ExportAsOptions } from './lib/utils/export/exportAs'
616
658
  export { fitFrameToContent, removeFrame } from './lib/utils/frames/frames'
617
659
  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)
@@ -1,4 +1,5 @@
1
1
  import { IndexKey, TLArrowShape, TLShapeId, Vec, createShapeId } from '@tldraw/editor'
2
+ import { vi } from 'vitest'
2
3
  import { TestEditor } from '../../../test/TestEditor'
3
4
  import { getArrowTargetState } from './arrowTargetState'
4
5
  import { getArrowBindings } from './shared'
@@ -13,7 +14,7 @@ global.cancelAnimationFrame = function cancelAnimationFrame(id) {
13
14
  clearTimeout(id)
14
15
  }
15
16
 
16
- jest.useFakeTimers()
17
+ vi.useFakeTimers()
17
18
 
18
19
  const ids = {
19
20
  box1: createShapeId('box1'),
@@ -242,7 +243,7 @@ describe('When pointing an end shape', () => {
242
243
  },
243
244
  })
244
245
 
245
- jest.advanceTimersByTime(1000)
246
+ vi.advanceTimersByTime(1000)
246
247
 
247
248
  arrow = editor.getCurrentPageShapes()[editor.getCurrentPageShapes().length - 1]
248
249
 
@@ -306,7 +307,7 @@ describe('When pointing an end shape', () => {
306
307
  })
307
308
 
308
309
  // Give time for the velocity to die down
309
- jest.advanceTimersByTime(1000)
310
+ vi.advanceTimersByTime(1000)
310
311
 
311
312
  arrow = editor.getCurrentPageShapes()[editor.getCurrentPageShapes().length - 1]
312
313
 
@@ -568,12 +569,12 @@ describe('reparenting issue', () => {
568
569
  const arrow1BoundIndex = editor.getShape(arrow1Id)!.index
569
570
  const arrow2BoundIndex = editor.getShape(arrow2Id)!.index
570
571
  expect(arrow1BoundIndex).toBe('a1V')
571
- expect(arrow2BoundIndex).toBe('a1F')
572
+ expect(arrow2BoundIndex).toBe('a1G')
572
573
 
573
574
  // nudge everything around and make sure we all stay in the right order
574
575
  editor.selectAll().nudgeShapes(editor.getSelectedShapeIds(), { x: -1, y: 0 })
575
576
  expect(editor.getShape(arrow1Id)!.index).toBe('a1V')
576
- expect(editor.getShape(arrow2Id)!.index).toBe('a1F')
577
+ expect(editor.getShape(arrow2Id)!.index).toBe('a1G')
577
578
  })
578
579
  })
579
580
 
@@ -1,4 +1,5 @@
1
1
  import { HALF_PI, TLArrowShape, TLShapeId, createShapeId, toRichText } from '@tldraw/editor'
2
+ import { vi } from 'vitest'
2
3
  import { TestEditor } from '../../../test/TestEditor'
3
4
  import { createOrUpdateArrowBinding, getArrowBindings } from './shared'
4
5
 
@@ -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)
@@ -217,7 +218,7 @@ describe('Other cases when arrow are moved', () => {
217
218
  // When box one is not selected, unbinds box1 and keeps binding to box2
218
219
  editor.select(ids.arrow1, ids.box2, ids.box3)
219
220
  editor.alignShapes(editor.getSelectedShapeIds(), 'right')
220
- jest.advanceTimersByTime(1000)
221
+ vi.advanceTimersByTime(1000)
221
222
 
222
223
  expect(bindings()).toMatchObject({
223
224
  start: { toId: ids.box1, props: { isPrecise: false } },
@@ -227,7 +228,7 @@ describe('Other cases when arrow are moved', () => {
227
228
  // maintains bindings if they would still be over the same shape (but makes them precise), but unbinds others
228
229
  editor.select(ids.arrow1, ids.box3)
229
230
  editor.alignShapes(editor.getSelectedShapeIds(), 'top')
230
- jest.advanceTimersByTime(1000)
231
+ vi.advanceTimersByTime(1000)
231
232
 
232
233
  expect(bindings()).toMatchObject({
233
234
  start: { toId: ids.box1, props: { isPrecise: true } },
@@ -244,7 +245,7 @@ describe('Other cases when arrow are moved', () => {
244
245
  // When box one is not selected, unbinds box1 and keeps binding to box2
245
246
  editor.select(ids.arrow1, ids.box2, ids.box3)
246
247
  editor.distributeShapes(editor.getSelectedShapeIds(), 'horizontal')
247
- jest.advanceTimersByTime(1000)
248
+ vi.advanceTimersByTime(1000)
248
249
 
249
250
  expect(bindings()).toMatchObject({
250
251
  start: { toId: ids.box1, props: { isPrecise: false } },
@@ -254,7 +255,7 @@ describe('Other cases when arrow are moved', () => {
254
255
  // unbinds when only the arrow is selected (not its bound shapes) if the arrow itself has moved
255
256
  editor.select(ids.arrow1, ids.box3, ids.box4)
256
257
  editor.distributeShapes(editor.getSelectedShapeIds(), 'vertical')
257
- jest.advanceTimersByTime(1000)
258
+ vi.advanceTimersByTime(1000)
258
259
 
259
260
  // The arrow didn't actually move
260
261
  expect(bindings()).toMatchObject({
@@ -265,7 +266,7 @@ describe('Other cases when arrow are moved', () => {
265
266
  // The arrow will not move because it is still bound to another shape
266
267
  editor.updateShapes([{ id: ids.box4, type: 'geo', y: -600 }])
267
268
  editor.distributeShapes(editor.getSelectedShapeIds(), 'vertical')
268
- jest.advanceTimersByTime(1000)
269
+ vi.advanceTimersByTime(1000)
269
270
 
270
271
  expect(bindings()).toMatchObject({
271
272
  start: undefined,
@@ -578,3 +579,44 @@ describe("an arrow's parents", () => {
578
579
  })
579
580
  })
580
581
  })
582
+
583
+ describe('Arrow export bounds', () => {
584
+ it('excludes labels from shape bounds for export', () => {
585
+ editor.selectAll().deleteShapes(editor.getSelectedShapeIds())
586
+
587
+ // Create shapes for the arrow to bind to
588
+ editor.createShapes([
589
+ { id: ids.box1, type: 'geo', x: 100, y: 100, props: { w: 100, h: 100 } },
590
+ { id: ids.box2, type: 'geo', x: 300, y: 100, props: { w: 100, h: 100 } },
591
+ ])
592
+
593
+ // Create an arrow with a label
594
+ editor.createShapes([
595
+ {
596
+ id: ids.arrow1,
597
+ type: 'arrow',
598
+ x: 0,
599
+ y: 0,
600
+ props: {
601
+ start: { x: 0, y: 0 },
602
+ end: { x: 0, y: 100 },
603
+ richText: toRichText('Test Label'),
604
+ },
605
+ },
606
+ ])
607
+
608
+ // Get the page bounds (should exclude labels due to excludeFromShapeBounds flag)
609
+ const pageBounds = editor.getShapePageBounds(ids.arrow1)
610
+ expect(pageBounds).toBeDefined()
611
+
612
+ // The bounds should be smaller than if labels were included
613
+ // Since the arrow has a label that's excluded, the bounds should be minimal
614
+ expect(pageBounds!.width).toBeLessThan(200) // Should not include label width
615
+ expect(pageBounds!.height).toBeLessThan(200) // Should not include label height
616
+
617
+ // Verify that the arrow has a label (which should be excluded from shape bounds)
618
+ const arrow = editor.getShape(ids.arrow1) as TLArrowShape
619
+ expect(arrow.props.richText).toBeDefined()
620
+ expect(arrow.props.richText).not.toBeNull()
621
+ })
622
+ })
@@ -31,6 +31,7 @@ import {
31
31
  clamp,
32
32
  debugFlags,
33
33
  exhaustiveSwitchError,
34
+ getColorValue,
34
35
  getDefaultColorTheme,
35
36
  getFontsFromRichText,
36
37
  invLerp,
@@ -785,8 +786,8 @@ export class ArrowShapeUtil extends ShapeUtil<TLArrowShape> {
785
786
  lineHeight={TEXT_PROPS.lineHeight}
786
787
  align="middle"
787
788
  verticalAlign="middle"
789
+ labelColor={getColorValue(theme, shape.props.labelColor, 'solid')}
788
790
  richText={shape.props.richText}
789
- labelColor={theme[shape.props.labelColor].solid}
790
791
  textWidth={labelPosition.box.w - ARROW_LABEL_PADDING * 2 * shape.props.scale}
791
792
  isSelected={isSelected}
792
793
  padding={0}
@@ -934,8 +935,8 @@ export class ArrowShapeUtil extends ShapeUtil<TLArrowShape> {
934
935
  font={shape.props.font}
935
936
  align="middle"
936
937
  verticalAlign="middle"
938
+ labelColor={getColorValue(theme, shape.props.labelColor, 'solid')}
937
939
  richText={shape.props.richText}
938
- labelColor={theme[shape.props.labelColor].solid}
939
940
  bounds={getArrowLabelPosition(this.editor, shape)
940
941
  .box.clone()
941
942
  .expandBy(-ARROW_LABEL_PADDING * shape.props.scale)}
@@ -1077,7 +1078,7 @@ const ArrowSvg = track(function ArrowSvg({
1077
1078
  </defs>
1078
1079
  <g
1079
1080
  fill="none"
1080
- stroke={theme[shape.props.color].solid}
1081
+ stroke={getColorValue(theme, shape.props.color, 'solid')}
1081
1082
  strokeWidth={strokeWidth}
1082
1083
  strokeLinejoin="round"
1083
1084
  strokeLinecap="round"
@@ -227,6 +227,14 @@ interface ArrowheadInfo {
227
227
  hasEndArrowhead: boolean
228
228
  }
229
229
  export function getArrowLabelPosition(editor: Editor, shape: TLArrowShape) {
230
+ const isEditing = editor.getEditingShapeId() === shape.id
231
+ if (!isEditing && isEmptyRichText(shape.props.richText)) {
232
+ // Short-circuit for empty labels.
233
+ const bodyGeom = getArrowBodyGeometry(editor, shape)
234
+ const labelCenter = bodyGeom.interpolateAlongEdge(0.5)
235
+ return { box: Box.FromCenter(labelCenter, new Vec(0, 0)), debugGeom: [] }
236
+ }
237
+
230
238
  const debugGeom: Geometry2d[] = []
231
239
  const info = getArrowInfo(editor, shape)!
232
240
 
@@ -94,7 +94,7 @@ export function updateArrowTargetState({
94
94
  const target = editor.getShapeAtPoint(pointInPageSpace, {
95
95
  hitInside: true,
96
96
  hitFrameInside: true,
97
- margin: arrowKind === 'elbow' ? 8 : 0,
97
+ margin: arrowKind === 'elbow' ? 8 : [8, 0],
98
98
  filter: (targetShape) => {
99
99
  return (
100
100
  !targetShape.isLocked &&
@@ -187,6 +187,7 @@ export function updateArrowTargetState({
187
187
  }
188
188
 
189
189
  const shouldSnapCenter = !isExact && precise && targetGeometryInTargetSpace.isClosed
190
+ // const shouldSnapEdges = !isExact && (precise || !targetGeometryInTargetSpace.isClosed)
190
191
  const shouldSnapEdges =
191
192
  !isExact && ((precise && arrowKind === 'elbow') || !targetGeometryInTargetSpace.isClosed)
192
193
  const shouldSnapEdgePoints =
@@ -98,7 +98,7 @@ export function ElbowArrowDebug({ arrow }: { arrow: TLArrowShape }) {
98
98
  y={fullBox.minY - 3}
99
99
  fontSize={10}
100
100
  fill="black"
101
- stroke="var(--color-background)"
101
+ stroke="var(--tl-color-background)"
102
102
  strokeWidth={2}
103
103
  paintOrder="stroke"
104
104
  >
@@ -109,7 +109,7 @@ export function ElbowArrowDebug({ arrow }: { arrow: TLArrowShape }) {
109
109
  y={info.A.expanded.y}
110
110
  fontSize={10}
111
111
  fill="black"
112
- stroke="var(--color-background)"
112
+ stroke="var(--tl-color-background)"
113
113
  strokeWidth={2}
114
114
  paintOrder="stroke"
115
115
  >
@@ -121,7 +121,7 @@ export function ElbowArrowDebug({ arrow }: { arrow: TLArrowShape }) {
121
121
  y={info.B.expanded.y}
122
122
  fontSize={10}
123
123
  fill="black"
124
- stroke="var(--color-background)"
124
+ stroke="var(--tl-color-background)"
125
125
  strokeWidth={2}
126
126
  paintOrder="stroke"
127
127
  >
@@ -13,7 +13,7 @@ import {
13
13
  debounce,
14
14
  getHashForString,
15
15
  lerp,
16
- stopEventPropagation,
16
+ markEventAsHandled,
17
17
  tlenv,
18
18
  toDomPrecision,
19
19
  useEditor,
@@ -132,9 +132,9 @@ function BookmarkShapeComponent({ shape }: { shape: TLBookmarkShape }) {
132
132
  const [isFaviconValid, setIsFaviconValid] = useState(true)
133
133
  const onFaviconError = () => setIsFaviconValid(false)
134
134
 
135
- const useStopPropagationOnShiftKey = useCallback<PointerEventHandler>(
135
+ const markAsHandledOnShiftKey = useCallback<PointerEventHandler>(
136
136
  (e) => {
137
- if (!editor.inputs.shiftKey) stopEventPropagation(e)
137
+ if (!editor.inputs.shiftKey) markEventAsHandled(e)
138
138
  },
139
139
  [editor]
140
140
  )
@@ -182,8 +182,8 @@ function BookmarkShapeComponent({ shape }: { shape: TLBookmarkShape }) {
182
182
  target="_blank"
183
183
  rel="noopener noreferrer"
184
184
  draggable={false}
185
- onPointerDown={useStopPropagationOnShiftKey}
186
- onPointerUp={useStopPropagationOnShiftKey}
185
+ onPointerDown={markAsHandledOnShiftKey}
186
+ onPointerUp={markAsHandledOnShiftKey}
187
187
  >
188
188
  {isFaviconValid && asset?.props.favicon ? (
189
189
  <img
@@ -1,5 +1,4 @@
1
1
  import { TestEditor } from '../../../test/TestEditor'
2
- import { DrawShapeTool } from './DrawShapeTool'
3
2
 
4
3
  let editor: TestEditor
5
4
 
@@ -10,10 +9,6 @@ afterEach(() => {
10
9
  editor?.dispose()
11
10
  })
12
11
 
13
- describe(DrawShapeTool, () => {
14
- return
15
- })
16
-
17
12
  describe('When in the idle state', () => {
18
13
  it('Returns to select on cancel', () => {
19
14
  editor.setCurrentTool('draw')
@@ -14,6 +14,7 @@ import {
14
14
  VecLike,
15
15
  drawShapeMigrations,
16
16
  drawShapeProps,
17
+ getColorValue,
17
18
  last,
18
19
  lerp,
19
20
  rng,
@@ -289,7 +290,7 @@ function DrawShapeSvg({ shape, zoomOverride }: { shape: TLDrawShape; zoomOverrid
289
290
  <path
290
291
  d={svgInk(allPointsFromSegments, options)}
291
292
  strokeLinecap="round"
292
- fill={theme[shape.props.color].solid}
293
+ fill={getColorValue(theme, shape.props.color, 'solid')}
293
294
  />
294
295
  </>
295
296
  )
@@ -313,8 +314,8 @@ function DrawShapeSvg({ shape, zoomOverride }: { shape: TLDrawShape; zoomOverrid
313
314
  <path
314
315
  d={solidStrokePath}
315
316
  strokeLinecap="round"
316
- fill={isDot ? theme[shape.props.color].solid : 'none'}
317
- stroke={theme[shape.props.color].solid}
317
+ fill={isDot ? getColorValue(theme, shape.props.color, 'solid') : 'none'}
318
+ stroke={getColorValue(theme, shape.props.color, 'solid')}
318
319
  strokeWidth={sw}
319
320
  strokeDasharray={isDot ? 'none' : getDrawShapeStrokeDashArray(shape, sw, dotAdjustment)}
320
321
  strokeDashoffset="0"
@@ -144,7 +144,7 @@ export class EmbedShapeUtil extends BaseBoxShapeUtil<TLEmbedShape> {
144
144
  border: 0,
145
145
  boxShadow: getRotatedBoxShadow(pageRotation),
146
146
  borderRadius: embedInfo?.definition.overrideOutlineRadius ?? 8,
147
- background: embedInfo?.definition.backgroundColor ?? 'var(--color-background)',
147
+ background: embedInfo?.definition.backgroundColor ?? 'var(--tl-color-background)',
148
148
  width: w,
149
149
  height: h,
150
150
  }}