tldraw 3.16.0-canary.fa3749606e52 → 3.16.0-internal.51e99e128bd4

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 (355) hide show
  1. package/dist-cjs/index.d.ts +171 -5
  2. package/dist-cjs/index.js +17 -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/arrowTargetState.js +1 -1
  9. package/dist-cjs/lib/shapes/arrow/arrowTargetState.js.map +2 -2
  10. package/dist-cjs/lib/shapes/arrow/elbow/ElbowArrowDebug.js +3 -3
  11. package/dist-cjs/lib/shapes/arrow/elbow/ElbowArrowDebug.js.map +1 -1
  12. package/dist-cjs/lib/shapes/draw/DrawShapeUtil.js +3 -3
  13. package/dist-cjs/lib/shapes/draw/DrawShapeUtil.js.map +2 -2
  14. package/dist-cjs/lib/shapes/embed/EmbedShapeUtil.js +1 -1
  15. package/dist-cjs/lib/shapes/embed/EmbedShapeUtil.js.map +1 -1
  16. package/dist-cjs/lib/shapes/frame/FrameShapeUtil.js +12 -12
  17. package/dist-cjs/lib/shapes/frame/FrameShapeUtil.js.map +2 -2
  18. package/dist-cjs/lib/shapes/frame/components/FrameHeading.js +1 -1
  19. package/dist-cjs/lib/shapes/frame/components/FrameHeading.js.map +2 -2
  20. package/dist-cjs/lib/shapes/geo/GeoShapeUtil.js +2 -2
  21. package/dist-cjs/lib/shapes/geo/GeoShapeUtil.js.map +2 -2
  22. package/dist-cjs/lib/shapes/geo/components/GeoShapeBody.js +2 -1
  23. package/dist-cjs/lib/shapes/geo/components/GeoShapeBody.js.map +2 -2
  24. package/dist-cjs/lib/shapes/highlight/HighlightShapeUtil.js +5 -1
  25. package/dist-cjs/lib/shapes/highlight/HighlightShapeUtil.js.map +2 -2
  26. package/dist-cjs/lib/shapes/image/ImageShapeUtil.js +3 -3
  27. package/dist-cjs/lib/shapes/image/ImageShapeUtil.js.map +1 -1
  28. package/dist-cjs/lib/shapes/line/LineShapeUtil.js +5 -1
  29. package/dist-cjs/lib/shapes/line/LineShapeUtil.js.map +2 -2
  30. package/dist-cjs/lib/shapes/note/NoteShapeUtil.js +4 -4
  31. package/dist-cjs/lib/shapes/note/NoteShapeUtil.js.map +2 -2
  32. package/dist-cjs/lib/shapes/shared/ShapeFill.js +4 -4
  33. package/dist-cjs/lib/shapes/shared/ShapeFill.js.map +2 -2
  34. package/dist-cjs/lib/shapes/shared/freehand/svg.js.map +2 -2
  35. package/dist-cjs/lib/shapes/shared/usePrefersReducedMotion.js +10 -1
  36. package/dist-cjs/lib/shapes/shared/usePrefersReducedMotion.js.map +2 -2
  37. package/dist-cjs/lib/shapes/text/TextShapeUtil.js +2 -2
  38. package/dist-cjs/lib/shapes/text/TextShapeUtil.js.map +2 -2
  39. package/dist-cjs/lib/shapes/video/VideoShapeUtil.js +3 -3
  40. package/dist-cjs/lib/shapes/video/VideoShapeUtil.js.map +1 -1
  41. package/dist-cjs/lib/tools/EraserTool/childStates/Erasing.js +25 -1
  42. package/dist-cjs/lib/tools/EraserTool/childStates/Erasing.js.map +2 -2
  43. package/dist-cjs/lib/tools/EraserTool/childStates/Pointing.js +12 -0
  44. package/dist-cjs/lib/tools/EraserTool/childStates/Pointing.js.map +2 -2
  45. package/dist-cjs/lib/ui/TldrawUi.js +14 -0
  46. package/dist-cjs/lib/ui/TldrawUi.js.map +3 -3
  47. package/dist-cjs/lib/ui/assetUrls.js +13 -10
  48. package/dist-cjs/lib/ui/assetUrls.js.map +2 -2
  49. package/dist-cjs/lib/ui/components/AccessibilityMenu.js +35 -0
  50. package/dist-cjs/lib/ui/components/AccessibilityMenu.js.map +7 -0
  51. package/dist-cjs/lib/ui/components/ActionsMenu/DefaultActionsMenu.js +12 -3
  52. package/dist-cjs/lib/ui/components/ActionsMenu/DefaultActionsMenu.js.map +2 -2
  53. package/dist-cjs/lib/ui/components/DefaultMenuPanel.js +3 -2
  54. package/dist-cjs/lib/ui/components/DefaultMenuPanel.js.map +2 -2
  55. package/dist-cjs/lib/ui/components/MainMenu/DefaultMainMenuContent.js +3 -3
  56. package/dist-cjs/lib/ui/components/MainMenu/DefaultMainMenuContent.js.map +2 -2
  57. package/dist-cjs/lib/ui/components/Minimap/MinimapManager.js +4 -4
  58. package/dist-cjs/lib/ui/components/Minimap/MinimapManager.js.map +2 -2
  59. package/dist-cjs/lib/ui/components/MobileStylePanel.js +5 -3
  60. package/dist-cjs/lib/ui/components/MobileStylePanel.js.map +2 -2
  61. package/dist-cjs/lib/ui/components/NavigationPanel/DefaultNavigationPanel.js +1 -1
  62. package/dist-cjs/lib/ui/components/NavigationPanel/DefaultNavigationPanel.js.map +2 -2
  63. package/dist-cjs/lib/ui/components/PageMenu/DefaultPageMenu.js +2 -1
  64. package/dist-cjs/lib/ui/components/PageMenu/DefaultPageMenu.js.map +2 -2
  65. package/dist-cjs/lib/ui/components/SharePanel/PeopleMenuItem.js +3 -2
  66. package/dist-cjs/lib/ui/components/SharePanel/PeopleMenuItem.js.map +2 -2
  67. package/dist-cjs/lib/ui/components/SharePanel/UserPresenceColorPicker.js +2 -2
  68. package/dist-cjs/lib/ui/components/SharePanel/UserPresenceColorPicker.js.map +2 -2
  69. package/dist-cjs/lib/ui/components/StylePanel/DefaultStylePanel.js +2 -0
  70. package/dist-cjs/lib/ui/components/StylePanel/DefaultStylePanel.js.map +2 -2
  71. package/dist-cjs/lib/ui/components/StylePanel/DefaultStylePanelContent.js +171 -140
  72. package/dist-cjs/lib/ui/components/StylePanel/DefaultStylePanelContent.js.map +2 -2
  73. package/dist-cjs/lib/ui/components/StylePanel/DoubleDropdownPicker.js +3 -3
  74. package/dist-cjs/lib/ui/components/StylePanel/DoubleDropdownPicker.js.map +2 -2
  75. package/dist-cjs/lib/ui/components/StylePanel/DropdownPicker.js +26 -25
  76. package/dist-cjs/lib/ui/components/StylePanel/DropdownPicker.js.map +3 -3
  77. package/dist-cjs/lib/ui/components/Toolbar/DefaultImageToolbarContent.js +1 -1
  78. package/dist-cjs/lib/ui/components/Toolbar/DefaultImageToolbarContent.js.map +2 -2
  79. package/dist-cjs/lib/ui/components/Toolbar/DefaultToolbar.js +66 -21
  80. package/dist-cjs/lib/ui/components/Toolbar/DefaultToolbar.js.map +3 -3
  81. package/dist-cjs/lib/ui/components/Toolbar/OverflowingToolbar.js +189 -80
  82. package/dist-cjs/lib/ui/components/Toolbar/OverflowingToolbar.js.map +3 -3
  83. package/dist-cjs/lib/ui/components/Toolbar/ToggleToolLockedButton.js +5 -4
  84. package/dist-cjs/lib/ui/components/Toolbar/ToggleToolLockedButton.js.map +2 -2
  85. package/dist-cjs/lib/ui/components/menu-items.js +6 -0
  86. package/dist-cjs/lib/ui/components/menu-items.js.map +2 -2
  87. package/dist-cjs/lib/ui/components/primitives/TldrawUiButtonPicker.js +5 -16
  88. package/dist-cjs/lib/ui/components/primitives/TldrawUiButtonPicker.js.map +3 -3
  89. package/dist-cjs/lib/ui/components/primitives/TldrawUiContextualToolbar.js +1 -1
  90. package/dist-cjs/lib/ui/components/primitives/TldrawUiContextualToolbar.js.map +2 -2
  91. package/dist-cjs/lib/ui/components/primitives/TldrawUiPopover.js +3 -2
  92. package/dist-cjs/lib/ui/components/primitives/TldrawUiPopover.js.map +3 -3
  93. package/dist-cjs/lib/ui/components/primitives/TldrawUiToolbar.js +30 -7
  94. package/dist-cjs/lib/ui/components/primitives/TldrawUiToolbar.js.map +2 -2
  95. package/dist-cjs/lib/ui/components/primitives/TldrawUiTooltip.js +268 -0
  96. package/dist-cjs/lib/ui/components/primitives/TldrawUiTooltip.js.map +7 -0
  97. package/dist-cjs/lib/ui/components/primitives/layout.js +76 -0
  98. package/dist-cjs/lib/ui/components/primitives/layout.js.map +7 -0
  99. package/dist-cjs/lib/ui/components/primitives/menus/TldrawUiMenuContext.js.map +2 -2
  100. package/dist-cjs/lib/ui/components/primitives/menus/TldrawUiMenuGroup.js +25 -12
  101. package/dist-cjs/lib/ui/components/primitives/menus/TldrawUiMenuGroup.js.map +2 -2
  102. package/dist-cjs/lib/ui/components/primitives/menus/TldrawUiMenuItem.js +12 -26
  103. package/dist-cjs/lib/ui/components/primitives/menus/TldrawUiMenuItem.js.map +2 -2
  104. package/dist-cjs/lib/ui/context/TldrawUiContextProvider.js +3 -2
  105. package/dist-cjs/lib/ui/context/TldrawUiContextProvider.js.map +2 -2
  106. package/dist-cjs/lib/ui/context/actions.js +15 -0
  107. package/dist-cjs/lib/ui/context/actions.js.map +2 -2
  108. package/dist-cjs/lib/ui/context/events.js.map +2 -2
  109. package/dist-cjs/lib/ui/hooks/useTools.js +21 -3
  110. package/dist-cjs/lib/ui/hooks/useTools.js.map +2 -2
  111. package/dist-cjs/lib/ui/hooks/useTranslation/TLUiTranslationKey.js.map +1 -1
  112. package/dist-cjs/lib/ui/hooks/useTranslation/defaultTranslation.js +3 -0
  113. package/dist-cjs/lib/ui/hooks/useTranslation/defaultTranslation.js.map +2 -2
  114. package/dist-cjs/lib/ui/version.js +3 -3
  115. package/dist-cjs/lib/ui/version.js.map +1 -1
  116. package/dist-esm/index.d.mts +171 -5
  117. package/dist-esm/index.mjs +27 -1
  118. package/dist-esm/index.mjs.map +2 -2
  119. package/dist-esm/lib/canvas/TldrawScribble.mjs +1 -1
  120. package/dist-esm/lib/canvas/TldrawScribble.mjs.map +2 -2
  121. package/dist-esm/lib/shapes/arrow/ArrowShapeUtil.mjs +4 -3
  122. package/dist-esm/lib/shapes/arrow/ArrowShapeUtil.mjs.map +2 -2
  123. package/dist-esm/lib/shapes/arrow/arrowTargetState.mjs +1 -1
  124. package/dist-esm/lib/shapes/arrow/arrowTargetState.mjs.map +2 -2
  125. package/dist-esm/lib/shapes/arrow/elbow/ElbowArrowDebug.mjs +3 -3
  126. package/dist-esm/lib/shapes/arrow/elbow/ElbowArrowDebug.mjs.map +1 -1
  127. package/dist-esm/lib/shapes/draw/DrawShapeUtil.mjs +4 -3
  128. package/dist-esm/lib/shapes/draw/DrawShapeUtil.mjs.map +2 -2
  129. package/dist-esm/lib/shapes/embed/EmbedShapeUtil.mjs +1 -1
  130. package/dist-esm/lib/shapes/embed/EmbedShapeUtil.mjs.map +1 -1
  131. package/dist-esm/lib/shapes/frame/FrameShapeUtil.mjs +13 -12
  132. package/dist-esm/lib/shapes/frame/FrameShapeUtil.mjs.map +2 -2
  133. package/dist-esm/lib/shapes/frame/components/FrameHeading.mjs +1 -1
  134. package/dist-esm/lib/shapes/frame/components/FrameHeading.mjs.map +2 -2
  135. package/dist-esm/lib/shapes/geo/GeoShapeUtil.mjs +3 -2
  136. package/dist-esm/lib/shapes/geo/GeoShapeUtil.mjs.map +2 -2
  137. package/dist-esm/lib/shapes/geo/components/GeoShapeBody.mjs +2 -1
  138. package/dist-esm/lib/shapes/geo/components/GeoShapeBody.mjs.map +2 -2
  139. package/dist-esm/lib/shapes/highlight/HighlightShapeUtil.mjs +6 -1
  140. package/dist-esm/lib/shapes/highlight/HighlightShapeUtil.mjs.map +2 -2
  141. package/dist-esm/lib/shapes/image/ImageShapeUtil.mjs +3 -3
  142. package/dist-esm/lib/shapes/image/ImageShapeUtil.mjs.map +1 -1
  143. package/dist-esm/lib/shapes/line/LineShapeUtil.mjs +6 -1
  144. package/dist-esm/lib/shapes/line/LineShapeUtil.mjs.map +2 -2
  145. package/dist-esm/lib/shapes/note/NoteShapeUtil.mjs +5 -4
  146. package/dist-esm/lib/shapes/note/NoteShapeUtil.mjs.map +2 -2
  147. package/dist-esm/lib/shapes/shared/ShapeFill.mjs +5 -4
  148. package/dist-esm/lib/shapes/shared/ShapeFill.mjs.map +2 -2
  149. package/dist-esm/lib/shapes/shared/freehand/svg.mjs.map +2 -2
  150. package/dist-esm/lib/shapes/shared/usePrefersReducedMotion.mjs +10 -1
  151. package/dist-esm/lib/shapes/shared/usePrefersReducedMotion.mjs.map +2 -2
  152. package/dist-esm/lib/shapes/text/TextShapeUtil.mjs +3 -2
  153. package/dist-esm/lib/shapes/text/TextShapeUtil.mjs.map +2 -2
  154. package/dist-esm/lib/shapes/video/VideoShapeUtil.mjs +3 -3
  155. package/dist-esm/lib/shapes/video/VideoShapeUtil.mjs.map +1 -1
  156. package/dist-esm/lib/tools/EraserTool/childStates/Erasing.mjs +26 -1
  157. package/dist-esm/lib/tools/EraserTool/childStates/Erasing.mjs.map +2 -2
  158. package/dist-esm/lib/tools/EraserTool/childStates/Pointing.mjs +13 -0
  159. package/dist-esm/lib/tools/EraserTool/childStates/Pointing.mjs.map +2 -2
  160. package/dist-esm/lib/ui/TldrawUi.mjs +16 -2
  161. package/dist-esm/lib/ui/TldrawUi.mjs.map +3 -3
  162. package/dist-esm/lib/ui/assetUrls.mjs +13 -10
  163. package/dist-esm/lib/ui/assetUrls.mjs.map +2 -2
  164. package/dist-esm/lib/ui/components/AccessibilityMenu.mjs +19 -0
  165. package/dist-esm/lib/ui/components/AccessibilityMenu.mjs.map +7 -0
  166. package/dist-esm/lib/ui/components/ActionsMenu/DefaultActionsMenu.mjs +12 -3
  167. package/dist-esm/lib/ui/components/ActionsMenu/DefaultActionsMenu.mjs.map +2 -2
  168. package/dist-esm/lib/ui/components/DefaultMenuPanel.mjs +3 -2
  169. package/dist-esm/lib/ui/components/DefaultMenuPanel.mjs.map +2 -2
  170. package/dist-esm/lib/ui/components/MainMenu/DefaultMainMenuContent.mjs +3 -5
  171. package/dist-esm/lib/ui/components/MainMenu/DefaultMainMenuContent.mjs.map +2 -2
  172. package/dist-esm/lib/ui/components/Minimap/MinimapManager.mjs +4 -4
  173. package/dist-esm/lib/ui/components/Minimap/MinimapManager.mjs.map +2 -2
  174. package/dist-esm/lib/ui/components/MobileStylePanel.mjs +6 -3
  175. package/dist-esm/lib/ui/components/MobileStylePanel.mjs.map +2 -2
  176. package/dist-esm/lib/ui/components/NavigationPanel/DefaultNavigationPanel.mjs +1 -1
  177. package/dist-esm/lib/ui/components/NavigationPanel/DefaultNavigationPanel.mjs.map +2 -2
  178. package/dist-esm/lib/ui/components/PageMenu/DefaultPageMenu.mjs +2 -1
  179. package/dist-esm/lib/ui/components/PageMenu/DefaultPageMenu.mjs.map +2 -2
  180. package/dist-esm/lib/ui/components/SharePanel/PeopleMenuItem.mjs +3 -2
  181. package/dist-esm/lib/ui/components/SharePanel/PeopleMenuItem.mjs.map +2 -2
  182. package/dist-esm/lib/ui/components/SharePanel/UserPresenceColorPicker.mjs +2 -2
  183. package/dist-esm/lib/ui/components/SharePanel/UserPresenceColorPicker.mjs.map +2 -2
  184. package/dist-esm/lib/ui/components/StylePanel/DefaultStylePanel.mjs +3 -1
  185. package/dist-esm/lib/ui/components/StylePanel/DefaultStylePanel.mjs.map +2 -2
  186. package/dist-esm/lib/ui/components/StylePanel/DefaultStylePanelContent.mjs +171 -140
  187. package/dist-esm/lib/ui/components/StylePanel/DefaultStylePanelContent.mjs.map +2 -2
  188. package/dist-esm/lib/ui/components/StylePanel/DoubleDropdownPicker.mjs +3 -3
  189. package/dist-esm/lib/ui/components/StylePanel/DoubleDropdownPicker.mjs.map +2 -2
  190. package/dist-esm/lib/ui/components/StylePanel/DropdownPicker.mjs +26 -25
  191. package/dist-esm/lib/ui/components/StylePanel/DropdownPicker.mjs.map +2 -2
  192. package/dist-esm/lib/ui/components/Toolbar/DefaultImageToolbarContent.mjs +1 -1
  193. package/dist-esm/lib/ui/components/Toolbar/DefaultImageToolbarContent.mjs.map +2 -2
  194. package/dist-esm/lib/ui/components/Toolbar/DefaultToolbar.mjs +56 -21
  195. package/dist-esm/lib/ui/components/Toolbar/DefaultToolbar.mjs.map +2 -2
  196. package/dist-esm/lib/ui/components/Toolbar/OverflowingToolbar.mjs +192 -81
  197. package/dist-esm/lib/ui/components/Toolbar/OverflowingToolbar.mjs.map +3 -3
  198. package/dist-esm/lib/ui/components/Toolbar/ToggleToolLockedButton.mjs +5 -4
  199. package/dist-esm/lib/ui/components/Toolbar/ToggleToolLockedButton.mjs.map +2 -2
  200. package/dist-esm/lib/ui/components/menu-items.mjs +6 -0
  201. package/dist-esm/lib/ui/components/menu-items.mjs.map +2 -2
  202. package/dist-esm/lib/ui/components/primitives/TldrawUiButtonPicker.mjs +6 -6
  203. package/dist-esm/lib/ui/components/primitives/TldrawUiButtonPicker.mjs.map +2 -2
  204. package/dist-esm/lib/ui/components/primitives/TldrawUiContextualToolbar.mjs +1 -1
  205. package/dist-esm/lib/ui/components/primitives/TldrawUiContextualToolbar.mjs.map +2 -2
  206. package/dist-esm/lib/ui/components/primitives/TldrawUiPopover.mjs +3 -2
  207. package/dist-esm/lib/ui/components/primitives/TldrawUiPopover.mjs.map +2 -2
  208. package/dist-esm/lib/ui/components/primitives/TldrawUiToolbar.mjs +30 -7
  209. package/dist-esm/lib/ui/components/primitives/TldrawUiToolbar.mjs.map +2 -2
  210. package/dist-esm/lib/ui/components/primitives/TldrawUiTooltip.mjs +245 -0
  211. package/dist-esm/lib/ui/components/primitives/TldrawUiTooltip.mjs.map +7 -0
  212. package/dist-esm/lib/ui/components/primitives/layout.mjs +46 -0
  213. package/dist-esm/lib/ui/components/primitives/layout.mjs.map +7 -0
  214. package/dist-esm/lib/ui/components/primitives/menus/TldrawUiMenuContext.mjs.map +2 -2
  215. package/dist-esm/lib/ui/components/primitives/menus/TldrawUiMenuGroup.mjs +25 -12
  216. package/dist-esm/lib/ui/components/primitives/menus/TldrawUiMenuGroup.mjs.map +2 -2
  217. package/dist-esm/lib/ui/components/primitives/menus/TldrawUiMenuItem.mjs +12 -26
  218. package/dist-esm/lib/ui/components/primitives/menus/TldrawUiMenuItem.mjs.map +2 -2
  219. package/dist-esm/lib/ui/context/TldrawUiContextProvider.mjs +3 -2
  220. package/dist-esm/lib/ui/context/TldrawUiContextProvider.mjs.map +2 -2
  221. package/dist-esm/lib/ui/context/actions.mjs +15 -0
  222. package/dist-esm/lib/ui/context/actions.mjs.map +2 -2
  223. package/dist-esm/lib/ui/context/events.mjs.map +2 -2
  224. package/dist-esm/lib/ui/hooks/useTools.mjs +22 -3
  225. package/dist-esm/lib/ui/hooks/useTools.mjs.map +2 -2
  226. package/dist-esm/lib/ui/hooks/useTranslation/defaultTranslation.mjs +3 -0
  227. package/dist-esm/lib/ui/hooks/useTranslation/defaultTranslation.mjs.map +2 -2
  228. package/dist-esm/lib/ui/version.mjs +3 -3
  229. package/dist-esm/lib/ui/version.mjs.map +1 -1
  230. package/package.json +11 -34
  231. package/src/index.ts +21 -0
  232. package/src/lib/canvas/TldrawScribble.tsx +1 -1
  233. package/src/lib/shapes/arrow/ArrowShapeOptions.test.ts +2 -1
  234. package/src/lib/shapes/arrow/ArrowShapeTool.test.ts +4 -3
  235. package/src/lib/shapes/arrow/ArrowShapeUtil.test.ts +7 -6
  236. package/src/lib/shapes/arrow/ArrowShapeUtil.tsx +4 -3
  237. package/src/lib/shapes/arrow/arrowTargetState.ts +2 -1
  238. package/src/lib/shapes/arrow/elbow/ElbowArrowDebug.tsx +3 -3
  239. package/src/lib/shapes/draw/DrawShapeTool.test.ts +0 -5
  240. package/src/lib/shapes/draw/DrawShapeUtil.tsx +4 -3
  241. package/src/lib/shapes/embed/EmbedShapeUtil.tsx +1 -1
  242. package/src/lib/shapes/frame/FrameShapeUtil.tsx +21 -14
  243. package/src/lib/shapes/frame/components/FrameHeading.tsx +1 -1
  244. package/src/lib/shapes/geo/GeoShapeUtil.tsx +3 -2
  245. package/src/lib/shapes/geo/components/GeoShapeBody.tsx +2 -2
  246. package/src/lib/shapes/highlight/HighlightShapeUtil.tsx +7 -1
  247. package/src/lib/shapes/image/ImageShapeUtil.tsx +3 -3
  248. package/src/lib/shapes/line/LineShapeUtil.test.tsx +4 -3
  249. package/src/lib/shapes/line/LineShapeUtil.tsx +6 -1
  250. package/src/lib/shapes/line/__snapshots__/LineShapeUtil.test.tsx.snap +2 -2
  251. package/src/lib/shapes/note/NoteShapeUtil.tsx +9 -4
  252. package/src/lib/shapes/shared/ShapeFill.tsx +5 -4
  253. package/src/lib/shapes/shared/freehand/svg.ts +2 -0
  254. package/src/lib/shapes/shared/usePrefersReducedMotion.tsx +11 -1
  255. package/src/lib/shapes/text/TextShapeTool.test.ts +6 -5
  256. package/src/lib/shapes/text/TextShapeUtil.tsx +3 -2
  257. package/src/lib/shapes/video/VideoShapeUtil.tsx +3 -3
  258. package/src/lib/tools/EraserTool/childStates/Erasing.ts +34 -1
  259. package/src/lib/tools/EraserTool/childStates/Pointing.ts +20 -0
  260. package/src/lib/ui/TldrawUi.tsx +17 -2
  261. package/src/lib/ui/assetUrls.ts +13 -10
  262. package/src/lib/ui/components/AccessibilityMenu.tsx +20 -0
  263. package/src/lib/ui/components/ActionsMenu/DefaultActionsMenu.tsx +15 -3
  264. package/src/lib/ui/components/DefaultMenuPanel.tsx +4 -3
  265. package/src/lib/ui/components/MainMenu/DefaultMainMenuContent.tsx +4 -4
  266. package/src/lib/ui/components/Minimap/MinimapManager.ts +4 -4
  267. package/src/lib/ui/components/MobileStylePanel.tsx +9 -6
  268. package/src/lib/ui/components/NavigationPanel/DefaultNavigationPanel.tsx +1 -1
  269. package/src/lib/ui/components/PageMenu/DefaultPageMenu.tsx +3 -2
  270. package/src/lib/ui/components/SharePanel/PeopleMenuItem.tsx +4 -3
  271. package/src/lib/ui/components/SharePanel/UserPresenceColorPicker.tsx +3 -3
  272. package/src/lib/ui/components/StylePanel/DefaultStylePanel.tsx +3 -1
  273. package/src/lib/ui/components/StylePanel/DefaultStylePanelContent.tsx +146 -107
  274. package/src/lib/ui/components/StylePanel/DoubleDropdownPicker.tsx +3 -3
  275. package/src/lib/ui/components/StylePanel/DropdownPicker.tsx +7 -6
  276. package/src/lib/ui/components/Toolbar/DefaultImageToolbarContent.tsx +1 -1
  277. package/src/lib/ui/components/Toolbar/DefaultToolbar.tsx +55 -23
  278. package/src/lib/ui/components/Toolbar/OverflowingToolbar.tsx +212 -61
  279. package/src/lib/ui/components/Toolbar/ToggleToolLockedButton.tsx +14 -11
  280. package/src/lib/ui/components/menu-items.tsx +8 -0
  281. package/src/lib/ui/components/primitives/TldrawUiButtonPicker.tsx +40 -37
  282. package/src/lib/ui/components/primitives/TldrawUiContextualToolbar.tsx +1 -1
  283. package/src/lib/ui/components/primitives/TldrawUiPopover.tsx +4 -2
  284. package/src/lib/ui/components/primitives/TldrawUiToolbar.tsx +51 -12
  285. package/src/lib/ui/components/primitives/TldrawUiTooltip.tsx +327 -0
  286. package/src/lib/ui/components/primitives/layout.tsx +107 -0
  287. package/src/lib/ui/components/primitives/menus/TldrawUiMenuContext.tsx +0 -1
  288. package/src/lib/ui/components/primitives/menus/TldrawUiMenuGroup.tsx +29 -16
  289. package/src/lib/ui/components/primitives/menus/TldrawUiMenuItem.tsx +18 -27
  290. package/src/lib/ui/context/TldrawUiContextProvider.tsx +23 -20
  291. package/src/lib/ui/context/actions.tsx +15 -0
  292. package/src/lib/ui/context/events.tsx +1 -0
  293. package/src/lib/ui/hooks/useTools.tsx +25 -3
  294. package/src/lib/ui/hooks/useTranslation/TLUiTranslationKey.ts +3 -0
  295. package/src/lib/ui/hooks/useTranslation/defaultTranslation.ts +3 -0
  296. package/src/lib/ui/version.ts +3 -3
  297. package/src/lib/ui.css +406 -292
  298. package/src/lib/utils/excalidraw/__snapshots__/putExcalidrawContent.test.tsx.snap +5 -5
  299. package/src/lib/utils/tldr/__snapshots__/buildFromV1Document.test.ts.snap +4 -4
  300. package/src/test/A11y.test.tsx +3 -2
  301. package/src/test/ClickManager.test.ts +7 -6
  302. package/src/test/Editor.test.tsx +20 -19
  303. package/src/test/EraserTool.test.ts +184 -13
  304. package/src/test/HandTool.test.ts +10 -9
  305. package/src/test/HighlightShape.test.ts +2 -1
  306. package/src/test/SelectTool.test.ts +3 -2
  307. package/src/test/TLUserPreferences.test.ts +4 -3
  308. package/src/test/TestEditor.ts +13 -15
  309. package/src/test/TldrawEditor.test.tsx +11 -10
  310. package/src/test/ZoomTool.test.ts +7 -6
  311. package/src/test/__snapshots__/drawing.test.ts.snap +2 -2
  312. package/src/test/__snapshots__/groups.test.tsx.snap +6 -6
  313. package/src/test/__snapshots__/resizing.test.ts.snap +2 -2
  314. package/src/test/arrows-megabus.test.tsx +17 -10
  315. package/src/test/bindings.test.tsx +24 -37
  316. package/src/test/bookmark-shapes.test.ts +1 -8
  317. package/src/test/commands/__snapshots__/getSvgString.test.ts.snap +23 -7
  318. package/src/test/commands/__snapshots__/packShapes.test.ts.snap +8 -8
  319. package/src/test/commands/__snapshots__/zoomToFit.test.ts.snap +2 -2
  320. package/src/test/commands/alignShapes.test.tsx +25 -24
  321. package/src/test/commands/animationSpeed.test.ts +2 -1
  322. package/src/test/commands/centerOnPoint.test.ts +3 -2
  323. package/src/test/commands/clipboard.test.ts +3 -2
  324. package/src/test/commands/createShapes.test.ts +2 -1
  325. package/src/test/commands/deleteShapes.test.ts +2 -1
  326. package/src/test/commands/distributeShapes.test.tsx +11 -10
  327. package/src/test/commands/getSvgString.test.ts +2 -1
  328. package/src/test/commands/packShapes.test.ts +5 -4
  329. package/src/test/commands/resizeShape.test.ts +2 -1
  330. package/src/test/commands/rotateShapes.test.ts +7 -6
  331. package/src/test/commands/setCamera.test.ts +4 -3
  332. package/src/test/commands/setCurrentPage.test.ts +3 -2
  333. package/src/test/commands/stackShapes.test.ts +11 -10
  334. package/src/test/commands/stretch.test.tsx +13 -12
  335. package/src/test/createDeepLink.test.tsx +2 -1
  336. package/src/test/cropping.test.ts +3 -2
  337. package/src/test/drawing.test.ts +2 -1
  338. package/src/test/flipShapes.test.ts +4 -3
  339. package/src/test/frames.test.ts +25 -24
  340. package/src/test/getCulledShapes.test.tsx +3 -2
  341. package/src/test/groups.test.tsx +1 -1
  342. package/src/test/handleDeepLink.test.tsx +2 -1
  343. package/src/test/inner-outer-margin.test.ts +315 -0
  344. package/src/test/maxShapes.test.ts +3 -2
  345. package/src/test/modifiers.test.ts +5 -4
  346. package/src/test/navigation.test.ts +12 -11
  347. package/src/test/panning.test.ts +2 -1
  348. package/src/test/perf/perf.test.ts +2 -1
  349. package/src/test/registerDeepLinkListener.test.tsx +10 -9
  350. package/src/test/resizing.test.ts +39 -38
  351. package/src/test/select.test.tsx +4 -3
  352. package/src/test/selection-omnibus.test.ts +11 -10
  353. package/src/test/shapeutils.test.ts +4 -3
  354. package/src/test/translating.test.ts +9 -8
  355. package/tldraw.css +699 -580
