tldraw 3.16.0-canary.dfdf6b7de8c2 → 3.16.0-canary.e1b1e53d3c16

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 (365) hide show
  1. package/dist-cjs/index.d.ts +181 -5
  2. package/dist-cjs/index.js +18 -1
  3. package/dist-cjs/index.js.map +2 -2
  4. package/dist-cjs/lib/canvas/TldrawScribble.js +1 -1
  5. package/dist-cjs/lib/canvas/TldrawScribble.js.map +2 -2
  6. package/dist-cjs/lib/defaultExternalContentHandlers.js +5 -4
  7. package/dist-cjs/lib/defaultExternalContentHandlers.js.map +2 -2
  8. package/dist-cjs/lib/shapes/arrow/ArrowShapeUtil.js +3 -3
  9. package/dist-cjs/lib/shapes/arrow/ArrowShapeUtil.js.map +2 -2
  10. package/dist-cjs/lib/shapes/arrow/arrowTargetState.js +1 -1
  11. package/dist-cjs/lib/shapes/arrow/arrowTargetState.js.map +2 -2
  12. package/dist-cjs/lib/shapes/arrow/elbow/ElbowArrowDebug.js +3 -3
  13. package/dist-cjs/lib/shapes/arrow/elbow/ElbowArrowDebug.js.map +1 -1
  14. package/dist-cjs/lib/shapes/draw/DrawShapeUtil.js +3 -3
  15. package/dist-cjs/lib/shapes/draw/DrawShapeUtil.js.map +2 -2
  16. package/dist-cjs/lib/shapes/embed/EmbedShapeUtil.js +1 -1
  17. package/dist-cjs/lib/shapes/embed/EmbedShapeUtil.js.map +1 -1
  18. package/dist-cjs/lib/shapes/frame/FrameShapeUtil.js +12 -12
  19. package/dist-cjs/lib/shapes/frame/FrameShapeUtil.js.map +2 -2
  20. package/dist-cjs/lib/shapes/frame/components/FrameHeading.js +1 -1
  21. package/dist-cjs/lib/shapes/frame/components/FrameHeading.js.map +2 -2
  22. package/dist-cjs/lib/shapes/geo/GeoShapeUtil.js +2 -2
  23. package/dist-cjs/lib/shapes/geo/GeoShapeUtil.js.map +2 -2
  24. package/dist-cjs/lib/shapes/geo/components/GeoShapeBody.js +2 -1
  25. package/dist-cjs/lib/shapes/geo/components/GeoShapeBody.js.map +2 -2
  26. package/dist-cjs/lib/shapes/highlight/HighlightShapeUtil.js +5 -1
  27. package/dist-cjs/lib/shapes/highlight/HighlightShapeUtil.js.map +2 -2
  28. package/dist-cjs/lib/shapes/image/ImageShapeUtil.js +3 -3
  29. package/dist-cjs/lib/shapes/image/ImageShapeUtil.js.map +1 -1
  30. package/dist-cjs/lib/shapes/line/LineShapeUtil.js +5 -1
  31. package/dist-cjs/lib/shapes/line/LineShapeUtil.js.map +2 -2
  32. package/dist-cjs/lib/shapes/note/NoteShapeUtil.js +4 -4
  33. package/dist-cjs/lib/shapes/note/NoteShapeUtil.js.map +2 -2
  34. package/dist-cjs/lib/shapes/shared/ShapeFill.js +4 -4
  35. package/dist-cjs/lib/shapes/shared/ShapeFill.js.map +2 -2
  36. package/dist-cjs/lib/shapes/shared/freehand/svg.js.map +2 -2
  37. package/dist-cjs/lib/shapes/shared/usePrefersReducedMotion.js +10 -1
  38. package/dist-cjs/lib/shapes/shared/usePrefersReducedMotion.js.map +2 -2
  39. package/dist-cjs/lib/shapes/text/TextShapeUtil.js +2 -2
  40. package/dist-cjs/lib/shapes/text/TextShapeUtil.js.map +2 -2
  41. package/dist-cjs/lib/shapes/video/VideoShapeUtil.js +3 -3
  42. package/dist-cjs/lib/shapes/video/VideoShapeUtil.js.map +1 -1
  43. package/dist-cjs/lib/tools/EraserTool/childStates/Erasing.js +25 -1
  44. package/dist-cjs/lib/tools/EraserTool/childStates/Erasing.js.map +2 -2
  45. package/dist-cjs/lib/tools/EraserTool/childStates/Pointing.js +12 -0
  46. package/dist-cjs/lib/tools/EraserTool/childStates/Pointing.js.map +2 -2
  47. package/dist-cjs/lib/ui/TldrawUi.js +14 -0
  48. package/dist-cjs/lib/ui/TldrawUi.js.map +3 -3
  49. package/dist-cjs/lib/ui/assetUrls.js +13 -10
  50. package/dist-cjs/lib/ui/assetUrls.js.map +2 -2
  51. package/dist-cjs/lib/ui/components/AccessibilityMenu.js +35 -0
  52. package/dist-cjs/lib/ui/components/AccessibilityMenu.js.map +7 -0
  53. package/dist-cjs/lib/ui/components/ActionsMenu/DefaultActionsMenu.js +12 -3
  54. package/dist-cjs/lib/ui/components/ActionsMenu/DefaultActionsMenu.js.map +2 -2
  55. package/dist-cjs/lib/ui/components/DefaultMenuPanel.js +3 -2
  56. package/dist-cjs/lib/ui/components/DefaultMenuPanel.js.map +2 -2
  57. package/dist-cjs/lib/ui/components/KeyboardShortcutsDialog/DefaultKeyboardShortcutsDialogContent.js +1 -1
  58. package/dist-cjs/lib/ui/components/KeyboardShortcutsDialog/DefaultKeyboardShortcutsDialogContent.js.map +1 -1
  59. package/dist-cjs/lib/ui/components/MainMenu/DefaultMainMenuContent.js +3 -3
  60. package/dist-cjs/lib/ui/components/MainMenu/DefaultMainMenuContent.js.map +2 -2
  61. package/dist-cjs/lib/ui/components/Minimap/MinimapManager.js +4 -4
  62. package/dist-cjs/lib/ui/components/Minimap/MinimapManager.js.map +2 -2
  63. package/dist-cjs/lib/ui/components/MobileStylePanel.js +5 -3
  64. package/dist-cjs/lib/ui/components/MobileStylePanel.js.map +2 -2
  65. package/dist-cjs/lib/ui/components/NavigationPanel/DefaultNavigationPanel.js +1 -1
  66. package/dist-cjs/lib/ui/components/NavigationPanel/DefaultNavigationPanel.js.map +2 -2
  67. package/dist-cjs/lib/ui/components/PageMenu/DefaultPageMenu.js +2 -1
  68. package/dist-cjs/lib/ui/components/PageMenu/DefaultPageMenu.js.map +2 -2
  69. package/dist-cjs/lib/ui/components/SharePanel/PeopleMenuItem.js +3 -2
  70. package/dist-cjs/lib/ui/components/SharePanel/PeopleMenuItem.js.map +2 -2
  71. package/dist-cjs/lib/ui/components/SharePanel/UserPresenceColorPicker.js +2 -2
  72. package/dist-cjs/lib/ui/components/SharePanel/UserPresenceColorPicker.js.map +2 -2
  73. package/dist-cjs/lib/ui/components/StylePanel/DefaultStylePanel.js +2 -0
  74. package/dist-cjs/lib/ui/components/StylePanel/DefaultStylePanel.js.map +2 -2
  75. package/dist-cjs/lib/ui/components/StylePanel/DefaultStylePanelContent.js +171 -140
  76. package/dist-cjs/lib/ui/components/StylePanel/DefaultStylePanelContent.js.map +2 -2
  77. package/dist-cjs/lib/ui/components/StylePanel/DoubleDropdownPicker.js +3 -3
  78. package/dist-cjs/lib/ui/components/StylePanel/DoubleDropdownPicker.js.map +2 -2
  79. package/dist-cjs/lib/ui/components/StylePanel/DropdownPicker.js +26 -25
  80. package/dist-cjs/lib/ui/components/StylePanel/DropdownPicker.js.map +3 -3
  81. package/dist-cjs/lib/ui/components/Toolbar/DefaultImageToolbarContent.js +1 -1
  82. package/dist-cjs/lib/ui/components/Toolbar/DefaultImageToolbarContent.js.map +2 -2
  83. package/dist-cjs/lib/ui/components/Toolbar/DefaultToolbar.js +66 -21
  84. package/dist-cjs/lib/ui/components/Toolbar/DefaultToolbar.js.map +3 -3
  85. package/dist-cjs/lib/ui/components/Toolbar/OverflowingToolbar.js +189 -80
  86. package/dist-cjs/lib/ui/components/Toolbar/OverflowingToolbar.js.map +3 -3
  87. package/dist-cjs/lib/ui/components/Toolbar/ToggleToolLockedButton.js +5 -4
  88. package/dist-cjs/lib/ui/components/Toolbar/ToggleToolLockedButton.js.map +2 -2
  89. package/dist-cjs/lib/ui/components/menu-items.js +6 -0
  90. package/dist-cjs/lib/ui/components/menu-items.js.map +2 -2
  91. package/dist-cjs/lib/ui/components/primitives/TldrawUiButtonPicker.js +5 -16
  92. package/dist-cjs/lib/ui/components/primitives/TldrawUiButtonPicker.js.map +3 -3
  93. package/dist-cjs/lib/ui/components/primitives/TldrawUiContextualToolbar.js +1 -1
  94. package/dist-cjs/lib/ui/components/primitives/TldrawUiContextualToolbar.js.map +2 -2
  95. package/dist-cjs/lib/ui/components/primitives/TldrawUiPopover.js +3 -2
  96. package/dist-cjs/lib/ui/components/primitives/TldrawUiPopover.js.map +3 -3
  97. package/dist-cjs/lib/ui/components/primitives/TldrawUiToolbar.js +30 -7
  98. package/dist-cjs/lib/ui/components/primitives/TldrawUiToolbar.js.map +2 -2
  99. package/dist-cjs/lib/ui/components/primitives/TldrawUiTooltip.js +262 -0
  100. package/dist-cjs/lib/ui/components/primitives/TldrawUiTooltip.js.map +7 -0
  101. package/dist-cjs/lib/ui/components/primitives/layout.js +76 -0
  102. package/dist-cjs/lib/ui/components/primitives/layout.js.map +7 -0
  103. package/dist-cjs/lib/ui/components/primitives/menus/TldrawUiMenuContext.js.map +2 -2
  104. package/dist-cjs/lib/ui/components/primitives/menus/TldrawUiMenuGroup.js +25 -12
  105. package/dist-cjs/lib/ui/components/primitives/menus/TldrawUiMenuGroup.js.map +2 -2
  106. package/dist-cjs/lib/ui/components/primitives/menus/TldrawUiMenuItem.js +12 -26
  107. package/dist-cjs/lib/ui/components/primitives/menus/TldrawUiMenuItem.js.map +2 -2
  108. package/dist-cjs/lib/ui/context/TldrawUiContextProvider.js +3 -2
  109. package/dist-cjs/lib/ui/context/TldrawUiContextProvider.js.map +2 -2
  110. package/dist-cjs/lib/ui/context/actions.js +31 -2
  111. package/dist-cjs/lib/ui/context/actions.js.map +2 -2
  112. package/dist-cjs/lib/ui/context/events.js.map +2 -2
  113. package/dist-cjs/lib/ui/hooks/useTools.js +21 -3
  114. package/dist-cjs/lib/ui/hooks/useTools.js.map +2 -2
  115. package/dist-cjs/lib/ui/hooks/useTranslation/TLUiTranslationKey.js.map +1 -1
  116. package/dist-cjs/lib/ui/hooks/useTranslation/defaultTranslation.js +3 -0
  117. package/dist-cjs/lib/ui/hooks/useTranslation/defaultTranslation.js.map +2 -2
  118. package/dist-cjs/lib/ui/version.js +3 -3
  119. package/dist-cjs/lib/ui/version.js.map +1 -1
  120. package/dist-esm/index.d.mts +181 -5
  121. package/dist-esm/index.mjs +29 -1
  122. package/dist-esm/index.mjs.map +2 -2
  123. package/dist-esm/lib/canvas/TldrawScribble.mjs +1 -1
  124. package/dist-esm/lib/canvas/TldrawScribble.mjs.map +2 -2
  125. package/dist-esm/lib/defaultExternalContentHandlers.mjs +5 -4
  126. package/dist-esm/lib/defaultExternalContentHandlers.mjs.map +2 -2
  127. package/dist-esm/lib/shapes/arrow/ArrowShapeUtil.mjs +4 -3
  128. package/dist-esm/lib/shapes/arrow/ArrowShapeUtil.mjs.map +2 -2
  129. package/dist-esm/lib/shapes/arrow/arrowTargetState.mjs +1 -1
  130. package/dist-esm/lib/shapes/arrow/arrowTargetState.mjs.map +2 -2
  131. package/dist-esm/lib/shapes/arrow/elbow/ElbowArrowDebug.mjs +3 -3
  132. package/dist-esm/lib/shapes/arrow/elbow/ElbowArrowDebug.mjs.map +1 -1
  133. package/dist-esm/lib/shapes/draw/DrawShapeUtil.mjs +4 -3
  134. package/dist-esm/lib/shapes/draw/DrawShapeUtil.mjs.map +2 -2
  135. package/dist-esm/lib/shapes/embed/EmbedShapeUtil.mjs +1 -1
  136. package/dist-esm/lib/shapes/embed/EmbedShapeUtil.mjs.map +1 -1
  137. package/dist-esm/lib/shapes/frame/FrameShapeUtil.mjs +13 -12
  138. package/dist-esm/lib/shapes/frame/FrameShapeUtil.mjs.map +2 -2
  139. package/dist-esm/lib/shapes/frame/components/FrameHeading.mjs +1 -1
  140. package/dist-esm/lib/shapes/frame/components/FrameHeading.mjs.map +2 -2
  141. package/dist-esm/lib/shapes/geo/GeoShapeUtil.mjs +3 -2
  142. package/dist-esm/lib/shapes/geo/GeoShapeUtil.mjs.map +2 -2
  143. package/dist-esm/lib/shapes/geo/components/GeoShapeBody.mjs +2 -1
  144. package/dist-esm/lib/shapes/geo/components/GeoShapeBody.mjs.map +2 -2
  145. package/dist-esm/lib/shapes/highlight/HighlightShapeUtil.mjs +6 -1
  146. package/dist-esm/lib/shapes/highlight/HighlightShapeUtil.mjs.map +2 -2
  147. package/dist-esm/lib/shapes/image/ImageShapeUtil.mjs +3 -3
  148. package/dist-esm/lib/shapes/image/ImageShapeUtil.mjs.map +1 -1
  149. package/dist-esm/lib/shapes/line/LineShapeUtil.mjs +6 -1
  150. package/dist-esm/lib/shapes/line/LineShapeUtil.mjs.map +2 -2
  151. package/dist-esm/lib/shapes/note/NoteShapeUtil.mjs +5 -4
  152. package/dist-esm/lib/shapes/note/NoteShapeUtil.mjs.map +2 -2
  153. package/dist-esm/lib/shapes/shared/ShapeFill.mjs +5 -4
  154. package/dist-esm/lib/shapes/shared/ShapeFill.mjs.map +2 -2
  155. package/dist-esm/lib/shapes/shared/freehand/svg.mjs.map +2 -2
  156. package/dist-esm/lib/shapes/shared/usePrefersReducedMotion.mjs +10 -1
  157. package/dist-esm/lib/shapes/shared/usePrefersReducedMotion.mjs.map +2 -2
  158. package/dist-esm/lib/shapes/text/TextShapeUtil.mjs +3 -2
  159. package/dist-esm/lib/shapes/text/TextShapeUtil.mjs.map +2 -2
  160. package/dist-esm/lib/shapes/video/VideoShapeUtil.mjs +3 -3
  161. package/dist-esm/lib/shapes/video/VideoShapeUtil.mjs.map +1 -1
  162. package/dist-esm/lib/tools/EraserTool/childStates/Erasing.mjs +26 -1
  163. package/dist-esm/lib/tools/EraserTool/childStates/Erasing.mjs.map +2 -2
  164. package/dist-esm/lib/tools/EraserTool/childStates/Pointing.mjs +13 -0
  165. package/dist-esm/lib/tools/EraserTool/childStates/Pointing.mjs.map +2 -2
  166. package/dist-esm/lib/ui/TldrawUi.mjs +16 -2
  167. package/dist-esm/lib/ui/TldrawUi.mjs.map +3 -3
  168. package/dist-esm/lib/ui/assetUrls.mjs +13 -10
  169. package/dist-esm/lib/ui/assetUrls.mjs.map +2 -2
  170. package/dist-esm/lib/ui/components/AccessibilityMenu.mjs +19 -0
  171. package/dist-esm/lib/ui/components/AccessibilityMenu.mjs.map +7 -0
  172. package/dist-esm/lib/ui/components/ActionsMenu/DefaultActionsMenu.mjs +12 -3
  173. package/dist-esm/lib/ui/components/ActionsMenu/DefaultActionsMenu.mjs.map +2 -2
  174. package/dist-esm/lib/ui/components/DefaultMenuPanel.mjs +3 -2
  175. package/dist-esm/lib/ui/components/DefaultMenuPanel.mjs.map +2 -2
  176. package/dist-esm/lib/ui/components/KeyboardShortcutsDialog/DefaultKeyboardShortcutsDialogContent.mjs +1 -1
  177. package/dist-esm/lib/ui/components/KeyboardShortcutsDialog/DefaultKeyboardShortcutsDialogContent.mjs.map +1 -1
  178. package/dist-esm/lib/ui/components/MainMenu/DefaultMainMenuContent.mjs +3 -5
  179. package/dist-esm/lib/ui/components/MainMenu/DefaultMainMenuContent.mjs.map +2 -2
  180. package/dist-esm/lib/ui/components/Minimap/MinimapManager.mjs +4 -4
  181. package/dist-esm/lib/ui/components/Minimap/MinimapManager.mjs.map +2 -2
  182. package/dist-esm/lib/ui/components/MobileStylePanel.mjs +6 -3
  183. package/dist-esm/lib/ui/components/MobileStylePanel.mjs.map +2 -2
  184. package/dist-esm/lib/ui/components/NavigationPanel/DefaultNavigationPanel.mjs +1 -1
  185. package/dist-esm/lib/ui/components/NavigationPanel/DefaultNavigationPanel.mjs.map +2 -2
  186. package/dist-esm/lib/ui/components/PageMenu/DefaultPageMenu.mjs +2 -1
  187. package/dist-esm/lib/ui/components/PageMenu/DefaultPageMenu.mjs.map +2 -2
  188. package/dist-esm/lib/ui/components/SharePanel/PeopleMenuItem.mjs +3 -2
  189. package/dist-esm/lib/ui/components/SharePanel/PeopleMenuItem.mjs.map +2 -2
  190. package/dist-esm/lib/ui/components/SharePanel/UserPresenceColorPicker.mjs +2 -2
  191. package/dist-esm/lib/ui/components/SharePanel/UserPresenceColorPicker.mjs.map +2 -2
  192. package/dist-esm/lib/ui/components/StylePanel/DefaultStylePanel.mjs +3 -1
  193. package/dist-esm/lib/ui/components/StylePanel/DefaultStylePanel.mjs.map +2 -2
  194. package/dist-esm/lib/ui/components/StylePanel/DefaultStylePanelContent.mjs +171 -140
  195. package/dist-esm/lib/ui/components/StylePanel/DefaultStylePanelContent.mjs.map +2 -2
  196. package/dist-esm/lib/ui/components/StylePanel/DoubleDropdownPicker.mjs +3 -3
  197. package/dist-esm/lib/ui/components/StylePanel/DoubleDropdownPicker.mjs.map +2 -2
  198. package/dist-esm/lib/ui/components/StylePanel/DropdownPicker.mjs +26 -25
  199. package/dist-esm/lib/ui/components/StylePanel/DropdownPicker.mjs.map +2 -2
  200. package/dist-esm/lib/ui/components/Toolbar/DefaultImageToolbarContent.mjs +1 -1
  201. package/dist-esm/lib/ui/components/Toolbar/DefaultImageToolbarContent.mjs.map +2 -2
  202. package/dist-esm/lib/ui/components/Toolbar/DefaultToolbar.mjs +56 -21
  203. package/dist-esm/lib/ui/components/Toolbar/DefaultToolbar.mjs.map +2 -2
  204. package/dist-esm/lib/ui/components/Toolbar/OverflowingToolbar.mjs +192 -81
  205. package/dist-esm/lib/ui/components/Toolbar/OverflowingToolbar.mjs.map +3 -3
  206. package/dist-esm/lib/ui/components/Toolbar/ToggleToolLockedButton.mjs +5 -4
  207. package/dist-esm/lib/ui/components/Toolbar/ToggleToolLockedButton.mjs.map +2 -2
  208. package/dist-esm/lib/ui/components/menu-items.mjs +6 -0
  209. package/dist-esm/lib/ui/components/menu-items.mjs.map +2 -2
  210. package/dist-esm/lib/ui/components/primitives/TldrawUiButtonPicker.mjs +6 -6
  211. package/dist-esm/lib/ui/components/primitives/TldrawUiButtonPicker.mjs.map +2 -2
  212. package/dist-esm/lib/ui/components/primitives/TldrawUiContextualToolbar.mjs +1 -1
  213. package/dist-esm/lib/ui/components/primitives/TldrawUiContextualToolbar.mjs.map +2 -2
  214. package/dist-esm/lib/ui/components/primitives/TldrawUiPopover.mjs +3 -2
  215. package/dist-esm/lib/ui/components/primitives/TldrawUiPopover.mjs.map +2 -2
  216. package/dist-esm/lib/ui/components/primitives/TldrawUiToolbar.mjs +30 -7
  217. package/dist-esm/lib/ui/components/primitives/TldrawUiToolbar.mjs.map +2 -2
  218. package/dist-esm/lib/ui/components/primitives/TldrawUiTooltip.mjs +239 -0
  219. package/dist-esm/lib/ui/components/primitives/TldrawUiTooltip.mjs.map +7 -0
  220. package/dist-esm/lib/ui/components/primitives/layout.mjs +46 -0
  221. package/dist-esm/lib/ui/components/primitives/layout.mjs.map +7 -0
  222. package/dist-esm/lib/ui/components/primitives/menus/TldrawUiMenuContext.mjs.map +2 -2
  223. package/dist-esm/lib/ui/components/primitives/menus/TldrawUiMenuGroup.mjs +25 -12
  224. package/dist-esm/lib/ui/components/primitives/menus/TldrawUiMenuGroup.mjs.map +2 -2
  225. package/dist-esm/lib/ui/components/primitives/menus/TldrawUiMenuItem.mjs +12 -26
  226. package/dist-esm/lib/ui/components/primitives/menus/TldrawUiMenuItem.mjs.map +2 -2
  227. package/dist-esm/lib/ui/context/TldrawUiContextProvider.mjs +3 -2
  228. package/dist-esm/lib/ui/context/TldrawUiContextProvider.mjs.map +2 -2
  229. package/dist-esm/lib/ui/context/actions.mjs +31 -2
  230. package/dist-esm/lib/ui/context/actions.mjs.map +2 -2
  231. package/dist-esm/lib/ui/context/events.mjs.map +2 -2
  232. package/dist-esm/lib/ui/hooks/useTools.mjs +22 -3
  233. package/dist-esm/lib/ui/hooks/useTools.mjs.map +2 -2
  234. package/dist-esm/lib/ui/hooks/useTranslation/defaultTranslation.mjs +3 -0
  235. package/dist-esm/lib/ui/hooks/useTranslation/defaultTranslation.mjs.map +2 -2
  236. package/dist-esm/lib/ui/version.mjs +3 -3
  237. package/dist-esm/lib/ui/version.mjs.map +1 -1
  238. package/package.json +11 -34
  239. package/src/index.ts +22 -0
  240. package/src/lib/canvas/TldrawScribble.tsx +1 -1
  241. package/src/lib/defaultExternalContentHandlers.ts +12 -4
  242. package/src/lib/shapes/arrow/ArrowShapeOptions.test.ts +2 -1
  243. package/src/lib/shapes/arrow/ArrowShapeTool.test.ts +4 -3
  244. package/src/lib/shapes/arrow/ArrowShapeUtil.test.ts +7 -6
  245. package/src/lib/shapes/arrow/ArrowShapeUtil.tsx +4 -3
  246. package/src/lib/shapes/arrow/arrowTargetState.ts +2 -1
  247. package/src/lib/shapes/arrow/elbow/ElbowArrowDebug.tsx +3 -3
  248. package/src/lib/shapes/draw/DrawShapeTool.test.ts +0 -5
  249. package/src/lib/shapes/draw/DrawShapeUtil.tsx +4 -3
  250. package/src/lib/shapes/embed/EmbedShapeUtil.tsx +1 -1
  251. package/src/lib/shapes/frame/FrameShapeUtil.tsx +21 -14
  252. package/src/lib/shapes/frame/components/FrameHeading.tsx +1 -1
  253. package/src/lib/shapes/geo/GeoShapeUtil.tsx +3 -2
  254. package/src/lib/shapes/geo/components/GeoShapeBody.tsx +2 -2
  255. package/src/lib/shapes/highlight/HighlightShapeUtil.tsx +7 -1
  256. package/src/lib/shapes/image/ImageShapeUtil.tsx +3 -3
  257. package/src/lib/shapes/line/LineShapeUtil.test.tsx +4 -3
  258. package/src/lib/shapes/line/LineShapeUtil.tsx +6 -1
  259. package/src/lib/shapes/line/__snapshots__/LineShapeUtil.test.tsx.snap +2 -2
  260. package/src/lib/shapes/note/NoteShapeUtil.tsx +9 -4
  261. package/src/lib/shapes/shared/ShapeFill.tsx +5 -4
  262. package/src/lib/shapes/shared/freehand/svg.ts +2 -0
  263. package/src/lib/shapes/shared/usePrefersReducedMotion.tsx +11 -1
  264. package/src/lib/shapes/text/TextShapeTool.test.ts +6 -5
  265. package/src/lib/shapes/text/TextShapeUtil.tsx +3 -2
  266. package/src/lib/shapes/video/VideoShapeUtil.tsx +3 -3
  267. package/src/lib/tools/EraserTool/childStates/Erasing.ts +34 -1
  268. package/src/lib/tools/EraserTool/childStates/Pointing.ts +20 -0
  269. package/src/lib/ui/TldrawUi.tsx +17 -2
  270. package/src/lib/ui/assetUrls.ts +13 -10
  271. package/src/lib/ui/components/AccessibilityMenu.tsx +20 -0
  272. package/src/lib/ui/components/ActionsMenu/DefaultActionsMenu.tsx +15 -3
  273. package/src/lib/ui/components/DefaultMenuPanel.tsx +4 -3
  274. package/src/lib/ui/components/KeyboardShortcutsDialog/DefaultKeyboardShortcutsDialogContent.tsx +1 -1
  275. package/src/lib/ui/components/MainMenu/DefaultMainMenuContent.tsx +4 -4
  276. package/src/lib/ui/components/Minimap/MinimapManager.ts +4 -4
  277. package/src/lib/ui/components/MobileStylePanel.tsx +9 -6
  278. package/src/lib/ui/components/NavigationPanel/DefaultNavigationPanel.tsx +1 -1
  279. package/src/lib/ui/components/PageMenu/DefaultPageMenu.tsx +3 -2
  280. package/src/lib/ui/components/SharePanel/PeopleMenuItem.tsx +4 -3
  281. package/src/lib/ui/components/SharePanel/UserPresenceColorPicker.tsx +3 -3
  282. package/src/lib/ui/components/StylePanel/DefaultStylePanel.tsx +3 -1
  283. package/src/lib/ui/components/StylePanel/DefaultStylePanelContent.tsx +146 -107
  284. package/src/lib/ui/components/StylePanel/DoubleDropdownPicker.tsx +3 -3
  285. package/src/lib/ui/components/StylePanel/DropdownPicker.tsx +7 -6
  286. package/src/lib/ui/components/Toolbar/DefaultImageToolbarContent.tsx +1 -1
  287. package/src/lib/ui/components/Toolbar/DefaultToolbar.tsx +55 -23
  288. package/src/lib/ui/components/Toolbar/OverflowingToolbar.tsx +212 -61
  289. package/src/lib/ui/components/Toolbar/ToggleToolLockedButton.tsx +14 -11
  290. package/src/lib/ui/components/menu-items.tsx +8 -0
  291. package/src/lib/ui/components/primitives/TldrawUiButtonPicker.tsx +40 -37
  292. package/src/lib/ui/components/primitives/TldrawUiContextualToolbar.tsx +1 -1
  293. package/src/lib/ui/components/primitives/TldrawUiPopover.tsx +4 -2
  294. package/src/lib/ui/components/primitives/TldrawUiToolbar.tsx +51 -12
  295. package/src/lib/ui/components/primitives/TldrawUiTooltip.tsx +325 -0
  296. package/src/lib/ui/components/primitives/layout.tsx +107 -0
  297. package/src/lib/ui/components/primitives/menus/TldrawUiMenuContext.tsx +0 -1
  298. package/src/lib/ui/components/primitives/menus/TldrawUiMenuGroup.tsx +29 -16
  299. package/src/lib/ui/components/primitives/menus/TldrawUiMenuItem.tsx +18 -27
  300. package/src/lib/ui/context/TldrawUiContextProvider.tsx +23 -20
  301. package/src/lib/ui/context/actions.tsx +31 -2
  302. package/src/lib/ui/context/events.tsx +1 -0
  303. package/src/lib/ui/hooks/useTools.tsx +25 -3
  304. package/src/lib/ui/hooks/useTranslation/TLUiTranslationKey.ts +3 -0
  305. package/src/lib/ui/hooks/useTranslation/defaultTranslation.ts +3 -0
  306. package/src/lib/ui/version.ts +3 -3
  307. package/src/lib/ui.css +409 -292
  308. package/src/lib/utils/excalidraw/__snapshots__/putExcalidrawContent.test.tsx.snap +5 -5
  309. package/src/lib/utils/tldr/__snapshots__/buildFromV1Document.test.ts.snap +4 -4
  310. package/src/test/A11y.test.tsx +3 -2
  311. package/src/test/ClickManager.test.ts +7 -6
  312. package/src/test/Editor.test.tsx +20 -19
  313. package/src/test/EraserTool.test.ts +184 -13
  314. package/src/test/HandTool.test.ts +10 -9
  315. package/src/test/HighlightShape.test.ts +2 -1
  316. package/src/test/SelectTool.test.ts +3 -2
  317. package/src/test/TLUserPreferences.test.ts +4 -3
  318. package/src/test/TestEditor.ts +13 -15
  319. package/src/test/TldrawEditor.test.tsx +11 -10
  320. package/src/test/ZoomTool.test.ts +7 -6
  321. package/src/test/__snapshots__/drawing.test.ts.snap +2 -2
  322. package/src/test/__snapshots__/groups.test.tsx.snap +6 -6
  323. package/src/test/__snapshots__/resizing.test.ts.snap +2 -2
  324. package/src/test/arrows-megabus.test.tsx +17 -10
  325. package/src/test/bindings.test.tsx +24 -37
  326. package/src/test/bookmark-shapes.test.ts +1 -8
  327. package/src/test/commands/__snapshots__/getSvgString.test.ts.snap +23 -7
  328. package/src/test/commands/__snapshots__/packShapes.test.ts.snap +8 -8
  329. package/src/test/commands/__snapshots__/zoomToFit.test.ts.snap +2 -2
  330. package/src/test/commands/alignShapes.test.tsx +25 -24
  331. package/src/test/commands/animationSpeed.test.ts +2 -1
  332. package/src/test/commands/centerOnPoint.test.ts +3 -2
  333. package/src/test/commands/clipboard.test.ts +3 -2
  334. package/src/test/commands/createShapes.test.ts +2 -1
  335. package/src/test/commands/deleteShapes.test.ts +2 -1
  336. package/src/test/commands/distributeShapes.test.tsx +11 -10
  337. package/src/test/commands/getSvgString.test.ts +2 -1
  338. package/src/test/commands/packShapes.test.ts +5 -4
  339. package/src/test/commands/resizeShape.test.ts +2 -1
  340. package/src/test/commands/rotateShapes.test.ts +7 -6
  341. package/src/test/commands/setCamera.test.ts +4 -3
  342. package/src/test/commands/setCurrentPage.test.ts +3 -2
  343. package/src/test/commands/stackShapes.test.ts +11 -10
  344. package/src/test/commands/stretch.test.tsx +13 -12
  345. package/src/test/createDeepLink.test.tsx +2 -1
  346. package/src/test/cropping.test.ts +3 -2
  347. package/src/test/drawing.test.ts +2 -1
  348. package/src/test/flipShapes.test.ts +4 -3
  349. package/src/test/frames.test.ts +25 -24
  350. package/src/test/getCulledShapes.test.tsx +3 -2
  351. package/src/test/groups.test.tsx +1 -1
  352. package/src/test/handleDeepLink.test.tsx +2 -1
  353. package/src/test/inner-outer-margin.test.ts +315 -0
  354. package/src/test/maxShapes.test.ts +3 -2
  355. package/src/test/modifiers.test.ts +5 -4
  356. package/src/test/navigation.test.ts +12 -11
  357. package/src/test/panning.test.ts +2 -1
  358. package/src/test/perf/perf.test.ts +2 -1
  359. package/src/test/registerDeepLinkListener.test.tsx +10 -9
  360. package/src/test/resizing.test.ts +39 -38
  361. package/src/test/select.test.tsx +4 -3
  362. package/src/test/selection-omnibus.test.ts +11 -10
  363. package/src/test/shapeutils.test.ts +4 -3
  364. package/src/test/translating.test.ts +9 -8
  365. package/tldraw.css +702 -580
