tldraw 3.16.0-canary.ca347c5375a5 → 3.16.0-canary.cb18f446a36f

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 (527) hide show
  1. package/dist-cjs/index.d.ts +443 -112
  2. package/dist-cjs/index.js +50 -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 +4 -3
  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/bookmark/BookmarkShapeUtil.js +4 -4
  20. package/dist-cjs/lib/shapes/bookmark/BookmarkShapeUtil.js.map +2 -2
  21. package/dist-cjs/lib/shapes/draw/DrawShapeUtil.js +3 -3
  22. package/dist-cjs/lib/shapes/draw/DrawShapeUtil.js.map +2 -2
  23. package/dist-cjs/lib/shapes/embed/EmbedShapeUtil.js +1 -1
  24. package/dist-cjs/lib/shapes/embed/EmbedShapeUtil.js.map +1 -1
  25. package/dist-cjs/lib/shapes/frame/FrameShapeUtil.js +20 -13
  26. package/dist-cjs/lib/shapes/frame/FrameShapeUtil.js.map +2 -2
  27. package/dist-cjs/lib/shapes/frame/components/FrameHeading.js +1 -1
  28. package/dist-cjs/lib/shapes/frame/components/FrameHeading.js.map +2 -2
  29. package/dist-cjs/lib/shapes/frame/components/FrameLabelInput.js +8 -2
  30. package/dist-cjs/lib/shapes/frame/components/FrameLabelInput.js.map +2 -2
  31. package/dist-cjs/lib/shapes/geo/GeoShapeUtil.js +3 -2
  32. package/dist-cjs/lib/shapes/geo/GeoShapeUtil.js.map +2 -2
  33. package/dist-cjs/lib/shapes/geo/components/GeoShapeBody.js +2 -1
  34. package/dist-cjs/lib/shapes/geo/components/GeoShapeBody.js.map +2 -2
  35. package/dist-cjs/lib/shapes/highlight/HighlightShapeUtil.js +5 -1
  36. package/dist-cjs/lib/shapes/highlight/HighlightShapeUtil.js.map +2 -2
  37. package/dist-cjs/lib/shapes/image/ImageShapeUtil.js +6 -3
  38. package/dist-cjs/lib/shapes/image/ImageShapeUtil.js.map +2 -2
  39. package/dist-cjs/lib/shapes/line/LineShapeUtil.js +5 -1
  40. package/dist-cjs/lib/shapes/line/LineShapeUtil.js.map +2 -2
  41. package/dist-cjs/lib/shapes/note/NoteShapeUtil.js +6 -5
  42. package/dist-cjs/lib/shapes/note/NoteShapeUtil.js.map +2 -2
  43. package/dist-cjs/lib/shapes/shared/HyperlinkButton.js +4 -4
  44. package/dist-cjs/lib/shapes/shared/HyperlinkButton.js.map +2 -2
  45. package/dist-cjs/lib/shapes/shared/PlainTextLabel.js +1 -3
  46. package/dist-cjs/lib/shapes/shared/PlainTextLabel.js.map +2 -2
  47. package/dist-cjs/lib/shapes/shared/ShapeFill.js +4 -4
  48. package/dist-cjs/lib/shapes/shared/ShapeFill.js.map +2 -2
  49. package/dist-cjs/lib/shapes/shared/freehand/svg.js.map +2 -2
  50. package/dist-cjs/lib/shapes/shared/useEditablePlainText.js +3 -5
  51. package/dist-cjs/lib/shapes/shared/useEditablePlainText.js.map +2 -2
  52. package/dist-cjs/lib/shapes/shared/useImageOrVideoAsset.js +0 -2
  53. package/dist-cjs/lib/shapes/shared/useImageOrVideoAsset.js.map +2 -2
  54. package/dist-cjs/lib/shapes/shared/usePrefersReducedMotion.js +10 -1
  55. package/dist-cjs/lib/shapes/shared/usePrefersReducedMotion.js.map +2 -2
  56. package/dist-cjs/lib/shapes/text/PlainTextArea.js +3 -2
  57. package/dist-cjs/lib/shapes/text/PlainTextArea.js.map +2 -2
  58. package/dist-cjs/lib/shapes/text/RichTextArea.js +3 -3
  59. package/dist-cjs/lib/shapes/text/RichTextArea.js.map +2 -2
  60. package/dist-cjs/lib/shapes/text/TextShapeUtil.js +2 -2
  61. package/dist-cjs/lib/shapes/text/TextShapeUtil.js.map +2 -2
  62. package/dist-cjs/lib/shapes/video/VideoShapeUtil.js +3 -3
  63. package/dist-cjs/lib/shapes/video/VideoShapeUtil.js.map +1 -1
  64. package/dist-cjs/lib/tools/EraserTool/childStates/Erasing.js +25 -1
  65. package/dist-cjs/lib/tools/EraserTool/childStates/Erasing.js.map +2 -2
  66. package/dist-cjs/lib/tools/EraserTool/childStates/Pointing.js +12 -0
  67. package/dist-cjs/lib/tools/EraserTool/childStates/Pointing.js.map +2 -2
  68. package/dist-cjs/lib/tools/SelectTool/childStates/Translating.js.map +2 -2
  69. package/dist-cjs/lib/ui/TldrawUi.js +27 -12
  70. package/dist-cjs/lib/ui/TldrawUi.js.map +3 -3
  71. package/dist-cjs/lib/ui/assetUrls.js +13 -10
  72. package/dist-cjs/lib/ui/assetUrls.js.map +2 -2
  73. package/dist-cjs/lib/ui/components/A11y.js +1 -1
  74. package/dist-cjs/lib/ui/components/A11y.js.map +2 -2
  75. package/dist-cjs/lib/ui/components/AccessibilityMenu.js +35 -0
  76. package/dist-cjs/lib/ui/components/AccessibilityMenu.js.map +7 -0
  77. package/dist-cjs/lib/ui/components/ActionsMenu/DefaultActionsMenu.js +12 -3
  78. package/dist-cjs/lib/ui/components/ActionsMenu/DefaultActionsMenu.js.map +2 -2
  79. package/dist-cjs/lib/ui/components/{FollowingIndicator.js → DefaultFollowingIndicator.js} +6 -6
  80. package/dist-cjs/lib/ui/components/DefaultFollowingIndicator.js.map +7 -0
  81. package/dist-cjs/lib/ui/components/DefaultMenuPanel.js +3 -2
  82. package/dist-cjs/lib/ui/components/DefaultMenuPanel.js.map +2 -2
  83. package/dist-cjs/lib/ui/components/KeyboardShortcutsDialog/DefaultKeyboardShortcutsDialogContent.js +6 -6
  84. package/dist-cjs/lib/ui/components/KeyboardShortcutsDialog/DefaultKeyboardShortcutsDialogContent.js.map +1 -1
  85. package/dist-cjs/lib/ui/components/LanguageMenu.js +1 -0
  86. package/dist-cjs/lib/ui/components/LanguageMenu.js.map +2 -2
  87. package/dist-cjs/lib/ui/components/MainMenu/DefaultMainMenuContent.js +3 -3
  88. package/dist-cjs/lib/ui/components/MainMenu/DefaultMainMenuContent.js.map +2 -2
  89. package/dist-cjs/lib/ui/components/Minimap/DefaultMinimap.js +2 -1
  90. package/dist-cjs/lib/ui/components/Minimap/DefaultMinimap.js.map +2 -2
  91. package/dist-cjs/lib/ui/components/Minimap/MinimapManager.js +4 -4
  92. package/dist-cjs/lib/ui/components/Minimap/MinimapManager.js.map +2 -2
  93. package/dist-cjs/lib/ui/components/MobileStylePanel.js +5 -3
  94. package/dist-cjs/lib/ui/components/MobileStylePanel.js.map +2 -2
  95. package/dist-cjs/lib/ui/components/NavigationPanel/DefaultNavigationPanel.js +1 -1
  96. package/dist-cjs/lib/ui/components/NavigationPanel/DefaultNavigationPanel.js.map +2 -2
  97. package/dist-cjs/lib/ui/components/PageMenu/DefaultPageMenu.js +3 -2
  98. package/dist-cjs/lib/ui/components/PageMenu/DefaultPageMenu.js.map +2 -2
  99. package/dist-cjs/lib/ui/components/SharePanel/PeopleMenuItem.js +3 -2
  100. package/dist-cjs/lib/ui/components/SharePanel/PeopleMenuItem.js.map +2 -2
  101. package/dist-cjs/lib/ui/components/SharePanel/UserPresenceColorPicker.js +2 -2
  102. package/dist-cjs/lib/ui/components/SharePanel/UserPresenceColorPicker.js.map +2 -2
  103. package/dist-cjs/lib/ui/components/StylePanel/DefaultStylePanel.js +11 -4
  104. package/dist-cjs/lib/ui/components/StylePanel/DefaultStylePanel.js.map +2 -2
  105. package/dist-cjs/lib/ui/components/StylePanel/DefaultStylePanelContent.js +249 -279
  106. package/dist-cjs/lib/ui/components/StylePanel/DefaultStylePanelContent.js.map +2 -2
  107. package/dist-cjs/lib/ui/components/StylePanel/StylePanelButtonPicker.js +147 -0
  108. package/dist-cjs/lib/ui/components/StylePanel/StylePanelButtonPicker.js.map +7 -0
  109. package/dist-cjs/lib/ui/components/StylePanel/StylePanelContext.js +68 -0
  110. package/dist-cjs/lib/ui/components/StylePanel/StylePanelContext.js.map +7 -0
  111. package/dist-cjs/lib/ui/components/StylePanel/{DoubleDropdownPicker.js → StylePanelDoubleDropdownPicker.js} +26 -25
  112. package/dist-cjs/lib/ui/components/StylePanel/StylePanelDoubleDropdownPicker.js.map +7 -0
  113. package/dist-cjs/lib/ui/components/StylePanel/{DropdownPicker.js → StylePanelDropdownPicker.js} +47 -43
  114. package/dist-cjs/lib/ui/components/StylePanel/StylePanelDropdownPicker.js.map +7 -0
  115. package/dist-cjs/lib/ui/components/StylePanel/StylePanelSubheading.js +28 -0
  116. package/dist-cjs/lib/ui/components/StylePanel/StylePanelSubheading.js.map +7 -0
  117. package/dist-cjs/lib/ui/components/Toolbar/AltTextEditor.js +2 -0
  118. package/dist-cjs/lib/ui/components/Toolbar/AltTextEditor.js.map +2 -2
  119. package/dist-cjs/lib/ui/components/Toolbar/DefaultImageToolbarContent.js +39 -10
  120. package/dist-cjs/lib/ui/components/Toolbar/DefaultImageToolbarContent.js.map +2 -2
  121. package/dist-cjs/lib/ui/components/Toolbar/DefaultToolbar.js +66 -21
  122. package/dist-cjs/lib/ui/components/Toolbar/DefaultToolbar.js.map +3 -3
  123. package/dist-cjs/lib/ui/components/Toolbar/DefaultVideoToolbarContent.js +15 -3
  124. package/dist-cjs/lib/ui/components/Toolbar/DefaultVideoToolbarContent.js.map +2 -2
  125. package/dist-cjs/lib/ui/components/Toolbar/LinkEditor.js +2 -1
  126. package/dist-cjs/lib/ui/components/Toolbar/LinkEditor.js.map +2 -2
  127. package/dist-cjs/lib/ui/components/Toolbar/OverflowingToolbar.js +189 -80
  128. package/dist-cjs/lib/ui/components/Toolbar/OverflowingToolbar.js.map +3 -3
  129. package/dist-cjs/lib/ui/components/Toolbar/ToggleToolLockedButton.js +10 -5
  130. package/dist-cjs/lib/ui/components/Toolbar/ToggleToolLockedButton.js.map +2 -2
  131. package/dist-cjs/lib/ui/components/menu-items.js +6 -0
  132. package/dist-cjs/lib/ui/components/menu-items.js.map +2 -2
  133. package/dist-cjs/lib/ui/components/primitives/TldrawUiContextualToolbar.js +11 -2
  134. package/dist-cjs/lib/ui/components/primitives/TldrawUiContextualToolbar.js.map +2 -2
  135. package/dist-cjs/lib/ui/components/primitives/TldrawUiInput.js +5 -3
  136. package/dist-cjs/lib/ui/components/primitives/TldrawUiInput.js.map +2 -2
  137. package/dist-cjs/lib/ui/components/primitives/TldrawUiPopover.js +3 -2
  138. package/dist-cjs/lib/ui/components/primitives/TldrawUiPopover.js.map +3 -3
  139. package/dist-cjs/lib/ui/components/primitives/TldrawUiSlider.js +18 -5
  140. package/dist-cjs/lib/ui/components/primitives/TldrawUiSlider.js.map +2 -2
  141. package/dist-cjs/lib/ui/components/primitives/TldrawUiToolbar.js +33 -7
  142. package/dist-cjs/lib/ui/components/primitives/TldrawUiToolbar.js.map +2 -2
  143. package/dist-cjs/lib/ui/components/primitives/TldrawUiTooltip.js +306 -0
  144. package/dist-cjs/lib/ui/components/primitives/TldrawUiTooltip.js.map +7 -0
  145. package/dist-cjs/lib/ui/components/primitives/layout.js +76 -0
  146. package/dist-cjs/lib/ui/components/primitives/layout.js.map +7 -0
  147. package/dist-cjs/lib/ui/components/primitives/menus/TldrawUiMenuCheckboxItem.js +3 -0
  148. package/dist-cjs/lib/ui/components/primitives/menus/TldrawUiMenuCheckboxItem.js.map +2 -2
  149. package/dist-cjs/lib/ui/components/primitives/menus/TldrawUiMenuContext.js.map +2 -2
  150. package/dist-cjs/lib/ui/components/primitives/menus/TldrawUiMenuGroup.js +25 -12
  151. package/dist-cjs/lib/ui/components/primitives/menus/TldrawUiMenuGroup.js.map +2 -2
  152. package/dist-cjs/lib/ui/components/primitives/menus/TldrawUiMenuItem.js +154 -20
  153. package/dist-cjs/lib/ui/components/primitives/menus/TldrawUiMenuItem.js.map +2 -2
  154. package/dist-cjs/lib/ui/context/TldrawUiContextProvider.js +3 -2
  155. package/dist-cjs/lib/ui/context/TldrawUiContextProvider.js.map +2 -2
  156. package/dist-cjs/lib/ui/context/actions.js +44 -10
  157. package/dist-cjs/lib/ui/context/actions.js.map +2 -2
  158. package/dist-cjs/lib/ui/context/components.js +2 -0
  159. package/dist-cjs/lib/ui/context/components.js.map +2 -2
  160. package/dist-cjs/lib/ui/context/events.js.map +2 -2
  161. package/dist-cjs/lib/ui/hooks/useClipboardEvents.js +1 -1
  162. package/dist-cjs/lib/ui/hooks/useClipboardEvents.js.map +2 -2
  163. package/dist-cjs/lib/ui/hooks/useExportAs.js +3 -2
  164. package/dist-cjs/lib/ui/hooks/useExportAs.js.map +2 -2
  165. package/dist-cjs/lib/ui/hooks/useTools.js +94 -9
  166. package/dist-cjs/lib/ui/hooks/useTools.js.map +2 -2
  167. package/dist-cjs/lib/ui/hooks/useTranslation/TLUiTranslationKey.js.map +1 -1
  168. package/dist-cjs/lib/ui/hooks/useTranslation/defaultTranslation.js +8 -1
  169. package/dist-cjs/lib/ui/hooks/useTranslation/defaultTranslation.js.map +2 -2
  170. package/dist-cjs/lib/ui/kbd-utils.js +9 -3
  171. package/dist-cjs/lib/ui/kbd-utils.js.map +2 -2
  172. package/dist-cjs/lib/ui/version.js +3 -3
  173. package/dist-cjs/lib/ui/version.js.map +1 -1
  174. package/dist-cjs/lib/utils/export/copyAs.js +1 -2
  175. package/dist-cjs/lib/utils/export/copyAs.js.map +2 -2
  176. package/dist-cjs/lib/utils/export/export.js +0 -20
  177. package/dist-cjs/lib/utils/export/export.js.map +2 -2
  178. package/dist-cjs/lib/utils/export/exportAs.js +1 -2
  179. package/dist-cjs/lib/utils/export/exportAs.js.map +2 -2
  180. package/dist-esm/index.d.mts +443 -112
  181. package/dist-esm/index.mjs +93 -29
  182. package/dist-esm/index.mjs.map +2 -2
  183. package/dist-esm/lib/Tldraw.mjs +14 -4
  184. package/dist-esm/lib/Tldraw.mjs.map +2 -2
  185. package/dist-esm/lib/canvas/TldrawScribble.mjs +1 -1
  186. package/dist-esm/lib/canvas/TldrawScribble.mjs.map +2 -2
  187. package/dist-esm/lib/defaultExternalContentHandlers.mjs +15 -4
  188. package/dist-esm/lib/defaultExternalContentHandlers.mjs.map +2 -2
  189. package/dist-esm/lib/shapes/arrow/ArrowShapeUtil.mjs +4 -3
  190. package/dist-esm/lib/shapes/arrow/ArrowShapeUtil.mjs.map +2 -2
  191. package/dist-esm/lib/shapes/arrow/arrowLabel.mjs +6 -0
  192. package/dist-esm/lib/shapes/arrow/arrowLabel.mjs.map +3 -3
  193. package/dist-esm/lib/shapes/arrow/arrowTargetState.mjs +4 -3
  194. package/dist-esm/lib/shapes/arrow/arrowTargetState.mjs.map +2 -2
  195. package/dist-esm/lib/shapes/arrow/elbow/ElbowArrowDebug.mjs +3 -3
  196. package/dist-esm/lib/shapes/arrow/elbow/ElbowArrowDebug.mjs.map +1 -1
  197. package/dist-esm/lib/shapes/bookmark/BookmarkShapeUtil.mjs +4 -5
  198. package/dist-esm/lib/shapes/bookmark/BookmarkShapeUtil.mjs.map +2 -2
  199. package/dist-esm/lib/shapes/draw/DrawShapeUtil.mjs +4 -3
  200. package/dist-esm/lib/shapes/draw/DrawShapeUtil.mjs.map +2 -2
  201. package/dist-esm/lib/shapes/embed/EmbedShapeUtil.mjs +1 -1
  202. package/dist-esm/lib/shapes/embed/EmbedShapeUtil.mjs.map +1 -1
  203. package/dist-esm/lib/shapes/frame/FrameShapeUtil.mjs +21 -13
  204. package/dist-esm/lib/shapes/frame/FrameShapeUtil.mjs.map +2 -2
  205. package/dist-esm/lib/shapes/frame/components/FrameHeading.mjs +1 -1
  206. package/dist-esm/lib/shapes/frame/components/FrameHeading.mjs.map +2 -2
  207. package/dist-esm/lib/shapes/frame/components/FrameLabelInput.mjs +9 -3
  208. package/dist-esm/lib/shapes/frame/components/FrameLabelInput.mjs.map +2 -2
  209. package/dist-esm/lib/shapes/geo/GeoShapeUtil.mjs +4 -2
  210. package/dist-esm/lib/shapes/geo/GeoShapeUtil.mjs.map +2 -2
  211. package/dist-esm/lib/shapes/geo/components/GeoShapeBody.mjs +2 -1
  212. package/dist-esm/lib/shapes/geo/components/GeoShapeBody.mjs.map +2 -2
  213. package/dist-esm/lib/shapes/highlight/HighlightShapeUtil.mjs +6 -1
  214. package/dist-esm/lib/shapes/highlight/HighlightShapeUtil.mjs.map +2 -2
  215. package/dist-esm/lib/shapes/image/ImageShapeUtil.mjs +6 -3
  216. package/dist-esm/lib/shapes/image/ImageShapeUtil.mjs.map +2 -2
  217. package/dist-esm/lib/shapes/line/LineShapeUtil.mjs +6 -1
  218. package/dist-esm/lib/shapes/line/LineShapeUtil.mjs.map +2 -2
  219. package/dist-esm/lib/shapes/note/NoteShapeUtil.mjs +7 -5
  220. package/dist-esm/lib/shapes/note/NoteShapeUtil.mjs.map +2 -2
  221. package/dist-esm/lib/shapes/shared/HyperlinkButton.mjs +5 -5
  222. package/dist-esm/lib/shapes/shared/HyperlinkButton.mjs.map +2 -2
  223. package/dist-esm/lib/shapes/shared/PlainTextLabel.mjs +1 -3
  224. package/dist-esm/lib/shapes/shared/PlainTextLabel.mjs.map +2 -2
  225. package/dist-esm/lib/shapes/shared/ShapeFill.mjs +5 -4
  226. package/dist-esm/lib/shapes/shared/ShapeFill.mjs.map +2 -2
  227. package/dist-esm/lib/shapes/shared/freehand/svg.mjs.map +2 -2
  228. package/dist-esm/lib/shapes/shared/useEditablePlainText.mjs +3 -6
  229. package/dist-esm/lib/shapes/shared/useEditablePlainText.mjs.map +2 -2
  230. package/dist-esm/lib/shapes/shared/useImageOrVideoAsset.mjs +0 -2
  231. package/dist-esm/lib/shapes/shared/useImageOrVideoAsset.mjs.map +2 -2
  232. package/dist-esm/lib/shapes/shared/usePrefersReducedMotion.mjs +10 -1
  233. package/dist-esm/lib/shapes/shared/usePrefersReducedMotion.mjs.map +2 -2
  234. package/dist-esm/lib/shapes/text/PlainTextArea.mjs +4 -3
  235. package/dist-esm/lib/shapes/text/PlainTextArea.mjs.map +2 -2
  236. package/dist-esm/lib/shapes/text/RichTextArea.mjs +3 -4
  237. package/dist-esm/lib/shapes/text/RichTextArea.mjs.map +2 -2
  238. package/dist-esm/lib/shapes/text/TextShapeUtil.mjs +3 -2
  239. package/dist-esm/lib/shapes/text/TextShapeUtil.mjs.map +2 -2
  240. package/dist-esm/lib/shapes/video/VideoShapeUtil.mjs +3 -3
  241. package/dist-esm/lib/shapes/video/VideoShapeUtil.mjs.map +1 -1
  242. package/dist-esm/lib/tools/EraserTool/childStates/Erasing.mjs +26 -1
  243. package/dist-esm/lib/tools/EraserTool/childStates/Erasing.mjs.map +2 -2
  244. package/dist-esm/lib/tools/EraserTool/childStates/Pointing.mjs +13 -0
  245. package/dist-esm/lib/tools/EraserTool/childStates/Pointing.mjs.map +2 -2
  246. package/dist-esm/lib/tools/SelectTool/childStates/Translating.mjs.map +2 -2
  247. package/dist-esm/lib/ui/TldrawUi.mjs +29 -14
  248. package/dist-esm/lib/ui/TldrawUi.mjs.map +3 -3
  249. package/dist-esm/lib/ui/assetUrls.mjs +13 -10
  250. package/dist-esm/lib/ui/assetUrls.mjs.map +2 -2
  251. package/dist-esm/lib/ui/components/A11y.mjs +1 -2
  252. package/dist-esm/lib/ui/components/A11y.mjs.map +2 -2
  253. package/dist-esm/lib/ui/components/AccessibilityMenu.mjs +19 -0
  254. package/dist-esm/lib/ui/components/AccessibilityMenu.mjs.map +7 -0
  255. package/dist-esm/lib/ui/components/ActionsMenu/DefaultActionsMenu.mjs +12 -3
  256. package/dist-esm/lib/ui/components/ActionsMenu/DefaultActionsMenu.mjs.map +2 -2
  257. package/dist-esm/lib/ui/components/{FollowingIndicator.mjs → DefaultFollowingIndicator.mjs} +3 -3
  258. package/dist-esm/lib/ui/components/DefaultFollowingIndicator.mjs.map +7 -0
  259. package/dist-esm/lib/ui/components/DefaultMenuPanel.mjs +3 -2
  260. package/dist-esm/lib/ui/components/DefaultMenuPanel.mjs.map +2 -2
  261. package/dist-esm/lib/ui/components/KeyboardShortcutsDialog/DefaultKeyboardShortcutsDialogContent.mjs +6 -6
  262. package/dist-esm/lib/ui/components/KeyboardShortcutsDialog/DefaultKeyboardShortcutsDialogContent.mjs.map +1 -1
  263. package/dist-esm/lib/ui/components/LanguageMenu.mjs +1 -0
  264. package/dist-esm/lib/ui/components/LanguageMenu.mjs.map +2 -2
  265. package/dist-esm/lib/ui/components/MainMenu/DefaultMainMenuContent.mjs +3 -5
  266. package/dist-esm/lib/ui/components/MainMenu/DefaultMainMenuContent.mjs.map +2 -2
  267. package/dist-esm/lib/ui/components/Minimap/DefaultMinimap.mjs +2 -1
  268. package/dist-esm/lib/ui/components/Minimap/DefaultMinimap.mjs.map +2 -2
  269. package/dist-esm/lib/ui/components/Minimap/MinimapManager.mjs +4 -4
  270. package/dist-esm/lib/ui/components/Minimap/MinimapManager.mjs.map +2 -2
  271. package/dist-esm/lib/ui/components/MobileStylePanel.mjs +6 -3
  272. package/dist-esm/lib/ui/components/MobileStylePanel.mjs.map +2 -2
  273. package/dist-esm/lib/ui/components/NavigationPanel/DefaultNavigationPanel.mjs +1 -1
  274. package/dist-esm/lib/ui/components/NavigationPanel/DefaultNavigationPanel.mjs.map +2 -2
  275. package/dist-esm/lib/ui/components/PageMenu/DefaultPageMenu.mjs +3 -3
  276. package/dist-esm/lib/ui/components/PageMenu/DefaultPageMenu.mjs.map +2 -2
  277. package/dist-esm/lib/ui/components/SharePanel/PeopleMenuItem.mjs +3 -2
  278. package/dist-esm/lib/ui/components/SharePanel/PeopleMenuItem.mjs.map +2 -2
  279. package/dist-esm/lib/ui/components/SharePanel/UserPresenceColorPicker.mjs +2 -2
  280. package/dist-esm/lib/ui/components/SharePanel/UserPresenceColorPicker.mjs.map +2 -2
  281. package/dist-esm/lib/ui/components/StylePanel/DefaultStylePanel.mjs +16 -5
  282. package/dist-esm/lib/ui/components/StylePanel/DefaultStylePanel.mjs.map +2 -2
  283. package/dist-esm/lib/ui/components/StylePanel/DefaultStylePanelContent.mjs +251 -283
  284. package/dist-esm/lib/ui/components/StylePanel/DefaultStylePanelContent.mjs.map +2 -2
  285. package/dist-esm/lib/ui/components/StylePanel/StylePanelButtonPicker.mjs +135 -0
  286. package/dist-esm/lib/ui/components/StylePanel/StylePanelButtonPicker.mjs.map +7 -0
  287. package/dist-esm/lib/ui/components/StylePanel/StylePanelContext.mjs +48 -0
  288. package/dist-esm/lib/ui/components/StylePanel/StylePanelContext.mjs.map +7 -0
  289. package/dist-esm/lib/ui/components/StylePanel/{DoubleDropdownPicker.mjs → StylePanelDoubleDropdownPicker.mjs} +23 -22
  290. package/dist-esm/lib/ui/components/StylePanel/StylePanelDoubleDropdownPicker.mjs.map +7 -0
  291. package/dist-esm/lib/ui/components/StylePanel/{DropdownPicker.mjs → StylePanelDropdownPicker.mjs} +44 -40
  292. package/dist-esm/lib/ui/components/StylePanel/StylePanelDropdownPicker.mjs.map +7 -0
  293. package/dist-esm/lib/ui/components/StylePanel/StylePanelSubheading.mjs +8 -0
  294. package/dist-esm/lib/ui/components/StylePanel/StylePanelSubheading.mjs.map +7 -0
  295. package/dist-esm/lib/ui/components/Toolbar/AltTextEditor.mjs +2 -0
  296. package/dist-esm/lib/ui/components/Toolbar/AltTextEditor.mjs.map +2 -2
  297. package/dist-esm/lib/ui/components/Toolbar/DefaultImageToolbarContent.mjs +39 -10
  298. package/dist-esm/lib/ui/components/Toolbar/DefaultImageToolbarContent.mjs.map +2 -2
  299. package/dist-esm/lib/ui/components/Toolbar/DefaultToolbar.mjs +56 -21
  300. package/dist-esm/lib/ui/components/Toolbar/DefaultToolbar.mjs.map +2 -2
  301. package/dist-esm/lib/ui/components/Toolbar/DefaultVideoToolbarContent.mjs +15 -3
  302. package/dist-esm/lib/ui/components/Toolbar/DefaultVideoToolbarContent.mjs.map +2 -2
  303. package/dist-esm/lib/ui/components/Toolbar/LinkEditor.mjs +2 -1
  304. package/dist-esm/lib/ui/components/Toolbar/LinkEditor.mjs.map +2 -2
  305. package/dist-esm/lib/ui/components/Toolbar/OverflowingToolbar.mjs +192 -81
  306. package/dist-esm/lib/ui/components/Toolbar/OverflowingToolbar.mjs.map +3 -3
  307. package/dist-esm/lib/ui/components/Toolbar/ToggleToolLockedButton.mjs +10 -5
  308. package/dist-esm/lib/ui/components/Toolbar/ToggleToolLockedButton.mjs.map +2 -2
  309. package/dist-esm/lib/ui/components/menu-items.mjs +6 -0
  310. package/dist-esm/lib/ui/components/menu-items.mjs.map +2 -2
  311. package/dist-esm/lib/ui/components/primitives/TldrawUiContextualToolbar.mjs +11 -3
  312. package/dist-esm/lib/ui/components/primitives/TldrawUiContextualToolbar.mjs.map +2 -2
  313. package/dist-esm/lib/ui/components/primitives/TldrawUiInput.mjs +6 -4
  314. package/dist-esm/lib/ui/components/primitives/TldrawUiInput.mjs.map +2 -2
  315. package/dist-esm/lib/ui/components/primitives/TldrawUiPopover.mjs +3 -2
  316. package/dist-esm/lib/ui/components/primitives/TldrawUiPopover.mjs.map +2 -2
  317. package/dist-esm/lib/ui/components/primitives/TldrawUiSlider.mjs +18 -5
  318. package/dist-esm/lib/ui/components/primitives/TldrawUiSlider.mjs.map +2 -2
  319. package/dist-esm/lib/ui/components/primitives/TldrawUiToolbar.mjs +33 -7
  320. package/dist-esm/lib/ui/components/primitives/TldrawUiToolbar.mjs.map +2 -2
  321. package/dist-esm/lib/ui/components/primitives/TldrawUiTooltip.mjs +284 -0
  322. package/dist-esm/lib/ui/components/primitives/TldrawUiTooltip.mjs.map +7 -0
  323. package/dist-esm/lib/ui/components/primitives/layout.mjs +46 -0
  324. package/dist-esm/lib/ui/components/primitives/layout.mjs.map +7 -0
  325. package/dist-esm/lib/ui/components/primitives/menus/TldrawUiMenuCheckboxItem.mjs +3 -0
  326. package/dist-esm/lib/ui/components/primitives/menus/TldrawUiMenuCheckboxItem.mjs.map +2 -2
  327. package/dist-esm/lib/ui/components/primitives/menus/TldrawUiMenuContext.mjs.map +2 -2
  328. package/dist-esm/lib/ui/components/primitives/menus/TldrawUiMenuGroup.mjs +25 -12
  329. package/dist-esm/lib/ui/components/primitives/menus/TldrawUiMenuGroup.mjs.map +2 -2
  330. package/dist-esm/lib/ui/components/primitives/menus/TldrawUiMenuItem.mjs +162 -22
  331. package/dist-esm/lib/ui/components/primitives/menus/TldrawUiMenuItem.mjs.map +2 -2
  332. package/dist-esm/lib/ui/context/TldrawUiContextProvider.mjs +3 -2
  333. package/dist-esm/lib/ui/context/TldrawUiContextProvider.mjs.map +2 -2
  334. package/dist-esm/lib/ui/context/actions.mjs +44 -10
  335. package/dist-esm/lib/ui/context/actions.mjs.map +2 -2
  336. package/dist-esm/lib/ui/context/components.mjs +2 -0
  337. package/dist-esm/lib/ui/context/components.mjs.map +2 -2
  338. package/dist-esm/lib/ui/context/events.mjs.map +2 -2
  339. package/dist-esm/lib/ui/hooks/useClipboardEvents.mjs +1 -2
  340. package/dist-esm/lib/ui/hooks/useClipboardEvents.mjs.map +2 -2
  341. package/dist-esm/lib/ui/hooks/useExportAs.mjs +3 -2
  342. package/dist-esm/lib/ui/hooks/useExportAs.mjs.map +2 -2
  343. package/dist-esm/lib/ui/hooks/useTools.mjs +102 -10
  344. package/dist-esm/lib/ui/hooks/useTools.mjs.map +2 -2
  345. package/dist-esm/lib/ui/hooks/useTranslation/defaultTranslation.mjs +8 -1
  346. package/dist-esm/lib/ui/hooks/useTranslation/defaultTranslation.mjs.map +2 -2
  347. package/dist-esm/lib/ui/kbd-utils.mjs +9 -3
  348. package/dist-esm/lib/ui/kbd-utils.mjs.map +2 -2
  349. package/dist-esm/lib/ui/version.mjs +3 -3
  350. package/dist-esm/lib/ui/version.mjs.map +1 -1
  351. package/dist-esm/lib/utils/export/copyAs.mjs +1 -2
  352. package/dist-esm/lib/utils/export/copyAs.mjs.map +2 -2
  353. package/dist-esm/lib/utils/export/export.mjs +0 -20
  354. package/dist-esm/lib/utils/export/export.mjs.map +2 -2
  355. package/dist-esm/lib/utils/export/exportAs.mjs +1 -2
  356. package/dist-esm/lib/utils/export/exportAs.mjs.map +2 -2
  357. package/package.json +11 -34
  358. package/src/index.ts +71 -22
  359. package/src/lib/Tldraw.tsx +15 -2
  360. package/src/lib/canvas/TldrawScribble.tsx +1 -1
  361. package/src/lib/defaultExternalContentHandlers.ts +26 -4
  362. package/src/lib/shapes/arrow/ArrowShapeOptions.test.ts +85 -14
  363. package/src/lib/shapes/arrow/ArrowShapeTool.test.ts +6 -5
  364. package/src/lib/shapes/arrow/ArrowShapeUtil.test.ts +48 -6
  365. package/src/lib/shapes/arrow/ArrowShapeUtil.tsx +4 -3
  366. package/src/lib/shapes/arrow/arrow-types.ts +3 -5
  367. package/src/lib/shapes/arrow/arrowLabel.ts +8 -0
  368. package/src/lib/shapes/arrow/arrowTargetState.ts +36 -4
  369. package/src/lib/shapes/arrow/elbow/ElbowArrowDebug.tsx +3 -3
  370. package/src/lib/shapes/bookmark/BookmarkShapeUtil.tsx +4 -5
  371. package/src/lib/shapes/draw/DrawShapeTool.test.ts +0 -5
  372. package/src/lib/shapes/draw/DrawShapeUtil.tsx +4 -3
  373. package/src/lib/shapes/embed/EmbedShapeUtil.tsx +1 -1
  374. package/src/lib/shapes/frame/FrameShapeUtil.tsx +30 -14
  375. package/src/lib/shapes/frame/components/FrameHeading.tsx +1 -1
  376. package/src/lib/shapes/frame/components/FrameLabelInput.tsx +10 -3
  377. package/src/lib/shapes/geo/GeoShapeUtil.tsx +4 -2
  378. package/src/lib/shapes/geo/components/GeoShapeBody.tsx +2 -2
  379. package/src/lib/shapes/highlight/HighlightShapeUtil.tsx +7 -1
  380. package/src/lib/shapes/image/ImageShapeUtil.tsx +6 -3
  381. package/src/lib/shapes/line/LineShapeUtil.test.tsx +4 -3
  382. package/src/lib/shapes/line/LineShapeUtil.tsx +6 -1
  383. package/src/lib/shapes/line/__snapshots__/LineShapeUtil.test.tsx.snap +2 -2
  384. package/src/lib/shapes/note/NoteShapeUtil.tsx +10 -4
  385. package/src/lib/shapes/shared/HyperlinkButton.tsx +5 -5
  386. package/src/lib/shapes/shared/PlainTextLabel.tsx +0 -6
  387. package/src/lib/shapes/shared/ShapeFill.tsx +5 -4
  388. package/src/lib/shapes/shared/freehand/svg.ts +2 -0
  389. package/src/lib/shapes/shared/useEditablePlainText.ts +3 -10
  390. package/src/lib/shapes/shared/useImageOrVideoAsset.ts +0 -7
  391. package/src/lib/shapes/shared/usePrefersReducedMotion.tsx +11 -1
  392. package/src/lib/shapes/text/PlainTextArea.tsx +4 -3
  393. package/src/lib/shapes/text/RichTextArea.tsx +3 -4
  394. package/src/lib/shapes/text/TextShapeTool.test.ts +6 -5
  395. package/src/lib/shapes/text/TextShapeUtil.tsx +3 -2
  396. package/src/lib/shapes/video/VideoShapeUtil.tsx +3 -3
  397. package/src/lib/tools/EraserTool/childStates/Erasing.ts +34 -1
  398. package/src/lib/tools/EraserTool/childStates/Pointing.ts +20 -0
  399. package/src/lib/tools/SelectTool/childStates/Translating.ts +0 -1
  400. package/src/lib/ui/TldrawUi.tsx +33 -12
  401. package/src/lib/ui/assetUrls.ts +13 -10
  402. package/src/lib/ui/components/A11y.tsx +1 -2
  403. package/src/lib/ui/components/AccessibilityMenu.tsx +20 -0
  404. package/src/lib/ui/components/ActionsMenu/DefaultActionsMenu.tsx +15 -3
  405. package/src/lib/ui/components/{FollowingIndicator.tsx → DefaultFollowingIndicator.tsx} +2 -1
  406. package/src/lib/ui/components/DefaultMenuPanel.tsx +4 -3
  407. package/src/lib/ui/components/KeyboardShortcutsDialog/DefaultKeyboardShortcutsDialogContent.tsx +6 -6
  408. package/src/lib/ui/components/LanguageMenu.tsx +1 -0
  409. package/src/lib/ui/components/MainMenu/DefaultMainMenuContent.tsx +4 -4
  410. package/src/lib/ui/components/Minimap/DefaultMinimap.tsx +2 -1
  411. package/src/lib/ui/components/Minimap/MinimapManager.ts +4 -4
  412. package/src/lib/ui/components/MobileStylePanel.tsx +9 -6
  413. package/src/lib/ui/components/NavigationPanel/DefaultNavigationPanel.tsx +1 -1
  414. package/src/lib/ui/components/PageMenu/DefaultPageMenu.tsx +4 -4
  415. package/src/lib/ui/components/SharePanel/PeopleMenuItem.tsx +4 -3
  416. package/src/lib/ui/components/SharePanel/UserPresenceColorPicker.tsx +3 -3
  417. package/src/lib/ui/components/StylePanel/DefaultStylePanel.tsx +28 -12
  418. package/src/lib/ui/components/StylePanel/DefaultStylePanelContent.tsx +261 -343
  419. package/src/lib/ui/components/{primitives/TldrawUiButtonPicker.tsx → StylePanel/StylePanelButtonPicker.tsx} +73 -50
  420. package/src/lib/ui/components/StylePanel/StylePanelContext.tsx +63 -0
  421. package/src/lib/ui/components/StylePanel/{DoubleDropdownPicker.tsx → StylePanelDoubleDropdownPicker.tsx} +31 -22
  422. package/src/lib/ui/components/StylePanel/StylePanelDropdownPicker.tsx +119 -0
  423. package/src/lib/ui/components/StylePanel/StylePanelSubheading.tsx +9 -0
  424. package/src/lib/ui/components/Toolbar/AltTextEditor.tsx +2 -0
  425. package/src/lib/ui/components/Toolbar/DefaultImageToolbarContent.tsx +33 -16
  426. package/src/lib/ui/components/Toolbar/DefaultToolbar.tsx +55 -23
  427. package/src/lib/ui/components/Toolbar/DefaultVideoToolbarContent.tsx +12 -4
  428. package/src/lib/ui/components/Toolbar/LinkEditor.tsx +1 -0
  429. package/src/lib/ui/components/Toolbar/OverflowingToolbar.tsx +212 -61
  430. package/src/lib/ui/components/Toolbar/ToggleToolLockedButton.tsx +21 -11
  431. package/src/lib/ui/components/menu-items.tsx +8 -0
  432. package/src/lib/ui/components/primitives/TldrawUiContextualToolbar.tsx +7 -3
  433. package/src/lib/ui/components/primitives/TldrawUiInput.tsx +6 -3
  434. package/src/lib/ui/components/primitives/TldrawUiPopover.tsx +4 -2
  435. package/src/lib/ui/components/primitives/TldrawUiSlider.tsx +52 -32
  436. package/src/lib/ui/components/primitives/TldrawUiToolbar.tsx +55 -12
  437. package/src/lib/ui/components/primitives/TldrawUiTooltip.tsx +379 -0
  438. package/src/lib/ui/components/primitives/layout.tsx +107 -0
  439. package/src/lib/ui/components/primitives/menus/TldrawUiMenuCheckboxItem.tsx +4 -0
  440. package/src/lib/ui/components/primitives/menus/TldrawUiMenuContext.tsx +0 -1
  441. package/src/lib/ui/components/primitives/menus/TldrawUiMenuGroup.tsx +29 -16
  442. package/src/lib/ui/components/primitives/menus/TldrawUiMenuItem.tsx +221 -19
  443. package/src/lib/ui/context/TldrawUiContextProvider.tsx +23 -20
  444. package/src/lib/ui/context/actions.tsx +51 -10
  445. package/src/lib/ui/context/components.tsx +3 -0
  446. package/src/lib/ui/context/events.tsx +3 -1
  447. package/src/lib/ui/hooks/useClipboardEvents.ts +1 -2
  448. package/src/lib/ui/hooks/useExportAs.ts +3 -2
  449. package/src/lib/ui/hooks/useTools.tsx +140 -10
  450. package/src/lib/ui/hooks/useTranslation/TLUiTranslationKey.ts +7 -0
  451. package/src/lib/ui/hooks/useTranslation/defaultTranslation.ts +8 -1
  452. package/src/lib/ui/kbd-utils.ts +10 -3
  453. package/src/lib/ui/version.ts +3 -3
  454. package/src/lib/ui.css +438 -293
  455. package/src/lib/utils/excalidraw/__snapshots__/putExcalidrawContent.test.tsx.snap +5 -5
  456. package/src/lib/utils/export/copyAs.ts +1 -24
  457. package/src/lib/utils/export/export.ts +0 -36
  458. package/src/lib/utils/export/exportAs.ts +1 -32
  459. package/src/lib/utils/tldr/__snapshots__/buildFromV1Document.test.ts.snap +4 -4
  460. package/src/test/A11y.test.tsx +3 -2
  461. package/src/test/ClickManager.test.ts +7 -6
  462. package/src/test/Editor.test.tsx +20 -19
  463. package/src/test/EraserTool.test.ts +184 -13
  464. package/src/test/HandTool.test.ts +10 -9
  465. package/src/test/HighlightShape.test.ts +2 -1
  466. package/src/test/SelectTool.test.ts +3 -2
  467. package/src/test/TLUserPreferences.test.ts +4 -3
  468. package/src/test/TestEditor.ts +13 -15
  469. package/src/test/TldrawEditor.test.tsx +11 -10
  470. package/src/test/ZoomTool.test.ts +7 -6
  471. package/src/test/__snapshots__/drawing.test.ts.snap +2 -2
  472. package/src/test/__snapshots__/groups.test.tsx.snap +6 -6
  473. package/src/test/__snapshots__/resizing.test.ts.snap +2 -2
  474. package/src/test/arrows-megabus.test.tsx +17 -10
  475. package/src/test/bindings.test.tsx +24 -37
  476. package/src/test/bookmark-shapes.test.ts +1 -8
  477. package/src/test/commands/__snapshots__/getSvgString.test.ts.snap +23 -7
  478. package/src/test/commands/__snapshots__/packShapes.test.ts.snap +8 -8
  479. package/src/test/commands/__snapshots__/zoomToFit.test.ts.snap +2 -2
  480. package/src/test/commands/alignShapes.test.tsx +25 -24
  481. package/src/test/commands/animationSpeed.test.ts +2 -1
  482. package/src/test/commands/centerOnPoint.test.ts +3 -2
  483. package/src/test/commands/clipboard.test.ts +3 -2
  484. package/src/test/commands/createShapes.test.ts +2 -1
  485. package/src/test/commands/deleteShapes.test.ts +2 -1
  486. package/src/test/commands/distributeShapes.test.tsx +11 -10
  487. package/src/test/commands/getSvgString.test.ts +2 -1
  488. package/src/test/commands/packShapes.test.ts +5 -4
  489. package/src/test/commands/resizeShape.test.ts +2 -1
  490. package/src/test/commands/rotateShapes.test.ts +7 -6
  491. package/src/test/commands/setCamera.test.ts +4 -3
  492. package/src/test/commands/setCurrentPage.test.ts +3 -2
  493. package/src/test/commands/stackShapes.test.ts +11 -10
  494. package/src/test/commands/stretch.test.tsx +13 -12
  495. package/src/test/createDeepLink.test.tsx +2 -1
  496. package/src/test/cropping.test.ts +3 -2
  497. package/src/test/custom-clipping.test.ts +436 -0
  498. package/src/test/drawing.test.ts +2 -1
  499. package/src/test/flipShapes.test.ts +4 -3
  500. package/src/test/frames.test.ts +25 -24
  501. package/src/test/getCulledShapes.test.tsx +74 -4
  502. package/src/test/groups.test.tsx +1 -1
  503. package/src/test/handleDeepLink.test.tsx +2 -1
  504. package/src/test/inner-outer-margin.test.ts +315 -0
  505. package/src/test/maxShapes.test.ts +3 -2
  506. package/src/test/modifiers.test.ts +5 -4
  507. package/src/test/navigation.test.ts +12 -11
  508. package/src/test/panning.test.ts +2 -1
  509. package/src/test/perf/perf.test.ts +2 -1
  510. package/src/test/registerDeepLinkListener.test.tsx +10 -9
  511. package/src/test/resizing.test.ts +39 -38
  512. package/src/test/select.test.tsx +4 -3
  513. package/src/test/selection-omnibus.test.ts +11 -10
  514. package/src/test/shapeutils.test.ts +4 -3
  515. package/src/test/translating.test.ts +9 -8
  516. package/tldraw.css +746 -583
  517. package/dist-cjs/lib/ui/components/FollowingIndicator.js.map +0 -7
  518. package/dist-cjs/lib/ui/components/StylePanel/DoubleDropdownPicker.js.map +0 -7
  519. package/dist-cjs/lib/ui/components/StylePanel/DropdownPicker.js.map +0 -7
  520. package/dist-cjs/lib/ui/components/primitives/TldrawUiButtonPicker.js +0 -142
  521. package/dist-cjs/lib/ui/components/primitives/TldrawUiButtonPicker.js.map +0 -7
  522. package/dist-esm/lib/ui/components/FollowingIndicator.mjs.map +0 -7
  523. package/dist-esm/lib/ui/components/StylePanel/DoubleDropdownPicker.mjs.map +0 -7
  524. package/dist-esm/lib/ui/components/StylePanel/DropdownPicker.mjs.map +0 -7
  525. package/dist-esm/lib/ui/components/primitives/TldrawUiButtonPicker.mjs +0 -115
  526. package/dist-esm/lib/ui/components/primitives/TldrawUiButtonPicker.mjs.map +0 -7
  527. package/src/lib/ui/components/StylePanel/DropdownPicker.tsx +0 -109