@@ -44,6 +44,7 @@ var import_useTranslation = require("../../hooks/useTranslation/useTranslation")
44
44
  var import_TldrawUiButtonIcon = require("../primitives/Button/TldrawUiButtonIcon");
45
45
  var import_TldrawUiPopover = require("../primitives/TldrawUiPopover");
46
46
  var import_TldrawUiToolbar = require("../primitives/TldrawUiToolbar");
47
+ var import_layout = require("../primitives/layout");
47
48
  var import_TldrawUiMenuContext = require("../primitives/menus/TldrawUiMenuContext");
48
49
  const IsInOverflowContext = (0, import_react.createContext)(false);
49
50
  const NUMBERED_SHORTCUT_KEYS = {
@@ -58,55 +59,130 @@ const NUMBERED_SHORTCUT_KEYS = {
58
59
  "9": 8,
59
60
  "0": 9
60
61
  };
61
- function OverflowingToolbar({ children }) {
62
+ function OverflowingToolbar({
63
+ children,
64
+ orientation,
65
+ sizingParentClassName,
66
+ minItems,
67
+ minSizePx,
68
+ maxItems,
69
+ maxSizePx
70
+ }) {
62
71
  const editor = (0, import_editor.useEditor)();
63
72
  const id = (0, import_editor.useUniqueSafeId)();
64
73
  const breakpoint = (0, import_breakpoints.useBreakpoint)();
65
74
  const msg = (0, import_useTranslation.useTranslation)();
66
75
  const rButtons = (0, import_react.useRef)([]);
67
76
  const [isOpen, setIsOpen] = (0, import_react.useState)(false);
68
- const overflowIndex = Math.min(8, 5 + breakpoint);
69
- const [totalItems, setTotalItems] = (0, import_react.useState)(0);
70
77
  const mainToolsRef = (0, import_react.useRef)(null);
78
+ const [overflowTools, setOverflowTools] = (0, import_react.useState)(null);
71
79
  const [lastActiveOverflowItem, setLastActiveOverflowItem] = (0, import_react.useState)(null);
72
- const css = (0, import_react.useMemo)(() => {
73
- const activeCss = lastActiveOverflowItem ? `:not([data-value="${lastActiveOverflowItem}"])` : "";
74
- return `
75
- #${id}_main > *:nth-child(n + ${overflowIndex + (lastActiveOverflowItem ? 1 : 2)})${activeCss} {
76
- display: none;
77
- }
78
- #${id}_more > *:nth-child(-n + ${overflowIndex}) {
79
- display: none;
80
- }
81
- #${id}_more > *:nth-child(-n + ${overflowIndex + 4}) {
82
- margin-top: 0;
83
- }
84
- `;
85
- }, [lastActiveOverflowItem, id, overflowIndex]);
80
+ const [shouldShowOverflow, setShouldShowOverflow] = (0, import_react.useState)(false);
86
81
  const onDomUpdate = (0, import_editor.useEvent)(() => {
87
82
  if (!mainToolsRef.current) return;
88
- const children2 = Array.from(mainToolsRef.current.children);
89
- setTotalItems(children2.length);
90
- const lastActiveElementIdx = children2.findIndex(
91
- (el) => el.getAttribute("data-value") === lastActiveOverflowItem
92
- );
93
- if (lastActiveElementIdx <= overflowIndex) {
94
- setLastActiveOverflowItem(null);
83
+ const sizeProp = orientation === "horizontal" ? "offsetWidth" : "offsetHeight";
84
+ const mainItems = collectItems(mainToolsRef.current.children);
85
+ const overflowItems = overflowTools ? collectItems(overflowTools.children) : null;
86
+ function collectItems(collection) {
87
+ const items = [];
88
+ for (const child of collection) {
89
+ if (child.classList.contains("tlui-main-toolbar__group")) {
90
+ items.push({
91
+ type: "group",
92
+ items: collectItems(child.children),
93
+ element: child
94
+ });
95
+ } else {
96
+ items.push({ type: "item", element: child });
97
+ }
98
+ }
99
+ return items;
95
100
  }
96
- const activeElementIdx = Array.from(mainToolsRef.current.children).findIndex(
97
- (el) => el.getAttribute("aria-pressed") === "true"
101
+ const sizingParent = findParentWithClassName(mainToolsRef.current, sizingParentClassName);
102
+ const size = sizingParent[sizeProp];
103
+ const itemsToShow = Math.floor(
104
+ (0, import_editor.modulate)(size, [minSizePx, maxSizePx], [minItems, maxItems], true)
98
105
  );
99
- if (activeElementIdx === -1) return;
100
- if (activeElementIdx >= overflowIndex) {
101
- setLastActiveOverflowItem(children2[activeElementIdx].getAttribute("data-value"));
102
- }
103
- rButtons.current = Array.from(mainToolsRef.current?.children ?? []).filter(
104
- (el) => {
105
- if (!(el instanceof HTMLElement)) return false;
106
- if (el.tagName.toLowerCase() !== "button") return false;
107
- return !!(el.offsetWidth || el.offsetHeight);
106
+ let mainItemCount = 0;
107
+ let newActiveOverflowItem = null;
108
+ let shouldInvalidateLastActiveOverflowItem = false;
109
+ const numberedButtons = [];
110
+ function visitItems(mainItems2, overflowItems2) {
111
+ if (overflowItems2) (0, import_editor.assert)(mainItems2.length === overflowItems2.length);
112
+ let didShowAnyInMain = false;
113
+ let didShowAnyInOverflow2 = false;
114
+ for (let i = 0; i < mainItems2.length; i++) {
115
+ const mainItem = mainItems2[i];
116
+ const overflowItem = overflowItems2?.[i];
117
+ if (mainItem.type === "item") {
118
+ const isLastActiveOverflowItem = mainItem.element.getAttribute("data-value") === lastActiveOverflowItem;
119
+ let shouldShowInMain;
120
+ if (lastActiveOverflowItem) {
121
+ shouldShowInMain = mainItemCount < itemsToShow || isLastActiveOverflowItem;
122
+ } else {
123
+ shouldShowInMain = mainItemCount <= itemsToShow;
124
+ }
125
+ const shouldShowInOverflow = mainItemCount >= itemsToShow;
126
+ didShowAnyInMain ||= shouldShowInMain;
127
+ didShowAnyInOverflow2 ||= shouldShowInOverflow;
128
+ setAttribute(
129
+ mainItem.element,
130
+ "data-toolbar-visible",
131
+ shouldShowInMain ? "true" : "false"
132
+ );
133
+ if (overflowItem) {
134
+ (0, import_editor.assert)(overflowItem.type === "item");
135
+ setAttribute(
136
+ overflowItem.element,
137
+ "data-toolbar-visible",
138
+ shouldShowInOverflow ? "true" : "false"
139
+ );
140
+ }
141
+ if (shouldShowInOverflow && mainItem.element.getAttribute("aria-pressed") === "true") {
142
+ newActiveOverflowItem = mainItem.element.getAttribute("data-value");
143
+ }
144
+ if (shouldShowInMain && mainItem.element.tagName === "BUTTON") {
145
+ numberedButtons.push(mainItem.element);
146
+ }
147
+ if (!shouldShowInOverflow && isLastActiveOverflowItem) {
148
+ shouldInvalidateLastActiveOverflowItem = true;
149
+ }
150
+ mainItemCount++;
151
+ } else {
152
+ let result, overflowGroup;
153
+ if (overflowItem) {
154
+ (0, import_editor.assert)(overflowItem.type === "group");
155
+ overflowGroup = overflowItem;
156
+ result = visitItems(mainItem.items, overflowGroup.items);
157
+ } else {
158
+ result = visitItems(mainItem.items, null);
159
+ }
160
+ didShowAnyInMain ||= result.didShowAnyInMain;
161
+ didShowAnyInOverflow2 ||= result.didShowAnyInOverflow;
162
+ setAttribute(
163
+ mainItem.element,
164
+ "data-toolbar-visible",
165
+ result.didShowAnyInMain ? "true" : "false"
166
+ );
167
+ if (overflowGroup) {
168
+ setAttribute(
169
+ overflowGroup.element,
170
+ "data-toolbar-visible",
171
+ result.didShowAnyInOverflow ? "true" : "false"
172
+ );
173
+ }
174
+ }
108
175
  }
109
- );
176
+ return { didShowAnyInMain, didShowAnyInOverflow: didShowAnyInOverflow2 };
177
+ }
178
+ const { didShowAnyInOverflow } = visitItems(mainItems, overflowItems);
179
+ setShouldShowOverflow(didShowAnyInOverflow);
180
+ if (newActiveOverflowItem) {
181
+ setLastActiveOverflowItem(newActiveOverflowItem);
182
+ } else if (shouldInvalidateLastActiveOverflowItem) {
183
+ setLastActiveOverflowItem(null);
184
+ }
185
+ rButtons.current = numberedButtons;
110
186
  });
111
187
  (0, import_react.useLayoutEffect)(() => {
112
188
  onDomUpdate();
@@ -117,20 +193,26 @@ function OverflowingToolbar({ children }) {
117
193
  mutationObserver.observe(mainToolsRef.current, {
118
194
  childList: true,
119
195
  subtree: true,
120
- attributeFilter: ["data-value", "aria-pressed"]
196
+ attributes: true,
197
+ characterData: true
121
198
  });
199
+ const sizingParent = findParentWithClassName(mainToolsRef.current, sizingParentClassName);
200
+ const resizeObserver = new ResizeObserver(onDomUpdate);
201
+ resizeObserver.observe(sizingParent);
122
202
  return () => {
123
203
  mutationObserver.disconnect();
204
+ resizeObserver.disconnect();
124
205
  };
125
- }, [onDomUpdate]);
206
+ }, [onDomUpdate, sizingParentClassName]);
126
207
  (0, import_react.useEffect)(() => {
127
208
  if (!editor.options.enableToolbarKeyboardShortcuts) return;
128
209
  function handleKeyDown(event) {
129
210
  if ((0, import_useKeyboardShortcuts.areShortcutsDisabled)(editor) || (0, import_editor.activeElementShouldCaptureKeys)(
130
211
  true
131
212
  /* allow buttons */
132
- ))
213
+ )) {
133
214
  return;
215
+ }
134
216
  if (event.ctrlKey || event.metaKey || event.altKey || event.shiftKey) return;
135
217
  const index = NUMBERED_SHORTCUT_KEYS[event.key];
136
218
  if (typeof index === "number") {
@@ -144,49 +226,76 @@ function OverflowingToolbar({ children }) {
144
226
  };
145
227
  }, [editor]);
146
228
  const popoverId = "toolbar overflow";
147
- return /* @__PURE__ */ (0, import_jsx_runtime.jsxs)(import_jsx_runtime.Fragment, { children: [
148
- /* @__PURE__ */ (0, import_jsx_runtime.jsx)("style", { nonce: editor.options.nonce, children: css }),
149
- /* @__PURE__ */ (0, import_jsx_runtime.jsxs)(
150
- import_TldrawUiToolbar.TldrawUiToolbar,
151
- {
152
- className: (0, import_classnames.default)("tlui-toolbar__tools", {
153
- "tlui-toolbar__tools__mobile": breakpoint < import_constants.PORTRAIT_BREAKPOINT.TABLET_SM
154
- }),
155
- label: msg("tool-panel.title"),
156
- children: [
157
- /* @__PURE__ */ (0, import_jsx_runtime.jsx)("div", { id: `${id}_main`, ref: mainToolsRef, className: "tlui-toolbar__tools__list", children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_TldrawUiMenuContext.TldrawUiMenuContextProvider, { type: "toolbar", sourceId: "toolbar", children }) }),
158
- totalItems > overflowIndex + 1 && /* @__PURE__ */ (0, import_jsx_runtime.jsx)(IsInOverflowContext.Provider, { value: true, children: /* @__PURE__ */ (0, import_jsx_runtime.jsxs)(import_TldrawUiPopover.TldrawUiPopover, { id: popoverId, open: isOpen, onOpenChange: setIsOpen, children: [
159
- /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_TldrawUiPopover.TldrawUiPopoverTrigger, { children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
160
- import_TldrawUiToolbar.TldrawUiToolbarButton,
161
- {
162
- title: msg("tool-panel.more"),
163
- type: "tool",
164
- className: "tlui-toolbar__overflow",
165
- "data-testid": "tools.more-button",
166
- children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_TldrawUiButtonIcon.TldrawUiButtonIcon, { icon: "chevron-up" })
167
- }
168
- ) }),
169
- /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_TldrawUiPopover.TldrawUiPopoverContent, { side: "top", align: "center", children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
170
- import_TldrawUiToolbar.TldrawUiToolbar,
171
- {
172
- className: "tlui-buttons__grid",
173
- "data-testid": "tools.more-content",
174
- label: msg("tool-panel.more"),
175
- id: `${id}_more`,
176
- onClick: () => {
177
- import_editor.tlmenus.deleteOpenMenu(popoverId, editor.contextId);
178
- setIsOpen(false);
179
- },
180
- children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_TldrawUiMenuContext.TldrawUiMenuContextProvider, { type: "toolbar-overflow", sourceId: "toolbar", children })
181
- }
182
- ) })
183
- ] }) })
184
- ]
185
- }
186
- )
187
- ] });
229
+ const Layout = orientation === "horizontal" ? import_layout.TldrawUiRow : import_layout.TldrawUiColumn;
230
+ return /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_jsx_runtime.Fragment, { children: /* @__PURE__ */ (0, import_jsx_runtime.jsxs)(
231
+ import_TldrawUiToolbar.TldrawUiToolbar,
232
+ {
233
+ orientation,
234
+ className: (0, import_classnames.default)("tlui-main-toolbar__tools", {
235
+ "tlui-main-toolbar__tools__mobile": breakpoint < import_constants.PORTRAIT_BREAKPOINT.TABLET_SM
236
+ }),
237
+ label: msg("tool-panel.title"),
238
+ children: [
239
+ /* @__PURE__ */ (0, import_jsx_runtime.jsx)(Layout, { id: `${id}_main`, ref: mainToolsRef, children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_TldrawUiMenuContext.TldrawUiMenuContextProvider, { type: "toolbar", sourceId: "toolbar", children }) }),
240
+ shouldShowOverflow && /* @__PURE__ */ (0, import_jsx_runtime.jsx)(IsInOverflowContext.Provider, { value: true, children: /* @__PURE__ */ (0, import_jsx_runtime.jsxs)(import_TldrawUiPopover.TldrawUiPopover, { id: popoverId, open: isOpen, onOpenChange: setIsOpen, children: [
241
+ /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_TldrawUiPopover.TldrawUiPopoverTrigger, { children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
242
+ import_TldrawUiToolbar.TldrawUiToolbarButton,
243
+ {
244
+ title: msg("tool-panel.more"),
245
+ type: "tool",
246
+ className: "tlui-main-toolbar__overflow",
247
+ "data-testid": "tools.more-button",
248
+ children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
249
+ import_TldrawUiButtonIcon.TldrawUiButtonIcon,
250
+ {
251
+ icon: orientation === "horizontal" ? "chevron-up" : "chevron-right"
252
+ }
253
+ )
254
+ }
255
+ ) }),
256
+ /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
257
+ import_TldrawUiPopover.TldrawUiPopoverContent,
258
+ {
259
+ side: orientation === "horizontal" ? "top" : "right",
260
+ align: orientation === "horizontal" ? "center" : "end",
261
+ children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
262
+ import_TldrawUiToolbar.TldrawUiToolbar,
263
+ {
264
+ orientation: "grid",
265
+ className: "tlui-main-toolbar__overflow-content",
266
+ ref: setOverflowTools,
267
+ "data-testid": "tools.more-content",
268
+ label: msg("tool-panel.more"),
269
+ id: `${id}_more`,
270
+ onClick: () => {
271
+ import_editor.tlmenus.deleteOpenMenu(popoverId, editor.contextId);
272
+ setIsOpen(false);
273
+ },
274
+ children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_TldrawUiMenuContext.TldrawUiMenuContextProvider, { type: "toolbar-overflow", sourceId: "toolbar", children })
275
+ }
276
+ )
277
+ }
278
+ )
279
+ ] }) })
280
+ ]
281
+ }
282
+ ) });
188
283
  }
