tldraw 3.16.0-canary.aa1aff3ffe55 → 3.16.0-canary.b5a35402e79e

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 (271) hide show
  1. package/dist-cjs/index.d.ts +132 -6
  2. package/dist-cjs/index.js +14 -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/shapes/arrow/ArrowShapeUtil.js +3 -3
  7. package/dist-cjs/lib/shapes/arrow/ArrowShapeUtil.js.map +2 -2
  8. package/dist-cjs/lib/shapes/arrow/elbow/ElbowArrowDebug.js +3 -3
  9. package/dist-cjs/lib/shapes/arrow/elbow/ElbowArrowDebug.js.map +1 -1
  10. package/dist-cjs/lib/shapes/draw/DrawShapeUtil.js +3 -3
  11. package/dist-cjs/lib/shapes/draw/DrawShapeUtil.js.map +2 -2
  12. package/dist-cjs/lib/shapes/embed/EmbedShapeUtil.js +1 -1
  13. package/dist-cjs/lib/shapes/embed/EmbedShapeUtil.js.map +1 -1
  14. package/dist-cjs/lib/shapes/frame/FrameShapeUtil.js +12 -12
  15. package/dist-cjs/lib/shapes/frame/FrameShapeUtil.js.map +2 -2
  16. package/dist-cjs/lib/shapes/frame/components/FrameHeading.js +1 -1
  17. package/dist-cjs/lib/shapes/frame/components/FrameHeading.js.map +2 -2
  18. package/dist-cjs/lib/shapes/geo/GeoShapeUtil.js +2 -2
  19. package/dist-cjs/lib/shapes/geo/GeoShapeUtil.js.map +2 -2
  20. package/dist-cjs/lib/shapes/geo/components/GeoShapeBody.js +2 -1
  21. package/dist-cjs/lib/shapes/geo/components/GeoShapeBody.js.map +2 -2
  22. package/dist-cjs/lib/shapes/highlight/HighlightShapeUtil.js +5 -1
  23. package/dist-cjs/lib/shapes/highlight/HighlightShapeUtil.js.map +2 -2
  24. package/dist-cjs/lib/shapes/image/ImageShapeUtil.js +3 -3
  25. package/dist-cjs/lib/shapes/image/ImageShapeUtil.js.map +1 -1
  26. package/dist-cjs/lib/shapes/line/LineShapeUtil.js +5 -1
  27. package/dist-cjs/lib/shapes/line/LineShapeUtil.js.map +2 -2
  28. package/dist-cjs/lib/shapes/note/NoteShapeUtil.js +4 -4
  29. package/dist-cjs/lib/shapes/note/NoteShapeUtil.js.map +2 -2
  30. package/dist-cjs/lib/shapes/shared/ShapeFill.js +4 -4
  31. package/dist-cjs/lib/shapes/shared/ShapeFill.js.map +2 -2
  32. package/dist-cjs/lib/shapes/shared/usePrefersReducedMotion.js +10 -1
  33. package/dist-cjs/lib/shapes/shared/usePrefersReducedMotion.js.map +2 -2
  34. package/dist-cjs/lib/shapes/text/TextShapeUtil.js +2 -2
  35. package/dist-cjs/lib/shapes/text/TextShapeUtil.js.map +2 -2
  36. package/dist-cjs/lib/shapes/video/VideoShapeUtil.js +3 -3
  37. package/dist-cjs/lib/shapes/video/VideoShapeUtil.js.map +1 -1
  38. package/dist-cjs/lib/tools/SelectTool/childStates/Translating.js.map +2 -2
  39. package/dist-cjs/lib/ui/TldrawUi.js +14 -0
  40. package/dist-cjs/lib/ui/TldrawUi.js.map +3 -3
  41. package/dist-cjs/lib/ui/components/AccessibilityMenu.js +35 -0
  42. package/dist-cjs/lib/ui/components/AccessibilityMenu.js.map +7 -0
  43. package/dist-cjs/lib/ui/components/ActionsMenu/DefaultActionsMenu.js +12 -3
  44. package/dist-cjs/lib/ui/components/ActionsMenu/DefaultActionsMenu.js.map +2 -2
  45. package/dist-cjs/lib/ui/components/DefaultMenuPanel.js +3 -2
  46. package/dist-cjs/lib/ui/components/DefaultMenuPanel.js.map +2 -2
  47. package/dist-cjs/lib/ui/components/MainMenu/DefaultMainMenuContent.js +3 -3
  48. package/dist-cjs/lib/ui/components/MainMenu/DefaultMainMenuContent.js.map +2 -2
  49. package/dist-cjs/lib/ui/components/Minimap/MinimapManager.js +4 -4
  50. package/dist-cjs/lib/ui/components/Minimap/MinimapManager.js.map +2 -2
  51. package/dist-cjs/lib/ui/components/MobileStylePanel.js +5 -3
  52. package/dist-cjs/lib/ui/components/MobileStylePanel.js.map +2 -2
  53. package/dist-cjs/lib/ui/components/NavigationPanel/DefaultNavigationPanel.js +1 -1
  54. package/dist-cjs/lib/ui/components/NavigationPanel/DefaultNavigationPanel.js.map +2 -2
  55. package/dist-cjs/lib/ui/components/PageMenu/DefaultPageMenu.js +2 -1
  56. package/dist-cjs/lib/ui/components/PageMenu/DefaultPageMenu.js.map +2 -2
  57. package/dist-cjs/lib/ui/components/SharePanel/PeopleMenuItem.js +3 -2
  58. package/dist-cjs/lib/ui/components/SharePanel/PeopleMenuItem.js.map +2 -2
  59. package/dist-cjs/lib/ui/components/SharePanel/UserPresenceColorPicker.js +2 -2
  60. package/dist-cjs/lib/ui/components/SharePanel/UserPresenceColorPicker.js.map +2 -2
  61. package/dist-cjs/lib/ui/components/StylePanel/DefaultStylePanel.js +2 -0
  62. package/dist-cjs/lib/ui/components/StylePanel/DefaultStylePanel.js.map +2 -2
  63. package/dist-cjs/lib/ui/components/StylePanel/DefaultStylePanelContent.js +171 -140
  64. package/dist-cjs/lib/ui/components/StylePanel/DefaultStylePanelContent.js.map +2 -2
  65. package/dist-cjs/lib/ui/components/StylePanel/DoubleDropdownPicker.js +3 -3
  66. package/dist-cjs/lib/ui/components/StylePanel/DoubleDropdownPicker.js.map +2 -2
  67. package/dist-cjs/lib/ui/components/StylePanel/DropdownPicker.js +26 -25
  68. package/dist-cjs/lib/ui/components/StylePanel/DropdownPicker.js.map +3 -3
  69. package/dist-cjs/lib/ui/components/Toolbar/DefaultImageToolbarContent.js +1 -1
  70. package/dist-cjs/lib/ui/components/Toolbar/DefaultImageToolbarContent.js.map +2 -2
  71. package/dist-cjs/lib/ui/components/Toolbar/DefaultToolbar.js +66 -21
  72. package/dist-cjs/lib/ui/components/Toolbar/DefaultToolbar.js.map +3 -3
  73. package/dist-cjs/lib/ui/components/Toolbar/OverflowingToolbar.js +189 -80
  74. package/dist-cjs/lib/ui/components/Toolbar/OverflowingToolbar.js.map +3 -3
  75. package/dist-cjs/lib/ui/components/Toolbar/ToggleToolLockedButton.js +5 -4
  76. package/dist-cjs/lib/ui/components/Toolbar/ToggleToolLockedButton.js.map +2 -2
  77. package/dist-cjs/lib/ui/components/menu-items.js +6 -0
  78. package/dist-cjs/lib/ui/components/menu-items.js.map +2 -2
  79. package/dist-cjs/lib/ui/components/primitives/TldrawUiButtonPicker.js +5 -16
  80. package/dist-cjs/lib/ui/components/primitives/TldrawUiButtonPicker.js.map +3 -3
  81. package/dist-cjs/lib/ui/components/primitives/TldrawUiContextualToolbar.js +1 -1
  82. package/dist-cjs/lib/ui/components/primitives/TldrawUiContextualToolbar.js.map +2 -2
  83. package/dist-cjs/lib/ui/components/primitives/TldrawUiPopover.js +3 -2
  84. package/dist-cjs/lib/ui/components/primitives/TldrawUiPopover.js.map +3 -3
  85. package/dist-cjs/lib/ui/components/primitives/TldrawUiToolbar.js +30 -7
  86. package/dist-cjs/lib/ui/components/primitives/TldrawUiToolbar.js.map +2 -2
  87. package/dist-cjs/lib/ui/components/primitives/TldrawUiTooltip.js +268 -0
  88. package/dist-cjs/lib/ui/components/primitives/TldrawUiTooltip.js.map +7 -0
  89. package/dist-cjs/lib/ui/components/primitives/layout.js +76 -0
  90. package/dist-cjs/lib/ui/components/primitives/layout.js.map +7 -0
  91. package/dist-cjs/lib/ui/components/primitives/menus/TldrawUiMenuContext.js.map +2 -2
  92. package/dist-cjs/lib/ui/components/primitives/menus/TldrawUiMenuGroup.js +25 -12
  93. package/dist-cjs/lib/ui/components/primitives/menus/TldrawUiMenuGroup.js.map +2 -2
  94. package/dist-cjs/lib/ui/components/primitives/menus/TldrawUiMenuItem.js +153 -20
  95. package/dist-cjs/lib/ui/components/primitives/menus/TldrawUiMenuItem.js.map +2 -2
  96. package/dist-cjs/lib/ui/context/TldrawUiContextProvider.js +3 -2
  97. package/dist-cjs/lib/ui/context/TldrawUiContextProvider.js.map +2 -2
  98. package/dist-cjs/lib/ui/context/actions.js +15 -0
  99. package/dist-cjs/lib/ui/context/actions.js.map +2 -2
  100. package/dist-cjs/lib/ui/context/events.js.map +2 -2
  101. package/dist-cjs/lib/ui/hooks/useTools.js +94 -9
  102. package/dist-cjs/lib/ui/hooks/useTools.js.map +2 -2
  103. package/dist-cjs/lib/ui/hooks/useTranslation/TLUiTranslationKey.js.map +1 -1
  104. package/dist-cjs/lib/ui/hooks/useTranslation/defaultTranslation.js +3 -0
  105. package/dist-cjs/lib/ui/hooks/useTranslation/defaultTranslation.js.map +2 -2
  106. package/dist-cjs/lib/ui/version.js +3 -3
  107. package/dist-cjs/lib/ui/version.js.map +1 -1
  108. package/dist-esm/index.d.mts +132 -6
  109. package/dist-esm/index.mjs +25 -1
  110. package/dist-esm/index.mjs.map +2 -2
  111. package/dist-esm/lib/canvas/TldrawScribble.mjs +1 -1
  112. package/dist-esm/lib/canvas/TldrawScribble.mjs.map +2 -2
  113. package/dist-esm/lib/shapes/arrow/ArrowShapeUtil.mjs +4 -3
  114. package/dist-esm/lib/shapes/arrow/ArrowShapeUtil.mjs.map +2 -2
  115. package/dist-esm/lib/shapes/arrow/elbow/ElbowArrowDebug.mjs +3 -3
  116. package/dist-esm/lib/shapes/arrow/elbow/ElbowArrowDebug.mjs.map +1 -1
  117. package/dist-esm/lib/shapes/draw/DrawShapeUtil.mjs +4 -3
  118. package/dist-esm/lib/shapes/draw/DrawShapeUtil.mjs.map +2 -2
  119. package/dist-esm/lib/shapes/embed/EmbedShapeUtil.mjs +1 -1
  120. package/dist-esm/lib/shapes/embed/EmbedShapeUtil.mjs.map +1 -1
  121. package/dist-esm/lib/shapes/frame/FrameShapeUtil.mjs +13 -12
  122. package/dist-esm/lib/shapes/frame/FrameShapeUtil.mjs.map +2 -2
  123. package/dist-esm/lib/shapes/frame/components/FrameHeading.mjs +1 -1
  124. package/dist-esm/lib/shapes/frame/components/FrameHeading.mjs.map +2 -2
  125. package/dist-esm/lib/shapes/geo/GeoShapeUtil.mjs +3 -2
  126. package/dist-esm/lib/shapes/geo/GeoShapeUtil.mjs.map +2 -2
  127. package/dist-esm/lib/shapes/geo/components/GeoShapeBody.mjs +2 -1
  128. package/dist-esm/lib/shapes/geo/components/GeoShapeBody.mjs.map +2 -2
  129. package/dist-esm/lib/shapes/highlight/HighlightShapeUtil.mjs +6 -1
  130. package/dist-esm/lib/shapes/highlight/HighlightShapeUtil.mjs.map +2 -2
  131. package/dist-esm/lib/shapes/image/ImageShapeUtil.mjs +3 -3
  132. package/dist-esm/lib/shapes/image/ImageShapeUtil.mjs.map +1 -1
  133. package/dist-esm/lib/shapes/line/LineShapeUtil.mjs +6 -1
  134. package/dist-esm/lib/shapes/line/LineShapeUtil.mjs.map +2 -2
  135. package/dist-esm/lib/shapes/note/NoteShapeUtil.mjs +5 -4
  136. package/dist-esm/lib/shapes/note/NoteShapeUtil.mjs.map +2 -2
  137. package/dist-esm/lib/shapes/shared/ShapeFill.mjs +5 -4
  138. package/dist-esm/lib/shapes/shared/ShapeFill.mjs.map +2 -2
  139. package/dist-esm/lib/shapes/shared/usePrefersReducedMotion.mjs +10 -1
  140. package/dist-esm/lib/shapes/shared/usePrefersReducedMotion.mjs.map +2 -2
  141. package/dist-esm/lib/shapes/text/TextShapeUtil.mjs +3 -2
  142. package/dist-esm/lib/shapes/text/TextShapeUtil.mjs.map +2 -2
  143. package/dist-esm/lib/shapes/video/VideoShapeUtil.mjs +3 -3
  144. package/dist-esm/lib/shapes/video/VideoShapeUtil.mjs.map +1 -1
  145. package/dist-esm/lib/tools/SelectTool/childStates/Translating.mjs.map +2 -2
  146. package/dist-esm/lib/ui/TldrawUi.mjs +16 -2
  147. package/dist-esm/lib/ui/TldrawUi.mjs.map +3 -3
  148. package/dist-esm/lib/ui/components/AccessibilityMenu.mjs +19 -0
  149. package/dist-esm/lib/ui/components/AccessibilityMenu.mjs.map +7 -0
  150. package/dist-esm/lib/ui/components/ActionsMenu/DefaultActionsMenu.mjs +12 -3
  151. package/dist-esm/lib/ui/components/ActionsMenu/DefaultActionsMenu.mjs.map +2 -2
  152. package/dist-esm/lib/ui/components/DefaultMenuPanel.mjs +3 -2
  153. package/dist-esm/lib/ui/components/DefaultMenuPanel.mjs.map +2 -2
  154. package/dist-esm/lib/ui/components/MainMenu/DefaultMainMenuContent.mjs +3 -5
  155. package/dist-esm/lib/ui/components/MainMenu/DefaultMainMenuContent.mjs.map +2 -2
  156. package/dist-esm/lib/ui/components/Minimap/MinimapManager.mjs +4 -4
  157. package/dist-esm/lib/ui/components/Minimap/MinimapManager.mjs.map +2 -2
  158. package/dist-esm/lib/ui/components/MobileStylePanel.mjs +6 -3
  159. package/dist-esm/lib/ui/components/MobileStylePanel.mjs.map +2 -2
  160. package/dist-esm/lib/ui/components/NavigationPanel/DefaultNavigationPanel.mjs +1 -1
  161. package/dist-esm/lib/ui/components/NavigationPanel/DefaultNavigationPanel.mjs.map +2 -2
  162. package/dist-esm/lib/ui/components/PageMenu/DefaultPageMenu.mjs +2 -1
  163. package/dist-esm/lib/ui/components/PageMenu/DefaultPageMenu.mjs.map +2 -2
  164. package/dist-esm/lib/ui/components/SharePanel/PeopleMenuItem.mjs +3 -2
  165. package/dist-esm/lib/ui/components/SharePanel/PeopleMenuItem.mjs.map +2 -2
  166. package/dist-esm/lib/ui/components/SharePanel/UserPresenceColorPicker.mjs +2 -2
  167. package/dist-esm/lib/ui/components/SharePanel/UserPresenceColorPicker.mjs.map +2 -2
  168. package/dist-esm/lib/ui/components/StylePanel/DefaultStylePanel.mjs +3 -1
  169. package/dist-esm/lib/ui/components/StylePanel/DefaultStylePanel.mjs.map +2 -2
  170. package/dist-esm/lib/ui/components/StylePanel/DefaultStylePanelContent.mjs +171 -140
  171. package/dist-esm/lib/ui/components/StylePanel/DefaultStylePanelContent.mjs.map +2 -2
  172. package/dist-esm/lib/ui/components/StylePanel/DoubleDropdownPicker.mjs +3 -3
  173. package/dist-esm/lib/ui/components/StylePanel/DoubleDropdownPicker.mjs.map +2 -2
  174. package/dist-esm/lib/ui/components/StylePanel/DropdownPicker.mjs +26 -25
  175. package/dist-esm/lib/ui/components/StylePanel/DropdownPicker.mjs.map +2 -2
  176. package/dist-esm/lib/ui/components/Toolbar/DefaultImageToolbarContent.mjs +1 -1
  177. package/dist-esm/lib/ui/components/Toolbar/DefaultImageToolbarContent.mjs.map +2 -2
  178. package/dist-esm/lib/ui/components/Toolbar/DefaultToolbar.mjs +56 -21
  179. package/dist-esm/lib/ui/components/Toolbar/DefaultToolbar.mjs.map +2 -2
  180. package/dist-esm/lib/ui/components/Toolbar/OverflowingToolbar.mjs +192 -81
  181. package/dist-esm/lib/ui/components/Toolbar/OverflowingToolbar.mjs.map +3 -3
  182. package/dist-esm/lib/ui/components/Toolbar/ToggleToolLockedButton.mjs +5 -4
  183. package/dist-esm/lib/ui/components/Toolbar/ToggleToolLockedButton.mjs.map +2 -2
  184. package/dist-esm/lib/ui/components/menu-items.mjs +6 -0
  185. package/dist-esm/lib/ui/components/menu-items.mjs.map +2 -2
  186. package/dist-esm/lib/ui/components/primitives/TldrawUiButtonPicker.mjs +6 -6
  187. package/dist-esm/lib/ui/components/primitives/TldrawUiButtonPicker.mjs.map +2 -2
  188. package/dist-esm/lib/ui/components/primitives/TldrawUiContextualToolbar.mjs +1 -1
  189. package/dist-esm/lib/ui/components/primitives/TldrawUiContextualToolbar.mjs.map +2 -2
  190. package/dist-esm/lib/ui/components/primitives/TldrawUiPopover.mjs +3 -2
  191. package/dist-esm/lib/ui/components/primitives/TldrawUiPopover.mjs.map +2 -2
  192. package/dist-esm/lib/ui/components/primitives/TldrawUiToolbar.mjs +30 -7
  193. package/dist-esm/lib/ui/components/primitives/TldrawUiToolbar.mjs.map +2 -2
  194. package/dist-esm/lib/ui/components/primitives/TldrawUiTooltip.mjs +245 -0
  195. package/dist-esm/lib/ui/components/primitives/TldrawUiTooltip.mjs.map +7 -0
  196. package/dist-esm/lib/ui/components/primitives/layout.mjs +46 -0
  197. package/dist-esm/lib/ui/components/primitives/layout.mjs.map +7 -0
  198. package/dist-esm/lib/ui/components/primitives/menus/TldrawUiMenuContext.mjs.map +2 -2
  199. package/dist-esm/lib/ui/components/primitives/menus/TldrawUiMenuGroup.mjs +25 -12
  200. package/dist-esm/lib/ui/components/primitives/menus/TldrawUiMenuGroup.mjs.map +2 -2
  201. package/dist-esm/lib/ui/components/primitives/menus/TldrawUiMenuItem.mjs +161 -22
  202. package/dist-esm/lib/ui/components/primitives/menus/TldrawUiMenuItem.mjs.map +2 -2
  203. package/dist-esm/lib/ui/context/TldrawUiContextProvider.mjs +3 -2
  204. package/dist-esm/lib/ui/context/TldrawUiContextProvider.mjs.map +2 -2
  205. package/dist-esm/lib/ui/context/actions.mjs +15 -0
  206. package/dist-esm/lib/ui/context/actions.mjs.map +2 -2
  207. package/dist-esm/lib/ui/context/events.mjs.map +2 -2
  208. package/dist-esm/lib/ui/hooks/useTools.mjs +102 -10
  209. package/dist-esm/lib/ui/hooks/useTools.mjs.map +2 -2
  210. package/dist-esm/lib/ui/hooks/useTranslation/defaultTranslation.mjs +3 -0
  211. package/dist-esm/lib/ui/hooks/useTranslation/defaultTranslation.mjs.map +2 -2
  212. package/dist-esm/lib/ui/version.mjs +3 -3
  213. package/dist-esm/lib/ui/version.mjs.map +1 -1
  214. package/package.json +3 -3
  215. package/src/index.ts +20 -0
  216. package/src/lib/canvas/TldrawScribble.tsx +1 -1
  217. package/src/lib/shapes/arrow/ArrowShapeUtil.tsx +4 -3
  218. package/src/lib/shapes/arrow/elbow/ElbowArrowDebug.tsx +3 -3
  219. package/src/lib/shapes/draw/DrawShapeUtil.tsx +4 -3
  220. package/src/lib/shapes/embed/EmbedShapeUtil.tsx +1 -1
  221. package/src/lib/shapes/frame/FrameShapeUtil.tsx +21 -14
  222. package/src/lib/shapes/frame/components/FrameHeading.tsx +1 -1
  223. package/src/lib/shapes/geo/GeoShapeUtil.tsx +3 -2
  224. package/src/lib/shapes/geo/components/GeoShapeBody.tsx +2 -2
  225. package/src/lib/shapes/highlight/HighlightShapeUtil.tsx +7 -1
  226. package/src/lib/shapes/image/ImageShapeUtil.tsx +3 -3
  227. package/src/lib/shapes/line/LineShapeUtil.tsx +6 -1
  228. package/src/lib/shapes/note/NoteShapeUtil.tsx +9 -4
  229. package/src/lib/shapes/shared/ShapeFill.tsx +5 -4
  230. package/src/lib/shapes/shared/usePrefersReducedMotion.tsx +11 -1
  231. package/src/lib/shapes/text/TextShapeUtil.tsx +3 -2
  232. package/src/lib/shapes/video/VideoShapeUtil.tsx +3 -3
  233. package/src/lib/tools/SelectTool/childStates/Translating.ts +0 -1
  234. package/src/lib/ui/TldrawUi.tsx +17 -2
  235. package/src/lib/ui/components/AccessibilityMenu.tsx +20 -0
  236. package/src/lib/ui/components/ActionsMenu/DefaultActionsMenu.tsx +15 -3
  237. package/src/lib/ui/components/DefaultMenuPanel.tsx +4 -3
  238. package/src/lib/ui/components/MainMenu/DefaultMainMenuContent.tsx +4 -4
  239. package/src/lib/ui/components/Minimap/MinimapManager.ts +4 -4
  240. package/src/lib/ui/components/MobileStylePanel.tsx +9 -6
  241. package/src/lib/ui/components/NavigationPanel/DefaultNavigationPanel.tsx +1 -1
  242. package/src/lib/ui/components/PageMenu/DefaultPageMenu.tsx +3 -2
  243. package/src/lib/ui/components/SharePanel/PeopleMenuItem.tsx +4 -3
  244. package/src/lib/ui/components/SharePanel/UserPresenceColorPicker.tsx +3 -3
  245. package/src/lib/ui/components/StylePanel/DefaultStylePanel.tsx +3 -1
  246. package/src/lib/ui/components/StylePanel/DefaultStylePanelContent.tsx +146 -107
  247. package/src/lib/ui/components/StylePanel/DoubleDropdownPicker.tsx +3 -3
  248. package/src/lib/ui/components/StylePanel/DropdownPicker.tsx +7 -6
  249. package/src/lib/ui/components/Toolbar/DefaultImageToolbarContent.tsx +1 -1
  250. package/src/lib/ui/components/Toolbar/DefaultToolbar.tsx +55 -23
  251. package/src/lib/ui/components/Toolbar/OverflowingToolbar.tsx +212 -61
  252. package/src/lib/ui/components/Toolbar/ToggleToolLockedButton.tsx +14 -11
  253. package/src/lib/ui/components/menu-items.tsx +8 -0
  254. package/src/lib/ui/components/primitives/TldrawUiButtonPicker.tsx +40 -37
  255. package/src/lib/ui/components/primitives/TldrawUiContextualToolbar.tsx +1 -1
  256. package/src/lib/ui/components/primitives/TldrawUiPopover.tsx +4 -2
  257. package/src/lib/ui/components/primitives/TldrawUiToolbar.tsx +51 -12
  258. package/src/lib/ui/components/primitives/TldrawUiTooltip.tsx +327 -0
  259. package/src/lib/ui/components/primitives/layout.tsx +107 -0
  260. package/src/lib/ui/components/primitives/menus/TldrawUiMenuContext.tsx +0 -1
  261. package/src/lib/ui/components/primitives/menus/TldrawUiMenuGroup.tsx +29 -16
  262. package/src/lib/ui/components/primitives/menus/TldrawUiMenuItem.tsx +220 -19
  263. package/src/lib/ui/context/TldrawUiContextProvider.tsx +23 -20
  264. package/src/lib/ui/context/actions.tsx +15 -0
  265. package/src/lib/ui/context/events.tsx +2 -0
  266. package/src/lib/ui/hooks/useTools.tsx +140 -10
  267. package/src/lib/ui/hooks/useTranslation/TLUiTranslationKey.ts +3 -0
  268. package/src/lib/ui/hooks/useTranslation/defaultTranslation.ts +3 -0
  269. package/src/lib/ui/version.ts +3 -3
  270. package/src/lib/ui.css +406 -292
  271. package/tldraw.css +699 -580