@@ -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
 
@@ -27,6 +27,11 @@ import {
27
27
  ElbowArrowSideDeltas,
28
28
  } from './elbow/definitions'
29
29
 
30
+ /**
31
+ * Options passed to {@link updateArrowTargetState}.
32
+ *
33
+ * @public
34
+ */
30
35
  export interface UpdateArrowTargetStateOpts {
31
36
  editor: Editor
32
37
  pointInPageSpace: VecLike
@@ -37,6 +42,13 @@ export interface UpdateArrowTargetStateOpts {
37
42
  oppositeBinding: TLArrowBinding | undefined
38
43
  }
39
44
 
45
+ /**
46
+ * State representing what we're pointing to when drawing or updating an arrow. You can get this
47
+ * state using {@link getArrowTargetState}, and update it as part of an arrow interaction with
48
+ * {@link updateArrowTargetState} or {@link clearArrowTargetState}.
49
+ *
50
+ * @public
51
+ */
40
52
  export interface ArrowTargetState {
41
53
  target: TLShape
42
54
  arrowKind: TLArrowShapeKind
@@ -63,14 +75,32 @@ function getArrowTargetAtom(editor: Editor) {
63
75
  return arrowTargetStore.get(editor, () => atom('arrowTarget', null))
64
76
  }
65
77
 
78
+ /**
79
+ * Get the current arrow target state for an editor. See {@link ArrowTargetState} for more
80
+ * information.
81
+ *
82
+ * @public
83
+ */
66
84
  export function getArrowTargetState(editor: Editor) {
67
85
  return getArrowTargetAtom(editor).get()
68
86
  }
69
87
 
88
+ /**
89
+ * Clear the current arrow target state for an editor. See {@link ArrowTargetState} for more
90
+ * information.
91
+ *
92
+ * @public
93
+ */
70
94
  export function clearArrowTargetState(editor: Editor) {
71
95
  getArrowTargetAtom(editor).set(null)
72
96
  }
73
97
 
98
+ /**
99
+ * Update the current arrow target state for an editor. See {@link ArrowTargetState} for more
100
+ * information.
101
+ *
102
+ * @public
103
+ */
74
104
  export function updateArrowTargetState({
75
105
  editor,
76
106
  pointInPageSpace,
@@ -87,14 +117,12 @@ export function updateArrowTargetState({
87
117
  return null
88
118
  }
89
119
 
90
- const isExact = util.options.shouldBeExact(editor)
91
-
92
120
  const arrowKind = arrow ? arrow.props.kind : editor.getStyleForNextShape(ArrowShapeKindStyle)
93
121
 
94
122
  const target = editor.getShapeAtPoint(pointInPageSpace, {
95
123
  hitInside: true,
96
124
  hitFrameInside: true,
97
- margin: arrowKind === 'elbow' ? 8 : 0,
125
+ margin: arrowKind === 'elbow' ? 8 : [8, 0],
98
126
  filter: (targetShape) => {
99
127
  return (
100
128
  !targetShape.isLocked &&
@@ -165,7 +193,7 @@ export function updateArrowTargetState({
165
193
  }
166
194
  }
167
195
 
168
- let precise = isPrecise || isExact
196
+ let precise = isPrecise
169
197
 
170
198
  if (!precise) {
171
199
  // If we're switching to a new bound shape, then precise only if moving slowly
@@ -186,7 +214,11 @@ export function updateArrowTargetState({
186
214
  }
187
215
  }
188
216
 
217
+ const isExact = util.options.shouldBeExact(editor, precise)
218
+ if (isExact) precise = true
219
+
189
220
  const shouldSnapCenter = !isExact && precise && targetGeometryInTargetSpace.isClosed
221
+ // const shouldSnapEdges = !isExact && (precise || !targetGeometryInTargetSpace.isClosed)
190
222
  const shouldSnapEdges =
191
223
  !isExact && ((precise && arrowKind === 'elbow') || !targetGeometryInTargetSpace.isClosed)
192
224
  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,6 @@ import {
13
13
  debounce,
14
14
  getHashForString,
15
15
  lerp,
16
- stopEventPropagation,
17
16
  tlenv,
18
17
  toDomPrecision,
19
18
  useEditor,
@@ -132,9 +131,9 @@ function BookmarkShapeComponent({ shape }: { shape: TLBookmarkShape }) {
132
131
  const [isFaviconValid, setIsFaviconValid] = useState(true)
133
132
  const onFaviconError = () => setIsFaviconValid(false)
134
133
 
135
- const useStopPropagationOnShiftKey = useCallback<PointerEventHandler>(
134
+ const markAsHandledOnShiftKey = useCallback<PointerEventHandler>(
136
135
  (e) => {
137
- if (!editor.inputs.shiftKey) stopEventPropagation(e)
136
+ if (!editor.inputs.shiftKey) editor.markEventAsHandled(e)
138
137
  },
139
138
  [editor]
140
139
  )
@@ -182,8 +181,8 @@ function BookmarkShapeComponent({ shape }: { shape: TLBookmarkShape }) {
182
181
  target="_blank"
183
182
  rel="noopener noreferrer"
184
183
  draggable={false}
185
- onPointerDown={useStopPropagationOnShiftKey}
186
- onPointerUp={useStopPropagationOnShiftKey}
184
+ onPointerDown={markAsHandledOnShiftKey}
185
+ onPointerUp={markAsHandledOnShiftKey}
187
186
  >
188
187
  {isFaviconValid && asset?.props.favicon ? (
189
188
  <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
  }}
@@ -19,6 +19,7 @@ import {
19
19
  compact,
20
20
  frameShapeMigrations,
21
21
  frameShapeProps,
22
+ getColorValue,
22
23
  getDefaultColorTheme,
23
24
  lerp,
24
25
  resizeBox,
@@ -99,6 +100,10 @@ export class FrameShapeUtil extends BaseBoxShapeUtil<TLFrameShape> {
99
100
  return false
100
101
  }
101
102
 
103
+ override isExportBoundsContainer(): boolean {
104
+ return true
105
+ }
106
+
102
107
  override getDefaultProps(): TLFrameShape['props'] {
103
108
  return { w: 160 * 2, h: 90 * 2, name: '', color: 'black' }
104
109
  }
@@ -191,6 +196,7 @@ export class FrameShapeUtil extends BaseBoxShapeUtil<TLFrameShape> {
191
196
  height,
192
197
  isFilled: true,
193
198
  isLabel: true,
199
+ excludeFromShapeBounds: true,
194
200
  }),
195
201
  ],
196
202
  })
@@ -220,13 +226,16 @@ export class FrameShapeUtil extends BaseBoxShapeUtil<TLFrameShape> {
220
226
  )
221
227
 
222
228
  const showFrameColors = this.options.showColors
223
-
224
- const color = theme[shape.props.color]
225
- const frameFill = showFrameColors ? color.frame.fill : theme.black.frame.fill
226
- const frameStroke = showFrameColors ? color.frame.stroke : theme.black.frame.stroke
227
- const frameHeadingStroke = showFrameColors ? color.frame.headingStroke : theme.background
228
- const frameHeadingFill = showFrameColors ? color.frame.headingFill : theme.background
229
- const frameHeadingText = showFrameColors ? color.frame.text : theme.text
229
+ const colorToUse = showFrameColors ? shape.props.color : 'black'
230
+ const frameFill = getColorValue(theme, colorToUse, 'frameFill')
231
+ const frameStroke = getColorValue(theme, colorToUse, 'frameStroke')
232
+ const frameHeadingStroke = showFrameColors
233
+ ? getColorValue(theme, colorToUse, 'frameHeadingStroke')
234
+ : theme.background
235
+ const frameHeadingFill = showFrameColors
236
+ ? getColorValue(theme, colorToUse, 'frameHeadingFill')
237
+ : theme.background
238
+ const frameHeadingText = getColorValue(theme, colorToUse, 'frameText')
230
239
 
231
240
  return (
232
241
  <>
@@ -277,13 +286,16 @@ export class FrameShapeUtil extends BaseBoxShapeUtil<TLFrameShape> {
277
286
  const text = createTextJsxFromSpans(this.editor, spans, opts)
278
287
 
279
288
  const showFrameColors = this.options.showColors
280
-
281
- const color = theme[shape.props.color]
282
- const frameFill = showFrameColors ? color.frame.fill : theme.black.frame.fill
283
- const frameStroke = showFrameColors ? color.frame.stroke : theme.black.frame.stroke
284
- const frameHeadingStroke = showFrameColors ? color.frame.headingStroke : theme.background
285
- const frameHeadingFill = showFrameColors ? color.frame.headingFill : theme.background
286
- const frameHeadingText = showFrameColors ? color.frame.text : theme.text
289
+ const colorToUse = showFrameColors ? shape.props.color : 'black'
290
+ const frameFill = getColorValue(theme, colorToUse, 'frameFill')
291
+ const frameStroke = getColorValue(theme, colorToUse, 'frameStroke')
292
+ const frameHeadingStroke = showFrameColors
293
+ ? getColorValue(theme, colorToUse, 'frameHeadingStroke')
294
+ : theme.background
295
+ const frameHeadingFill = showFrameColors
296
+ ? getColorValue(theme, colorToUse, 'frameHeadingFill')
297
+ : theme.background
298
+ const frameHeadingText = getColorValue(theme, colorToUse, 'frameText')
287
299
 
288
300
  return (
289
301
  <>
@@ -328,6 +340,10 @@ export class FrameShapeUtil extends BaseBoxShapeUtil<TLFrameShape> {
328
340
  return true
329
341
  }
330
342
 
343
+ override getClipPath(shape: TLFrameShape) {
344
+ return this.editor.getShapeGeometry(shape.id).vertices
345
+ }
346
+
331
347
  override canReceiveNewChildrenOfType(shape: TLShape) {
332
348
  return !shape.isLocked
333
349
  }
@@ -64,7 +64,7 @@ export const FrameHeading = memo(function FrameHeading({
64
64
  overflow: isEditing ? 'visible' : 'hidden',
65
65
  maxWidth: `calc(var(--tl-zoom) * ${
66
66
  side === 0 || side === 2 ? Math.ceil(width) : Math.ceil(height)
67
- }px + ${showColors ? '0px' : 'var(--frame-offset-width)'})`,
67
+ }px + ${showColors ? '0px' : 'var(--tl-frame-offset-width)'})`,
68
68
  bottom: '100%',
69
69
  transform: `${translation} scale(var(--tl-scale)) translateX(${offsetX}px)`,
70
70
  }}
@@ -1,4 +1,4 @@
1
- import { TLFrameShape, TLShapeId, stopEventPropagation, useEditor } from '@tldraw/editor'
1
+ import { TLFrameShape, TLShapeId, useEditor } from '@tldraw/editor'
2
2
  import { forwardRef, useCallback } from 'react'
3
3
  import { defaultEmptyAs } from '../FrameShapeUtil'
4
4
 
@@ -8,12 +8,19 @@ export const FrameLabelInput = forwardRef<
8
8
  >(({ id, name, isEditing }, ref) => {
9
9
  const editor = useEditor()
10
10
 
11
+ const handlePointerDown = useCallback(
12
+ (e: React.PointerEvent) => {
13
+ if (isEditing) editor.markEventAsHandled(e)
14
+ },
15
+ [editor, isEditing]
16
+ )
17
+
11
18
  const handleKeyDown = useCallback(
12
19
  (e: React.KeyboardEvent<HTMLInputElement>) => {
13
20
  if (e.key === 'Enter' && !e.nativeEvent.isComposing) {
14
21
  // need to prevent the enter keydown making it's way up to the Idle state
15
22
  // and sending us back into edit mode
16
- stopEventPropagation(e)
23
+ editor.markEventAsHandled(e)
17
24
  e.currentTarget.blur()
18
25
  editor.setEditingShape(null)
19
26
  }
@@ -74,7 +81,7 @@ export const FrameLabelInput = forwardRef<
74
81
  onKeyDown={handleKeyDown}
75
82
  onBlur={handleBlur}
76
83
  onChange={handleChange}
77
- onPointerDown={isEditing ? stopEventPropagation : undefined}
84
+ onPointerDown={handlePointerDown}
78
85
  draggable={false}
79
86
  />
80
87
  {defaultEmptyAs(name, 'Frame') + String.fromCharCode(8203)}
@@ -18,6 +18,7 @@ import {
18
18
  exhaustiveSwitchError,
19
19
  geoShapeMigrations,
20
20
  geoShapeProps,
21
+ getColorValue,
21
22
  getDefaultColorTheme,
22
23
  getFontsFromRichText,
23
24
  isEqual,
@@ -125,6 +126,7 @@ export class GeoShapeUtil extends BaseBoxShapeUtil<TLGeoShape> {
125
126
  height: unscaledLabelHeight * shape.props.scale,
126
127
  isFilled: true,
127
128
  isLabel: true,
129
+ excludeFromShapeBounds: true,
128
130
  isEmptyLabel: isEmptyRichText(shape.props.richText),
129
131
  }),
130
132
  ],
@@ -220,7 +222,7 @@ export class GeoShapeUtil extends BaseBoxShapeUtil<TLGeoShape> {
220
222
  verticalAlign={verticalAlign}
221
223
  richText={richText}
222
224
  isSelected={isOnlySelected}
223
- labelColor={theme[props.labelColor].solid}
225
+ labelColor={getColorValue(theme, props.labelColor, 'solid')}
224
226
  wrap
225
227
  />
226
228
  </HTMLContainer>
@@ -278,7 +280,7 @@ export class GeoShapeUtil extends BaseBoxShapeUtil<TLGeoShape> {
278
280
  align={props.align}
279
281
  verticalAlign={props.verticalAlign}
280
282
  richText={props.richText}
281
- labelColor={theme[props.labelColor].solid}
283
+ labelColor={getColorValue(theme, props.labelColor, 'solid')}
282
284
  bounds={bounds}
283
285
  padding={LABEL_PADDING}
284
286
  />
@@ -1,4 +1,4 @@
1
- import { TLGeoShape } from '@tldraw/editor'
1
+ import { getColorValue, TLGeoShape } from '@tldraw/editor'
2
2
  import { ShapeFill } from '../../shared/ShapeFill'
3
3
  import { STROKE_SIZES } from '../../shared/default-shape-constants'
4
4
  import { useDefaultColorTheme } from '../../shared/useDefaultColorTheme'
@@ -33,7 +33,7 @@ export function GeoShapeBody({
33
33
  strokeWidth,
34
34
  forceSolid,
35
35
  randomSeed: shape.id,
36
- props: { fill: 'none', stroke: theme[color].solid },
36
+ props: { fill: 'none', stroke: getColorValue(theme, color, 'solid') },
37
37
  })}
38
38
  </>
39
39
  )
@@ -10,6 +10,7 @@ import {
10
10
  TLHighlightShapeProps,
11
11
  TLResizeInfo,
12
12
  VecLike,
13
+ getColorValue,
13
14
  highlightShapeMigrations,
14
15
  highlightShapeProps,
15
16
  last,
@@ -289,7 +290,12 @@ function HighlightRenderer({
289
290
  : getShapeDot(shape.props.segments[0].points[0])
290
291
 
291
292
  const colorSpace = useColorSpace()
292
- const color = theme[shape.props.color].highlight[colorSpace]
293
+
294
+ const color = getColorValue(
295
+ theme,
296
+ shape.props.color,
297
+ colorSpace === 'p3' ? 'highlightP3' : 'highlightSrgb'
298
+ )
293
299
 
294
300
  return (
295
301
  <path
@@ -57,6 +57,9 @@ export class ImageShapeUtil extends BaseBoxShapeUtil<TLImageShape> {
57
57
  override canCrop() {
58
58
  return true
59
59
  }
60
+ override isExportBoundsContainer(): boolean {
61
+ return true
62
+ }
60
63
 
61
64
  override getDefaultProps(): TLImageShape['props'] {
62
65
  return {
@@ -314,9 +317,9 @@ const ImageShape = memo(function ImageShape({ shape }: { shape: TLImageShape })
314
317
  overflow: 'hidden',
315
318
  width: shape.props.w,
316
319
  height: shape.props.h,
317
- color: 'var(--color-text-3)',
318
- backgroundColor: 'var(--color-low)',
319
- border: '1px solid var(--color-low-border)',
320
+ color: 'var(--tl-color-text-3)',
321
+ backgroundColor: 'var(--tl-color-low)',
322
+ border: '1px solid var(--tl-color-low-border)',
320
323
  }}
321
324
  >
322
325
  <div
@@ -7,6 +7,7 @@ import {
7
7
  sortByIndex,
8
8
  structuredClone,
9
9
  } from '@tldraw/editor'
10
+ import { vi } from 'vitest'
10
11
  import { TestEditor } from '../../../test/TestEditor'
11
12
  import { TL } from '../../../test/test-jsx'
12
13
 
@@ -16,7 +17,7 @@ mockUniqueId(() => 'id' + nextId++)
16
17
  let editor: TestEditor
17
18
  const id = createShapeId('line1')
18
19
 
19
- jest.useFakeTimers()
20
+ vi.useFakeTimers()
20
21
 
21
22
  beforeEach(() => {
22
23
  editor = new TestEditor()
@@ -338,12 +339,12 @@ describe('Misc', () => {
338
339
 
339
340
  expect(editor.getShapePageBounds(box)!.maxX).not.toEqual(editor.getShapePageBounds(line)!.maxX)
340
341
  editor.alignShapes(editor.getSelectedShapeIds(), 'right')
341
- jest.advanceTimersByTime(1000)
342
+ vi.advanceTimersByTime(1000)
342
343
  expect(editor.getShapePageBounds(box)!.maxX).toEqual(editor.getShapePageBounds(line)!.maxX)
343
344
 
344
345
  expect(editor.getShapePageBounds(box)!.maxY).not.toEqual(editor.getShapePageBounds(line)!.maxY)
345
346
  editor.alignShapes(editor.getSelectedShapeIds(), 'bottom')
346
- jest.advanceTimersByTime(1000)
347
+ vi.advanceTimersByTime(1000)
347
348
  expect(editor.getShapePageBounds(box)!.maxY).toEqual(editor.getShapePageBounds(line)!.maxY)
348
349
  })
349
350
 
@@ -12,6 +12,7 @@ import {
12
12
  WeakCache,
13
13
  ZERO_INDEX_KEY,
14
14
  assert,
15
+ getColorValue,
15
16
  getIndexAbove,
16
17
  getIndexBetween,
17
18
  getIndices,
@@ -346,6 +347,10 @@ function LineShapeSvg({
346
347
  strokeWidth,
347
348
  forceSolid,
348
349
  randomSeed: shape.id,
349
- props: { transform: `scale(${scale})`, stroke: theme[color].solid, fill: 'none' },
350
+ props: {
351
+ transform: `scale(${scale})`,
352
+ stroke: getColorValue(theme, color, 'solid'),
353
+ fill: 'none',
354
+ },
350
355
  })
351
356
  }
@@ -1,6 +1,6 @@
1
- // Jest Snapshot v1, https://goo.gl/fbAQLP
1
+ // Vitest Snapshot v1, https://vitest.dev/guide/snapshot.html
2
2
 
3
- exports[`Misc resizes: line shape after resize 1`] = `
3
+ exports[`Misc > resizes > line shape after resize 1`] = `
4
4
  {
5
5
  "id": "shape:line1",
6
6
  "index": "a1",
@@ -17,6 +17,7 @@ import {
17
17
  Vec,
18
18
  WeakCache,
19
19
  exhaustiveSwitchError,
20
+ getColorValue,
20
21
  getDefaultColorTheme,
21
22
  getFontsFromRichText,
22
23
  isEqual,
@@ -146,6 +147,7 @@ export class NoteShapeUtil extends ShapeUtil<TLNoteShape> {
146
147
  height: lh,
147
148
  isFilled: true,
148
149
  isLabel: true,
150
+ excludeFromShapeBounds: true,
149
151
  }),
150
152
  ],
151
153
  })
@@ -288,7 +290,7 @@ export class NoteShapeUtil extends ShapeUtil<TLNoteShape> {
288
290
  style={{
289
291
  width: nw,
290
292
  height: nh,
291
- backgroundColor: theme[color].note.fill,
293
+ backgroundColor: getColorValue(theme, color, 'noteFill'),
292
294
  borderBottom: hideShadows
293
295
  ? isDarkMode
294
296
  ? `${2 * scale}px solid rgb(20, 20, 20)`
@@ -308,7 +310,11 @@ export class NoteShapeUtil extends ShapeUtil<TLNoteShape> {
308
310
  verticalAlign={verticalAlign}
309
311
  richText={richText}
310
312
  isSelected={isSelected}
311
- labelColor={labelColor === 'black' ? theme[color].note.text : theme[labelColor].fill}
313
+ labelColor={
314
+ labelColor === 'black'
315
+ ? getColorValue(theme, color, 'noteText')
316
+ : getColorValue(theme, labelColor, 'fill')
317
+ }
312
318
  wrap
313
319
  padding={LABEL_PADDING * scale}
314
320
  hasCustomTabBehavior
@@ -343,7 +349,7 @@ export class NoteShapeUtil extends ShapeUtil<TLNoteShape> {
343
349
  align={shape.props.align}
344
350
  verticalAlign={shape.props.verticalAlign}
345
351
  richText={shape.props.richText}
346
- labelColor={theme[shape.props.color].note.text}
352
+ labelColor={getColorValue(theme, shape.props.color, 'noteText')}
347
353
  bounds={bounds}
348
354
  padding={LABEL_PADDING}
349
355
  showTextOutline={false}
@@ -357,7 +363,7 @@ export class NoteShapeUtil extends ShapeUtil<TLNoteShape> {
357
363
  rx={1}
358
364
  width={NOTE_SIZE}
359
365
  height={bounds.h}
360
- fill={theme[shape.props.color].note.fill}
366
+ fill={getColorValue(theme, shape.props.color, 'noteFill')}
361
367
  />
362
368
  {textLabel}
363
369
  </>
@@ -1,4 +1,4 @@
1
- import { stopEventPropagation, useEditor, useValue } from '@tldraw/editor'
1
+ import { useEditor, useValue } from '@tldraw/editor'
2
2
  import classNames from 'classnames'
3
3
  import { PointerEventHandler, useCallback } from 'react'
4
4
 
@@ -8,9 +8,9 @@ const LINK_ICON =
8
8
  export function HyperlinkButton({ url }: { url: string }) {
9
9
  const editor = useEditor()
10
10
  const hideButton = useValue('zoomLevel', () => editor.getZoomLevel() < 0.32, [editor])
11
- const useStopPropagationOnShiftKey = useCallback<PointerEventHandler>(
11
+ const markAsHandledOnShiftKey = useCallback<PointerEventHandler>(
12
12
  (e) => {
13
- if (!editor.inputs.shiftKey) stopEventPropagation(e)
13
+ if (!editor.inputs.shiftKey) editor.markEventAsHandled(e)
14
14
  },
15
15
  [editor]
16
16
  )
@@ -22,8 +22,8 @@ export function HyperlinkButton({ url }: { url: string }) {
22
22
  href={url}
23
23
  target="_blank"
24
24
  rel="noopener noreferrer"
25
- onPointerDown={useStopPropagationOnShiftKey}
26
- onPointerUp={useStopPropagationOnShiftKey}
25
+ onPointerDown={markAsHandledOnShiftKey}
26
+ onPointerUp={markAsHandledOnShiftKey}
27
27
  title={url}
28
28
  draggable={false}
29
29
  >
@@ -130,9 +130,3 @@ export const PlainTextLabel = React.memo(function PlainTextLabel({
130
130
  </div>
131
131
  )
132
132
  })
133
-
134
- /**
135
- * @deprecated Use `PlainTextLabel` instead.
136
- * @public
137
- */
138
- export const TextLabel = PlainTextLabel
@@ -1,4 +1,5 @@
1
1
  import {
2
+ getColorValue,
2
3
  TLDefaultColorStyle,
3
4
  TLDefaultColorTheme,
4
5
  TLDefaultFillStyle,
@@ -29,13 +30,13 @@ export const ShapeFill = React.memo(function ShapeFill({
29
30
  return null
30
31
  }
31
32
  case 'solid': {
32
- return <path fill={theme[color].semi} d={d} />
33
+ return <path fill={getColorValue(theme, color, 'semi')} d={d} />
33
34
  }
34
35
  case 'semi': {
35
36
  return <path fill={theme.solid} d={d} />
36
37
  }
37
38
  case 'fill': {
38
- return <path fill={theme[color].fill} d={d} />
39
+ return <path fill={getColorValue(theme, color, 'fill')} d={d} />
39
40
  }
40
41
  case 'pattern': {
41
42
  return <PatternFill theme={theme} color={color} fill={fill} d={d} scale={scale} />
@@ -53,13 +54,13 @@ export function PatternFill({ d, color, theme }: ShapeFillProps) {
53
54
 
54
55
  return (
55
56
  <>
56
- <path fill={theme[color].pattern} d={d} />
57
+ <path fill={getColorValue(theme, color, 'pattern')} d={d} />
57
58
  <path
58
59
  fill={
59
60
  svgExport
60
61
  ? `url(#${getHashPatternZoomName(1, theme.id)})`
61
62
  : teenyTiny
62
- ? theme[color].semi
63
+ ? getColorValue(theme, color, 'semi')
63
64
  : `url(#${getHashPatternZoomName(zoomLevel, theme.id)})`
64
65
  }
65
66
  d={d}
@@ -6,6 +6,8 @@ import { StrokePoint } from './types'
6
6
  *
7
7
  * @param points - The stroke points returned from perfect-freehand
8
8
  * @param closed - Whether the shape is closed
9
+ *
10
+ * @public
9
11
  */
10
12
  export function getSvgPathFromStrokePoints(points: StrokePoint[], closed = false): string {
11
13
  const len = points.length