189
284
  const isActiveTLUiToolItem = (item, activeToolId, geoState) => {
190
285
  return item.meta?.geo ? activeToolId === "geo" && geoState === item.meta?.geo : activeToolId === item.id;
191
286
  };
287
+ function findParentWithClassName(startingElement, className) {
288
+ let element = startingElement;
289
+ while (element) {
290
+ if (element.classList.contains(className)) {
291
+ return element;
292
+ }
293
+ element = element.parentElement;
294
+ }
295
+ throw new Error("Could not find parent with class name " + className);
296
+ }
297
+ function setAttribute(element, name, value) {
298
+ if (element.getAttribute(name) === value) return;
299
+ element.setAttribute(name, value);
300
+ }
192
301
  //# sourceMappingURL=OverflowingToolbar.js.map
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../../../src/lib/ui/components/Toolbar/OverflowingToolbar.tsx"],
4
- "sourcesContent": ["import {\n\tactiveElementShouldCaptureKeys,\n\tpreventDefault,\n\ttlmenus,\n\tuseEditor,\n\tuseEvent,\n\tuseUniqueSafeId,\n} from '@tldraw/editor'\nimport classNames from 'classnames'\nimport { createContext, useEffect, useLayoutEffect, useMemo, useRef, useState } from 'react'\nimport { PORTRAIT_BREAKPOINT } from '../../constants'\nimport { useBreakpoint } from '../../context/breakpoints'\nimport { areShortcutsDisabled } from '../../hooks/useKeyboardShortcuts'\nimport { TLUiToolItem } from '../../hooks/useTools'\nimport { useTranslation } from '../../hooks/useTranslation/useTranslation'\nimport { TldrawUiButtonIcon } from '../primitives/Button/TldrawUiButtonIcon'\nimport {\n\tTldrawUiPopover,\n\tTldrawUiPopoverContent,\n\tTldrawUiPopoverTrigger,\n} from '../primitives/TldrawUiPopover'\nimport { TldrawUiToolbar, TldrawUiToolbarButton } from '../primitives/TldrawUiToolbar'\nimport { TldrawUiMenuContextProvider } from '../primitives/menus/TldrawUiMenuContext'\n\nexport const IsInOverflowContext = createContext(false)\n\nconst NUMBERED_SHORTCUT_KEYS: Record<string, number> = {\n\t'1': 0,\n\t'2': 1,\n\t'3': 2,\n\t'4': 3,\n\t'5': 4,\n\t'6': 5,\n\t'7': 6,\n\t'8': 7,\n\t'9': 8,\n\t'0': 9,\n}\n\n/** @public */\nexport interface OverflowingToolbarProps {\n\tchildren: React.ReactNode\n}\n\n/** @public @react */\nexport function OverflowingToolbar({ children }: OverflowingToolbarProps) {\n\tconst editor = useEditor()\n\tconst id = useUniqueSafeId()\n\tconst breakpoint = useBreakpoint()\n\tconst msg = useTranslation()\n\tconst rButtons = useRef<HTMLElement[]>([])\n\tconst [isOpen, setIsOpen] = useState(false)\n\n\tconst overflowIndex = Math.min(8, 5 + breakpoint)\n\n\tconst [totalItems, setTotalItems] = useState(0)\n\tconst mainToolsRef = useRef<HTMLDivElement>(null)\n\tconst [lastActiveOverflowItem, setLastActiveOverflowItem] = useState<string | null>(null)\n\n\tconst css = useMemo(() => {\n\t\tconst activeCss = lastActiveOverflowItem ? `:not([data-value=\"${lastActiveOverflowItem}\"])` : ''\n\n\t\treturn `\n\t\t\t#${id}_main > *:nth-child(n + ${overflowIndex + (lastActiveOverflowItem ? 1 : 2)})${activeCss} {\n\t\t\t\tdisplay: none;\n\t\t\t}\n\t\t\t#${id}_more > *:nth-child(-n + ${overflowIndex}) {\n\t\t\t\tdisplay: none;\n\t\t\t}\n\t\t\t#${id}_more > *:nth-child(-n + ${overflowIndex + 4}) {\n\t\t\t\tmargin-top: 0;\n\t\t\t}\n `\n\t}, [lastActiveOverflowItem, id, overflowIndex])\n\n\tconst onDomUpdate = useEvent(() => {\n\t\tif (!mainToolsRef.current) return\n\n\t\tconst children = Array.from(mainToolsRef.current.children)\n\t\tsetTotalItems(children.length)\n\n\t\t// If the last active overflow item is no longer in the overflow, clear it\n\t\tconst lastActiveElementIdx = children.findIndex(\n\t\t\t(el) => el.getAttribute('data-value') === lastActiveOverflowItem\n\t\t)\n\t\tif (lastActiveElementIdx <= overflowIndex) {\n\t\t\tsetLastActiveOverflowItem(null)\n\t\t}\n\n\t\t// But if there's a new active item...\n\t\tconst activeElementIdx = Array.from(mainToolsRef.current.children).findIndex(\n\t\t\t(el) => el.getAttribute('aria-pressed') === 'true'\n\t\t)\n\t\tif (activeElementIdx === -1) return\n\n\t\t// ...and it's in the overflow, set it as the last active overflow item\n\t\tif (activeElementIdx >= overflowIndex) {\n\t\t\tsetLastActiveOverflowItem(children[activeElementIdx].getAttribute('data-value'))\n\t\t}\n\n\t\t// Save the buttons that are actually visible\n\t\trButtons.current = Array.from(mainToolsRef.current?.children ?? []).filter(\n\t\t\t(el): el is HTMLElement => {\n\t\t\t\t// only count html elements...\n\t\t\t\tif (!(el instanceof HTMLElement)) return false\n\n\t\t\t\t// ...that are buttons...\n\t\t\t\tif (el.tagName.toLowerCase() !== 'button') return false\n\n\t\t\t\t// ...that are actually visible\n\t\t\t\treturn !!(el.offsetWidth || el.offsetHeight)\n\t\t\t}\n\t\t)\n\t})\n\n\tuseLayoutEffect(() => {\n\t\tonDomUpdate()\n\t})\n\n\tuseLayoutEffect(() => {\n\t\tif (!mainToolsRef.current) return\n\n\t\tconst mutationObserver = new MutationObserver(onDomUpdate)\n\t\tmutationObserver.observe(mainToolsRef.current, {\n\t\t\tchildList: true,\n\t\t\tsubtree: true,\n\t\t\tattributeFilter: ['data-value', 'aria-pressed'],\n\t\t})\n\n\t\treturn () => {\n\t\t\tmutationObserver.disconnect()\n\t\t}\n\t}, [onDomUpdate])\n\n\tuseEffect(() => {\n\t\tif (!editor.options.enableToolbarKeyboardShortcuts) return\n\n\t\tfunction handleKeyDown(event: KeyboardEvent) {\n\t\t\tif (areShortcutsDisabled(editor) || activeElementShouldCaptureKeys(true /* allow buttons */))\n\t\t\t\treturn\n\t\t\t// no accelerator keys\n\t\t\tif (event.ctrlKey || event.metaKey || event.altKey || event.shiftKey) return\n\t\t\tconst index = NUMBERED_SHORTCUT_KEYS[event.key]\n\t\t\tif (typeof index === 'number') {\n\t\t\t\tpreventDefault(event)\n\t\t\t\trButtons.current[index]?.click()\n\t\t\t}\n\t\t}\n\n\t\tdocument.addEventListener('keydown', handleKeyDown)\n\t\treturn () => {\n\t\t\tdocument.removeEventListener('keydown', handleKeyDown)\n\t\t}\n\t}, [editor])\n\n\tconst popoverId = 'toolbar overflow'\n\treturn (\n\t\t<>\n\t\t\t<style nonce={editor.options.nonce}>{css}</style>\n\t\t\t<TldrawUiToolbar\n\t\t\t\tclassName={classNames('tlui-toolbar__tools', {\n\t\t\t\t\t'tlui-toolbar__tools__mobile': breakpoint < PORTRAIT_BREAKPOINT.TABLET_SM,\n\t\t\t\t})}\n\t\t\t\tlabel={msg('tool-panel.title')}\n\t\t\t>\n\t\t\t\t<div id={`${id}_main`} ref={mainToolsRef} className=\"tlui-toolbar__tools__list\">\n\t\t\t\t\t<TldrawUiMenuContextProvider type=\"toolbar\" sourceId=\"toolbar\">\n\t\t\t\t\t\t{children}\n\t\t\t\t\t</TldrawUiMenuContextProvider>\n\t\t\t\t</div>\n\t\t\t\t{/* There is a +1 because if the menu is just one item, it's not necessary. */}\n\t\t\t\t{totalItems > overflowIndex + 1 && (\n\t\t\t\t\t<IsInOverflowContext.Provider value={true}>\n\t\t\t\t\t\t<TldrawUiPopover id={popoverId} open={isOpen} onOpenChange={setIsOpen}>\n\t\t\t\t\t\t\t<TldrawUiPopoverTrigger>\n\t\t\t\t\t\t\t\t<TldrawUiToolbarButton\n\t\t\t\t\t\t\t\t\ttitle={msg('tool-panel.more')}\n\t\t\t\t\t\t\t\t\ttype=\"tool\"\n\t\t\t\t\t\t\t\t\tclassName=\"tlui-toolbar__overflow\"\n\t\t\t\t\t\t\t\t\tdata-testid=\"tools.more-button\"\n\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t\t<TldrawUiButtonIcon icon=\"chevron-up\" />\n\t\t\t\t\t\t\t\t</TldrawUiToolbarButton>\n\t\t\t\t\t\t\t</TldrawUiPopoverTrigger>\n\t\t\t\t\t\t\t<TldrawUiPopoverContent side=\"top\" align=\"center\">\n\t\t\t\t\t\t\t\t<TldrawUiToolbar\n\t\t\t\t\t\t\t\t\tclassName=\"tlui-buttons__grid\"\n\t\t\t\t\t\t\t\t\tdata-testid=\"tools.more-content\"\n\t\t\t\t\t\t\t\t\tlabel={msg('tool-panel.more')}\n\t\t\t\t\t\t\t\t\tid={`${id}_more`}\n\t\t\t\t\t\t\t\t\tonClick={() => {\n\t\t\t\t\t\t\t\t\t\ttlmenus.deleteOpenMenu(popoverId, editor.contextId)\n\t\t\t\t\t\t\t\t\t\tsetIsOpen(false)\n\t\t\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t\t<TldrawUiMenuContextProvider type=\"toolbar-overflow\" sourceId=\"toolbar\">\n\t\t\t\t\t\t\t\t\t\t{children}\n\t\t\t\t\t\t\t\t\t</TldrawUiMenuContextProvider>\n\t\t\t\t\t\t\t\t</TldrawUiToolbar>\n\t\t\t\t\t\t\t</TldrawUiPopoverContent>\n\t\t\t\t\t\t</TldrawUiPopover>\n\t\t\t\t\t</IsInOverflowContext.Provider>\n\t\t\t\t)}\n\t\t\t</TldrawUiToolbar>\n\t\t</>\n\t)\n}\n\nexport const isActiveTLUiToolItem = (\n\titem: TLUiToolItem,\n\tactiveToolId: string | undefined,\n\tgeoState: string | null | undefined\n) => {\n\treturn item.meta?.geo\n\t\t? activeToolId === 'geo' && geoState === item.meta?.geo\n\t\t: activeToolId === item.id\n}\n"],
5
- "mappings": "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",
6
- "names": ["children", "classNames"]
4
+ "sourcesContent": ["import {\n\tactiveElementShouldCaptureKeys,\n\tassert,\n\tmodulate,\n\tpreventDefault,\n\ttlmenus,\n\tuseEditor,\n\tuseEvent,\n\tuseUniqueSafeId,\n} from '@tldraw/editor'\nimport classNames from 'classnames'\nimport { createContext, useEffect, useLayoutEffect, useRef, useState } from 'react'\nimport { PORTRAIT_BREAKPOINT } from '../../constants'\nimport { useBreakpoint } from '../../context/breakpoints'\nimport { areShortcutsDisabled } from '../../hooks/useKeyboardShortcuts'\nimport { TLUiToolItem } from '../../hooks/useTools'\nimport { useTranslation } from '../../hooks/useTranslation/useTranslation'\nimport { TldrawUiButtonIcon } from '../primitives/Button/TldrawUiButtonIcon'\nimport {\n\tTldrawUiPopover,\n\tTldrawUiPopoverContent,\n\tTldrawUiPopoverTrigger,\n} from '../primitives/TldrawUiPopover'\nimport { TldrawUiToolbar, TldrawUiToolbarButton } from '../primitives/TldrawUiToolbar'\nimport { TldrawUiColumn, TldrawUiRow } from '../primitives/layout'\nimport { TldrawUiMenuContextProvider } from '../primitives/menus/TldrawUiMenuContext'\n\nexport const IsInOverflowContext = createContext(false)\n\nconst NUMBERED_SHORTCUT_KEYS: Record<string, number> = {\n\t'1': 0,\n\t'2': 1,\n\t'3': 2,\n\t'4': 3,\n\t'5': 4,\n\t'6': 5,\n\t'7': 6,\n\t'8': 7,\n\t'9': 8,\n\t'0': 9,\n}\n\n/** @public */\nexport interface OverflowingToolbarProps {\n\tchildren: React.ReactNode\n\torientation: 'horizontal' | 'vertical'\n\tsizingParentClassName: string\n\tminItems: number\n\tminSizePx: number\n\tmaxItems: number\n\tmaxSizePx: number\n}\n\n/** @public @react */\nexport function OverflowingToolbar({\n\tchildren,\n\torientation,\n\tsizingParentClassName,\n\tminItems,\n\tminSizePx,\n\tmaxItems,\n\tmaxSizePx,\n}: OverflowingToolbarProps) {\n\tconst editor = useEditor()\n\tconst id = useUniqueSafeId()\n\tconst breakpoint = useBreakpoint()\n\tconst msg = useTranslation()\n\tconst rButtons = useRef<HTMLElement[]>([])\n\tconst [isOpen, setIsOpen] = useState(false)\n\n\tconst mainToolsRef = useRef<HTMLDivElement>(null)\n\n\t// we have to use state instead of a ref here so that we get\n\t// an update when the overflow popover mounts / unmounts\n\tconst [overflowTools, setOverflowTools] = useState<HTMLDivElement | null>(null)\n\tconst [lastActiveOverflowItem, setLastActiveOverflowItem] = useState<string | null>(null)\n\tconst [shouldShowOverflow, setShouldShowOverflow] = useState(false)\n\n\tconst onDomUpdate = useEvent(() => {\n\t\tif (!mainToolsRef.current) return\n\n\t\t// whenever we get an update, we need to re-calculate the number of items to show and update\n\t\t// the component accordingly.\n\t\tconst sizeProp = orientation === 'horizontal' ? 'offsetWidth' : 'offsetHeight'\n\n\t\t// toolbars can contain both single items and groups. we need to keep track of both.\n\t\ttype Items = (\n\t\t\t| { type: 'item'; element: HTMLElement }\n\t\t\t| { type: 'group'; items: Items; element: HTMLElement }\n\t\t)[]\n\n\t\t// walk through the dom and collect items so we can calculate what to show/hide\n\t\tconst mainItems = collectItems(mainToolsRef.current.children)\n\t\tconst overflowItems = overflowTools ? collectItems(overflowTools.children) : null\n\t\tfunction collectItems(collection: HTMLCollection) {\n\t\t\tconst items: Items = []\n\t\t\tfor (const child of collection) {\n\t\t\t\tif (child.classList.contains('tlui-main-toolbar__group')) {\n\t\t\t\t\titems.push({\n\t\t\t\t\t\ttype: 'group',\n\t\t\t\t\t\titems: collectItems(child.children),\n\t\t\t\t\t\telement: child as HTMLElement,\n\t\t\t\t\t})\n\t\t\t\t} else {\n\t\t\t\t\titems.push({ type: 'item', element: child as HTMLElement })\n\t\t\t\t}\n\t\t\t}\n\n\t\t\treturn items\n\t\t}\n\n\t\t// the number of items to show is based on the space available to the toolbar.\n\t\tconst sizingParent = findParentWithClassName(mainToolsRef.current, sizingParentClassName)\n\t\tconst size = sizingParent[sizeProp]\n\t\tconst itemsToShow = Math.floor(\n\t\t\tmodulate(size, [minSizePx, maxSizePx], [minItems, maxItems], true)\n\t\t)\n\n\t\t// now we know how many items to show, we need to walk through the items we found and show /\n\t\t// hide them accordingly. We need to keep track of:\n\t\t// the number of item's we've shown in the main content so far\n\t\tlet mainItemCount = 0\n\t\t// the item that is currently active in the overflow content (if any)\n\t\tlet newActiveOverflowItem: string | null = null\n\t\t// whether the last active overflow item is actually still in the overflow content\n\t\tlet shouldInvalidateLastActiveOverflowItem = false\n\t\t// the buttons visible in the main content\n\t\tconst numberedButtons: HTMLButtonElement[] = []\n\t\tfunction visitItems(\n\t\t\tmainItems: Items,\n\t\t\toverflowItems: Items | null\n\t\t): {\n\t\t\t// for each group of items we visit, we need to know whether we showed anything in\n\t\t\t// either section\n\t\t\tdidShowAnyInMain: boolean\n\t\t\tdidShowAnyInOverflow: boolean\n\t\t} {\n\t\t\tif (overflowItems) assert(mainItems.length === overflowItems.length)\n\n\t\t\tlet didShowAnyInMain = false\n\t\t\tlet didShowAnyInOverflow = false\n\n\t\t\tfor (let i = 0; i < mainItems.length; i++) {\n\t\t\t\tconst mainItem = mainItems[i]\n\t\t\t\tconst overflowItem = overflowItems?.[i]\n\n\t\t\t\tif (mainItem.type === 'item') {\n\t\t\t\t\tconst isLastActiveOverflowItem =\n\t\t\t\t\t\tmainItem.element.getAttribute('data-value') === lastActiveOverflowItem\n\n\t\t\t\t\t// for single items, we show them in main if we have space, or if they're the\n\t\t\t\t\t// last-used item from the overflow.\n\t\t\t\t\tlet shouldShowInMain\n\t\t\t\t\tif (lastActiveOverflowItem) {\n\t\t\t\t\t\tshouldShowInMain = mainItemCount < itemsToShow || isLastActiveOverflowItem\n\t\t\t\t\t} else {\n\t\t\t\t\t\t// we use <= here because if there is no last active overflow item, we want\n\t\t\t\t\t\t// to show at least one item in the main toolbar.\n\t\t\t\t\t\tshouldShowInMain = mainItemCount <= itemsToShow\n\t\t\t\t\t}\n\t\t\t\t\tconst shouldShowInOverflow = mainItemCount >= itemsToShow\n\n\t\t\t\t\tdidShowAnyInMain ||= shouldShowInMain\n\t\t\t\t\tdidShowAnyInOverflow ||= shouldShowInOverflow\n\n\t\t\t\t\tsetAttribute(\n\t\t\t\t\t\tmainItem.element,\n\t\t\t\t\t\t'data-toolbar-visible',\n\t\t\t\t\t\tshouldShowInMain ? 'true' : 'false'\n\t\t\t\t\t)\n\t\t\t\t\tif (overflowItem) {\n\t\t\t\t\t\tassert(overflowItem.type === 'item')\n\t\t\t\t\t\tsetAttribute(\n\t\t\t\t\t\t\toverflowItem.element,\n\t\t\t\t\t\t\t'data-toolbar-visible',\n\t\t\t\t\t\t\tshouldShowInOverflow ? 'true' : 'false'\n\t\t\t\t\t\t)\n\t\t\t\t\t}\n\t\t\t\t\tif (shouldShowInOverflow && mainItem.element.getAttribute('aria-pressed') === 'true') {\n\t\t\t\t\t\tnewActiveOverflowItem = mainItem.element.getAttribute('data-value')\n\t\t\t\t\t}\n\t\t\t\t\tif (shouldShowInMain && mainItem.element.tagName === 'BUTTON') {\n\t\t\t\t\t\tnumberedButtons.push(mainItem.element as HTMLButtonElement)\n\t\t\t\t\t}\n\t\t\t\t\tif (!shouldShowInOverflow && isLastActiveOverflowItem) {\n\t\t\t\t\t\tshouldInvalidateLastActiveOverflowItem = true\n\t\t\t\t\t}\n\t\t\t\t\tmainItemCount++\n\t\t\t\t} else {\n\t\t\t\t\t// for groups, we show them in main if we have space, or if they're the\n\t\t\t\t\t// last-used item from the overflow.\n\t\t\t\t\tlet result, overflowGroup\n\t\t\t\t\tif (overflowItem) {\n\t\t\t\t\t\tassert(overflowItem.type === 'group')\n\t\t\t\t\t\toverflowGroup = overflowItem\n\t\t\t\t\t\tresult = visitItems(mainItem.items, overflowGroup.items)\n\t\t\t\t\t} else {\n\t\t\t\t\t\tresult = visitItems(mainItem.items, null)\n\t\t\t\t\t}\n\n\t\t\t\t\tdidShowAnyInMain ||= result.didShowAnyInMain\n\t\t\t\t\tdidShowAnyInOverflow ||= result.didShowAnyInOverflow\n\n\t\t\t\t\tsetAttribute(\n\t\t\t\t\t\tmainItem.element,\n\t\t\t\t\t\t'data-toolbar-visible',\n\t\t\t\t\t\tresult.didShowAnyInMain ? 'true' : 'false'\n\t\t\t\t\t)\n\t\t\t\t\tif (overflowGroup) {\n\t\t\t\t\t\tsetAttribute(\n\t\t\t\t\t\t\toverflowGroup.element,\n\t\t\t\t\t\t\t'data-toolbar-visible',\n\t\t\t\t\t\t\tresult.didShowAnyInOverflow ? 'true' : 'false'\n\t\t\t\t\t\t)\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t\treturn { didShowAnyInMain, didShowAnyInOverflow }\n\t\t}\n\n\t\tconst { didShowAnyInOverflow } = visitItems(mainItems, overflowItems)\n\t\tsetShouldShowOverflow(didShowAnyInOverflow)\n\t\tif (newActiveOverflowItem) {\n\t\t\tsetLastActiveOverflowItem(newActiveOverflowItem)\n\t\t} else if (shouldInvalidateLastActiveOverflowItem) {\n\t\t\tsetLastActiveOverflowItem(null)\n\t\t}\n\n\t\trButtons.current = numberedButtons\n\t})\n\n\tuseLayoutEffect(() => {\n\t\tonDomUpdate()\n\t})\n\n\tuseLayoutEffect(() => {\n\t\tif (!mainToolsRef.current) return\n\n\t\tconst mutationObserver = new MutationObserver(onDomUpdate)\n\t\tmutationObserver.observe(mainToolsRef.current, {\n\t\t\tchildList: true,\n\t\t\tsubtree: true,\n\t\t\tattributes: true,\n\t\t\tcharacterData: true,\n\t\t})\n\n\t\tconst sizingParent = findParentWithClassName(mainToolsRef.current, sizingParentClassName)\n\t\tconst resizeObserver = new ResizeObserver(onDomUpdate)\n\t\tresizeObserver.observe(sizingParent)\n\n\t\treturn () => {\n\t\t\tmutationObserver.disconnect()\n\t\t\tresizeObserver.disconnect()\n\t\t}\n\t}, [onDomUpdate, sizingParentClassName])\n\n\tuseEffect(() => {\n\t\tif (!editor.options.enableToolbarKeyboardShortcuts) return\n\n\t\tfunction handleKeyDown(event: KeyboardEvent) {\n\t\t\tif (\n\t\t\t\tareShortcutsDisabled(editor) ||\n\t\t\t\tactiveElementShouldCaptureKeys(true /* allow buttons */)\n\t\t\t) {\n\t\t\t\treturn\n\t\t\t}\n\n\t\t\t// no accelerator keys\n\t\t\tif (event.ctrlKey || event.metaKey || event.altKey || event.shiftKey) return\n\t\t\tconst index = NUMBERED_SHORTCUT_KEYS[event.key]\n\t\t\tif (typeof index === 'number') {\n\t\t\t\tpreventDefault(event)\n\t\t\t\trButtons.current[index]?.click()\n\t\t\t}\n\t\t}\n\n\t\tdocument.addEventListener('keydown', handleKeyDown)\n\t\treturn () => {\n\t\t\tdocument.removeEventListener('keydown', handleKeyDown)\n\t\t}\n\t}, [editor])\n\n\tconst popoverId = 'toolbar overflow'\n\n\tconst Layout = orientation === 'horizontal' ? TldrawUiRow : TldrawUiColumn\n\treturn (\n\t\t<>\n\t\t\t<TldrawUiToolbar\n\t\t\t\torientation={orientation}\n\t\t\t\tclassName={classNames('tlui-main-toolbar__tools', {\n\t\t\t\t\t'tlui-main-toolbar__tools__mobile': breakpoint < PORTRAIT_BREAKPOINT.TABLET_SM,\n\t\t\t\t})}\n\t\t\t\tlabel={msg('tool-panel.title')}\n\t\t\t>\n\t\t\t\t<Layout id={`${id}_main`} ref={mainToolsRef}>\n\t\t\t\t\t<TldrawUiMenuContextProvider type=\"toolbar\" sourceId=\"toolbar\">\n\t\t\t\t\t\t{children}\n\t\t\t\t\t</TldrawUiMenuContextProvider>\n\t\t\t\t</Layout>\n\t\t\t\t{shouldShowOverflow && (\n\t\t\t\t\t<IsInOverflowContext.Provider value={true}>\n\t\t\t\t\t\t<TldrawUiPopover id={popoverId} open={isOpen} onOpenChange={setIsOpen}>\n\t\t\t\t\t\t\t<TldrawUiPopoverTrigger>\n\t\t\t\t\t\t\t\t<TldrawUiToolbarButton\n\t\t\t\t\t\t\t\t\ttitle={msg('tool-panel.more')}\n\t\t\t\t\t\t\t\t\ttype=\"tool\"\n\t\t\t\t\t\t\t\t\tclassName=\"tlui-main-toolbar__overflow\"\n\t\t\t\t\t\t\t\t\tdata-testid=\"tools.more-button\"\n\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t\t<TldrawUiButtonIcon\n\t\t\t\t\t\t\t\t\t\ticon={orientation === 'horizontal' ? 'chevron-up' : 'chevron-right'}\n\t\t\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t\t\t</TldrawUiToolbarButton>\n\t\t\t\t\t\t\t</TldrawUiPopoverTrigger>\n\t\t\t\t\t\t\t<TldrawUiPopoverContent\n\t\t\t\t\t\t\t\tside={orientation === 'horizontal' ? 'top' : 'right'}\n\t\t\t\t\t\t\t\talign={orientation === 'horizontal' ? 'center' : 'end'}\n\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t<TldrawUiToolbar\n\t\t\t\t\t\t\t\t\torientation=\"grid\"\n\t\t\t\t\t\t\t\t\tclassName=\"tlui-main-toolbar__overflow-content\"\n\t\t\t\t\t\t\t\t\tref={setOverflowTools}\n\t\t\t\t\t\t\t\t\tdata-testid=\"tools.more-content\"\n\t\t\t\t\t\t\t\t\tlabel={msg('tool-panel.more')}\n\t\t\t\t\t\t\t\t\tid={`${id}_more`}\n\t\t\t\t\t\t\t\t\tonClick={() => {\n\t\t\t\t\t\t\t\t\t\ttlmenus.deleteOpenMenu(popoverId, editor.contextId)\n\t\t\t\t\t\t\t\t\t\tsetIsOpen(false)\n\t\t\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t\t<TldrawUiMenuContextProvider type=\"toolbar-overflow\" sourceId=\"toolbar\">\n\t\t\t\t\t\t\t\t\t\t{children}\n\t\t\t\t\t\t\t\t\t</TldrawUiMenuContextProvider>\n\t\t\t\t\t\t\t\t</TldrawUiToolbar>\n\t\t\t\t\t\t\t</TldrawUiPopoverContent>\n\t\t\t\t\t\t</TldrawUiPopover>\n\t\t\t\t\t</IsInOverflowContext.Provider>\n\t\t\t\t)}\n\t\t\t</TldrawUiToolbar>\n\t\t</>\n\t)\n}\n\nexport const isActiveTLUiToolItem = (\n\titem: TLUiToolItem,\n\tactiveToolId: string | undefined,\n\tgeoState: string | null | undefined\n) => {\n\treturn item.meta?.geo\n\t\t? activeToolId === 'geo' && geoState === item.meta?.geo\n\t\t: activeToolId === item.id\n}\n\nfunction findParentWithClassName(startingElement: HTMLElement, className: string): HTMLElement {\n\tlet element: HTMLElement | null = startingElement\n\twhile (element) {\n\t\tif (element.classList.contains(className)) {\n\t\t\treturn element\n\t\t}\n\t\telement = element.parentElement\n\t}\n\tthrow new Error('Could not find parent with class name ' + className)\n}\n\nfunction setAttribute(element: HTMLElement, name: string, value: string) {\n\tif (element.getAttribute(name) === value) return\n\telement.setAttribute(name, value)\n}\n"],
5
+ "mappings": "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",
6
+ "names": ["mainItems", "overflowItems", "didShowAnyInOverflow", "classNames"]
7
7
  }