@@ -4,6 +4,7 @@ import {
4
4
  TLGroupShape,
5
5
  TLPointerEventInfo,
6
6
  TLShapeId,
7
+ isAccelKey,
7
8
  pointInPolygon,
8
9
  } from '@tldraw/editor'
9
10
 
@@ -15,7 +16,15 @@ export class Erasing extends StateNode {
15
16
  private markId = ''
16
17
  private excludedShapeIds = new Set<TLShapeId>()
17
18
 
19
+ _isHoldingAccelKey = false
20
+ _firstErasingShapeId: TLShapeId | null = null
21
+ _erasingShapeIds: TLShapeId[] = []
22
+
18
23
  override onEnter(info: TLPointerEventInfo) {
24
+ this._isHoldingAccelKey = isAccelKey(this.editor.inputs)
25
+ this._firstErasingShapeId = this.editor.getErasingShapeIds()[0] // the first one should be the first one we hit... is it?
26
+ this._erasingShapeIds = this.editor.getErasingShapeIds()
27
+
19
28
  this.markId = this.editor.markHistoryStoppingPoint('erase scribble begin')
20
29
  this.info = info
21
30
 
@@ -76,6 +85,16 @@ export class Erasing extends StateNode {
76
85
  this.complete()
77
86
  }
78
87
 
88
+ override onKeyUp() {
89
+ this._isHoldingAccelKey = isAccelKey(this.editor.inputs)
90
+ this.update()
91
+ }
92
+
93
+ override onKeyDown() {
94
+ this._isHoldingAccelKey = isAccelKey(this.editor.inputs)
95
+ this.update()
96
+ }
97
+
79
98
  update() {
80
99
  const { editor, excludedShapeIds } = this
81
100
  const erasingShapeIds = editor.getErasingShapeIds()
@@ -87,6 +106,7 @@ export class Erasing extends StateNode {
87
106
 
88
107
  this.pushPointToScribble()
89
108
 
109
+ // Otherwise, erasing shapes are all the shapes that were hit before plus any new shapes that are hit
90
110
  const erasing = new Set<TLShapeId>(erasingShapeIds)
91
111
  const minDist = this.editor.options.hitTestMargin / zoomLevel
92
112
 
@@ -121,18 +141,31 @@ export class Erasing extends StateNode {
121
141
  if (geometry.hitTestLineSegment(A, B, minDist)) {
122
142
  erasing.add(editor.getOutermostSelectableShape(shape).id)
123
143
  }
144
+
145
+ this._erasingShapeIds = [...erasing]
146
+ }
147
+
148
+ // If the user is holding the meta / ctrl key, we should only erase the first shape we hit
149
+ if (this._isHoldingAccelKey && this._firstErasingShapeId) {
150
+ const erasingShapeId = this._firstErasingShapeId
151
+ if (erasingShapeId && this.editor.getShape(erasingShapeId)) {
152
+ editor.setErasingShapes([erasingShapeId])
153
+ }
154
+ return
124
155
  }
125
156
 
126
157
  // Remove the hit shapes, except if they're in the list of excluded shapes
127
158
  // (these excluded shapes will be any frames or groups the pointer was inside of
128
159
  // when the user started erasing)
129
- this.editor.setErasingShapes([...erasing].filter((id) => !excludedShapeIds.has(id)))
160
+ this.editor.setErasingShapes(this._erasingShapeIds.filter((id) => !excludedShapeIds.has(id)))
130
161
  }
131
162
 
132
163
  complete() {
133
164
  const { editor } = this
134
165
  editor.deleteShapes(editor.getCurrentPageState().erasingShapeIds)
135
166
  this.parent.transition('idle')
167
+ this._erasingShapeIds = []
168
+ this._firstErasingShapeId = null
136
169
  }
137
170
 
138
171
  cancel() {
@@ -1,4 +1,5 @@
1
1
  import {
2
+ isAccelKey,
2
3
  StateNode,
3
4
  TLFrameShape,
4
5
  TLGroupShape,
@@ -9,7 +10,11 @@ import {
9
10
  export class Pointing extends StateNode {
10
11
  static override id = 'pointing'
11
12
 
13
+ _isHoldingAccelKey = false
14
+
12
15
  override onEnter() {
16
+ this._isHoldingAccelKey = isAccelKey(this.editor.inputs)
17
+
13
18
  const zoomLevel = this.editor.getZoomLevel()
14
19
  const currentPageShapesSorted = this.editor.getCurrentPageRenderingShapesSorted()
15
20
  const {
@@ -45,12 +50,25 @@ export class Pointing extends StateNode {
45
50
  }
46
51
 
47
52
  erasing.add(hitShape.id)
53
+
54
+ // If the user is holding the meta / ctrl key, stop after the first shape
55
+ if (this._isHoldingAccelKey) {
56
+ break
57
+ }
48
58
  }
49
59
  }
50
60
 
51
61
  this.editor.setErasingShapes([...erasing])
52
62
  }
53
63
 
64
+ override onKeyUp() {
65
+ this._isHoldingAccelKey = isAccelKey(this.editor.inputs)
66
+ }
67
+
68
+ override onKeyDown() {
69
+ this._isHoldingAccelKey = isAccelKey(this.editor.inputs)
70
+ }
71
+
54
72
  override onLongPress(info: TLPointerEventInfo) {
55
73
  this.startErasing(info)
56
74
  }
@@ -62,6 +80,8 @@ export class Pointing extends StateNode {
62
80
  }
63
81
 
64
82
  override onPointerMove(info: TLPointerEventInfo) {
83
+ if (this._isHoldingAccelKey) return
84
+
65
85
  if (this.editor.inputs.isDragging) {
66
86
  this.startErasing(info)
67
87
  }
@@ -1,12 +1,12 @@
1
1
  import { tlenv, useEditor, useReactor, useValue } from '@tldraw/editor'
2
2
  import classNames from 'classnames'
3
- import React, { ReactNode, useRef, useState } from 'react'
3
+ import React, { ReactNode, useMemo, useRef, useState } from 'react'
4
4
  import { TLUiAssetUrlOverrides } from './assetUrls'
5
5
  import { SkipToMainContent } from './components/A11y'
6
6
  import { FollowingIndicator } from './components/FollowingIndicator'
7
7
  import { TldrawUiButton } from './components/primitives/Button/TldrawUiButton'
8
8
  import { TldrawUiButtonIcon } from './components/primitives/Button/TldrawUiButtonIcon'
9
- import { PORTRAIT_BREAKPOINT } from './constants'
9
+ import { PORTRAIT_BREAKPOINT, PORTRAIT_BREAKPOINTS } from './constants'
10
10
  import {
11
11
  TLUiContextProviderProps,
12
12
  TldrawUiContextProvider,
@@ -160,6 +160,19 @@ const TldrawUiContent = React.memo(function TldrawUI() {
160
160
 
161
161
  const { 'toggle-focus-mode': toggleFocus } = useActions()
162
162
 
163
+ const { breakpointsAbove, breakpointsBelow } = useMemo(() => {
164
+ const breakpointsAbove = []
165
+ const breakpointsBelow = []
166
+ for (let bp = 0; bp < PORTRAIT_BREAKPOINTS.length; bp++) {
167
+ if (bp <= breakpoint) {
168
+ breakpointsAbove.push(bp)
169
+ } else {
170
+ breakpointsBelow.push(bp)
171
+ }
172
+ }
173
+ return { breakpointsAbove, breakpointsBelow }
174
+ }, [breakpoint])
175
+
163
176
  return (
164
177
  <div
165
178
  className={classNames('tlui-layout', {
@@ -169,6 +182,8 @@ const TldrawUiContent = React.memo(function TldrawUI() {
169
182
  // But when the virtual keyboard is closing we want to wait a bit before showing it again.
170
183
  data-iseditinganything={hideToolbarWhileEditing}
171
184
  data-breakpoint={breakpoint}
185
+ data-breakpoints-above={breakpointsAbove.join(' ')}
186
+ data-breakpoints-below={breakpointsBelow.join(' ')}
172
187
  >
173
188
  <SkipToMainContent />
174
189
  {isFocusMode ? (
@@ -1,4 +1,5 @@
1
1
  import { LANGUAGES, RecursivePartial, getDefaultCdnBaseUrl } from '@tldraw/editor'
2
+ import { useMemo } from 'react'
2
3
  import { DEFAULT_EMBED_DEFINITIONS } from '../defaultEmbedDefinitions'
3
4
  import { TLEditorAssetUrls, defaultEditorAssetUrls } from '../utils/static-assets/assetUrls'
4
5
  import { TLUiIconType, iconTypes } from './icon-types'
@@ -41,15 +42,17 @@ export function setDefaultUiAssetUrls(urls: TLUiAssetUrls) {
41
42
  export function useDefaultUiAssetUrlsWithOverrides(
42
43
  overrides?: TLUiAssetUrlOverrides
43
44
  ): TLUiAssetUrls {
44
- if (!overrides) return defaultUiAssetUrls
45
+ return useMemo(() => {
46
+ if (!overrides) return defaultUiAssetUrls
45
47
 
46
- return {
47
- fonts: Object.assign({ ...defaultUiAssetUrls.fonts }, { ...overrides?.fonts }),
48
- icons: Object.assign({ ...defaultUiAssetUrls.icons }, { ...overrides?.icons }),
49
- embedIcons: Object.assign({ ...defaultUiAssetUrls.embedIcons }, { ...overrides?.embedIcons }),
50
- translations: Object.assign(
51
- { ...defaultUiAssetUrls.translations },
52
- { ...overrides?.translations }
53
- ),
54
- }
48
+ return {
49
+ fonts: Object.assign({ ...defaultUiAssetUrls.fonts }, { ...overrides?.fonts }),
50
+ icons: Object.assign({ ...defaultUiAssetUrls.icons }, { ...overrides?.icons }),
51
+ embedIcons: Object.assign({ ...defaultUiAssetUrls.embedIcons }, { ...overrides?.embedIcons }),
52
+ translations: Object.assign(
53
+ { ...defaultUiAssetUrls.translations },
54
+ { ...overrides?.translations }
55
+ ),
56
+ }
57
+ }, [overrides])
55
58
  }
@@ -0,0 +1,20 @@
1
+ import {
2
+ ToggleKeyboardShortcutsItem,
3
+ ToggleReduceMotionItem,
4
+ ToggleUiLabelsItem,
5
+ } from './menu-items'
6
+ import { TldrawUiMenuGroup } from './primitives/menus/TldrawUiMenuGroup'
7
+ import { TldrawUiMenuSubmenu } from './primitives/menus/TldrawUiMenuSubmenu'
8
+
9
+ /** @public @react */
10
+ export function AccessibilityMenu() {
11
+ return (
12
+ <TldrawUiMenuSubmenu id="help menu accessibility" label="menu.accessibility">
13
+ <TldrawUiMenuGroup id="accessibility">
14
+ <ToggleReduceMotionItem />
15
+ <ToggleKeyboardShortcutsItem />
16
+ <ToggleUiLabelsItem />
17
+ </TldrawUiMenuGroup>
18
+ </TldrawUiMenuSubmenu>
19
+ )
20
+ }
@@ -11,6 +11,7 @@ import {
11
11
  TldrawUiPopoverTrigger,
12
12
  } from '../primitives/TldrawUiPopover'
13
13
  import { TldrawUiToolbar, TldrawUiToolbarButton } from '../primitives/TldrawUiToolbar'
14
+ import { useTldrawUiOrientation } from '../primitives/layout'
14
15
  import { TldrawUiMenuContextProvider } from '../primitives/menus/TldrawUiMenuContext'
15
16
  import { DefaultActionsMenuContent } from './DefaultActionsMenuContent'
16
17
 
@@ -26,6 +27,7 @@ export const DefaultActionsMenu = memo(function DefaultActionsMenu({
26
27
  const msg = useTranslation()
27
28
  const breakpoint = useBreakpoint()
28
29
  const isReadonlyMode = useReadonly()
30
+ const { orientation } = useTldrawUiOrientation()
29
31
 
30
32
  const ref = useRef<HTMLDivElement>(null)
31
33
  usePassThroughWheelEvents(ref)
@@ -52,18 +54,28 @@ export const DefaultActionsMenu = memo(function DefaultActionsMenu({
52
54
  data-testid="actions-menu.button"
53
55
  title={msg('actions-menu.title')}
54
56
  >
55
- <TldrawUiButtonIcon icon="dots-vertical" small />
57
+ <TldrawUiButtonIcon
58
+ icon={orientation === 'horizontal' ? 'dots-vertical' : 'dots-horizontal'}
59
+ small
60
+ />
56
61
  </TldrawUiToolbarButton>
57
62
  </TldrawUiPopoverTrigger>
58
63
  <TldrawUiPopoverContent
59
- side={breakpoint >= PORTRAIT_BREAKPOINT.TABLET ? 'bottom' : 'top'}
64
+ side={
65
+ orientation === 'horizontal'
66
+ ? breakpoint >= PORTRAIT_BREAKPOINT.TABLET
67
+ ? 'bottom'
68
+ : 'top'
69
+ : 'right'
70
+ }
60
71
  sideOffset={6}
61
72
  >
62
73
  <TldrawUiToolbar
63
74
  ref={ref}
64
75
  label={msg('actions-menu.title')}
65
- className="tlui-actions-menu tlui-buttons__grid"
76
+ className="tlui-actions-menu"
66
77
  data-testid="actions-menu.content"
78
+ orientation="grid"
67
79
  >
68
80
  <TldrawUiMenuContextProvider type="icons" sourceId="actions-menu">
69
81
  {content}
@@ -5,6 +5,7 @@ import { useBreakpoint } from '../context/breakpoints'
5
5
  import { useTldrawUiComponents } from '../context/components'
6
6
  import { useTranslation } from '../hooks/useTranslation/useTranslation'
7
7
  import { TldrawUiToolbar } from './primitives/TldrawUiToolbar'
8
+ import { TldrawUiRow } from './primitives/layout'
8
9
 
9
10
  /** @public @react */
10
11
  export const DefaultMenuPanel = memo(function MenuPanel() {
@@ -32,16 +33,16 @@ export const DefaultMenuPanel = memo(function MenuPanel() {
32
33
 
33
34
  return (
34
35
  <nav ref={ref} className="tlui-menu-zone">
35
- <div className="tlui-buttons__horizontal">
36
+ <TldrawUiRow>
36
37
  {MainMenu && <MainMenu />}
37
38
  {PageMenu && !isSinglePageMode && <PageMenu />}
38
39
  {showQuickActions ? (
39
- <TldrawUiToolbar className="tlui-buttons__horizontal" label={msg('actions-menu.title')}>
40
+ <TldrawUiToolbar orientation="horizontal" label={msg('actions-menu.title')}>
40
41
  {QuickActions && <QuickActions />}
41
42
  {ActionsMenu && <ActionsMenu />}
42
43
  </TldrawUiToolbar>
43
44
  ) : null}
44
- </div>
45
+ </TldrawUiRow>
45
46
  </nav>
46
47
  )
47
48
  })
@@ -123,7 +123,7 @@ export function DefaultKeyboardShortcutsDialogContent() {
123
123
  <TldrawUiMenuItem
124
124
  id="text-header"
125
125
  label="tool.rich-text-header"
126
- kbd="cmd+shift+[[1-6]]"
126
+ kbd="cmd+alt+[[1-6]]"
127
127
  onSelect={() => {
128
128
  /* do nothing */
129
129
  }}
@@ -1,4 +1,5 @@
1
1
  import { useCanRedo, useCanUndo } from '../../hooks/menu-hooks'
2
+ import { AccessibilityMenu } from '../AccessibilityMenu'
2
3
  import { ColorSchemeMenu } from '../ColorSchemeMenu'
3
4
  import { KeyboardShortcutsMenuItem } from '../HelpMenu/DefaultHelpMenuContent'
4
5
  import { LanguageMenu } from '../LanguageMenu'
@@ -19,10 +20,8 @@ import {
19
20
  ToggleEdgeScrollingItem,
20
21
  ToggleFocusModeItem,
21
22
  ToggleGridItem,
22
- ToggleKeyboardShortcutsItem,
23
23
  ToggleLockMenuItem,
24
24
  TogglePasteAtCursorItem,
25
- ToggleReduceMotionItem,
26
25
  ToggleSnapModeItem,
27
26
  ToggleToolLockItem,
28
27
  ToggleTransparentBgMenuItem,
@@ -161,8 +160,6 @@ export function PreferencesGroup() {
161
160
  <ToggleWrapModeItem />
162
161
  <ToggleFocusModeItem />
163
162
  <ToggleEdgeScrollingItem />
164
- <ToggleReduceMotionItem />
165
- <ToggleKeyboardShortcutsItem />
166
163
  <ToggleDynamicSizeModeItem />
167
164
  <TogglePasteAtCursorItem />
168
165
  <ToggleDebugModeItem />
@@ -170,6 +167,9 @@ export function PreferencesGroup() {
170
167
  <TldrawUiMenuGroup id="color-scheme">
171
168
  <ColorSchemeMenu />
172
169
  </TldrawUiMenuGroup>
170
+ <TldrawUiMenuGroup id="accessibility-menu">
171
+ <AccessibilityMenu />
172
+ </TldrawUiMenuGroup>
173
173
  </TldrawUiMenuSubmenu>
174
174
  <LanguageMenu />
175
175
  <KeyboardShortcutsMenuItem />
@@ -46,10 +46,10 @@ export class MinimapManager {
46
46
  const style = getComputedStyle(this.editor.getContainer())
47
47
 
48
48
  return {
49
- shapeFill: getRgba(style.getPropertyValue('--color-text-3').trim()),
50
- selectFill: getRgba(style.getPropertyValue('--color-selected').trim()),
51
- viewportFill: getRgba(style.getPropertyValue('--color-muted-1').trim()),
52
- background: getRgba(style.getPropertyValue('--color-low').trim()),
49
+ shapeFill: getRgba(style.getPropertyValue('--tl-color-text-3').trim()),
50
+ selectFill: getRgba(style.getPropertyValue('--tl-color-selected').trim()),
51
+ viewportFill: getRgba(style.getPropertyValue('--tl-color-muted-1').trim()),
52
+ background: getRgba(style.getPropertyValue('--tl-color-low').trim()),
53
53
  }
54
54
  }
55
55
 
@@ -1,6 +1,7 @@
1
1
  import {
2
2
  DefaultColorStyle,
3
3
  TLDefaultColorStyle,
4
+ getColorValue,
4
5
  getDefaultColorTheme,
5
6
  useEditor,
6
7
  useValue,
@@ -16,18 +17,20 @@ import {
16
17
  TldrawUiPopoverContent,
17
18
  TldrawUiPopoverTrigger,
18
19
  } from './primitives/TldrawUiPopover'
20
+ import { useTldrawUiOrientation } from './primitives/layout'
19
21
 
20
22
  /** @public @react */
21
23
  export function MobileStylePanel() {
22
24
  const editor = useEditor()
23
25
  const msg = useTranslation()
24
-
26
+ const { orientation } = useTldrawUiOrientation()
25
27
  const relevantStyles = useRelevantStyles()
26
28
  const color = relevantStyles?.get(DefaultColorStyle)
27
29
  const theme = getDefaultColorTheme({ isDarkMode: editor.user.getIsDarkMode() })
28
- const currentColor = (
29
- color?.type === 'shared' ? theme[color.value as TLDefaultColorStyle] : theme.black
30
- ).solid
30
+ const currentColor =
31
+ color?.type === 'shared'
32
+ ? getColorValue(theme, color.value as TLDefaultColorStyle, 'solid')
33
+ : getColorValue(theme, 'black', 'solid')
31
34
 
32
35
  const disableStylePanel = useValue(
33
36
  'disable style panel',
@@ -54,7 +57,7 @@ export function MobileStylePanel() {
54
57
  type="tool"
55
58
  data-testid="mobile-styles.button"
56
59
  style={{
57
- color: disableStylePanel ? 'var(--color-muted-1)' : currentColor,
60
+ color: disableStylePanel ? 'var(--tl-color-muted-1)' : currentColor,
58
61
  }}
59
62
  title={msg('style-panel.title')}
60
63
  disabled={disableStylePanel}
@@ -64,7 +67,7 @@ export function MobileStylePanel() {
64
67
  />
65
68
  </TldrawUiButton>
66
69
  </TldrawUiPopoverTrigger>
67
- <TldrawUiPopoverContent side="top" align="end">
70
+ <TldrawUiPopoverContent side={orientation === 'horizontal' ? 'top' : 'right'} align="end">
68
71
  {StylePanel && <StylePanel isMobile />}
69
72
  </TldrawUiPopoverContent>
70
73
  </TldrawUiPopover>
@@ -33,7 +33,7 @@ export const DefaultNavigationPanel = memo(function DefaultNavigationPanel() {
33
33
 
34
34
  return (
35
35
  <div ref={ref} className="tlui-navigation-panel">
36
- <TldrawUiToolbar className="tlui-buttons__horizontal" label={msg('navigation-zone.title')}>
36
+ <TldrawUiToolbar orientation="horizontal" label={msg('navigation-zone.title')}>
37
37
  {ZoomMenu && breakpoint < PORTRAIT_BREAKPOINT.TABLET ? (
38
38
  <ZoomMenu />
39
39
  ) : (
@@ -24,6 +24,7 @@ import {
24
24
  TldrawUiPopoverContent,
25
25
  TldrawUiPopoverTrigger,
26
26
  } from '../primitives/TldrawUiPopover'
27
+ import { TldrawUiRow } from '../primitives/layout'
27
28
  import { PageItemInput } from './PageItemInput'
28
29
  import { PageItemSubmenu } from './PageItemSubmenu'
29
30
  import { onMovePage } from './edit-pages-shared'
@@ -329,7 +330,7 @@ export const DefaultPageMenu = memo(function DefaultPageMenu() {
329
330
  <div className="tlui-page-menu__header">
330
331
  <div className="tlui-page-menu__header__title">{msg('page-menu.title')}</div>
331
332
  {!isReadonlyMode && (
332
- <div className="tlui-buttons__horizontal">
333
+ <TldrawUiRow>
333
334
  <TldrawUiButton
334
335
  type="icon"
335
336
  data-testid="page-menu.edit"
@@ -351,7 +352,7 @@ export const DefaultPageMenu = memo(function DefaultPageMenu() {
351
352
  >
352
353
  <TldrawUiButtonIcon icon="plus" />
353
354
  </TldrawUiButton>
354
- </div>
355
+ </TldrawUiRow>
355
356
  )}
356
357
  </div>
357
358
  <div
@@ -5,6 +5,7 @@ import { useTranslation } from '../../hooks/useTranslation/useTranslation'
5
5
  import { TldrawUiButton } from '../primitives/Button/TldrawUiButton'
6
6
  import { TldrawUiButtonIcon } from '../primitives/Button/TldrawUiButtonIcon'
7
7
  import { TldrawUiIcon } from '../primitives/TldrawUiIcon'
8
+ import { TldrawUiRow } from '../primitives/layout'
8
9
 
9
10
  export const PeopleMenuItem = track(function PeopleMenuItem({ userId }: { userId: string }) {
10
11
  const editor = useEditor()
@@ -29,8 +30,8 @@ export const PeopleMenuItem = track(function PeopleMenuItem({ userId }: { userId
29
30
  if (!presence) return null
30
31
 
31
32
  return (
32
- <div
33
- className="tlui-people-menu__item tlui-buttons__horizontal"
33
+ <TldrawUiRow
34
+ className="tlui-people-menu__item"
34
35
  data-follow={youAreFollowingThem || theyAreFollowingYou}
35
36
  >
36
37
  <TldrawUiButton
@@ -61,6 +62,6 @@ export const PeopleMenuItem = track(function PeopleMenuItem({ userId }: { userId
61
62
  icon={theyAreFollowingYou ? 'leading' : youAreFollowingThem ? 'following' : 'follow'}
62
63
  />
63
64
  </TldrawUiButton>
64
- </div>
65
+ </TldrawUiRow>
65
66
  )
66
67
  })
@@ -5,6 +5,7 @@ import { useUiEvents } from '../../context/events'
5
5
  import { useTranslation } from '../../hooks/useTranslation/useTranslation'
6
6
  import { TldrawUiButton } from '../primitives/Button/TldrawUiButton'
7
7
  import { TldrawUiButtonIcon } from '../primitives/Button/TldrawUiButtonIcon'
8
+ import { TldrawUiGrid } from '../primitives/layout'
8
9
 
9
10
  export const UserPresenceColorPicker = track(function UserPresenceColorPicker() {
10
11
  const editor = useEditor()
@@ -100,7 +101,7 @@ export const UserPresenceColorPicker = track(function UserPresenceColorPicker()
100
101
  side="left"
101
102
  sideOffset={8}
102
103
  >
103
- <div className={'tlui-buttons__grid'}>
104
+ <TldrawUiGrid>
104
105
  {USER_COLORS.map((item: string) => (
105
106
  <TldrawUiButton
106
107
  type="icon"
@@ -110,7 +111,6 @@ export const UserPresenceColorPicker = track(function UserPresenceColorPicker()
110
111
  aria-label={item}
111
112
  isActive={value === item}
112
113
  title={item}
113
- className={'tlui-button-grid__button'}
114
114
  style={{ color: item }}
115
115
  onPointerEnter={handleButtonPointerEnter}
116
116
  onPointerDown={handleButtonPointerDown}
@@ -120,7 +120,7 @@ export const UserPresenceColorPicker = track(function UserPresenceColorPicker()
120
120
  <TldrawUiButtonIcon icon="color" />
121
121
  </TldrawUiButton>
122
122
  ))}
123
- </div>
123
+ </TldrawUiGrid>
124
124
  </_Popover.Content>
125
125
  </_Popover.Portal>
126
126
  </_Popover.Root>
@@ -1,4 +1,4 @@
1
- import { useEditor, usePassThroughWheelEvents } from '@tldraw/editor'
1
+ import { useEditor, usePassThroughWheelEvents, useValue } from '@tldraw/editor'
2
2
  import classNames from 'classnames'
3
3
  import { ReactNode, memo, useCallback, useEffect, useRef } from 'react'
4
4
  import { useRelevantStyles } from '../../hooks/useRelevantStyles'
@@ -16,6 +16,7 @@ export const DefaultStylePanel = memo(function DefaultStylePanel({
16
16
  children,
17
17
  }: TLUiStylePanelProps) {
18
18
  const editor = useEditor()
19
+ const showUiLabels = useValue('showUiLabels', () => editor.user.getShowUiLabels(), [editor])
19
20
 
20
21
  const ref = useRef<HTMLDivElement>(null)
21
22
  usePassThroughWheelEvents(ref)
@@ -50,6 +51,7 @@ export const DefaultStylePanel = memo(function DefaultStylePanel({
50
51
  ref={ref}
51
52
  className={classNames('tlui-style-panel', { 'tlui-style-panel__wrapper': !isMobile })}
52
53
  data-ismobile={isMobile}
54
+ data-show-ui-labels={showUiLabels}
53
55
  onPointerLeave={handlePointerOut}
54
56
  >
55
57
  {content}