tldraw 3.16.0-internal.51e99e128bd4 → 3.16.0-internal.71f83a8a571b

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 (310) hide show
  1. package/dist-cjs/index.d.ts +177 -110
  2. package/dist-cjs/index.js +29 -14
  3. package/dist-cjs/index.js.map +2 -2
  4. package/dist-cjs/lib/Tldraw.js +12 -2
  5. package/dist-cjs/lib/Tldraw.js.map +2 -2
  6. package/dist-cjs/lib/defaultExternalContentHandlers.js +5 -4
  7. package/dist-cjs/lib/defaultExternalContentHandlers.js.map +2 -2
  8. package/dist-cjs/lib/shapes/arrow/arrowLabel.js +6 -0
  9. package/dist-cjs/lib/shapes/arrow/arrowLabel.js.map +3 -3
  10. package/dist-cjs/lib/shapes/arrow/arrowTargetState.js.map +2 -2
  11. package/dist-cjs/lib/shapes/arrow/elbow/elbowArrowSnapLines.js.map +1 -1
  12. package/dist-cjs/lib/shapes/bookmark/BookmarkShapeUtil.js +4 -4
  13. package/dist-cjs/lib/shapes/bookmark/BookmarkShapeUtil.js.map +2 -2
  14. package/dist-cjs/lib/shapes/frame/FrameShapeTool.js.map +1 -1
  15. package/dist-cjs/lib/shapes/frame/FrameShapeUtil.js +8 -1
  16. package/dist-cjs/lib/shapes/frame/FrameShapeUtil.js.map +2 -2
  17. package/dist-cjs/lib/shapes/frame/components/FrameLabelInput.js +2 -2
  18. package/dist-cjs/lib/shapes/frame/components/FrameLabelInput.js.map +2 -2
  19. package/dist-cjs/lib/shapes/geo/GeoShapeUtil.js +1 -0
  20. package/dist-cjs/lib/shapes/geo/GeoShapeUtil.js.map +2 -2
  21. package/dist-cjs/lib/shapes/image/ImageShapeUtil.js +3 -0
  22. package/dist-cjs/lib/shapes/image/ImageShapeUtil.js.map +2 -2
  23. package/dist-cjs/lib/shapes/note/NoteShapeUtil.js +2 -1
  24. package/dist-cjs/lib/shapes/note/NoteShapeUtil.js.map +2 -2
  25. package/dist-cjs/lib/shapes/shared/HyperlinkButton.js +4 -4
  26. package/dist-cjs/lib/shapes/shared/HyperlinkButton.js.map +2 -2
  27. package/dist-cjs/lib/shapes/shared/PlainTextLabel.js +1 -3
  28. package/dist-cjs/lib/shapes/shared/PlainTextLabel.js.map +2 -2
  29. package/dist-cjs/lib/shapes/shared/RichTextLabel.js.map +2 -2
  30. package/dist-cjs/lib/shapes/shared/crop.js +1 -0
  31. package/dist-cjs/lib/shapes/shared/crop.js.map +2 -2
  32. package/dist-cjs/lib/shapes/shared/useEditablePlainText.js +3 -4
  33. package/dist-cjs/lib/shapes/shared/useEditablePlainText.js.map +2 -2
  34. package/dist-cjs/lib/shapes/shared/useEditableRichText.js.map +2 -2
  35. package/dist-cjs/lib/shapes/shared/useImageOrVideoAsset.js +0 -2
  36. package/dist-cjs/lib/shapes/shared/useImageOrVideoAsset.js.map +2 -2
  37. package/dist-cjs/lib/shapes/text/PlainTextArea.js +2 -2
  38. package/dist-cjs/lib/shapes/text/PlainTextArea.js.map +2 -2
  39. package/dist-cjs/lib/shapes/text/RichTextArea.js +3 -3
  40. package/dist-cjs/lib/shapes/text/RichTextArea.js.map +2 -2
  41. package/dist-cjs/lib/tools/SelectTool/childStates/DraggingHandle.js +1 -1
  42. package/dist-cjs/lib/tools/SelectTool/childStates/DraggingHandle.js.map +2 -2
  43. package/dist-cjs/lib/ui/TldrawUi.js +13 -12
  44. package/dist-cjs/lib/ui/TldrawUi.js.map +2 -2
  45. package/dist-cjs/lib/ui/components/A11y.js +1 -1
  46. package/dist-cjs/lib/ui/components/A11y.js.map +2 -2
  47. package/dist-cjs/lib/ui/components/{FollowingIndicator.js → DefaultFollowingIndicator.js} +6 -6
  48. package/dist-cjs/lib/ui/components/DefaultFollowingIndicator.js.map +7 -0
  49. package/dist-cjs/lib/ui/components/EditLinkDialog.js +11 -1
  50. package/dist-cjs/lib/ui/components/EditLinkDialog.js.map +2 -2
  51. package/dist-cjs/lib/ui/components/KeyboardShortcutsDialog/DefaultKeyboardShortcutsDialogContent.js +6 -6
  52. package/dist-cjs/lib/ui/components/KeyboardShortcutsDialog/DefaultKeyboardShortcutsDialogContent.js.map +1 -1
  53. package/dist-cjs/lib/ui/components/PageMenu/DefaultPageMenu.js +1 -1
  54. package/dist-cjs/lib/ui/components/PageMenu/DefaultPageMenu.js.map +2 -2
  55. package/dist-cjs/lib/ui/components/StylePanel/DefaultStylePanel.js +9 -4
  56. package/dist-cjs/lib/ui/components/StylePanel/DefaultStylePanel.js.map +2 -2
  57. package/dist-cjs/lib/ui/components/StylePanel/DefaultStylePanelContent.js +255 -316
  58. package/dist-cjs/lib/ui/components/StylePanel/DefaultStylePanelContent.js.map +2 -2
  59. package/dist-cjs/lib/ui/components/{primitives/TldrawUiButtonPicker.js → StylePanel/StylePanelButtonPicker.js} +52 -45
  60. package/dist-cjs/lib/ui/components/StylePanel/StylePanelButtonPicker.js.map +7 -0
  61. package/dist-cjs/lib/ui/components/StylePanel/StylePanelContext.js +68 -0
  62. package/dist-cjs/lib/ui/components/StylePanel/StylePanelContext.js.map +7 -0
  63. package/dist-cjs/lib/ui/components/StylePanel/{DoubleDropdownPicker.js → StylePanelDoubleDropdownPicker.js} +23 -22
  64. package/dist-cjs/lib/ui/components/StylePanel/StylePanelDoubleDropdownPicker.js.map +7 -0
  65. package/dist-cjs/lib/ui/components/StylePanel/{DropdownPicker.js → StylePanelDropdownPicker.js} +24 -21
  66. package/dist-cjs/lib/ui/components/StylePanel/StylePanelDropdownPicker.js.map +7 -0
  67. package/dist-cjs/lib/ui/components/StylePanel/StylePanelSubheading.js +28 -0
  68. package/dist-cjs/lib/ui/components/StylePanel/StylePanelSubheading.js.map +7 -0
  69. package/dist-cjs/lib/ui/components/Toolbar/AltTextEditor.js +3 -2
  70. package/dist-cjs/lib/ui/components/Toolbar/AltTextEditor.js.map +2 -2
  71. package/dist-cjs/lib/ui/components/Toolbar/DefaultImageToolbarContent.js +38 -9
  72. package/dist-cjs/lib/ui/components/Toolbar/DefaultImageToolbarContent.js.map +2 -2
  73. package/dist-cjs/lib/ui/components/Toolbar/DefaultVideoToolbarContent.js +15 -3
  74. package/dist-cjs/lib/ui/components/Toolbar/DefaultVideoToolbarContent.js.map +2 -2
  75. package/dist-cjs/lib/ui/components/Toolbar/LinkEditor.js +3 -3
  76. package/dist-cjs/lib/ui/components/Toolbar/LinkEditor.js.map +2 -2
  77. package/dist-cjs/lib/ui/components/primitives/TldrawUiContextualToolbar.js +11 -2
  78. package/dist-cjs/lib/ui/components/primitives/TldrawUiContextualToolbar.js.map +2 -2
  79. package/dist-cjs/lib/ui/components/primitives/TldrawUiInput.js +2 -2
  80. package/dist-cjs/lib/ui/components/primitives/TldrawUiInput.js.map +2 -2
  81. package/dist-cjs/lib/ui/components/primitives/TldrawUiSlider.js +18 -5
  82. package/dist-cjs/lib/ui/components/primitives/TldrawUiSlider.js.map +2 -2
  83. package/dist-cjs/lib/ui/components/primitives/TldrawUiToolbar.js +2 -0
  84. package/dist-cjs/lib/ui/components/primitives/TldrawUiToolbar.js.map +2 -2
  85. package/dist-cjs/lib/ui/components/primitives/TldrawUiTooltip.js +62 -36
  86. package/dist-cjs/lib/ui/components/primitives/TldrawUiTooltip.js.map +2 -2
  87. package/dist-cjs/lib/ui/components/primitives/menus/TldrawUiMenuItem.js +5 -5
  88. package/dist-cjs/lib/ui/components/primitives/menus/TldrawUiMenuItem.js.map +1 -1
  89. package/dist-cjs/lib/ui/context/actions.js +23 -10
  90. package/dist-cjs/lib/ui/context/actions.js.map +2 -2
  91. package/dist-cjs/lib/ui/context/components.js +2 -0
  92. package/dist-cjs/lib/ui/context/components.js.map +2 -2
  93. package/dist-cjs/lib/ui/context/events.js.map +1 -1
  94. package/dist-cjs/lib/ui/hooks/useClipboardEvents.js +1 -1
  95. package/dist-cjs/lib/ui/hooks/useClipboardEvents.js.map +2 -2
  96. package/dist-cjs/lib/ui/hooks/useExportAs.js +3 -2
  97. package/dist-cjs/lib/ui/hooks/useExportAs.js.map +2 -2
  98. package/dist-cjs/lib/ui/hooks/useTools.js +1 -1
  99. package/dist-cjs/lib/ui/hooks/useTools.js.map +2 -2
  100. package/dist-cjs/lib/ui/hooks/useTranslation/TLUiTranslationKey.js.map +1 -1
  101. package/dist-cjs/lib/ui/hooks/useTranslation/defaultTranslation.js +4 -2
  102. package/dist-cjs/lib/ui/hooks/useTranslation/defaultTranslation.js.map +2 -2
  103. package/dist-cjs/lib/ui/kbd-utils.js +9 -3
  104. package/dist-cjs/lib/ui/kbd-utils.js.map +2 -2
  105. package/dist-cjs/lib/ui/version.js +3 -3
  106. package/dist-cjs/lib/ui/version.js.map +1 -1
  107. package/dist-cjs/lib/utils/excalidraw/putExcalidrawContent.js.map +1 -1
  108. package/dist-cjs/lib/utils/export/copyAs.js +1 -2
  109. package/dist-cjs/lib/utils/export/copyAs.js.map +2 -2
  110. package/dist-cjs/lib/utils/export/export.js +0 -20
  111. package/dist-cjs/lib/utils/export/export.js.map +2 -2
  112. package/dist-cjs/lib/utils/export/exportAs.js +1 -2
  113. package/dist-cjs/lib/utils/export/exportAs.js.map +2 -2
  114. package/dist-esm/index.d.mts +177 -110
  115. package/dist-esm/index.mjs +57 -29
  116. package/dist-esm/index.mjs.map +2 -2
  117. package/dist-esm/lib/Tldraw.mjs +14 -4
  118. package/dist-esm/lib/Tldraw.mjs.map +2 -2
  119. package/dist-esm/lib/defaultExternalContentHandlers.mjs +5 -4
  120. package/dist-esm/lib/defaultExternalContentHandlers.mjs.map +2 -2
  121. package/dist-esm/lib/shapes/arrow/arrowLabel.mjs +6 -0
  122. package/dist-esm/lib/shapes/arrow/arrowLabel.mjs.map +3 -3
  123. package/dist-esm/lib/shapes/arrow/arrowTargetState.mjs.map +2 -2
  124. package/dist-esm/lib/shapes/arrow/elbow/elbowArrowSnapLines.mjs.map +1 -1
  125. package/dist-esm/lib/shapes/bookmark/BookmarkShapeUtil.mjs +5 -5
  126. package/dist-esm/lib/shapes/bookmark/BookmarkShapeUtil.mjs.map +2 -2
  127. package/dist-esm/lib/shapes/frame/FrameShapeTool.mjs.map +1 -1
  128. package/dist-esm/lib/shapes/frame/FrameShapeUtil.mjs +8 -1
  129. package/dist-esm/lib/shapes/frame/FrameShapeUtil.mjs.map +2 -2
  130. package/dist-esm/lib/shapes/frame/components/FrameLabelInput.mjs +3 -3
  131. package/dist-esm/lib/shapes/frame/components/FrameLabelInput.mjs.map +2 -2
  132. package/dist-esm/lib/shapes/geo/GeoShapeUtil.mjs +1 -0
  133. package/dist-esm/lib/shapes/geo/GeoShapeUtil.mjs.map +2 -2
  134. package/dist-esm/lib/shapes/image/ImageShapeUtil.mjs +3 -0
  135. package/dist-esm/lib/shapes/image/ImageShapeUtil.mjs.map +2 -2
  136. package/dist-esm/lib/shapes/note/NoteShapeUtil.mjs +2 -1
  137. package/dist-esm/lib/shapes/note/NoteShapeUtil.mjs.map +2 -2
  138. package/dist-esm/lib/shapes/shared/HyperlinkButton.mjs +5 -5
  139. package/dist-esm/lib/shapes/shared/HyperlinkButton.mjs.map +2 -2
  140. package/dist-esm/lib/shapes/shared/PlainTextLabel.mjs +1 -3
  141. package/dist-esm/lib/shapes/shared/PlainTextLabel.mjs.map +2 -2
  142. package/dist-esm/lib/shapes/shared/RichTextLabel.mjs.map +2 -2
  143. package/dist-esm/lib/shapes/shared/crop.mjs +1 -0
  144. package/dist-esm/lib/shapes/shared/crop.mjs.map +2 -2
  145. package/dist-esm/lib/shapes/shared/useEditablePlainText.mjs +4 -5
  146. package/dist-esm/lib/shapes/shared/useEditablePlainText.mjs.map +2 -2
  147. package/dist-esm/lib/shapes/shared/useEditableRichText.mjs.map +2 -2
  148. package/dist-esm/lib/shapes/shared/useImageOrVideoAsset.mjs +0 -2
  149. package/dist-esm/lib/shapes/shared/useImageOrVideoAsset.mjs.map +2 -2
  150. package/dist-esm/lib/shapes/text/PlainTextArea.mjs +3 -3
  151. package/dist-esm/lib/shapes/text/PlainTextArea.mjs.map +2 -2
  152. package/dist-esm/lib/shapes/text/RichTextArea.mjs +3 -4
  153. package/dist-esm/lib/shapes/text/RichTextArea.mjs.map +2 -2
  154. package/dist-esm/lib/tools/SelectTool/childStates/DraggingHandle.mjs +1 -1
  155. package/dist-esm/lib/tools/SelectTool/childStates/DraggingHandle.mjs.map +2 -2
  156. package/dist-esm/lib/ui/TldrawUi.mjs +13 -12
  157. package/dist-esm/lib/ui/TldrawUi.mjs.map +2 -2
  158. package/dist-esm/lib/ui/components/A11y.mjs +2 -2
  159. package/dist-esm/lib/ui/components/A11y.mjs.map +2 -2
  160. package/dist-esm/lib/ui/components/{FollowingIndicator.mjs → DefaultFollowingIndicator.mjs} +3 -3
  161. package/dist-esm/lib/ui/components/DefaultFollowingIndicator.mjs.map +7 -0
  162. package/dist-esm/lib/ui/components/EditLinkDialog.mjs +11 -1
  163. package/dist-esm/lib/ui/components/EditLinkDialog.mjs.map +2 -2
  164. package/dist-esm/lib/ui/components/KeyboardShortcutsDialog/DefaultKeyboardShortcutsDialogContent.mjs +6 -6
  165. package/dist-esm/lib/ui/components/KeyboardShortcutsDialog/DefaultKeyboardShortcutsDialogContent.mjs.map +1 -1
  166. package/dist-esm/lib/ui/components/PageMenu/DefaultPageMenu.mjs +2 -2
  167. package/dist-esm/lib/ui/components/PageMenu/DefaultPageMenu.mjs.map +2 -2
  168. package/dist-esm/lib/ui/components/StylePanel/DefaultStylePanel.mjs +14 -5
  169. package/dist-esm/lib/ui/components/StylePanel/DefaultStylePanel.mjs.map +2 -2
  170. package/dist-esm/lib/ui/components/StylePanel/DefaultStylePanelContent.mjs +257 -320
  171. package/dist-esm/lib/ui/components/StylePanel/DefaultStylePanelContent.mjs.map +2 -2
  172. package/dist-esm/lib/ui/components/{primitives/TldrawUiButtonPicker.mjs → StylePanel/StylePanelButtonPicker.mjs} +54 -43
  173. package/dist-esm/lib/ui/components/StylePanel/StylePanelButtonPicker.mjs.map +7 -0
  174. package/dist-esm/lib/ui/components/StylePanel/StylePanelContext.mjs +48 -0
  175. package/dist-esm/lib/ui/components/StylePanel/StylePanelContext.mjs.map +7 -0
  176. package/dist-esm/lib/ui/components/StylePanel/{DoubleDropdownPicker.mjs → StylePanelDoubleDropdownPicker.mjs} +20 -19
  177. package/dist-esm/lib/ui/components/StylePanel/StylePanelDoubleDropdownPicker.mjs.map +7 -0
  178. package/dist-esm/lib/ui/components/StylePanel/{DropdownPicker.mjs → StylePanelDropdownPicker.mjs} +21 -18
  179. package/dist-esm/lib/ui/components/StylePanel/StylePanelDropdownPicker.mjs.map +7 -0
  180. package/dist-esm/lib/ui/components/StylePanel/StylePanelSubheading.mjs +8 -0
  181. package/dist-esm/lib/ui/components/StylePanel/StylePanelSubheading.mjs.map +7 -0
  182. package/dist-esm/lib/ui/components/Toolbar/AltTextEditor.mjs +3 -2
  183. package/dist-esm/lib/ui/components/Toolbar/AltTextEditor.mjs.map +2 -2
  184. package/dist-esm/lib/ui/components/Toolbar/DefaultImageToolbarContent.mjs +38 -9
  185. package/dist-esm/lib/ui/components/Toolbar/DefaultImageToolbarContent.mjs.map +2 -2
  186. package/dist-esm/lib/ui/components/Toolbar/DefaultVideoToolbarContent.mjs +15 -3
  187. package/dist-esm/lib/ui/components/Toolbar/DefaultVideoToolbarContent.mjs.map +2 -2
  188. package/dist-esm/lib/ui/components/Toolbar/LinkEditor.mjs +3 -3
  189. package/dist-esm/lib/ui/components/Toolbar/LinkEditor.mjs.map +2 -2
  190. package/dist-esm/lib/ui/components/primitives/TldrawUiContextualToolbar.mjs +12 -3
  191. package/dist-esm/lib/ui/components/primitives/TldrawUiContextualToolbar.mjs.map +2 -2
  192. package/dist-esm/lib/ui/components/primitives/TldrawUiInput.mjs +3 -3
  193. package/dist-esm/lib/ui/components/primitives/TldrawUiInput.mjs.map +2 -2
  194. package/dist-esm/lib/ui/components/primitives/TldrawUiSlider.mjs +18 -5
  195. package/dist-esm/lib/ui/components/primitives/TldrawUiSlider.mjs.map +2 -2
  196. package/dist-esm/lib/ui/components/primitives/TldrawUiToolbar.mjs +2 -0
  197. package/dist-esm/lib/ui/components/primitives/TldrawUiToolbar.mjs.map +2 -2
  198. package/dist-esm/lib/ui/components/primitives/TldrawUiTooltip.mjs +63 -36
  199. package/dist-esm/lib/ui/components/primitives/TldrawUiTooltip.mjs.map +2 -2
  200. package/dist-esm/lib/ui/components/primitives/menus/TldrawUiMenuItem.mjs +5 -5
  201. package/dist-esm/lib/ui/components/primitives/menus/TldrawUiMenuItem.mjs.map +1 -1
  202. package/dist-esm/lib/ui/context/actions.mjs +23 -10
  203. package/dist-esm/lib/ui/context/actions.mjs.map +2 -2
  204. package/dist-esm/lib/ui/context/components.mjs +2 -0
  205. package/dist-esm/lib/ui/context/components.mjs.map +2 -2
  206. package/dist-esm/lib/ui/context/events.mjs.map +1 -1
  207. package/dist-esm/lib/ui/hooks/useClipboardEvents.mjs +2 -2
  208. package/dist-esm/lib/ui/hooks/useClipboardEvents.mjs.map +2 -2
  209. package/dist-esm/lib/ui/hooks/useExportAs.mjs +3 -2
  210. package/dist-esm/lib/ui/hooks/useExportAs.mjs.map +2 -2
  211. package/dist-esm/lib/ui/hooks/useTools.mjs +1 -1
  212. package/dist-esm/lib/ui/hooks/useTools.mjs.map +2 -2
  213. package/dist-esm/lib/ui/hooks/useTranslation/defaultTranslation.mjs +4 -2
  214. package/dist-esm/lib/ui/hooks/useTranslation/defaultTranslation.mjs.map +2 -2
  215. package/dist-esm/lib/ui/kbd-utils.mjs +9 -3
  216. package/dist-esm/lib/ui/kbd-utils.mjs.map +2 -2
  217. package/dist-esm/lib/ui/version.mjs +3 -3
  218. package/dist-esm/lib/ui/version.mjs.map +1 -1
  219. package/dist-esm/lib/utils/excalidraw/putExcalidrawContent.mjs.map +1 -1
  220. package/dist-esm/lib/utils/export/copyAs.mjs +1 -2
  221. package/dist-esm/lib/utils/export/copyAs.mjs.map +2 -2
  222. package/dist-esm/lib/utils/export/export.mjs +0 -20
  223. package/dist-esm/lib/utils/export/export.mjs.map +2 -2
  224. package/dist-esm/lib/utils/export/exportAs.mjs +1 -2
  225. package/dist-esm/lib/utils/export/exportAs.mjs.map +2 -2
  226. package/package.json +3 -3
  227. package/src/index.ts +41 -22
  228. package/src/lib/Tldraw.tsx +15 -2
  229. package/src/lib/defaultExternalContentHandlers.ts +12 -4
  230. package/src/lib/shapes/arrow/ArrowShapeTool.test.ts +2 -2
  231. package/src/lib/shapes/arrow/ArrowShapeUtil.test.ts +41 -0
  232. package/src/lib/shapes/arrow/arrowLabel.ts +8 -0
  233. package/src/lib/shapes/arrow/arrowTargetState.ts +1 -1
  234. package/src/lib/shapes/arrow/elbow/elbowArrowSnapLines.tsx +2 -2
  235. package/src/lib/shapes/bookmark/BookmarkShapeUtil.tsx +5 -5
  236. package/src/lib/shapes/frame/FrameShapeTool.ts +1 -1
  237. package/src/lib/shapes/frame/FrameShapeUtil.tsx +9 -0
  238. package/src/lib/shapes/frame/components/FrameLabelInput.tsx +3 -3
  239. package/src/lib/shapes/geo/GeoShapeUtil.tsx +1 -0
  240. package/src/lib/shapes/image/ImageShapeUtil.tsx +3 -0
  241. package/src/lib/shapes/line/LineShapeUtil.test.tsx +4 -4
  242. package/src/lib/shapes/note/NoteShapeTool.test.ts +2 -1
  243. package/src/lib/shapes/note/NoteShapeUtil.tsx +1 -0
  244. package/src/lib/shapes/shared/HyperlinkButton.tsx +5 -5
  245. package/src/lib/shapes/shared/PlainTextLabel.tsx +2 -7
  246. package/src/lib/shapes/shared/RichTextLabel.tsx +2 -1
  247. package/src/lib/shapes/shared/crop.ts +1 -0
  248. package/src/lib/shapes/shared/useEditablePlainText.ts +12 -12
  249. package/src/lib/shapes/shared/useEditableRichText.ts +7 -3
  250. package/src/lib/shapes/shared/useImageOrVideoAsset.ts +0 -7
  251. package/src/lib/shapes/text/PlainTextArea.tsx +3 -3
  252. package/src/lib/shapes/text/RichTextArea.tsx +3 -4
  253. package/src/lib/tools/SelectTool/childStates/DraggingHandle.tsx +1 -1
  254. package/src/lib/ui/TldrawUi.tsx +16 -10
  255. package/src/lib/ui/components/A11y.tsx +2 -2
  256. package/src/lib/ui/components/{FollowingIndicator.tsx → DefaultFollowingIndicator.tsx} +2 -1
  257. package/src/lib/ui/components/EditLinkDialog.tsx +16 -6
  258. package/src/lib/ui/components/KeyboardShortcutsDialog/DefaultKeyboardShortcutsDialogContent.tsx +6 -6
  259. package/src/lib/ui/components/PageMenu/DefaultPageMenu.tsx +2 -2
  260. package/src/lib/ui/components/StylePanel/DefaultStylePanel.tsx +27 -13
  261. package/src/lib/ui/components/StylePanel/DefaultStylePanelContent.tsx +260 -381
  262. package/src/lib/ui/components/{primitives/TldrawUiButtonPicker.tsx → StylePanel/StylePanelButtonPicker.tsx} +63 -50
  263. package/src/lib/ui/components/StylePanel/StylePanelContext.tsx +63 -0
  264. package/src/lib/ui/components/StylePanel/{DoubleDropdownPicker.tsx → StylePanelDoubleDropdownPicker.tsx} +28 -19
  265. package/src/lib/ui/components/StylePanel/StylePanelDropdownPicker.tsx +119 -0
  266. package/src/lib/ui/components/StylePanel/StylePanelSubheading.tsx +9 -0
  267. package/src/lib/ui/components/Toolbar/AltTextEditor.tsx +5 -4
  268. package/src/lib/ui/components/Toolbar/DefaultImageToolbarContent.tsx +32 -15
  269. package/src/lib/ui/components/Toolbar/DefaultVideoToolbarContent.tsx +12 -4
  270. package/src/lib/ui/components/Toolbar/LinkEditor.tsx +5 -5
  271. package/src/lib/ui/components/primitives/TldrawUiContextualToolbar.tsx +8 -3
  272. package/src/lib/ui/components/primitives/TldrawUiInput.tsx +3 -3
  273. package/src/lib/ui/components/primitives/TldrawUiSlider.tsx +52 -32
  274. package/src/lib/ui/components/primitives/TldrawUiToolbar.tsx +3 -0
  275. package/src/lib/ui/components/primitives/TldrawUiTooltip.tsx +67 -29
  276. package/src/lib/ui/components/primitives/menus/TldrawUiMenuItem.tsx +6 -6
  277. package/src/lib/ui/context/actions.tsx +23 -10
  278. package/src/lib/ui/context/components.tsx +3 -0
  279. package/src/lib/ui/context/events.tsx +1 -1
  280. package/src/lib/ui/hooks/useClipboardEvents.ts +2 -2
  281. package/src/lib/ui/hooks/useExportAs.ts +3 -2
  282. package/src/lib/ui/hooks/useTools.tsx +1 -1
  283. package/src/lib/ui/hooks/useTranslation/TLUiTranslationKey.ts +2 -0
  284. package/src/lib/ui/hooks/useTranslation/defaultTranslation.ts +4 -2
  285. package/src/lib/ui/kbd-utils.ts +10 -3
  286. package/src/lib/ui/version.ts +3 -3
  287. package/src/lib/ui.css +19 -2
  288. package/src/lib/utils/excalidraw/putExcalidrawContent.ts +6 -6
  289. package/src/lib/utils/export/copyAs.ts +1 -24
  290. package/src/lib/utils/export/export.ts +0 -36
  291. package/src/lib/utils/export/exportAs.ts +1 -32
  292. package/src/test/Editor.test.tsx +37 -10
  293. package/src/test/TldrawEditor.test.tsx +15 -9
  294. package/src/test/commands/putContent.test.ts +1 -0
  295. package/src/test/commands/updateShapes.test.ts +9 -5
  296. package/src/test/custom-clipping.test.ts +442 -0
  297. package/src/test/customSnapping.test.tsx +55 -41
  298. package/src/test/getCulledShapes.test.tsx +77 -2
  299. package/src/test/groups.test.tsx +4 -2
  300. package/src/test/translating.test.ts +2 -2
  301. package/tldraw.css +35 -5
  302. package/dist-cjs/lib/ui/components/FollowingIndicator.js.map +0 -7
  303. package/dist-cjs/lib/ui/components/StylePanel/DoubleDropdownPicker.js.map +0 -7
  304. package/dist-cjs/lib/ui/components/StylePanel/DropdownPicker.js.map +0 -7
  305. package/dist-cjs/lib/ui/components/primitives/TldrawUiButtonPicker.js.map +0 -7
  306. package/dist-esm/lib/ui/components/FollowingIndicator.mjs.map +0 -7
  307. package/dist-esm/lib/ui/components/StylePanel/DoubleDropdownPicker.mjs.map +0 -7
  308. package/dist-esm/lib/ui/components/StylePanel/DropdownPicker.mjs.map +0 -7
  309. package/dist-esm/lib/ui/components/primitives/TldrawUiButtonPicker.mjs.map +0 -7
  310. package/src/lib/ui/components/StylePanel/DropdownPicker.tsx +0 -110