@@ -39,6 +39,7 @@ var import_breakpoints = require("../../context/breakpoints");
39
39
  var import_useTranslation = require("../../hooks/useTranslation/useTranslation");
40
40
  var import_TldrawUiButton = require("../primitives/Button/TldrawUiButton");
41
41
  var import_TldrawUiButtonIcon = require("../primitives/Button/TldrawUiButtonIcon");
42
+ var import_TldrawUiTooltip = require("../primitives/TldrawUiTooltip");
42
43
  function ToggleToolLockedButton({ activeToolId }) {
43
44
  const editor = (0, import_editor.useEditor)();
44
45
  const breakpoint = (0, import_breakpoints.useBreakpoint)();
@@ -48,18 +49,18 @@ function ToggleToolLockedButton({ activeToolId }) {
48
49
  ]);
49
50
  const tool = (0, import_editor.useValue)("current tool", () => editor.getCurrentTool(), [editor]);
50
51
  if (!activeToolId || !tool.isLockable) return null;
51
- return /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
52
+ return /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_TldrawUiTooltip.TldrawUiTooltip, { content: msg("action.toggle-tool-lock"), children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
52
53
  import_TldrawUiButton.TldrawUiButton,
53
54
  {
54
55
  type: "normal",
55
56
  title: msg("action.toggle-tool-lock"),
56
57
  "data-testid": "tool-lock",
57
- className: (0, import_classnames.default)("tlui-toolbar__lock-button", {
58
- "tlui-toolbar__lock-button__mobile": breakpoint < import_constants.PORTRAIT_BREAKPOINT.TABLET_SM
58
+ className: (0, import_classnames.default)("tlui-main-toolbar__lock-button", {
59
+ "tlui-main-toolbar__lock-button__mobile": breakpoint < import_constants.PORTRAIT_BREAKPOINT.TABLET_SM
59
60
  }),
60
61
  onClick: () => editor.updateInstanceState({ isToolLocked: !isToolLocked }),
61
62
  children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_TldrawUiButtonIcon.TldrawUiButtonIcon, { icon: isToolLocked ? "lock" : "unlock", small: true })
62
63
  }
63
- );
64
+ ) });
64
65
  }