@@ -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
  >
@@ -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,
@@ -220,13 +221,16 @@ export class FrameShapeUtil extends BaseBoxShapeUtil<TLFrameShape> {
220
221
  )
221
222
 
222
223
  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
224
+ const colorToUse = showFrameColors ? shape.props.color : 'black'
225
+ const frameFill = getColorValue(theme, colorToUse, 'frameFill')
226
+ const frameStroke = getColorValue(theme, colorToUse, 'frameStroke')
227
+ const frameHeadingStroke = showFrameColors
228
+ ? getColorValue(theme, colorToUse, 'frameHeadingStroke')
229
+ : theme.background
230
+ const frameHeadingFill = showFrameColors
231
+ ? getColorValue(theme, colorToUse, 'frameHeadingFill')
232
+ : theme.background
233
+ const frameHeadingText = getColorValue(theme, colorToUse, 'frameText')
230
234
 
231
235
  return (
232
236
  <>
@@ -277,13 +281,16 @@ export class FrameShapeUtil extends BaseBoxShapeUtil<TLFrameShape> {
277
281
  const text = createTextJsxFromSpans(this.editor, spans, opts)
278
282
 
279
283
  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
284
+ const colorToUse = showFrameColors ? shape.props.color : 'black'
285
+ const frameFill = getColorValue(theme, colorToUse, 'frameFill')
286
+ const frameStroke = getColorValue(theme, colorToUse, 'frameStroke')
287
+ const frameHeadingStroke = showFrameColors
288
+ ? getColorValue(theme, colorToUse, 'frameHeadingStroke')
289
+ : theme.background
290
+ const frameHeadingFill = showFrameColors
291
+ ? getColorValue(theme, colorToUse, 'frameHeadingFill')
292
+ : theme.background
293
+ const frameHeadingText = getColorValue(theme, colorToUse, 'frameText')
287
294
 
288
295
  return (
289
296
  <>
@@ -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
  }}
@@ -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,
@@ -220,7 +221,7 @@ export class GeoShapeUtil extends BaseBoxShapeUtil<TLGeoShape> {
220
221
  verticalAlign={verticalAlign}
221
222
  richText={richText}
222
223
  isSelected={isOnlySelected}
223
- labelColor={theme[props.labelColor].solid}
224
+ labelColor={getColorValue(theme, props.labelColor, 'solid')}
224
225
  wrap
225
226
  />
226
227
  </HTMLContainer>
@@ -278,7 +279,7 @@ export class GeoShapeUtil extends BaseBoxShapeUtil<TLGeoShape> {
278
279
  align={props.align}
279
280
  verticalAlign={props.verticalAlign}
280
281
  richText={props.richText}
281
- labelColor={theme[props.labelColor].solid}
282
+ labelColor={getColorValue(theme, props.labelColor, 'solid')}
282
283
  bounds={bounds}
283
284
  padding={LABEL_PADDING}
284
285
  />
@@ -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
@@ -314,9 +314,9 @@ const ImageShape = memo(function ImageShape({ shape }: { shape: TLImageShape })
314
314
  overflow: 'hidden',
315
315
  width: shape.props.w,
316
316
  height: shape.props.h,
317
- color: 'var(--color-text-3)',
318
- backgroundColor: 'var(--color-low)',
319
- border: '1px solid var(--color-low-border)',
317
+ color: 'var(--tl-color-text-3)',
318
+ backgroundColor: 'var(--tl-color-low)',
319
+ border: '1px solid var(--tl-color-low-border)',
320
320
  }}
321
321
  >
322
322
  <div
@@ -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
  }
@@ -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,
@@ -288,7 +289,7 @@ export class NoteShapeUtil extends ShapeUtil<TLNoteShape> {
288
289
  style={{
289
290
  width: nw,
290
291
  height: nh,
291
- backgroundColor: theme[color].note.fill,
292
+ backgroundColor: getColorValue(theme, color, 'noteFill'),
292
293
  borderBottom: hideShadows
293
294
  ? isDarkMode
294
295
  ? `${2 * scale}px solid rgb(20, 20, 20)`
@@ -308,7 +309,11 @@ export class NoteShapeUtil extends ShapeUtil<TLNoteShape> {
308
309
  verticalAlign={verticalAlign}
309
310
  richText={richText}
310
311
  isSelected={isSelected}
311
- labelColor={labelColor === 'black' ? theme[color].note.text : theme[labelColor].fill}
312
+ labelColor={
313
+ labelColor === 'black'
314
+ ? getColorValue(theme, color, 'noteText')
315
+ : getColorValue(theme, labelColor, 'fill')
316
+ }
312
317
  wrap
313
318
  padding={LABEL_PADDING * scale}
314
319
  hasCustomTabBehavior
@@ -343,7 +348,7 @@ export class NoteShapeUtil extends ShapeUtil<TLNoteShape> {
343
348
  align={shape.props.align}
344
349
  verticalAlign={shape.props.verticalAlign}
345
350
  richText={shape.props.richText}
346
- labelColor={theme[shape.props.color].note.text}
351
+ labelColor={getColorValue(theme, shape.props.color, 'noteText')}
347
352
  bounds={bounds}
348
353
  padding={LABEL_PADDING}
349
354
  showTextOutline={false}
@@ -357,7 +362,7 @@ export class NoteShapeUtil extends ShapeUtil<TLNoteShape> {
357
362
  rx={1}
358
363
  width={NOTE_SIZE}
359
364
  height={bounds.h}
360
- fill={theme[shape.props.color].note.fill}
365
+ fill={getColorValue(theme, shape.props.color, 'noteFill')}
361
366
  />
362
367
  {textLabel}
363
368
  </>
@@ -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}
@@ -1,10 +1,20 @@
1
+ import { useMaybeEditor, useValue } from '@tldraw/editor'
1
2
  import { useEffect, useState } from 'react'
2
3
 
3
4
  /** @public */
4
5
  export function usePrefersReducedMotion() {
6
+ const editor = useMaybeEditor()
7
+ const animationSpeed = useValue('animationSpeed', () => editor?.user.getAnimationSpeed(), [
8
+ editor,
9
+ ])
5
10
  const [prefersReducedMotion, setPrefersReducedMotion] = useState(false)
6
11
 
7
12
  useEffect(() => {
13
+ if (animationSpeed !== undefined) {
14
+ setPrefersReducedMotion(animationSpeed === 0 ? true : false)
15
+ return
16
+ }
17
+
8
18
  if (typeof window === 'undefined' || !('matchMedia' in window)) return
9
19
  const mql = window.matchMedia('(prefers-reduced-motion: reduce)')
10
20
  const handler = () => {
@@ -13,7 +23,7 @@ export function usePrefersReducedMotion() {
13
23
  handler()
14
24
  mql.addEventListener('change', handler)
15
25
  return () => mql.removeEventListener('change', handler)
16
- }, [])
26
+ }, [animationSpeed])
17
27
 
18
28
  return prefersReducedMotion
19
29
  }
@@ -11,6 +11,7 @@ import {
11
11
  TLTextShape,
12
12
  Vec,
13
13
  createComputedCache,
14
+ getColorValue,
14
15
  getDefaultColorTheme,
15
16
  getFontsFromRichText,
16
17
  isEqual,
@@ -135,7 +136,7 @@ export class TextShapeUtil extends ShapeUtil<TLTextShape> {
135
136
  align={textAlign}
136
137
  verticalAlign="middle"
137
138
  richText={richText}
138
- labelColor={theme[color].solid}
139
+ labelColor={getColorValue(theme, color, 'solid')}
139
140
  isSelected={isSelected}
140
141
  textWidth={width}
141
142
  textHeight={height}
@@ -171,7 +172,7 @@ export class TextShapeUtil extends ShapeUtil<TLTextShape> {
171
172
  align={shape.props.textAlign}
172
173
  verticalAlign="middle"
173
174
  richText={shape.props.richText}
174
- labelColor={theme[shape.props.color].solid}
175
+ labelColor={getColorValue(theme, shape.props.color, 'solid')}
175
176
  bounds={exportBounds}
176
177
  padding={0}
177
178
  />
@@ -142,9 +142,9 @@ const VideoShape = memo(function VideoShape({ shape }: { shape: TLVideoShape })
142
142
  <HTMLContainer
143
143
  id={shape.id}
144
144
  style={{
145
- color: 'var(--color-text-3)',
146
- backgroundColor: asset ? 'transparent' : 'var(--color-low)',
147
- border: asset ? 'none' : '1px solid var(--color-low-border)',
145
+ color: 'var(--tl-color-text-3)',
146
+ backgroundColor: asset ? 'transparent' : 'var(--tl-color-low)',
147
+ border: asset ? 'none' : '1px solid var(--tl-color-low-border)',
148
148
  }}
149
149
  >
150
150
  <div className="tl-counter-scaled">
@@ -28,7 +28,6 @@ export type TranslatingInfo = TLPointerEventInfo & {
28
28
  isCreating?: boolean
29
29
  creatingMarkId?: string
30
30
  onCreate?(): void
31
- didStartInPit?: boolean
32
31
  onInteractionEnd?: string
33
32
  }
34
33
 
@@ -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 ? (
@@ -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
  })
@@ -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
  ) : (