package/src/lib/ui.css CHANGED
@@ -1007,9 +1007,23 @@
1007
1007
  flex-direction: column;
1008
1008
  }
1009
1009
 
1010
- .tlui-style-panel__section:nth-of-type(n + 2):not(:last-child) {
1010
+ /*
1011
+ add a border to the bottom of all but the last section. we have to handle empty sections too, which
1012
+ are hidden and shouldn't be counted
1013
+ */
1014
+ .tlui-style-panel__section:not(:nth-last-child(-n + 1 of .tlui-style-panel__section:not(:empty))) {
1011
1015
  border-bottom: 1px solid var(--tl-color-divider);
1012
1016
  }
1017
+ /*
1018
+ if a section ends with a slider and we're adding a border, we need some extra space for visual
1019
+ balance. we need to handle empty sections as above. is this the most complex css selector in all of
1020
+ tldraw? probably.
1021
+ */
1022
+ .tlui-style-panel__section:has(.tlui-slider__container:last-child):not(
1023
+ :nth-last-child(-n + 1 of .tlui-style-panel__section:not(:empty))
1024
+ ) {
1025
+ margin-bottom: 7px;
1026
+ }
1013
1027
 
1014
1028
  .tlui-style-panel__section:empty {
1015
1029
  display: none;
@@ -1021,7 +1035,7 @@
1021
1035
  }
1022
1036
 
1023
1037
  .tlui-style-panel__dropdown-picker:only-child {
1024
- width: 100%;
1038
+ flex: 1;
1025
1039
  }
1026
1040
 
1027
1041
  .tlui-style-panel__double-select-picker {
@@ -1047,6 +1061,9 @@
1047
1061
  }
1048
1062
 
1049
1063
  @media (hover: hover) {
1064
+ .tlui-style-panel .tlui-button[aria-expanded='true'] {
1065
+ background: none;
1066
+ }
1050
1067
  .tlui-style-panel .tlui-button[data-state='open']:not(:hover)::after {
1051
1068
  opacity: 1;
1052
1069
  background: linear-gradient(270deg, rgba(144, 144, 144, 0) 0%, var(--tl-color-muted-2) 100%);
@@ -143,7 +143,7 @@ export async function putExcalidrawContent(
143
143
  align,
144
144
  dash: getDash(element),
145
145
  fill: getFill(element),
146
- },
146
+ } as any,
147
147
  })