65
66
  //# sourceMappingURL=ToggleToolLockedButton.js.map
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../../../src/lib/ui/components/Toolbar/ToggleToolLockedButton.tsx"],
4
- "sourcesContent": ["import { useEditor, useValue } from '@tldraw/editor'\nimport classNames from 'classnames'\nimport { PORTRAIT_BREAKPOINT } from '../../constants'\nimport { useBreakpoint } from '../../context/breakpoints'\nimport { useTranslation } from '../../hooks/useTranslation/useTranslation'\nimport { TldrawUiButton } from '../primitives/Button/TldrawUiButton'\nimport { TldrawUiButtonIcon } from '../primitives/Button/TldrawUiButtonIcon'\n\n/** @public */\nexport interface ToggleToolLockedButtonProps {\n\tactiveToolId?: string\n}\n\n/** @public @react */\nexport function ToggleToolLockedButton({ activeToolId }: ToggleToolLockedButtonProps) {\n\tconst editor = useEditor()\n\tconst breakpoint = useBreakpoint()\n\tconst msg = useTranslation()\n\n\tconst isToolLocked = useValue('is tool locked', () => editor.getInstanceState().isToolLocked, [\n\t\teditor,\n\t])\n\tconst tool = useValue('current tool', () => editor.getCurrentTool(), [editor])\n\n\tif (!activeToolId || !tool.isLockable) return null\n\n\treturn (\n\t\t<TldrawUiButton\n\t\t\ttype=\"normal\"\n\t\t\ttitle={msg('action.toggle-tool-lock')}\n\t\t\tdata-testid=\"tool-lock\"\n\t\t\tclassName={classNames('tlui-toolbar__lock-button', {\n\t\t\t\t'tlui-toolbar__lock-button__mobile': breakpoint < PORTRAIT_BREAKPOINT.TABLET_SM,\n\t\t\t})}\n\t\t\tonClick={() => editor.updateInstanceState({ isToolLocked: !isToolLocked })}\n\t\t>\n\t\t\t<TldrawUiButtonIcon icon={isToolLocked ? 'lock' : 'unlock'} small />\n\t\t</TldrawUiButton>\n\t)\n}\n"],
5
- "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAoCG;AApCH,oBAAoC;AACpC,wBAAuB;AACvB,uBAAoC;AACpC,yBAA8B;AAC9B,4BAA+B;AAC/B,4BAA+B;AAC/B,gCAAmC;AAQ5B,SAAS,uBAAuB,EAAE,aAAa,GAAgC;AACrF,QAAM,aAAS,yBAAU;AACzB,QAAM,iBAAa,kCAAc;AACjC,QAAM,UAAM,sCAAe;AAE3B,QAAM,mBAAe,wBAAS,kBAAkB,MAAM,OAAO,iBAAiB,EAAE,cAAc;AAAA,IAC7F;AAAA,EACD,CAAC;AACD,QAAM,WAAO,wBAAS,gBAAgB,MAAM,OAAO,eAAe,GAAG,CAAC,MAAM,CAAC;AAE7E,MAAI,CAAC,gBAAgB,CAAC,KAAK,WAAY,QAAO;AAE9C,SACC;AAAA,IAAC;AAAA;AAAA,MACA,MAAK;AAAA,MACL,OAAO,IAAI,yBAAyB;AAAA,MACpC,eAAY;AAAA,MACZ,eAAW,kBAAAA,SAAW,6BAA6B;AAAA,QAClD,qCAAqC,aAAa,qCAAoB;AAAA,MACvE,CAAC;AAAA,MACD,SAAS,MAAM,OAAO,oBAAoB,EAAE,cAAc,CAAC,aAAa,CAAC;AAAA,MAEzE,sDAAC,gDAAmB,MAAM,eAAe,SAAS,UAAU,OAAK,MAAC;AAAA;AAAA,EACnE;AAEF;",
4
+ "sourcesContent": ["import { useEditor, useValue } from '@tldraw/editor'\nimport classNames from 'classnames'\nimport { PORTRAIT_BREAKPOINT } from '../../constants'\nimport { useBreakpoint } from '../../context/breakpoints'\nimport { useTranslation } from '../../hooks/useTranslation/useTranslation'\nimport { TldrawUiButton } from '../primitives/Button/TldrawUiButton'\nimport { TldrawUiButtonIcon } from '../primitives/Button/TldrawUiButtonIcon'\nimport { TldrawUiTooltip } from '../primitives/TldrawUiTooltip'\n\n/** @public */\nexport interface ToggleToolLockedButtonProps {\n\tactiveToolId?: string\n}\n\n/** @public @react */\nexport function ToggleToolLockedButton({ activeToolId }: ToggleToolLockedButtonProps) {\n\tconst editor = useEditor()\n\tconst breakpoint = useBreakpoint()\n\tconst msg = useTranslation()\n\n\tconst isToolLocked = useValue('is tool locked', () => editor.getInstanceState().isToolLocked, [\n\t\teditor,\n\t])\n\tconst tool = useValue('current tool', () => editor.getCurrentTool(), [editor])\n\n\tif (!activeToolId || !tool.isLockable) return null\n\n\treturn (\n\t\t<TldrawUiTooltip content={msg('action.toggle-tool-lock')}>\n\t\t\t<TldrawUiButton\n\t\t\t\ttype=\"normal\"\n\t\t\t\ttitle={msg('action.toggle-tool-lock')}\n\t\t\t\tdata-testid=\"tool-lock\"\n\t\t\t\tclassName={classNames('tlui-main-toolbar__lock-button', {\n\t\t\t\t\t'tlui-main-toolbar__lock-button__mobile': breakpoint < PORTRAIT_BREAKPOINT.TABLET_SM,\n\t\t\t\t})}\n\t\t\t\tonClick={() => editor.updateInstanceState({ isToolLocked: !isToolLocked })}\n\t\t\t>\n\t\t\t\t<TldrawUiButtonIcon icon={isToolLocked ? 'lock' : 'unlock'} small />\n\t\t\t</TldrawUiButton>\n\t\t</TldrawUiTooltip>\n\t)\n}\n"],
5
+ "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAsCI;AAtCJ,oBAAoC;AACpC,wBAAuB;AACvB,uBAAoC;AACpC,yBAA8B;AAC9B,4BAA+B;AAC/B,4BAA+B;AAC/B,gCAAmC;AACnC,6BAAgC;AAQzB,SAAS,uBAAuB,EAAE,aAAa,GAAgC;AACrF,QAAM,aAAS,yBAAU;AACzB,QAAM,iBAAa,kCAAc;AACjC,QAAM,UAAM,sCAAe;AAE3B,QAAM,mBAAe,wBAAS,kBAAkB,MAAM,OAAO,iBAAiB,EAAE,cAAc;AAAA,IAC7F;AAAA,EACD,CAAC;AACD,QAAM,WAAO,wBAAS,gBAAgB,MAAM,OAAO,eAAe,GAAG,CAAC,MAAM,CAAC;AAE7E,MAAI,CAAC,gBAAgB,CAAC,KAAK,WAAY,QAAO;AAE9C,SACC,4CAAC,0CAAgB,SAAS,IAAI,yBAAyB,GACtD;AAAA,IAAC;AAAA;AAAA,MACA,MAAK;AAAA,MACL,OAAO,IAAI,yBAAyB;AAAA,MACpC,eAAY;AAAA,MACZ,eAAW,kBAAAA,SAAW,kCAAkC;AAAA,QACvD,0CAA0C,aAAa,qCAAoB;AAAA,MAC5E,CAAC;AAAA,MACD,SAAS,MAAM,OAAO,oBAAoB,EAAE,cAAc,CAAC,aAAa,CAAC;AAAA,MAEzE,sDAAC,gDAAmB,MAAM,eAAe,SAAS,UAAU,OAAK,MAAC;AAAA;AAAA,EACnE,GACD;AAEF;",
6
6
  "names": ["classNames"]