148
148
  break
149
149
  }
@@ -165,7 +165,7 @@ export async function putExcalidrawContent(
165
165
  })),
166
166
  },
167
167
  ],
168
- },
168
+ } as any,
169
169
  })
170
170
  break
171
171
  }
@@ -192,7 +192,7 @@ export async function putExcalidrawContent(
192
192
  })
193
193
  ),
194
194
  },
195
- },
195
+ } as any,
196
196
  })
197
197
 
198
198
  break
@@ -231,7 +231,7 @@ export async function putExcalidrawContent(
231
231
  end: { x: end[0], y: end[1] },
232
232
  arrowheadEnd: arrowheadsToArrowheadTypes[element.endArrowhead] ?? 'none',
233
233
  arrowheadStart: arrowheadsToArrowheadTypes[element.startArrowhead] ?? 'none',
234
- },
234
+ } as any,
235
235
  })
236
236
 
237
237
  if (startTargetId) {
@@ -281,7 +281,7 @@ export async function putExcalidrawContent(
281
281
  color: colorsToColors[element.strokeColor] ?? 'black',
282
282
  richText: toRichText(element.text),
283
283
  textAlign: textAlignToTextAlignTypes[element.textAlign],
284
- },
284
+ } as any,
285
285
  })
286
286
  break