7
7
  }
@@ -55,6 +55,7 @@ __export(menu_items_exports, {
55
55
  ToggleSnapModeItem: () => ToggleSnapModeItem,
56
56
  ToggleToolLockItem: () => ToggleToolLockItem,
57
57
  ToggleTransparentBgMenuItem: () => ToggleTransparentBgMenuItem,
58
+ ToggleUiLabelsItem: () => ToggleUiLabelsItem,
58
59
  ToggleWrapModeItem: () => ToggleWrapModeItem,
59
60
  UngroupMenuItem: () => UngroupMenuItem,
60
61
  UnlockAllMenuItem: () => UnlockAllMenuItem,
@@ -520,6 +521,11 @@ function ToggleKeyboardShortcutsItem() {
520
521
  }
521
522
  );
522
523
  }
524
+ function ToggleUiLabelsItem() {
525
+ const editor = (0, import_editor.useEditor)();
526
+ const showUiLabels = (0, import_editor.useValue)("showUiLabels", () => editor.user.getShowUiLabels(), [editor]);
527
+ return /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_TldrawUiMenuActionCheckboxItem.TldrawUiMenuActionCheckboxItem, { actionId: "toggle-ui-labels", checked: showUiLabels });
528
+ }
523
529
  function ToggleDebugModeItem() {
524
530
  const editor = (0, import_editor.useEditor)();
525
531
  const isDebugMode = (0, import_editor.useValue)("isDebugMode", () => editor.getInstanceState().isDebugMode, [editor]);