287
287
  }
@@ -313,7 +313,7 @@ export async function putExcalidrawContent(
313
313
  w: element.width,
314
314
  h: element.height,
315
315
  assetId,
316
- },
316
+ } as any,
317
317
  })
318
318
  }
319
319
  }
@@ -31,30 +31,7 @@ export interface CopyAsOptions extends TLImageExportOptions {
31
31
  *
32
32
  * @public
33
33
  */
34
- export function copyAs(editor: Editor, ids: TLShapeId[], opts: CopyAsOptions): Promise<void>
35
- /**
36
- * @deprecated The format parameter is now part of the opts object.
37
- * @public
38
- */
39
- export function copyAs(
40
- editor: Editor,
41
- ids: TLShapeId[],
42
- format: TLCopyType,
43
- opts?: TLImageExportOptions & { format?: undefined }
44
- ): Promise<void>
45
- export function copyAs(
46
- ...args:
47
- | [editor: Editor, ids: TLShapeId[], opts: TLImageExportOptions & { format: TLCopyType }]
48
- | [
49
- editor: Editor,
50
- ids: TLShapeId[],
51
- format: TLCopyType,
52
- opts?: TLImageExportOptions & { format?: undefined },
53
- ]
54
- ) {
55
- const [editor, ids, opts] =
56
- typeof args[2] === 'string' ? [args[0], args[1], { ...args[3], format: args[2] }] : args
57
-
34
+ export function copyAs(editor: Editor, ids: TLShapeId[], opts: CopyAsOptions): Promise<void> {
58
35
  // Note: it's important that this function itself isn't async and doesn't really use promises -
59
36
  // we need to create the relevant `ClipboardItem`s and call navigator.clipboard.write
60
37
  // synchronously to make sure safari knows that the user _wants_ to copy See
@@ -1,7 +1,6 @@
1
1
  import {
2
2
  Editor,
3
3
  FileHelpers,
4
- TLExportType,
5
4
  TLImageExportOptions,
6
5
  TLShapeId,
7
6
  exhaustiveSwitchError,
@@ -35,41 +34,6 @@ export async function exportToString(
35
34
  }
36
35
  }
37
36
 
38
- /**
39
- * Export the given shapes as a blob.
40
- * @param editor - The editor instance.
41
- * @param ids - The ids of the shapes to export.
42
- * @param format - The format to export as.
43
- * @param opts - Rendering options.
44
- * @returns A promise that resolves to a blob.
45
- * @deprecated Use {@link @tldraw/editor#Editor.toImage} instead.
46
- * @public
47
- */
48
- export async function exportToBlob({
49
- editor,
50
- ids,
51
- format,
52
- opts = {},
53
- }: {
54
- editor: Editor
55
- ids: TLShapeId[]
56
- format: TLExportType
57
- opts?: TLImageExportOptions
58
- }): Promise<Blob> {
59
- const idsToUse = ids?.length ? ids : [...editor.getCurrentPageShapeIds()]
60
- switch (format) {
61
- case 'jpeg':
62
- case 'png':
63
- case 'webp':
64
- case 'svg': {
65
- return (await editor.toImage(idsToUse, { ...opts, format })).blob
66
- }
67
- default: {
68
- exhaustiveSwitchError(format)
69
- }
70
- }
71
- }
72
-
73
37
  const clipboardMimeTypesByFormat = {
74
38
  jpeg: 'image/jpeg',
75
39
  png: 'image/png',
@@ -28,38 +28,7 @@ export async function exportAs(
28
28
  editor: Editor,
29
29
  ids: TLShapeId[],
30
30
  opts: ExportAsOptions
31
- ): Promise<void>
32
- /**
33
- * @deprecated The format & name parameters are now part of the opts object.
34
- * @public
35
- */
36
- export async function exportAs(
37
- editor: Editor,
38
- ids: TLShapeId[],
39
- format?: TLExportType,
40
- name?: string,
41
- opts?: TLImageExportOptions
42
- ): Promise<void>
43
- export async function exportAs(
44
- ...args:
45
- | [
46
- editor: Editor,
47
- ids: TLShapeId[],
48
- opts: TLImageExportOptions & { format: TLExportType; name?: string },
49
- ]
50
- | [
51
- editor: Editor,
52
- ids: TLShapeId[],
53
- format?: TLExportType,
54
- name?: string,
55
- opts?: TLImageExportOptions,
56
- ]
57
- ) {
58
- const [editor, ids, opts] =
59
- typeof args[2] === 'object'
60
- ? args
61
- : [args[0], args[1], { ...args[4], format: args[2] ?? 'png', name: args[3] }]
62
-
31
+ ): Promise<void> {
63
32
  // If we don't get name then use a predefined one
64
33
  let name = opts.name
65
34
  if (!name) {
@@ -4,6 +4,7 @@ import {
4
4
  Geometry2d,
5
5
  PageRecordType,
6
6
  Rectangle2d,
7
+ TLBaseShape,
7
8
  TLGeoShapeProps,
8
9
  TLShape,
9
10
  TldrawEditorProps,
@@ -472,6 +473,18 @@ describe('isFocused', () => {
472
473
  })
473
474
  })
474
475
 
476
+ declare module '@tldraw/tlschema' {
477
+ export interface GlobalShapePropsMap {
478
+ blorg: TLBaseShape<
479
+ 'blorg',
480
+ {
481
+ w: number
482
+ h: number
483
+ }
484
+ >
485
+ }
486
+ }
487
+
475
488
  describe('getShapeUtil', () => {
476
489
  let myUtil: any
477
490
 
@@ -519,16 +532,22 @@ describe('getShapeUtil', () => {
519
532
  })
520
533
 
521
534
  it('throws if that shape type isnt registered', () => {
522
- const myMissingShape = { type: 'missing' } as TLShape
523
- expect(() => editor.getShapeUtil(myMissingShape)).toThrowErrorMatchingInlineSnapshot(
524
- `[Error: No shape util found for type "missing"]`
525
- )
535
+ const myMissingShape = { type: 'missing' }
536
+ expect(() =>
537
+ editor.getShapeUtil(
538
+ // @ts-expect-error
539
+ myMissingShape
540
+ )
541
+ ).toThrowErrorMatchingInlineSnapshot(`[Error: No shape util found for type "missing"]`)
526
542
  })
527
543
 
528
544
  it('throws if that type isnt registered', () => {
529
- expect(() => editor.getShapeUtil('missing')).toThrowErrorMatchingInlineSnapshot(
530
- `[Error: No shape util found for type "missing"]`
531
- )
545
+ expect(() =>
546
+ editor.getShapeUtil(
547
+ // @ts-expect-error
548
+ 'missing'
549
+ )
550
+ ).toThrowErrorMatchingInlineSnapshot(`[Error: No shape util found for type "missing"]`)
532
551
  })
533
552
  })
534
553
 
@@ -866,9 +885,17 @@ describe('instance.isReadonly', () => {
866
885
  })
867
886
  })
868
887
 
888
+ type MyCustomShape = TLBaseShape<'my-custom-shape', { w: number; h: number }>
889
+
890
+ declare module '@tldraw/tlschema' {
891
+ export interface GlobalShapePropsMap {
892
+ 'my-custom-shape': MyCustomShape
893
+ }
894
+ }
895
+
869
896
  describe('the geometry cache', () => {
870
- class CustomShapeUtil extends BaseBoxShapeUtil<any> {
871
- static override type = 'custom'
897
+ class CustomShapeUtil extends BaseBoxShapeUtil<MyCustomShape> {
898
+ static override type = 'custom' as const
872
899
 
873
900
  getDefaultProps() {
874
901
  return {
@@ -896,7 +923,7 @@ describe('the geometry cache', () => {
896
923
  })
897
924
  const { A } = editor.createShapesFromJsx([<TL.custom ref="A" x={0} y={0} w={100} h={100} />])
898
925
  expect(editor.getShapePageBounds(A)!.width).toBe(100)
899
- editor.updateShape({ id: A, type: 'custom', meta: { double: true } })
926
+ editor.updateShape({ id: A, type: 'my-custom-shape', meta: { double: true } })
900
927
  expect(editor.getShapePageBounds(A)!.width).toBe(200)
901
928
  })
902
929
  })
@@ -411,15 +411,21 @@ describe('<TldrawEditor />', () => {
411
411
  })
412
412
  })
413
413
 
414
- describe('Custom shapes', () => {
415
- type CardShape = TLBaseShape<
416
- 'card',
417
- {
418
- w: number
419
- h: number
420
- }
421
- >
414
+ declare module '@tldraw/tlschema' {
415
+ export interface GlobalShapePropsMap {
416
+ card: CardShape
417
+ }
418
+ }
422
419
 
420
+ type CardShape = TLBaseShape<
421
+ 'card',
422
+ {
423
+ w: number
424
+ h: number
425
+ }
426
+ >
427
+
428
+ describe('Custom shapes', () => {
423
429
  class CardUtil extends BaseBoxShapeUtil<CardShape> {
424
430
  static override type = 'card' as const
425
431
 
@@ -463,7 +469,7 @@ describe('Custom shapes', () => {
463
469
  class CardTool extends BaseBoxShapeTool {
464
470
  static override id = 'card'
465
471
  static override initial = 'idle'
466
- override shapeType = 'card'
472
+ override shapeType = 'card' as const
467
473
  }
468
474
 
469
475
  const tools = [CardTool]
@@ -25,6 +25,7 @@ describe('Migrations', () => {
25
25
 
26
26
  it('Throws error if any shape is invalid due to wrong type', () => {
27
27
  const withInvalidShapeType = structuredClone(clipboardContent)
28
+ // @ts-expect-error
28
29
  withInvalidShapeType.shapes[0].type = 'invalid'
29
30
  expect(() => editor.putContentOntoCurrentPage(withInvalidShapeType)).toThrow()
30
31
  })
@@ -15,22 +15,26 @@ beforeEach(() => {
15
15
 
16
16
  it('Uses typescript generics', () => {
17
17
  expect(() => {
18
- // No error here because no generic, the editor doesn't know what this guy is
19
18
  editor.updateShapes([
20
19
  {
21
20
  id: ids.box1,
22
21
  type: 'geo',
23
- props: { w: 'OH NO' },
22
+ props: {
23
+ // @ts-expect-error
24
+ w: 'OH NO',
25
+ },
24
26
  },
25
27
  ])
26
28
 
27
- // Yep error here because we are giving the wrong props to the shape
29
+ // error here because we are giving the wrong props to the shape
28
30
  editor.updateShapes<TLGeoShape>([
29
31
  {
30
32
  id: ids.box1,
31
33
  type: 'geo',
32
- //@ts-expect-error
33
- props: { w: 'OH NO' },
34
+ props: {
35
+ // @ts-expect-error
36
+ w: 'OH NO',
37
+ },
34
38
  },
35
39
  ])
36
40