tldraw 3.16.0-canary.ed8bd30c0f28 → 3.16.0-canary.f20b7a478e22

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 (525) hide show
  1. package/dist-cjs/index.d.ts +359 -109
  2. package/dist-cjs/index.js +46 -14
  3. package/dist-cjs/index.js.map +2 -2
  4. package/dist-cjs/lib/Tldraw.js +12 -2
  5. package/dist-cjs/lib/Tldraw.js.map +2 -2
  6. package/dist-cjs/lib/canvas/TldrawScribble.js +1 -1
  7. package/dist-cjs/lib/canvas/TldrawScribble.js.map +2 -2
  8. package/dist-cjs/lib/defaultExternalContentHandlers.js +15 -4
  9. package/dist-cjs/lib/defaultExternalContentHandlers.js.map +2 -2
  10. package/dist-cjs/lib/shapes/arrow/ArrowShapeUtil.js +3 -3
  11. package/dist-cjs/lib/shapes/arrow/ArrowShapeUtil.js.map +2 -2
  12. package/dist-cjs/lib/shapes/arrow/arrowLabel.js +6 -0
  13. package/dist-cjs/lib/shapes/arrow/arrowLabel.js.map +3 -3
  14. package/dist-cjs/lib/shapes/arrow/arrowTargetState.js +1 -1
  15. package/dist-cjs/lib/shapes/arrow/arrowTargetState.js.map +2 -2
  16. package/dist-cjs/lib/shapes/arrow/elbow/ElbowArrowDebug.js +3 -3
  17. package/dist-cjs/lib/shapes/arrow/elbow/ElbowArrowDebug.js.map +1 -1
  18. package/dist-cjs/lib/shapes/bookmark/BookmarkShapeUtil.js +4 -4
  19. package/dist-cjs/lib/shapes/bookmark/BookmarkShapeUtil.js.map +2 -2
  20. package/dist-cjs/lib/shapes/draw/DrawShapeUtil.js +3 -3
  21. package/dist-cjs/lib/shapes/draw/DrawShapeUtil.js.map +2 -2
  22. package/dist-cjs/lib/shapes/embed/EmbedShapeUtil.js +1 -1
  23. package/dist-cjs/lib/shapes/embed/EmbedShapeUtil.js.map +1 -1
  24. package/dist-cjs/lib/shapes/frame/FrameShapeUtil.js +20 -13
  25. package/dist-cjs/lib/shapes/frame/FrameShapeUtil.js.map +2 -2
  26. package/dist-cjs/lib/shapes/frame/components/FrameHeading.js +1 -1
  27. package/dist-cjs/lib/shapes/frame/components/FrameHeading.js.map +2 -2
  28. package/dist-cjs/lib/shapes/frame/components/FrameLabelInput.js +2 -2
  29. package/dist-cjs/lib/shapes/frame/components/FrameLabelInput.js.map +2 -2
  30. package/dist-cjs/lib/shapes/geo/GeoShapeUtil.js +3 -2
  31. package/dist-cjs/lib/shapes/geo/GeoShapeUtil.js.map +2 -2
  32. package/dist-cjs/lib/shapes/geo/components/GeoShapeBody.js +2 -1
  33. package/dist-cjs/lib/shapes/geo/components/GeoShapeBody.js.map +2 -2
  34. package/dist-cjs/lib/shapes/highlight/HighlightShapeUtil.js +5 -1
  35. package/dist-cjs/lib/shapes/highlight/HighlightShapeUtil.js.map +2 -2
  36. package/dist-cjs/lib/shapes/image/ImageShapeUtil.js +6 -3
  37. package/dist-cjs/lib/shapes/image/ImageShapeUtil.js.map +2 -2
  38. package/dist-cjs/lib/shapes/line/LineShapeUtil.js +5 -1
  39. package/dist-cjs/lib/shapes/line/LineShapeUtil.js.map +2 -2
  40. package/dist-cjs/lib/shapes/note/NoteShapeUtil.js +6 -5
  41. package/dist-cjs/lib/shapes/note/NoteShapeUtil.js.map +2 -2
  42. package/dist-cjs/lib/shapes/shared/HyperlinkButton.js +4 -4
  43. package/dist-cjs/lib/shapes/shared/HyperlinkButton.js.map +2 -2
  44. package/dist-cjs/lib/shapes/shared/PlainTextLabel.js +1 -3
  45. package/dist-cjs/lib/shapes/shared/PlainTextLabel.js.map +2 -2
  46. package/dist-cjs/lib/shapes/shared/ShapeFill.js +4 -4
  47. package/dist-cjs/lib/shapes/shared/ShapeFill.js.map +2 -2
  48. package/dist-cjs/lib/shapes/shared/freehand/svg.js.map +2 -2
  49. package/dist-cjs/lib/shapes/shared/useEditablePlainText.js +3 -4
  50. package/dist-cjs/lib/shapes/shared/useEditablePlainText.js.map +2 -2
  51. package/dist-cjs/lib/shapes/shared/useImageOrVideoAsset.js +0 -2
  52. package/dist-cjs/lib/shapes/shared/useImageOrVideoAsset.js.map +2 -2
  53. package/dist-cjs/lib/shapes/shared/usePrefersReducedMotion.js +10 -1
  54. package/dist-cjs/lib/shapes/shared/usePrefersReducedMotion.js.map +2 -2
  55. package/dist-cjs/lib/shapes/text/PlainTextArea.js +2 -2
  56. package/dist-cjs/lib/shapes/text/PlainTextArea.js.map +2 -2
  57. package/dist-cjs/lib/shapes/text/RichTextArea.js +3 -3
  58. package/dist-cjs/lib/shapes/text/RichTextArea.js.map +2 -2
  59. package/dist-cjs/lib/shapes/text/TextShapeUtil.js +2 -2
  60. package/dist-cjs/lib/shapes/text/TextShapeUtil.js.map +2 -2
  61. package/dist-cjs/lib/shapes/video/VideoShapeUtil.js +3 -3
  62. package/dist-cjs/lib/shapes/video/VideoShapeUtil.js.map +1 -1
  63. package/dist-cjs/lib/tools/EraserTool/childStates/Erasing.js +25 -1
  64. package/dist-cjs/lib/tools/EraserTool/childStates/Erasing.js.map +2 -2
  65. package/dist-cjs/lib/tools/EraserTool/childStates/Pointing.js +12 -0
  66. package/dist-cjs/lib/tools/EraserTool/childStates/Pointing.js.map +2 -2
  67. package/dist-cjs/lib/tools/SelectTool/childStates/Translating.js.map +2 -2
  68. package/dist-cjs/lib/ui/TldrawUi.js +27 -12
  69. package/dist-cjs/lib/ui/TldrawUi.js.map +3 -3
  70. package/dist-cjs/lib/ui/assetUrls.js +13 -10
  71. package/dist-cjs/lib/ui/assetUrls.js.map +2 -2
  72. package/dist-cjs/lib/ui/components/A11y.js +1 -1
  73. package/dist-cjs/lib/ui/components/A11y.js.map +2 -2
  74. package/dist-cjs/lib/ui/components/AccessibilityMenu.js +35 -0
  75. package/dist-cjs/lib/ui/components/AccessibilityMenu.js.map +7 -0
  76. package/dist-cjs/lib/ui/components/ActionsMenu/DefaultActionsMenu.js +12 -3
  77. package/dist-cjs/lib/ui/components/ActionsMenu/DefaultActionsMenu.js.map +2 -2
  78. package/dist-cjs/lib/ui/components/{FollowingIndicator.js → DefaultFollowingIndicator.js} +6 -6
  79. package/dist-cjs/lib/ui/components/DefaultFollowingIndicator.js.map +7 -0
  80. package/dist-cjs/lib/ui/components/DefaultMenuPanel.js +3 -2
  81. package/dist-cjs/lib/ui/components/DefaultMenuPanel.js.map +2 -2
  82. package/dist-cjs/lib/ui/components/KeyboardShortcutsDialog/DefaultKeyboardShortcutsDialogContent.js +6 -6
  83. package/dist-cjs/lib/ui/components/KeyboardShortcutsDialog/DefaultKeyboardShortcutsDialogContent.js.map +1 -1
  84. package/dist-cjs/lib/ui/components/LanguageMenu.js +1 -0
  85. package/dist-cjs/lib/ui/components/LanguageMenu.js.map +2 -2
  86. package/dist-cjs/lib/ui/components/MainMenu/DefaultMainMenuContent.js +3 -3
  87. package/dist-cjs/lib/ui/components/MainMenu/DefaultMainMenuContent.js.map +2 -2
  88. package/dist-cjs/lib/ui/components/Minimap/DefaultMinimap.js +1 -0
  89. package/dist-cjs/lib/ui/components/Minimap/DefaultMinimap.js.map +2 -2
  90. package/dist-cjs/lib/ui/components/Minimap/MinimapManager.js +4 -4
  91. package/dist-cjs/lib/ui/components/Minimap/MinimapManager.js.map +2 -2
  92. package/dist-cjs/lib/ui/components/MobileStylePanel.js +5 -3
  93. package/dist-cjs/lib/ui/components/MobileStylePanel.js.map +2 -2
  94. package/dist-cjs/lib/ui/components/NavigationPanel/DefaultNavigationPanel.js +1 -1
  95. package/dist-cjs/lib/ui/components/NavigationPanel/DefaultNavigationPanel.js.map +2 -2
  96. package/dist-cjs/lib/ui/components/PageMenu/DefaultPageMenu.js +3 -2
  97. package/dist-cjs/lib/ui/components/PageMenu/DefaultPageMenu.js.map +2 -2
  98. package/dist-cjs/lib/ui/components/SharePanel/PeopleMenuItem.js +3 -2
  99. package/dist-cjs/lib/ui/components/SharePanel/PeopleMenuItem.js.map +2 -2
  100. package/dist-cjs/lib/ui/components/SharePanel/UserPresenceColorPicker.js +2 -2
  101. package/dist-cjs/lib/ui/components/SharePanel/UserPresenceColorPicker.js.map +2 -2
  102. package/dist-cjs/lib/ui/components/StylePanel/DefaultStylePanel.js +11 -4
  103. package/dist-cjs/lib/ui/components/StylePanel/DefaultStylePanel.js.map +2 -2
  104. package/dist-cjs/lib/ui/components/StylePanel/DefaultStylePanelContent.js +249 -279
  105. package/dist-cjs/lib/ui/components/StylePanel/DefaultStylePanelContent.js.map +2 -2
  106. package/dist-cjs/lib/ui/components/StylePanel/StylePanelButtonPicker.js +147 -0
  107. package/dist-cjs/lib/ui/components/StylePanel/StylePanelButtonPicker.js.map +7 -0
  108. package/dist-cjs/lib/ui/components/StylePanel/StylePanelContext.js +68 -0
  109. package/dist-cjs/lib/ui/components/StylePanel/StylePanelContext.js.map +7 -0
  110. package/dist-cjs/lib/ui/components/StylePanel/{DoubleDropdownPicker.js → StylePanelDoubleDropdownPicker.js} +26 -25
  111. package/dist-cjs/lib/ui/components/StylePanel/StylePanelDoubleDropdownPicker.js.map +7 -0
  112. package/dist-cjs/lib/ui/components/StylePanel/{DropdownPicker.js → StylePanelDropdownPicker.js} +47 -43
  113. package/dist-cjs/lib/ui/components/StylePanel/StylePanelDropdownPicker.js.map +7 -0
  114. package/dist-cjs/lib/ui/components/StylePanel/StylePanelSubheading.js +28 -0
  115. package/dist-cjs/lib/ui/components/StylePanel/StylePanelSubheading.js.map +7 -0
  116. package/dist-cjs/lib/ui/components/Toolbar/AltTextEditor.js +2 -0
  117. package/dist-cjs/lib/ui/components/Toolbar/AltTextEditor.js.map +2 -2
  118. package/dist-cjs/lib/ui/components/Toolbar/DefaultImageToolbarContent.js +39 -10
  119. package/dist-cjs/lib/ui/components/Toolbar/DefaultImageToolbarContent.js.map +2 -2
  120. package/dist-cjs/lib/ui/components/Toolbar/DefaultToolbar.js +66 -21
  121. package/dist-cjs/lib/ui/components/Toolbar/DefaultToolbar.js.map +3 -3
  122. package/dist-cjs/lib/ui/components/Toolbar/DefaultVideoToolbarContent.js +15 -3
  123. package/dist-cjs/lib/ui/components/Toolbar/DefaultVideoToolbarContent.js.map +2 -2
  124. package/dist-cjs/lib/ui/components/Toolbar/LinkEditor.js +2 -1
  125. package/dist-cjs/lib/ui/components/Toolbar/LinkEditor.js.map +2 -2
  126. package/dist-cjs/lib/ui/components/Toolbar/OverflowingToolbar.js +189 -80
  127. package/dist-cjs/lib/ui/components/Toolbar/OverflowingToolbar.js.map +3 -3
  128. package/dist-cjs/lib/ui/components/Toolbar/ToggleToolLockedButton.js +10 -5
  129. package/dist-cjs/lib/ui/components/Toolbar/ToggleToolLockedButton.js.map +2 -2
  130. package/dist-cjs/lib/ui/components/menu-items.js +6 -0
  131. package/dist-cjs/lib/ui/components/menu-items.js.map +2 -2
  132. package/dist-cjs/lib/ui/components/primitives/TldrawUiContextualToolbar.js +11 -2
  133. package/dist-cjs/lib/ui/components/primitives/TldrawUiContextualToolbar.js.map +2 -2
  134. package/dist-cjs/lib/ui/components/primitives/TldrawUiInput.js +5 -3
  135. package/dist-cjs/lib/ui/components/primitives/TldrawUiInput.js.map +2 -2
  136. package/dist-cjs/lib/ui/components/primitives/TldrawUiPopover.js +3 -2
  137. package/dist-cjs/lib/ui/components/primitives/TldrawUiPopover.js.map +3 -3
  138. package/dist-cjs/lib/ui/components/primitives/TldrawUiSlider.js +18 -5
  139. package/dist-cjs/lib/ui/components/primitives/TldrawUiSlider.js.map +2 -2
  140. package/dist-cjs/lib/ui/components/primitives/TldrawUiToolbar.js +33 -7
  141. package/dist-cjs/lib/ui/components/primitives/TldrawUiToolbar.js.map +2 -2
  142. package/dist-cjs/lib/ui/components/primitives/TldrawUiTooltip.js +306 -0
  143. package/dist-cjs/lib/ui/components/primitives/TldrawUiTooltip.js.map +7 -0
  144. package/dist-cjs/lib/ui/components/primitives/layout.js +76 -0
  145. package/dist-cjs/lib/ui/components/primitives/layout.js.map +7 -0
  146. package/dist-cjs/lib/ui/components/primitives/menus/TldrawUiMenuCheckboxItem.js +3 -0
  147. package/dist-cjs/lib/ui/components/primitives/menus/TldrawUiMenuCheckboxItem.js.map +2 -2
  148. package/dist-cjs/lib/ui/components/primitives/menus/TldrawUiMenuContext.js.map +2 -2
  149. package/dist-cjs/lib/ui/components/primitives/menus/TldrawUiMenuGroup.js +25 -12
  150. package/dist-cjs/lib/ui/components/primitives/menus/TldrawUiMenuGroup.js.map +2 -2
  151. package/dist-cjs/lib/ui/components/primitives/menus/TldrawUiMenuItem.js +154 -20
  152. package/dist-cjs/lib/ui/components/primitives/menus/TldrawUiMenuItem.js.map +2 -2
  153. package/dist-cjs/lib/ui/context/TldrawUiContextProvider.js +3 -2
  154. package/dist-cjs/lib/ui/context/TldrawUiContextProvider.js.map +2 -2
  155. package/dist-cjs/lib/ui/context/actions.js +44 -10
  156. package/dist-cjs/lib/ui/context/actions.js.map +2 -2
  157. package/dist-cjs/lib/ui/context/components.js +2 -0
  158. package/dist-cjs/lib/ui/context/components.js.map +2 -2
  159. package/dist-cjs/lib/ui/context/events.js.map +2 -2
  160. package/dist-cjs/lib/ui/hooks/useClipboardEvents.js +1 -1
  161. package/dist-cjs/lib/ui/hooks/useClipboardEvents.js.map +2 -2
  162. package/dist-cjs/lib/ui/hooks/useExportAs.js +3 -2
  163. package/dist-cjs/lib/ui/hooks/useExportAs.js.map +2 -2
  164. package/dist-cjs/lib/ui/hooks/useTools.js +94 -9
  165. package/dist-cjs/lib/ui/hooks/useTools.js.map +2 -2
  166. package/dist-cjs/lib/ui/hooks/useTranslation/TLUiTranslationKey.js.map +1 -1
  167. package/dist-cjs/lib/ui/hooks/useTranslation/defaultTranslation.js +8 -1
  168. package/dist-cjs/lib/ui/hooks/useTranslation/defaultTranslation.js.map +2 -2
  169. package/dist-cjs/lib/ui/kbd-utils.js +9 -3
  170. package/dist-cjs/lib/ui/kbd-utils.js.map +2 -2
  171. package/dist-cjs/lib/ui/version.js +3 -3
  172. package/dist-cjs/lib/ui/version.js.map +1 -1
  173. package/dist-cjs/lib/utils/export/copyAs.js +1 -2
  174. package/dist-cjs/lib/utils/export/copyAs.js.map +2 -2
  175. package/dist-cjs/lib/utils/export/export.js +0 -20
  176. package/dist-cjs/lib/utils/export/export.js.map +2 -2
  177. package/dist-cjs/lib/utils/export/exportAs.js +1 -2
  178. package/dist-cjs/lib/utils/export/exportAs.js.map +2 -2
  179. package/dist-esm/index.d.mts +359 -109
  180. package/dist-esm/index.mjs +85 -29
  181. package/dist-esm/index.mjs.map +2 -2
  182. package/dist-esm/lib/Tldraw.mjs +14 -4
  183. package/dist-esm/lib/Tldraw.mjs.map +2 -2
  184. package/dist-esm/lib/canvas/TldrawScribble.mjs +1 -1
  185. package/dist-esm/lib/canvas/TldrawScribble.mjs.map +2 -2
  186. package/dist-esm/lib/defaultExternalContentHandlers.mjs +15 -4
  187. package/dist-esm/lib/defaultExternalContentHandlers.mjs.map +2 -2
  188. package/dist-esm/lib/shapes/arrow/ArrowShapeUtil.mjs +4 -3
  189. package/dist-esm/lib/shapes/arrow/ArrowShapeUtil.mjs.map +2 -2
  190. package/dist-esm/lib/shapes/arrow/arrowLabel.mjs +6 -0
  191. package/dist-esm/lib/shapes/arrow/arrowLabel.mjs.map +3 -3
  192. package/dist-esm/lib/shapes/arrow/arrowTargetState.mjs +1 -1
  193. package/dist-esm/lib/shapes/arrow/arrowTargetState.mjs.map +2 -2
  194. package/dist-esm/lib/shapes/arrow/elbow/ElbowArrowDebug.mjs +3 -3
  195. package/dist-esm/lib/shapes/arrow/elbow/ElbowArrowDebug.mjs.map +1 -1
  196. package/dist-esm/lib/shapes/bookmark/BookmarkShapeUtil.mjs +5 -5
  197. package/dist-esm/lib/shapes/bookmark/BookmarkShapeUtil.mjs.map +2 -2
  198. package/dist-esm/lib/shapes/draw/DrawShapeUtil.mjs +4 -3
  199. package/dist-esm/lib/shapes/draw/DrawShapeUtil.mjs.map +2 -2
  200. package/dist-esm/lib/shapes/embed/EmbedShapeUtil.mjs +1 -1
  201. package/dist-esm/lib/shapes/embed/EmbedShapeUtil.mjs.map +1 -1
  202. package/dist-esm/lib/shapes/frame/FrameShapeUtil.mjs +21 -13
  203. package/dist-esm/lib/shapes/frame/FrameShapeUtil.mjs.map +2 -2
  204. package/dist-esm/lib/shapes/frame/components/FrameHeading.mjs +1 -1
  205. package/dist-esm/lib/shapes/frame/components/FrameHeading.mjs.map +2 -2
  206. package/dist-esm/lib/shapes/frame/components/FrameLabelInput.mjs +3 -3
  207. package/dist-esm/lib/shapes/frame/components/FrameLabelInput.mjs.map +2 -2
  208. package/dist-esm/lib/shapes/geo/GeoShapeUtil.mjs +4 -2
  209. package/dist-esm/lib/shapes/geo/GeoShapeUtil.mjs.map +2 -2
  210. package/dist-esm/lib/shapes/geo/components/GeoShapeBody.mjs +2 -1
  211. package/dist-esm/lib/shapes/geo/components/GeoShapeBody.mjs.map +2 -2
  212. package/dist-esm/lib/shapes/highlight/HighlightShapeUtil.mjs +6 -1
  213. package/dist-esm/lib/shapes/highlight/HighlightShapeUtil.mjs.map +2 -2
  214. package/dist-esm/lib/shapes/image/ImageShapeUtil.mjs +6 -3
  215. package/dist-esm/lib/shapes/image/ImageShapeUtil.mjs.map +2 -2
  216. package/dist-esm/lib/shapes/line/LineShapeUtil.mjs +6 -1
  217. package/dist-esm/lib/shapes/line/LineShapeUtil.mjs.map +2 -2
  218. package/dist-esm/lib/shapes/note/NoteShapeUtil.mjs +7 -5
  219. package/dist-esm/lib/shapes/note/NoteShapeUtil.mjs.map +2 -2
  220. package/dist-esm/lib/shapes/shared/HyperlinkButton.mjs +5 -5
  221. package/dist-esm/lib/shapes/shared/HyperlinkButton.mjs.map +2 -2
  222. package/dist-esm/lib/shapes/shared/PlainTextLabel.mjs +1 -3
  223. package/dist-esm/lib/shapes/shared/PlainTextLabel.mjs.map +2 -2
  224. package/dist-esm/lib/shapes/shared/ShapeFill.mjs +5 -4
  225. package/dist-esm/lib/shapes/shared/ShapeFill.mjs.map +2 -2
  226. package/dist-esm/lib/shapes/shared/freehand/svg.mjs.map +2 -2
  227. package/dist-esm/lib/shapes/shared/useEditablePlainText.mjs +4 -5
  228. package/dist-esm/lib/shapes/shared/useEditablePlainText.mjs.map +2 -2
  229. package/dist-esm/lib/shapes/shared/useImageOrVideoAsset.mjs +0 -2
  230. package/dist-esm/lib/shapes/shared/useImageOrVideoAsset.mjs.map +2 -2
  231. package/dist-esm/lib/shapes/shared/usePrefersReducedMotion.mjs +10 -1
  232. package/dist-esm/lib/shapes/shared/usePrefersReducedMotion.mjs.map +2 -2
  233. package/dist-esm/lib/shapes/text/PlainTextArea.mjs +3 -3
  234. package/dist-esm/lib/shapes/text/PlainTextArea.mjs.map +2 -2
  235. package/dist-esm/lib/shapes/text/RichTextArea.mjs +3 -4
  236. package/dist-esm/lib/shapes/text/RichTextArea.mjs.map +2 -2
  237. package/dist-esm/lib/shapes/text/TextShapeUtil.mjs +3 -2
  238. package/dist-esm/lib/shapes/text/TextShapeUtil.mjs.map +2 -2
  239. package/dist-esm/lib/shapes/video/VideoShapeUtil.mjs +3 -3
  240. package/dist-esm/lib/shapes/video/VideoShapeUtil.mjs.map +1 -1
  241. package/dist-esm/lib/tools/EraserTool/childStates/Erasing.mjs +26 -1
  242. package/dist-esm/lib/tools/EraserTool/childStates/Erasing.mjs.map +2 -2
  243. package/dist-esm/lib/tools/EraserTool/childStates/Pointing.mjs +13 -0
  244. package/dist-esm/lib/tools/EraserTool/childStates/Pointing.mjs.map +2 -2
  245. package/dist-esm/lib/tools/SelectTool/childStates/Translating.mjs.map +2 -2
  246. package/dist-esm/lib/ui/TldrawUi.mjs +29 -14
  247. package/dist-esm/lib/ui/TldrawUi.mjs.map +3 -3
  248. package/dist-esm/lib/ui/assetUrls.mjs +13 -10
  249. package/dist-esm/lib/ui/assetUrls.mjs.map +2 -2
  250. package/dist-esm/lib/ui/components/A11y.mjs +2 -2
  251. package/dist-esm/lib/ui/components/A11y.mjs.map +2 -2
  252. package/dist-esm/lib/ui/components/AccessibilityMenu.mjs +19 -0
  253. package/dist-esm/lib/ui/components/AccessibilityMenu.mjs.map +7 -0
  254. package/dist-esm/lib/ui/components/ActionsMenu/DefaultActionsMenu.mjs +12 -3
  255. package/dist-esm/lib/ui/components/ActionsMenu/DefaultActionsMenu.mjs.map +2 -2
  256. package/dist-esm/lib/ui/components/{FollowingIndicator.mjs → DefaultFollowingIndicator.mjs} +3 -3
  257. package/dist-esm/lib/ui/components/DefaultFollowingIndicator.mjs.map +7 -0
  258. package/dist-esm/lib/ui/components/DefaultMenuPanel.mjs +3 -2
  259. package/dist-esm/lib/ui/components/DefaultMenuPanel.mjs.map +2 -2
  260. package/dist-esm/lib/ui/components/KeyboardShortcutsDialog/DefaultKeyboardShortcutsDialogContent.mjs +6 -6
  261. package/dist-esm/lib/ui/components/KeyboardShortcutsDialog/DefaultKeyboardShortcutsDialogContent.mjs.map +1 -1
  262. package/dist-esm/lib/ui/components/LanguageMenu.mjs +1 -0
  263. package/dist-esm/lib/ui/components/LanguageMenu.mjs.map +2 -2
  264. package/dist-esm/lib/ui/components/MainMenu/DefaultMainMenuContent.mjs +3 -5
  265. package/dist-esm/lib/ui/components/MainMenu/DefaultMainMenuContent.mjs.map +2 -2
  266. package/dist-esm/lib/ui/components/Minimap/DefaultMinimap.mjs +1 -0
  267. package/dist-esm/lib/ui/components/Minimap/DefaultMinimap.mjs.map +2 -2
  268. package/dist-esm/lib/ui/components/Minimap/MinimapManager.mjs +4 -4
  269. package/dist-esm/lib/ui/components/Minimap/MinimapManager.mjs.map +2 -2
  270. package/dist-esm/lib/ui/components/MobileStylePanel.mjs +6 -3
  271. package/dist-esm/lib/ui/components/MobileStylePanel.mjs.map +2 -2
  272. package/dist-esm/lib/ui/components/NavigationPanel/DefaultNavigationPanel.mjs +1 -1
  273. package/dist-esm/lib/ui/components/NavigationPanel/DefaultNavigationPanel.mjs.map +2 -2
  274. package/dist-esm/lib/ui/components/PageMenu/DefaultPageMenu.mjs +4 -3
  275. package/dist-esm/lib/ui/components/PageMenu/DefaultPageMenu.mjs.map +2 -2
  276. package/dist-esm/lib/ui/components/SharePanel/PeopleMenuItem.mjs +3 -2
  277. package/dist-esm/lib/ui/components/SharePanel/PeopleMenuItem.mjs.map +2 -2
  278. package/dist-esm/lib/ui/components/SharePanel/UserPresenceColorPicker.mjs +2 -2
  279. package/dist-esm/lib/ui/components/SharePanel/UserPresenceColorPicker.mjs.map +2 -2
  280. package/dist-esm/lib/ui/components/StylePanel/DefaultStylePanel.mjs +16 -5
  281. package/dist-esm/lib/ui/components/StylePanel/DefaultStylePanel.mjs.map +2 -2
  282. package/dist-esm/lib/ui/components/StylePanel/DefaultStylePanelContent.mjs +251 -283
  283. package/dist-esm/lib/ui/components/StylePanel/DefaultStylePanelContent.mjs.map +2 -2
  284. package/dist-esm/lib/ui/components/StylePanel/StylePanelButtonPicker.mjs +135 -0
  285. package/dist-esm/lib/ui/components/StylePanel/StylePanelButtonPicker.mjs.map +7 -0
  286. package/dist-esm/lib/ui/components/StylePanel/StylePanelContext.mjs +48 -0
  287. package/dist-esm/lib/ui/components/StylePanel/StylePanelContext.mjs.map +7 -0
  288. package/dist-esm/lib/ui/components/StylePanel/{DoubleDropdownPicker.mjs → StylePanelDoubleDropdownPicker.mjs} +23 -22
  289. package/dist-esm/lib/ui/components/StylePanel/StylePanelDoubleDropdownPicker.mjs.map +7 -0
  290. package/dist-esm/lib/ui/components/StylePanel/{DropdownPicker.mjs → StylePanelDropdownPicker.mjs} +44 -40
  291. package/dist-esm/lib/ui/components/StylePanel/StylePanelDropdownPicker.mjs.map +7 -0
  292. package/dist-esm/lib/ui/components/StylePanel/StylePanelSubheading.mjs +8 -0
  293. package/dist-esm/lib/ui/components/StylePanel/StylePanelSubheading.mjs.map +7 -0
  294. package/dist-esm/lib/ui/components/Toolbar/AltTextEditor.mjs +2 -0
  295. package/dist-esm/lib/ui/components/Toolbar/AltTextEditor.mjs.map +2 -2
  296. package/dist-esm/lib/ui/components/Toolbar/DefaultImageToolbarContent.mjs +39 -10
  297. package/dist-esm/lib/ui/components/Toolbar/DefaultImageToolbarContent.mjs.map +2 -2
  298. package/dist-esm/lib/ui/components/Toolbar/DefaultToolbar.mjs +56 -21
  299. package/dist-esm/lib/ui/components/Toolbar/DefaultToolbar.mjs.map +2 -2
  300. package/dist-esm/lib/ui/components/Toolbar/DefaultVideoToolbarContent.mjs +15 -3
  301. package/dist-esm/lib/ui/components/Toolbar/DefaultVideoToolbarContent.mjs.map +2 -2
  302. package/dist-esm/lib/ui/components/Toolbar/LinkEditor.mjs +2 -1
  303. package/dist-esm/lib/ui/components/Toolbar/LinkEditor.mjs.map +2 -2
  304. package/dist-esm/lib/ui/components/Toolbar/OverflowingToolbar.mjs +192 -81
  305. package/dist-esm/lib/ui/components/Toolbar/OverflowingToolbar.mjs.map +3 -3
  306. package/dist-esm/lib/ui/components/Toolbar/ToggleToolLockedButton.mjs +10 -5
  307. package/dist-esm/lib/ui/components/Toolbar/ToggleToolLockedButton.mjs.map +2 -2
  308. package/dist-esm/lib/ui/components/menu-items.mjs +6 -0
  309. package/dist-esm/lib/ui/components/menu-items.mjs.map +2 -2
  310. package/dist-esm/lib/ui/components/primitives/TldrawUiContextualToolbar.mjs +12 -3
  311. package/dist-esm/lib/ui/components/primitives/TldrawUiContextualToolbar.mjs.map +2 -2
  312. package/dist-esm/lib/ui/components/primitives/TldrawUiInput.mjs +6 -4
  313. package/dist-esm/lib/ui/components/primitives/TldrawUiInput.mjs.map +2 -2
  314. package/dist-esm/lib/ui/components/primitives/TldrawUiPopover.mjs +3 -2
  315. package/dist-esm/lib/ui/components/primitives/TldrawUiPopover.mjs.map +2 -2
  316. package/dist-esm/lib/ui/components/primitives/TldrawUiSlider.mjs +18 -5
  317. package/dist-esm/lib/ui/components/primitives/TldrawUiSlider.mjs.map +2 -2
  318. package/dist-esm/lib/ui/components/primitives/TldrawUiToolbar.mjs +33 -7
  319. package/dist-esm/lib/ui/components/primitives/TldrawUiToolbar.mjs.map +2 -2
  320. package/dist-esm/lib/ui/components/primitives/TldrawUiTooltip.mjs +284 -0
  321. package/dist-esm/lib/ui/components/primitives/TldrawUiTooltip.mjs.map +7 -0
  322. package/dist-esm/lib/ui/components/primitives/layout.mjs +46 -0
  323. package/dist-esm/lib/ui/components/primitives/layout.mjs.map +7 -0
  324. package/dist-esm/lib/ui/components/primitives/menus/TldrawUiMenuCheckboxItem.mjs +3 -0
  325. package/dist-esm/lib/ui/components/primitives/menus/TldrawUiMenuCheckboxItem.mjs.map +2 -2
  326. package/dist-esm/lib/ui/components/primitives/menus/TldrawUiMenuContext.mjs.map +2 -2
  327. package/dist-esm/lib/ui/components/primitives/menus/TldrawUiMenuGroup.mjs +25 -12
  328. package/dist-esm/lib/ui/components/primitives/menus/TldrawUiMenuGroup.mjs.map +2 -2
  329. package/dist-esm/lib/ui/components/primitives/menus/TldrawUiMenuItem.mjs +162 -22
  330. package/dist-esm/lib/ui/components/primitives/menus/TldrawUiMenuItem.mjs.map +2 -2
  331. package/dist-esm/lib/ui/context/TldrawUiContextProvider.mjs +3 -2
  332. package/dist-esm/lib/ui/context/TldrawUiContextProvider.mjs.map +2 -2
  333. package/dist-esm/lib/ui/context/actions.mjs +44 -10
  334. package/dist-esm/lib/ui/context/actions.mjs.map +2 -2
  335. package/dist-esm/lib/ui/context/components.mjs +2 -0
  336. package/dist-esm/lib/ui/context/components.mjs.map +2 -2
  337. package/dist-esm/lib/ui/context/events.mjs.map +2 -2
  338. package/dist-esm/lib/ui/hooks/useClipboardEvents.mjs +2 -2
  339. package/dist-esm/lib/ui/hooks/useClipboardEvents.mjs.map +2 -2
  340. package/dist-esm/lib/ui/hooks/useExportAs.mjs +3 -2
  341. package/dist-esm/lib/ui/hooks/useExportAs.mjs.map +2 -2
  342. package/dist-esm/lib/ui/hooks/useTools.mjs +102 -10
  343. package/dist-esm/lib/ui/hooks/useTools.mjs.map +2 -2
  344. package/dist-esm/lib/ui/hooks/useTranslation/defaultTranslation.mjs +8 -1
  345. package/dist-esm/lib/ui/hooks/useTranslation/defaultTranslation.mjs.map +2 -2
  346. package/dist-esm/lib/ui/kbd-utils.mjs +9 -3
  347. package/dist-esm/lib/ui/kbd-utils.mjs.map +2 -2
  348. package/dist-esm/lib/ui/version.mjs +3 -3
  349. package/dist-esm/lib/ui/version.mjs.map +1 -1
  350. package/dist-esm/lib/utils/export/copyAs.mjs +1 -2
  351. package/dist-esm/lib/utils/export/copyAs.mjs.map +2 -2
  352. package/dist-esm/lib/utils/export/export.mjs +0 -20
  353. package/dist-esm/lib/utils/export/export.mjs.map +2 -2
  354. package/dist-esm/lib/utils/export/exportAs.mjs +1 -2
  355. package/dist-esm/lib/utils/export/exportAs.mjs.map +2 -2
  356. package/package.json +11 -34
  357. package/src/index.ts +64 -22
  358. package/src/lib/Tldraw.tsx +15 -2
  359. package/src/lib/canvas/TldrawScribble.tsx +1 -1
  360. package/src/lib/defaultExternalContentHandlers.ts +26 -4
  361. package/src/lib/shapes/arrow/ArrowShapeOptions.test.ts +2 -1
  362. package/src/lib/shapes/arrow/ArrowShapeTool.test.ts +6 -5
  363. package/src/lib/shapes/arrow/ArrowShapeUtil.test.ts +48 -6
  364. package/src/lib/shapes/arrow/ArrowShapeUtil.tsx +4 -3
  365. package/src/lib/shapes/arrow/arrowLabel.ts +8 -0
  366. package/src/lib/shapes/arrow/arrowTargetState.ts +2 -1
  367. package/src/lib/shapes/arrow/elbow/ElbowArrowDebug.tsx +3 -3
  368. package/src/lib/shapes/bookmark/BookmarkShapeUtil.tsx +5 -5
  369. package/src/lib/shapes/draw/DrawShapeTool.test.ts +0 -5
  370. package/src/lib/shapes/draw/DrawShapeUtil.tsx +4 -3
  371. package/src/lib/shapes/embed/EmbedShapeUtil.tsx +1 -1
  372. package/src/lib/shapes/frame/FrameShapeUtil.tsx +30 -14
  373. package/src/lib/shapes/frame/components/FrameHeading.tsx +1 -1
  374. package/src/lib/shapes/frame/components/FrameLabelInput.tsx +3 -3
  375. package/src/lib/shapes/geo/GeoShapeUtil.tsx +4 -2
  376. package/src/lib/shapes/geo/components/GeoShapeBody.tsx +2 -2
  377. package/src/lib/shapes/highlight/HighlightShapeUtil.tsx +7 -1
  378. package/src/lib/shapes/image/ImageShapeUtil.tsx +6 -3
  379. package/src/lib/shapes/line/LineShapeUtil.test.tsx +4 -3
  380. package/src/lib/shapes/line/LineShapeUtil.tsx +6 -1
  381. package/src/lib/shapes/line/__snapshots__/LineShapeUtil.test.tsx.snap +2 -2
  382. package/src/lib/shapes/note/NoteShapeUtil.tsx +10 -4
  383. package/src/lib/shapes/shared/HyperlinkButton.tsx +5 -5
  384. package/src/lib/shapes/shared/PlainTextLabel.tsx +0 -6
  385. package/src/lib/shapes/shared/ShapeFill.tsx +5 -4
  386. package/src/lib/shapes/shared/freehand/svg.ts +2 -0
  387. package/src/lib/shapes/shared/useEditablePlainText.ts +5 -9
  388. package/src/lib/shapes/shared/useImageOrVideoAsset.ts +0 -7
  389. package/src/lib/shapes/shared/usePrefersReducedMotion.tsx +11 -1
  390. package/src/lib/shapes/text/PlainTextArea.tsx +3 -3
  391. package/src/lib/shapes/text/RichTextArea.tsx +3 -4
  392. package/src/lib/shapes/text/TextShapeTool.test.ts +6 -5
  393. package/src/lib/shapes/text/TextShapeUtil.tsx +3 -2
  394. package/src/lib/shapes/video/VideoShapeUtil.tsx +3 -3
  395. package/src/lib/tools/EraserTool/childStates/Erasing.ts +34 -1
  396. package/src/lib/tools/EraserTool/childStates/Pointing.ts +20 -0
  397. package/src/lib/tools/SelectTool/childStates/Translating.ts +0 -1
  398. package/src/lib/ui/TldrawUi.tsx +33 -12
  399. package/src/lib/ui/assetUrls.ts +13 -10
  400. package/src/lib/ui/components/A11y.tsx +2 -2
  401. package/src/lib/ui/components/AccessibilityMenu.tsx +20 -0
  402. package/src/lib/ui/components/ActionsMenu/DefaultActionsMenu.tsx +15 -3
  403. package/src/lib/ui/components/{FollowingIndicator.tsx → DefaultFollowingIndicator.tsx} +2 -1
  404. package/src/lib/ui/components/DefaultMenuPanel.tsx +4 -3
  405. package/src/lib/ui/components/KeyboardShortcutsDialog/DefaultKeyboardShortcutsDialogContent.tsx +6 -6
  406. package/src/lib/ui/components/LanguageMenu.tsx +1 -0
  407. package/src/lib/ui/components/MainMenu/DefaultMainMenuContent.tsx +4 -4
  408. package/src/lib/ui/components/Minimap/DefaultMinimap.tsx +1 -0
  409. package/src/lib/ui/components/Minimap/MinimapManager.ts +4 -4
  410. package/src/lib/ui/components/MobileStylePanel.tsx +9 -6
  411. package/src/lib/ui/components/NavigationPanel/DefaultNavigationPanel.tsx +1 -1
  412. package/src/lib/ui/components/PageMenu/DefaultPageMenu.tsx +5 -4
  413. package/src/lib/ui/components/SharePanel/PeopleMenuItem.tsx +4 -3
  414. package/src/lib/ui/components/SharePanel/UserPresenceColorPicker.tsx +3 -3
  415. package/src/lib/ui/components/StylePanel/DefaultStylePanel.tsx +28 -12
  416. package/src/lib/ui/components/StylePanel/DefaultStylePanelContent.tsx +261 -343
  417. package/src/lib/ui/components/{primitives/TldrawUiButtonPicker.tsx → StylePanel/StylePanelButtonPicker.tsx} +73 -50
  418. package/src/lib/ui/components/StylePanel/StylePanelContext.tsx +63 -0
  419. package/src/lib/ui/components/StylePanel/{DoubleDropdownPicker.tsx → StylePanelDoubleDropdownPicker.tsx} +31 -22
  420. package/src/lib/ui/components/StylePanel/StylePanelDropdownPicker.tsx +119 -0
  421. package/src/lib/ui/components/StylePanel/StylePanelSubheading.tsx +9 -0
  422. package/src/lib/ui/components/Toolbar/AltTextEditor.tsx +2 -0
  423. package/src/lib/ui/components/Toolbar/DefaultImageToolbarContent.tsx +33 -16
  424. package/src/lib/ui/components/Toolbar/DefaultToolbar.tsx +55 -23
  425. package/src/lib/ui/components/Toolbar/DefaultVideoToolbarContent.tsx +12 -4
  426. package/src/lib/ui/components/Toolbar/LinkEditor.tsx +1 -0
  427. package/src/lib/ui/components/Toolbar/OverflowingToolbar.tsx +212 -61
  428. package/src/lib/ui/components/Toolbar/ToggleToolLockedButton.tsx +21 -11
  429. package/src/lib/ui/components/menu-items.tsx +8 -0
  430. package/src/lib/ui/components/primitives/TldrawUiContextualToolbar.tsx +8 -3
  431. package/src/lib/ui/components/primitives/TldrawUiInput.tsx +6 -3
  432. package/src/lib/ui/components/primitives/TldrawUiPopover.tsx +4 -2
  433. package/src/lib/ui/components/primitives/TldrawUiSlider.tsx +52 -32
  434. package/src/lib/ui/components/primitives/TldrawUiToolbar.tsx +55 -12
  435. package/src/lib/ui/components/primitives/TldrawUiTooltip.tsx +379 -0
  436. package/src/lib/ui/components/primitives/layout.tsx +107 -0
  437. package/src/lib/ui/components/primitives/menus/TldrawUiMenuCheckboxItem.tsx +4 -0
  438. package/src/lib/ui/components/primitives/menus/TldrawUiMenuContext.tsx +0 -1
  439. package/src/lib/ui/components/primitives/menus/TldrawUiMenuGroup.tsx +29 -16
  440. package/src/lib/ui/components/primitives/menus/TldrawUiMenuItem.tsx +221 -19
  441. package/src/lib/ui/context/TldrawUiContextProvider.tsx +23 -20
  442. package/src/lib/ui/context/actions.tsx +51 -10
  443. package/src/lib/ui/context/components.tsx +3 -0
  444. package/src/lib/ui/context/events.tsx +3 -1
  445. package/src/lib/ui/hooks/useClipboardEvents.ts +2 -2
  446. package/src/lib/ui/hooks/useExportAs.ts +3 -2
  447. package/src/lib/ui/hooks/useTools.tsx +140 -10
  448. package/src/lib/ui/hooks/useTranslation/TLUiTranslationKey.ts +7 -0
  449. package/src/lib/ui/hooks/useTranslation/defaultTranslation.ts +8 -1
  450. package/src/lib/ui/kbd-utils.ts +10 -3
  451. package/src/lib/ui/version.ts +3 -3
  452. package/src/lib/ui.css +434 -293
  453. package/src/lib/utils/excalidraw/__snapshots__/putExcalidrawContent.test.tsx.snap +5 -5
  454. package/src/lib/utils/export/copyAs.ts +1 -24
  455. package/src/lib/utils/export/export.ts +0 -36
  456. package/src/lib/utils/export/exportAs.ts +1 -32
  457. package/src/lib/utils/tldr/__snapshots__/buildFromV1Document.test.ts.snap +4 -4
  458. package/src/test/A11y.test.tsx +3 -2
  459. package/src/test/ClickManager.test.ts +7 -6
  460. package/src/test/Editor.test.tsx +20 -19
  461. package/src/test/EraserTool.test.ts +184 -13
  462. package/src/test/HandTool.test.ts +10 -9
  463. package/src/test/HighlightShape.test.ts +2 -1
  464. package/src/test/SelectTool.test.ts +3 -2
  465. package/src/test/TLUserPreferences.test.ts +4 -3
  466. package/src/test/TestEditor.ts +13 -15
  467. package/src/test/TldrawEditor.test.tsx +11 -10
  468. package/src/test/ZoomTool.test.ts +7 -6
  469. package/src/test/__snapshots__/drawing.test.ts.snap +2 -2
  470. package/src/test/__snapshots__/groups.test.tsx.snap +6 -6
  471. package/src/test/__snapshots__/resizing.test.ts.snap +2 -2
  472. package/src/test/arrows-megabus.test.tsx +17 -10
  473. package/src/test/bindings.test.tsx +24 -37
  474. package/src/test/bookmark-shapes.test.ts +1 -8
  475. package/src/test/commands/__snapshots__/getSvgString.test.ts.snap +23 -7
  476. package/src/test/commands/__snapshots__/packShapes.test.ts.snap +8 -8
  477. package/src/test/commands/__snapshots__/zoomToFit.test.ts.snap +2 -2
  478. package/src/test/commands/alignShapes.test.tsx +25 -24
  479. package/src/test/commands/animationSpeed.test.ts +2 -1
  480. package/src/test/commands/centerOnPoint.test.ts +3 -2
  481. package/src/test/commands/clipboard.test.ts +3 -2
  482. package/src/test/commands/createShapes.test.ts +2 -1
  483. package/src/test/commands/deleteShapes.test.ts +2 -1
  484. package/src/test/commands/distributeShapes.test.tsx +11 -10
  485. package/src/test/commands/getSvgString.test.ts +2 -1
  486. package/src/test/commands/packShapes.test.ts +5 -4
  487. package/src/test/commands/resizeShape.test.ts +2 -1
  488. package/src/test/commands/rotateShapes.test.ts +7 -6
  489. package/src/test/commands/setCamera.test.ts +4 -3
  490. package/src/test/commands/setCurrentPage.test.ts +3 -2
  491. package/src/test/commands/stackShapes.test.ts +11 -10
  492. package/src/test/commands/stretch.test.tsx +13 -12
  493. package/src/test/createDeepLink.test.tsx +2 -1
  494. package/src/test/cropping.test.ts +3 -2
  495. package/src/test/custom-clipping.test.ts +436 -0
  496. package/src/test/drawing.test.ts +2 -1
  497. package/src/test/flipShapes.test.ts +4 -3
  498. package/src/test/frames.test.ts +25 -24
  499. package/src/test/getCulledShapes.test.tsx +74 -4
  500. package/src/test/groups.test.tsx +1 -1
  501. package/src/test/handleDeepLink.test.tsx +2 -1
  502. package/src/test/inner-outer-margin.test.ts +315 -0
  503. package/src/test/maxShapes.test.ts +3 -2
  504. package/src/test/modifiers.test.ts +5 -4
  505. package/src/test/navigation.test.ts +12 -11
  506. package/src/test/panning.test.ts +2 -1
  507. package/src/test/perf/perf.test.ts +2 -1
  508. package/src/test/registerDeepLinkListener.test.tsx +10 -9
  509. package/src/test/resizing.test.ts +39 -38
  510. package/src/test/select.test.tsx +4 -3
  511. package/src/test/selection-omnibus.test.ts +11 -10
  512. package/src/test/shapeutils.test.ts +4 -3
  513. package/src/test/translating.test.ts +9 -8
  514. package/tldraw.css +742 -583
  515. package/dist-cjs/lib/ui/components/FollowingIndicator.js.map +0 -7
  516. package/dist-cjs/lib/ui/components/StylePanel/DoubleDropdownPicker.js.map +0 -7
  517. package/dist-cjs/lib/ui/components/StylePanel/DropdownPicker.js.map +0 -7
  518. package/dist-cjs/lib/ui/components/primitives/TldrawUiButtonPicker.js +0 -142
  519. package/dist-cjs/lib/ui/components/primitives/TldrawUiButtonPicker.js.map +0 -7
  520. package/dist-esm/lib/ui/components/FollowingIndicator.mjs.map +0 -7
  521. package/dist-esm/lib/ui/components/StylePanel/DoubleDropdownPicker.mjs.map +0 -7
  522. package/dist-esm/lib/ui/components/StylePanel/DropdownPicker.mjs.map +0 -7
  523. package/dist-esm/lib/ui/components/primitives/TldrawUiButtonPicker.mjs +0 -115
  524. package/dist-esm/lib/ui/components/primitives/TldrawUiButtonPicker.mjs.map +0 -7
  525. package/src/lib/ui/components/StylePanel/DropdownPicker.tsx +0 -109
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../../../src/lib/ui/components/FollowingIndicator.tsx"],
4
- "sourcesContent": ["import { useEditor, usePresence, useValue } from '@tldraw/editor'\n\nexport function FollowingIndicator() {\n\tconst editor = useEditor()\n\tconst followingUserId = useValue('follow', () => editor.getInstanceState().followingUserId, [\n\t\teditor,\n\t])\n\tif (!followingUserId) return null\n\treturn <FollowingIndicatorInner userId={followingUserId} />\n}\n\nfunction FollowingIndicatorInner({ userId }: { userId: string }) {\n\tconst presence = usePresence(userId)\n\tif (!presence) return null\n\treturn <div className=\"tlui-following-indicator\" style={{ borderColor: presence.color }} />\n}\n"],
5
- "mappings": ";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAQQ;AARR,oBAAiD;AAE1C,SAAS,qBAAqB;AACpC,QAAM,aAAS,yBAAU;AACzB,QAAM,sBAAkB,wBAAS,UAAU,MAAM,OAAO,iBAAiB,EAAE,iBAAiB;AAAA,IAC3F;AAAA,EACD,CAAC;AACD,MAAI,CAAC,gBAAiB,QAAO;AAC7B,SAAO,4CAAC,2BAAwB,QAAQ,iBAAiB;AAC1D;AAEA,SAAS,wBAAwB,EAAE,OAAO,GAAuB;AAChE,QAAM,eAAW,2BAAY,MAAM;AACnC,MAAI,CAAC,SAAU,QAAO;AACtB,SAAO,4CAAC,SAAI,WAAU,4BAA2B,OAAO,EAAE,aAAa,SAAS,MAAM,GAAG;AAC1F;",
6
- "names": []
7
- }
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../../../../src/lib/ui/components/StylePanel/DoubleDropdownPicker.tsx"],
4
- "sourcesContent": ["import { SharedStyle, StyleProp, tlmenus, useEditor } from '@tldraw/editor'\nimport * as React from 'react'\nimport { StyleValuesForUi } from '../../../styles'\nimport { TLUiTranslationKey } from '../../hooks/useTranslation/TLUiTranslationKey'\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\ninterface DoubleDropdownPickerProps<T extends string> {\n\tuiTypeA: string\n\tuiTypeB: string\n\tlabel: TLUiTranslationKey | Exclude<string, TLUiTranslationKey>\n\tlabelA: TLUiTranslationKey | Exclude<string, TLUiTranslationKey>\n\tlabelB: TLUiTranslationKey | Exclude<string, TLUiTranslationKey>\n\titemsA: StyleValuesForUi<T>\n\titemsB: StyleValuesForUi<T>\n\tstyleA: StyleProp<T>\n\tstyleB: StyleProp<T>\n\tvalueA: SharedStyle<T>\n\tvalueB: SharedStyle<T>\n\tonValueChange(style: StyleProp<T>, value: T): void\n}\n\nfunction DoubleDropdownPickerInner<T extends string>({\n\tlabel,\n\tuiTypeA,\n\tuiTypeB,\n\tlabelA,\n\tlabelB,\n\titemsA,\n\titemsB,\n\tstyleA,\n\tstyleB,\n\tvalueA,\n\tvalueB,\n\tonValueChange,\n}: DoubleDropdownPickerProps<T>) {\n\tconst editor = useEditor()\n\tconst msg = useTranslation()\n\tconst [isOpenA, setIsOpenA] = React.useState(false)\n\tconst [isOpenB, setIsOpenB] = React.useState(false)\n\n\tconst iconA = React.useMemo(\n\t\t() =>\n\t\t\titemsA.find((item) => valueA.type === 'shared' && valueA.value === item.value)?.icon ??\n\t\t\t'mixed',\n\t\t[itemsA, valueA]\n\t)\n\tconst iconB = React.useMemo(\n\t\t() =>\n\t\t\titemsB.find((item) => valueB.type === 'shared' && valueB.value === item.value)?.icon ??\n\t\t\t'mixed',\n\t\t[itemsB, valueB]\n\t)\n\n\tif (valueA === undefined && valueB === undefined) return null\n\n\tconst idA = `style panel ${uiTypeA} A`\n\tconst idB = `style panel ${uiTypeB} B`\n\treturn (\n\t\t<div className=\"tlui-style-panel__double-select-picker\">\n\t\t\t<div title={msg(label)} className=\"tlui-style-panel__double-select-picker-label\">\n\t\t\t\t{msg(label)}\n\t\t\t</div>\n\t\t\t<TldrawUiToolbar label={msg(label)} className=\"tlui-buttons__horizontal\">\n\t\t\t\t<TldrawUiPopover id={idA} open={isOpenA} onOpenChange={setIsOpenA}>\n\t\t\t\t\t<TldrawUiPopoverTrigger>\n\t\t\t\t\t\t<TldrawUiToolbarButton\n\t\t\t\t\t\t\ttype=\"icon\"\n\t\t\t\t\t\t\tdata-testid={`style.${uiTypeA}`}\n\t\t\t\t\t\t\ttitle={\n\t\t\t\t\t\t\t\tmsg(labelA) +\n\t\t\t\t\t\t\t\t' \u2014 ' +\n\t\t\t\t\t\t\t\t(valueA === null || valueA.type === 'mixed'\n\t\t\t\t\t\t\t\t\t? msg('style-panel.mixed')\n\t\t\t\t\t\t\t\t\t: msg(`${uiTypeA}-style.${valueA.value}` as TLUiTranslationKey))\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t<TldrawUiButtonIcon icon={iconA} small invertIcon />\n\t\t\t\t\t\t</TldrawUiToolbarButton>\n\t\t\t\t\t</TldrawUiPopoverTrigger>\n\t\t\t\t\t<TldrawUiPopoverContent side=\"left\" align=\"center\" sideOffset={80} alignOffset={0}>\n\t\t\t\t\t\t<TldrawUiToolbar label={msg(labelA)} className=\"tlui-buttons__grid\">\n\t\t\t\t\t\t\t<TldrawUiMenuContextProvider type=\"icons\" sourceId=\"style-panel\">\n\t\t\t\t\t\t\t\t{itemsA.map((item) => {\n\t\t\t\t\t\t\t\t\treturn (\n\t\t\t\t\t\t\t\t\t\t<TldrawUiToolbarButton\n\t\t\t\t\t\t\t\t\t\t\tdata-testid={`style.${uiTypeA}.${item.value}`}\n\t\t\t\t\t\t\t\t\t\t\ttype=\"icon\"\n\t\t\t\t\t\t\t\t\t\t\tkey={item.value}\n\t\t\t\t\t\t\t\t\t\t\tonClick={() => {\n\t\t\t\t\t\t\t\t\t\t\t\tonValueChange(styleA, item.value)\n\t\t\t\t\t\t\t\t\t\t\t\ttlmenus.deleteOpenMenu(idA, editor.contextId)\n\t\t\t\t\t\t\t\t\t\t\t\tsetIsOpenA(false)\n\t\t\t\t\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\t\t\t\t\ttitle={`${msg(labelA)} \u2014 ${msg(`${uiTypeA}-style.${item.value}`)}`}\n\t\t\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t\t\t\t<TldrawUiButtonIcon icon={item.icon} invertIcon />\n\t\t\t\t\t\t\t\t\t\t</TldrawUiToolbarButton>\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</TldrawUiMenuContextProvider>\n\t\t\t\t\t\t</TldrawUiToolbar>\n\t\t\t\t\t</TldrawUiPopoverContent>\n\t\t\t\t</TldrawUiPopover>\n\t\t\t\t<TldrawUiPopover id={idB} open={isOpenB} onOpenChange={setIsOpenB}>\n\t\t\t\t\t<TldrawUiPopoverTrigger>\n\t\t\t\t\t\t<TldrawUiToolbarButton\n\t\t\t\t\t\t\ttype=\"icon\"\n\t\t\t\t\t\t\tdata-testid={`style.${uiTypeB}`}\n\t\t\t\t\t\t\ttitle={\n\t\t\t\t\t\t\t\tmsg(labelB) +\n\t\t\t\t\t\t\t\t' \u2014 ' +\n\t\t\t\t\t\t\t\t(valueB === null || valueB.type === 'mixed'\n\t\t\t\t\t\t\t\t\t? msg('style-panel.mixed')\n\t\t\t\t\t\t\t\t\t: msg(`${uiTypeB}-style.${valueB.value}` as TLUiTranslationKey))\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t<TldrawUiButtonIcon icon={iconB} small />\n\t\t\t\t\t\t</TldrawUiToolbarButton>\n\t\t\t\t\t</TldrawUiPopoverTrigger>\n\t\t\t\t\t<TldrawUiPopoverContent side=\"left\" align=\"center\" sideOffset={116} alignOffset={0}>\n\t\t\t\t\t\t<TldrawUiToolbar label={msg(labelB)} className=\"tlui-buttons__grid\">\n\t\t\t\t\t\t\t<TldrawUiMenuContextProvider type=\"icons\" sourceId=\"style-panel\">\n\t\t\t\t\t\t\t\t{itemsB.map((item) => {\n\t\t\t\t\t\t\t\t\treturn (\n\t\t\t\t\t\t\t\t\t\t<TldrawUiToolbarButton\n\t\t\t\t\t\t\t\t\t\t\tkey={item.value}\n\t\t\t\t\t\t\t\t\t\t\ttype=\"icon\"\n\t\t\t\t\t\t\t\t\t\t\ttitle={`${msg(labelB)} \u2014 ${msg(`${uiTypeB}-style.${item.value}` as TLUiTranslationKey)}`}\n\t\t\t\t\t\t\t\t\t\t\tdata-testid={`style.${uiTypeB}.${item.value}`}\n\t\t\t\t\t\t\t\t\t\t\tonClick={() => {\n\t\t\t\t\t\t\t\t\t\t\t\tonValueChange(styleB, item.value)\n\t\t\t\t\t\t\t\t\t\t\t\ttlmenus.deleteOpenMenu(idB, editor.contextId)\n\t\t\t\t\t\t\t\t\t\t\t\tsetIsOpenB(false)\n\t\t\t\t\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t\t\t\t<TldrawUiButtonIcon icon={item.icon} />\n\t\t\t\t\t\t\t\t\t\t</TldrawUiToolbarButton>\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</TldrawUiMenuContextProvider>\n\t\t\t\t\t\t</TldrawUiToolbar>\n\t\t\t\t\t</TldrawUiPopoverContent>\n\t\t\t\t</TldrawUiPopover>\n\t\t\t</TldrawUiToolbar>\n\t\t</div>\n\t)\n}\n\n// need to memo like this to get generics\nexport const DoubleDropdownPicker = React.memo(\n\tDoubleDropdownPickerInner\n) as typeof DoubleDropdownPickerInner\n"],
5
- "mappings": "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",
6
- "names": []
7
- }
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../../../../src/lib/ui/components/StylePanel/DropdownPicker.tsx"],
4
- "sourcesContent": ["import { SharedStyle, StyleProp, tlmenus, useEditor } from '@tldraw/editor'\nimport classNames from 'classnames'\nimport * as React from 'react'\nimport { StyleValuesForUi } from '../../../styles'\nimport { TLUiTranslationKey } from '../../hooks/useTranslation/TLUiTranslationKey'\nimport { useTranslation } from '../../hooks/useTranslation/useTranslation'\nimport { TLUiIconType } from '../../icon-types'\nimport { TldrawUiButtonIcon } from '../primitives/Button/TldrawUiButtonIcon'\nimport { TldrawUiButtonLabel } from '../primitives/Button/TldrawUiButtonLabel'\nimport {\n\tTldrawUiPopover,\n\tTldrawUiPopoverContent,\n\tTldrawUiPopoverTrigger,\n} from '../primitives/TldrawUiPopover'\nimport { TldrawUiToolbar, TldrawUiToolbarButton } from '../primitives/TldrawUiToolbar'\nimport { TldrawUiMenuContextProvider } from '../primitives/menus/TldrawUiMenuContext'\n\ninterface DropdownPickerProps<T extends string> {\n\tid: string\n\tlabel?: TLUiTranslationKey | Exclude<string, TLUiTranslationKey>\n\tuiType: string\n\tstylePanelType: string\n\tstyle: StyleProp<T>\n\tvalue: SharedStyle<T>\n\titems: StyleValuesForUi<T>\n\ttype: 'icon' | 'tool' | 'menu'\n\tonValueChange(style: StyleProp<T>, value: T): void\n}\n\nfunction DropdownPickerInner<T extends string>({\n\tid,\n\tlabel,\n\tuiType,\n\tstylePanelType,\n\tstyle,\n\titems,\n\ttype,\n\tvalue,\n\tonValueChange,\n}: DropdownPickerProps<T>) {\n\tconst msg = useTranslation()\n\tconst editor = useEditor()\n\tconst [isOpen, setIsOpen] = React.useState(false)\n\n\tconst icon = React.useMemo(\n\t\t() => items.find((item) => value.type === 'shared' && item.value === value.value)?.icon,\n\t\t[items, value]\n\t)\n\n\tconst stylePanelName = msg(`style-panel.${stylePanelType}` as TLUiTranslationKey)\n\n\tconst titleStr =\n\t\tvalue.type === 'mixed'\n\t\t\t? msg('style-panel.mixed')\n\t\t\t: stylePanelName + ' \u2014 ' + msg(`${uiType}-style.${value.value}` as TLUiTranslationKey)\n\tconst labelStr = label ? msg(label) : ''\n\n\tconst popoverId = `style panel ${id}`\n\treturn (\n\t\t<TldrawUiPopover id={popoverId} open={isOpen} onOpenChange={setIsOpen}>\n\t\t\t<TldrawUiPopoverTrigger>\n\t\t\t\t<TldrawUiToolbarButton\n\t\t\t\t\ttype={type}\n\t\t\t\t\tdata-testid={`style.${uiType}`}\n\t\t\t\t\tdata-direction=\"left\"\n\t\t\t\t\ttitle={titleStr}\n\t\t\t\t>\n\t\t\t\t\t{labelStr && <TldrawUiButtonLabel>{labelStr}</TldrawUiButtonLabel>}\n\t\t\t\t\t<TldrawUiButtonIcon icon={(icon as TLUiIconType) ?? 'mixed'} />\n\t\t\t\t</TldrawUiToolbarButton>\n\t\t\t</TldrawUiPopoverTrigger>\n\t\t\t<TldrawUiPopoverContent side=\"left\" align=\"center\">\n\t\t\t\t<TldrawUiToolbar\n\t\t\t\t\tlabel={labelStr}\n\t\t\t\t\tclassName={classNames('tlui-buttons__grid', `tlui-buttons__${stylePanelType}`)}\n\t\t\t\t>\n\t\t\t\t\t<TldrawUiMenuContextProvider type=\"icons\" sourceId=\"style-panel\">\n\t\t\t\t\t\t{items.map((item) => {\n\t\t\t\t\t\t\treturn (\n\t\t\t\t\t\t\t\t<TldrawUiToolbarButton\n\t\t\t\t\t\t\t\t\tkey={item.value}\n\t\t\t\t\t\t\t\t\ttype=\"icon\"\n\t\t\t\t\t\t\t\t\tdata-testid={`style.${uiType}.${item.value}`}\n\t\t\t\t\t\t\t\t\ttitle={\n\t\t\t\t\t\t\t\t\t\tstylePanelName +\n\t\t\t\t\t\t\t\t\t\t' \u2014 ' +\n\t\t\t\t\t\t\t\t\t\tmsg(`${uiType}-style.${item.value}` as TLUiTranslationKey)\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\tisActive={icon === item.icon}\n\t\t\t\t\t\t\t\t\tonClick={() => {\n\t\t\t\t\t\t\t\t\t\teditor.markHistoryStoppingPoint('select style dropdown item')\n\t\t\t\t\t\t\t\t\t\tonValueChange(style, item.value)\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<TldrawUiButtonIcon icon={item.icon} />\n\t\t\t\t\t\t\t\t</TldrawUiToolbarButton>\n\t\t\t\t\t\t\t)\n\t\t\t\t\t\t})}\n\t\t\t\t\t</TldrawUiMenuContextProvider>\n\t\t\t\t</TldrawUiToolbar>\n\t\t\t</TldrawUiPopoverContent>\n\t\t</TldrawUiPopover>\n\t)\n}\n\n// need to export like this to get generics\nexport const DropdownPicker = React.memo(DropdownPickerInner) as typeof DropdownPickerInner\n"],
5
- "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AA6DI;AA7DJ,oBAA2D;AAC3D,wBAAuB;AACvB,YAAuB;AAGvB,4BAA+B;AAE/B,gCAAmC;AACnC,iCAAoC;AACpC,6BAIO;AACP,6BAAuD;AACvD,iCAA4C;AAc5C,SAAS,oBAAsC;AAAA,EAC9C;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACD,GAA2B;AAC1B,QAAM,UAAM,sCAAe;AAC3B,QAAM,aAAS,yBAAU;AACzB,QAAM,CAAC,QAAQ,SAAS,IAAI,MAAM,SAAS,KAAK;AAEhD,QAAM,OAAO,MAAM;AAAA,IAClB,MAAM,MAAM,KAAK,CAAC,SAAS,MAAM,SAAS,YAAY,KAAK,UAAU,MAAM,KAAK,GAAG;AAAA,IACnF,CAAC,OAAO,KAAK;AAAA,EACd;AAEA,QAAM,iBAAiB,IAAI,eAAe,cAAc,EAAwB;AAEhF,QAAM,WACL,MAAM,SAAS,UACZ,IAAI,mBAAmB,IACvB,iBAAiB,aAAQ,IAAI,GAAG,MAAM,UAAU,MAAM,KAAK,EAAwB;AACvF,QAAM,WAAW,QAAQ,IAAI,KAAK,IAAI;AAEtC,QAAM,YAAY,eAAe,EAAE;AACnC,SACC,6CAAC,0CAAgB,IAAI,WAAW,MAAM,QAAQ,cAAc,WAC3D;AAAA,gDAAC,iDACA;AAAA,MAAC;AAAA;AAAA,QACA;AAAA,QACA,eAAa,SAAS,MAAM;AAAA,QAC5B,kBAAe;AAAA,QACf,OAAO;AAAA,QAEN;AAAA,sBAAY,4CAAC,kDAAqB,oBAAS;AAAA,UAC5C,4CAAC,gDAAmB,MAAO,QAAyB,SAAS;AAAA;AAAA;AAAA,IAC9D,GACD;AAAA,IACA,4CAAC,iDAAuB,MAAK,QAAO,OAAM,UACzC;AAAA,MAAC;AAAA;AAAA,QACA,OAAO;AAAA,QACP,eAAW,kBAAAA,SAAW,sBAAsB,iBAAiB,cAAc,EAAE;AAAA,QAE7E,sDAAC,0DAA4B,MAAK,SAAQ,UAAS,eACjD,gBAAM,IAAI,CAAC,SAAS;AACpB,iBACC;AAAA,YAAC;AAAA;AAAA,cAEA,MAAK;AAAA,cACL,eAAa,SAAS,MAAM,IAAI,KAAK,KAAK;AAAA,cAC1C,OACC,iBACA,aACA,IAAI,GAAG,MAAM,UAAU,KAAK,KAAK,EAAwB;AAAA,cAE1D,UAAU,SAAS,KAAK;AAAA,cACxB,SAAS,MAAM;AACd,uBAAO,yBAAyB,4BAA4B;AAC5D,8BAAc,OAAO,KAAK,KAAK;AAC/B,sCAAQ,eAAe,WAAW,OAAO,SAAS;AAClD,0BAAU,KAAK;AAAA,cAChB;AAAA,cAEA,sDAAC,gDAAmB,MAAM,KAAK,MAAM;AAAA;AAAA,YAhBhC,KAAK;AAAA,UAiBX;AAAA,QAEF,CAAC,GACF;AAAA;AAAA,IACD,GACD;AAAA,KACD;AAEF;AAGO,MAAM,iBAAiB,MAAM,KAAK,mBAAmB;",
6
- "names": ["classNames"]
7
- }
@@ -1,142 +0,0 @@
1
- "use strict";
2
- var __create = Object.create;
3
- var __defProp = Object.defineProperty;
4
- var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
5
- var __getOwnPropNames = Object.getOwnPropertyNames;
6
- var __getProtoOf = Object.getPrototypeOf;
7
- var __hasOwnProp = Object.prototype.hasOwnProperty;
8
- var __export = (target, all) => {
9
- for (var name in all)
10
- __defProp(target, name, { get: all[name], enumerable: true });
11
- };
12
- var __copyProps = (to, from, except, desc) => {
13
- if (from && typeof from === "object" || typeof from === "function") {
14
- for (let key of __getOwnPropNames(from))
15
- if (!__hasOwnProp.call(to, key) && key !== except)
16
- __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
17
- }
18
- return to;
19
- };
20
- var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
21
- // If the importer is in node compatibility mode or this is not an ESM
22
- // file that has been converted to a CommonJS file using a Babel-
23
- // compatible transform (i.e. "__esModule" has not been set), then set
24
- // "default" to the CommonJS "module.exports" for node compatibility.
25
- isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
26
- mod
27
- ));
28
- var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
29
- var TldrawUiButtonPicker_exports = {};
30
- __export(TldrawUiButtonPicker_exports, {
31
- TldrawUiButtonPicker: () => TldrawUiButtonPicker
32
- });
33
- module.exports = __toCommonJS(TldrawUiButtonPicker_exports);
34
- var import_jsx_runtime = require("react/jsx-runtime");
35
- var import_editor = require("@tldraw/editor");
36
- var import_classnames = __toESM(require("classnames"));
37
- var import_react = require("react");
38
- var import_constants = require("../../constants");
39
- var import_breakpoints = require("../../context/breakpoints");
40
- var import_useTranslation = require("../../hooks/useTranslation/useTranslation");
41
- var import_TldrawUiButtonIcon = require("./Button/TldrawUiButtonIcon");
42
- var import_TldrawUiToolbar = require("./TldrawUiToolbar");
43
- const TldrawUiButtonPicker = (0, import_react.memo)(function TldrawUiButtonPicker2(props) {
44
- const {
45
- uiType,
46
- items,
47
- title,
48
- style,
49
- value,
50
- // columns = clamp(items.length, 2, 4),
51
- onValueChange,
52
- onHistoryMark,
53
- theme
54
- } = props;
55
- const editor = (0, import_editor.useEditor)();
56
- const msg = (0, import_useTranslation.useTranslation)();
57
- const breakpoint = (0, import_breakpoints.useBreakpoint)();
58
- const rPointing = (0, import_react.useRef)(false);
59
- const rPointingOriginalActiveElement = (0, import_react.useRef)(null);
60
- const {
61
- handleButtonClick,
62
- handleButtonPointerDown,
63
- handleButtonPointerEnter,
64
- handleButtonPointerUp
65
- } = (0, import_react.useMemo)(() => {
66
- const handlePointerUp = () => {
67
- rPointing.current = false;
68
- window.removeEventListener("pointerup", handlePointerUp);
69
- const origActiveEl = rPointingOriginalActiveElement.current;
70
- if (origActiveEl && (["TEXTAREA", "INPUT"].includes(origActiveEl.nodeName) || origActiveEl.isContentEditable)) {
71
- origActiveEl.focus();
72
- } else if (breakpoint >= import_constants.PORTRAIT_BREAKPOINT.TABLET_SM) {
73
- editor.getContainer().focus();
74
- }
75
- rPointingOriginalActiveElement.current = null;
76
- };
77
- const handleButtonClick2 = (e) => {
78
- const { id } = e.currentTarget.dataset;
79
- if (value.type === "shared" && value.value === id) return;
80
- onHistoryMark?.("point picker item");
81
- onValueChange(style, id);
82
- };
83
- const handleButtonPointerDown2 = (e) => {
84
- const { id } = e.currentTarget.dataset;
85
- onHistoryMark?.("point picker item");
86
- onValueChange(style, id);
87
- rPointing.current = true;
88
- rPointingOriginalActiveElement.current = document.activeElement;
89
- window.addEventListener("pointerup", handlePointerUp);
90
- };
91
- const handleButtonPointerEnter2 = (e) => {
92
- if (!rPointing.current) return;
93
- const { id } = e.currentTarget.dataset;
94
- onValueChange(style, id);
95
- };
96
- const handleButtonPointerUp2 = (e) => {
97
- const { id } = e.currentTarget.dataset;
98
- if (value.type === "shared" && value.value === id) return;
99
- onValueChange(style, id);
100
- };
101
- return {
102
- handleButtonClick: handleButtonClick2,
103
- handleButtonPointerDown: handleButtonPointerDown2,
104
- handleButtonPointerEnter: handleButtonPointerEnter2,
105
- handleButtonPointerUp: handleButtonPointerUp2
106
- };
107
- }, [editor, breakpoint, value, onHistoryMark, onValueChange, style]);
108
- return /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
109
- import_TldrawUiToolbar.TldrawUiToolbarToggleGroup,
110
- {
111
- "data-testid": `style.${uiType}`,
112
- type: "single",
113
- className: (0, import_classnames.default)("tlui-buttons__grid"),
114
- value: value.type === "shared" ? value.value : void 0,
115
- children: items.map((item) => {
116
- const label = title + " \u2014 " + msg(`${uiType}-style.${item.value}`);
117
- return /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
118
- import_TldrawUiToolbar.TldrawUiToolbarToggleItem,
119
- {
120
- type: "icon",
121
- "data-id": item.value,
122
- "data-testid": `style.${uiType}.${item.value}`,
123
- "aria-label": label,
124
- value: item.value,
125
- "data-state": value.type === "shared" && value.value === item.value ? "on" : "off",
126
- "data-isactive": value.type === "shared" && value.value === item.value,
127
- title: label,
128
- className: (0, import_classnames.default)("tlui-button-grid__button"),
129
- style: style === import_editor.DefaultColorStyle ? { color: theme[item.value].solid } : void 0,
130
- onPointerEnter: handleButtonPointerEnter,
131
- onPointerDown: handleButtonPointerDown,
132
- onPointerUp: handleButtonPointerUp,
133
- onClick: handleButtonClick,
134
- children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_TldrawUiButtonIcon.TldrawUiButtonIcon, { icon: item.icon })
135
- },
136
- item.value
137
- );
138
- })
139
- }
140
- );
141
- });
142
- //# sourceMappingURL=TldrawUiButtonPicker.js.map
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../../../../src/lib/ui/components/primitives/TldrawUiButtonPicker.tsx"],
4
- "sourcesContent": ["import {\n\tDefaultColorStyle,\n\tSharedStyle,\n\tStyleProp,\n\tTLDefaultColorStyle,\n\tTLDefaultColorTheme,\n\tuseEditor,\n} from '@tldraw/editor'\nimport classNames from 'classnames'\nimport { ReactElement, memo, useMemo, useRef } from 'react'\nimport { StyleValuesForUi } from '../../../styles'\nimport { PORTRAIT_BREAKPOINT } from '../../constants'\nimport { useBreakpoint } from '../../context/breakpoints'\nimport { TLUiTranslationKey } from '../../hooks/useTranslation/TLUiTranslationKey'\nimport { useTranslation } from '../../hooks/useTranslation/useTranslation'\nimport { TldrawUiButtonIcon } from './Button/TldrawUiButtonIcon'\nimport { TldrawUiToolbarToggleGroup, TldrawUiToolbarToggleItem } from './TldrawUiToolbar'\n\n/** @public */\nexport interface TLUiButtonPickerProps<T extends string> {\n\ttitle: string\n\tuiType: string\n\tstyle: StyleProp<T>\n\tvalue: SharedStyle<T>\n\titems: StyleValuesForUi<T>\n\ttheme: TLDefaultColorTheme\n\tonValueChange(style: StyleProp<T>, value: T): void\n\tonHistoryMark?(id: string): void\n}\n\n/** @public */\nexport const TldrawUiButtonPicker = memo(function TldrawUiButtonPicker<T extends string>(\n\tprops: TLUiButtonPickerProps<T>\n) {\n\tconst {\n\t\tuiType,\n\t\titems,\n\t\ttitle,\n\t\tstyle,\n\t\tvalue,\n\t\t// columns = clamp(items.length, 2, 4),\n\t\tonValueChange,\n\t\tonHistoryMark,\n\t\ttheme,\n\t} = props\n\tconst editor = useEditor()\n\tconst msg = useTranslation()\n\tconst breakpoint = useBreakpoint()\n\n\tconst rPointing = useRef(false)\n\tconst rPointingOriginalActiveElement = useRef<HTMLElement | null>(null)\n\n\tconst {\n\t\thandleButtonClick,\n\t\thandleButtonPointerDown,\n\t\thandleButtonPointerEnter,\n\t\thandleButtonPointerUp,\n\t} = useMemo(() => {\n\t\tconst handlePointerUp = () => {\n\t\t\trPointing.current = false\n\t\t\twindow.removeEventListener('pointerup', handlePointerUp)\n\n\t\t\t// This is fun little micro-optimization to make sure that the focus\n\t\t\t// is retained on a text label. That way, you can continue typing\n\t\t\t// after selecting a style.\n\t\t\tconst origActiveEl = rPointingOriginalActiveElement.current\n\t\t\tif (\n\t\t\t\torigActiveEl &&\n\t\t\t\t(['TEXTAREA', 'INPUT'].includes(origActiveEl.nodeName) || origActiveEl.isContentEditable)\n\t\t\t) {\n\t\t\t\torigActiveEl.focus()\n\t\t\t} else if (breakpoint >= PORTRAIT_BREAKPOINT.TABLET_SM) {\n\t\t\t\teditor.getContainer().focus()\n\t\t\t}\n\t\t\trPointingOriginalActiveElement.current = null\n\t\t}\n\n\t\tconst handleButtonClick = (e: React.PointerEvent<HTMLButtonElement>) => {\n\t\t\tconst { id } = e.currentTarget.dataset\n\t\t\tif (value.type === 'shared' && value.value === id) return\n\n\t\t\tonHistoryMark?.('point picker item')\n\t\t\tonValueChange(style, id as T)\n\t\t}\n\n\t\tconst handleButtonPointerDown = (e: React.PointerEvent<HTMLButtonElement>) => {\n\t\t\tconst { id } = e.currentTarget.dataset\n\n\t\t\tonHistoryMark?.('point picker item')\n\t\t\tonValueChange(style, id as T)\n\n\t\t\trPointing.current = true\n\t\t\trPointingOriginalActiveElement.current = document.activeElement as HTMLElement\n\t\t\twindow.addEventListener('pointerup', handlePointerUp) // see TLD-658\n\t\t}\n\n\t\tconst handleButtonPointerEnter = (e: React.PointerEvent<HTMLButtonElement>) => {\n\t\t\tif (!rPointing.current) return\n\n\t\t\tconst { id } = e.currentTarget.dataset\n\t\t\tonValueChange(style, id as T)\n\t\t}\n\n\t\tconst handleButtonPointerUp = (e: React.PointerEvent<HTMLButtonElement>) => {\n\t\t\tconst { id } = e.currentTarget.dataset\n\t\t\tif (value.type === 'shared' && value.value === id) return\n\n\t\t\tonValueChange(style, id as T)\n\t\t}\n\n\t\treturn {\n\t\t\thandleButtonClick,\n\t\t\thandleButtonPointerDown,\n\t\t\thandleButtonPointerEnter,\n\t\t\thandleButtonPointerUp,\n\t\t}\n\t}, [editor, breakpoint, value, onHistoryMark, onValueChange, style])\n\n\treturn (\n\t\t<TldrawUiToolbarToggleGroup\n\t\t\tdata-testid={`style.${uiType}`}\n\t\t\ttype=\"single\"\n\t\t\tclassName={classNames('tlui-buttons__grid')}\n\t\t\tvalue={value.type === 'shared' ? value.value : undefined}\n\t\t>\n\t\t\t{items.map((item) => {\n\t\t\t\tconst label = title + ' \u2014 ' + msg(`${uiType}-style.${item.value}` as TLUiTranslationKey)\n\t\t\t\treturn (\n\t\t\t\t\t<TldrawUiToolbarToggleItem\n\t\t\t\t\t\ttype=\"icon\"\n\t\t\t\t\t\tkey={item.value}\n\t\t\t\t\t\tdata-id={item.value}\n\t\t\t\t\t\tdata-testid={`style.${uiType}.${item.value}`}\n\t\t\t\t\t\taria-label={label}\n\t\t\t\t\t\tvalue={item.value}\n\t\t\t\t\t\tdata-state={value.type === 'shared' && value.value === item.value ? 'on' : 'off'}\n\t\t\t\t\t\tdata-isactive={value.type === 'shared' && value.value === item.value}\n\t\t\t\t\t\ttitle={label}\n\t\t\t\t\t\tclassName={classNames('tlui-button-grid__button')}\n\t\t\t\t\t\tstyle={\n\t\t\t\t\t\t\tstyle === (DefaultColorStyle as StyleProp<unknown>)\n\t\t\t\t\t\t\t\t? { color: theme[item.value as TLDefaultColorStyle].solid }\n\t\t\t\t\t\t\t\t: undefined\n\t\t\t\t\t\t}\n\t\t\t\t\t\tonPointerEnter={handleButtonPointerEnter}\n\t\t\t\t\t\tonPointerDown={handleButtonPointerDown}\n\t\t\t\t\t\tonPointerUp={handleButtonPointerUp}\n\t\t\t\t\t\tonClick={handleButtonClick}\n\t\t\t\t\t>\n\t\t\t\t\t\t<TldrawUiButtonIcon icon={item.icon} />\n\t\t\t\t\t</TldrawUiToolbarToggleItem>\n\t\t\t\t)\n\t\t\t})}\n\t\t</TldrawUiToolbarToggleGroup>\n\t)\n}) as <T extends string>(props: TLUiButtonPickerProps<T>) => ReactElement\n"],
5
- "mappings": "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",
6
- "names": ["TldrawUiButtonPicker", "handleButtonClick", "handleButtonPointerDown", "handleButtonPointerEnter", "handleButtonPointerUp", "classNames"]
7
- }
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../../../src/lib/ui/components/FollowingIndicator.tsx"],
4
- "sourcesContent": ["import { useEditor, usePresence, useValue } from '@tldraw/editor'\n\nexport function FollowingIndicator() {\n\tconst editor = useEditor()\n\tconst followingUserId = useValue('follow', () => editor.getInstanceState().followingUserId, [\n\t\teditor,\n\t])\n\tif (!followingUserId) return null\n\treturn <FollowingIndicatorInner userId={followingUserId} />\n}\n\nfunction FollowingIndicatorInner({ userId }: { userId: string }) {\n\tconst presence = usePresence(userId)\n\tif (!presence) return null\n\treturn <div className=\"tlui-following-indicator\" style={{ borderColor: presence.color }} />\n}\n"],
5
- "mappings": "AAQQ;AARR,SAAS,WAAW,aAAa,gBAAgB;AAE1C,SAAS,qBAAqB;AACpC,QAAM,SAAS,UAAU;AACzB,QAAM,kBAAkB,SAAS,UAAU,MAAM,OAAO,iBAAiB,EAAE,iBAAiB;AAAA,IAC3F;AAAA,EACD,CAAC;AACD,MAAI,CAAC,gBAAiB,QAAO;AAC7B,SAAO,oBAAC,2BAAwB,QAAQ,iBAAiB;AAC1D;AAEA,SAAS,wBAAwB,EAAE,OAAO,GAAuB;AAChE,QAAM,WAAW,YAAY,MAAM;AACnC,MAAI,CAAC,SAAU,QAAO;AACtB,SAAO,oBAAC,SAAI,WAAU,4BAA2B,OAAO,EAAE,aAAa,SAAS,MAAM,GAAG;AAC1F;",
6
- "names": []
7
- }
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../../../../src/lib/ui/components/StylePanel/DoubleDropdownPicker.tsx"],
4
- "sourcesContent": ["import { SharedStyle, StyleProp, tlmenus, useEditor } from '@tldraw/editor'\nimport * as React from 'react'\nimport { StyleValuesForUi } from '../../../styles'\nimport { TLUiTranslationKey } from '../../hooks/useTranslation/TLUiTranslationKey'\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\ninterface DoubleDropdownPickerProps<T extends string> {\n\tuiTypeA: string\n\tuiTypeB: string\n\tlabel: TLUiTranslationKey | Exclude<string, TLUiTranslationKey>\n\tlabelA: TLUiTranslationKey | Exclude<string, TLUiTranslationKey>\n\tlabelB: TLUiTranslationKey | Exclude<string, TLUiTranslationKey>\n\titemsA: StyleValuesForUi<T>\n\titemsB: StyleValuesForUi<T>\n\tstyleA: StyleProp<T>\n\tstyleB: StyleProp<T>\n\tvalueA: SharedStyle<T>\n\tvalueB: SharedStyle<T>\n\tonValueChange(style: StyleProp<T>, value: T): void\n}\n\nfunction DoubleDropdownPickerInner<T extends string>({\n\tlabel,\n\tuiTypeA,\n\tuiTypeB,\n\tlabelA,\n\tlabelB,\n\titemsA,\n\titemsB,\n\tstyleA,\n\tstyleB,\n\tvalueA,\n\tvalueB,\n\tonValueChange,\n}: DoubleDropdownPickerProps<T>) {\n\tconst editor = useEditor()\n\tconst msg = useTranslation()\n\tconst [isOpenA, setIsOpenA] = React.useState(false)\n\tconst [isOpenB, setIsOpenB] = React.useState(false)\n\n\tconst iconA = React.useMemo(\n\t\t() =>\n\t\t\titemsA.find((item) => valueA.type === 'shared' && valueA.value === item.value)?.icon ??\n\t\t\t'mixed',\n\t\t[itemsA, valueA]\n\t)\n\tconst iconB = React.useMemo(\n\t\t() =>\n\t\t\titemsB.find((item) => valueB.type === 'shared' && valueB.value === item.value)?.icon ??\n\t\t\t'mixed',\n\t\t[itemsB, valueB]\n\t)\n\n\tif (valueA === undefined && valueB === undefined) return null\n\n\tconst idA = `style panel ${uiTypeA} A`\n\tconst idB = `style panel ${uiTypeB} B`\n\treturn (\n\t\t<div className=\"tlui-style-panel__double-select-picker\">\n\t\t\t<div title={msg(label)} className=\"tlui-style-panel__double-select-picker-label\">\n\t\t\t\t{msg(label)}\n\t\t\t</div>\n\t\t\t<TldrawUiToolbar label={msg(label)} className=\"tlui-buttons__horizontal\">\n\t\t\t\t<TldrawUiPopover id={idA} open={isOpenA} onOpenChange={setIsOpenA}>\n\t\t\t\t\t<TldrawUiPopoverTrigger>\n\t\t\t\t\t\t<TldrawUiToolbarButton\n\t\t\t\t\t\t\ttype=\"icon\"\n\t\t\t\t\t\t\tdata-testid={`style.${uiTypeA}`}\n\t\t\t\t\t\t\ttitle={\n\t\t\t\t\t\t\t\tmsg(labelA) +\n\t\t\t\t\t\t\t\t' \u2014 ' +\n\t\t\t\t\t\t\t\t(valueA === null || valueA.type === 'mixed'\n\t\t\t\t\t\t\t\t\t? msg('style-panel.mixed')\n\t\t\t\t\t\t\t\t\t: msg(`${uiTypeA}-style.${valueA.value}` as TLUiTranslationKey))\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t<TldrawUiButtonIcon icon={iconA} small invertIcon />\n\t\t\t\t\t\t</TldrawUiToolbarButton>\n\t\t\t\t\t</TldrawUiPopoverTrigger>\n\t\t\t\t\t<TldrawUiPopoverContent side=\"left\" align=\"center\" sideOffset={80} alignOffset={0}>\n\t\t\t\t\t\t<TldrawUiToolbar label={msg(labelA)} className=\"tlui-buttons__grid\">\n\t\t\t\t\t\t\t<TldrawUiMenuContextProvider type=\"icons\" sourceId=\"style-panel\">\n\t\t\t\t\t\t\t\t{itemsA.map((item) => {\n\t\t\t\t\t\t\t\t\treturn (\n\t\t\t\t\t\t\t\t\t\t<TldrawUiToolbarButton\n\t\t\t\t\t\t\t\t\t\t\tdata-testid={`style.${uiTypeA}.${item.value}`}\n\t\t\t\t\t\t\t\t\t\t\ttype=\"icon\"\n\t\t\t\t\t\t\t\t\t\t\tkey={item.value}\n\t\t\t\t\t\t\t\t\t\t\tonClick={() => {\n\t\t\t\t\t\t\t\t\t\t\t\tonValueChange(styleA, item.value)\n\t\t\t\t\t\t\t\t\t\t\t\ttlmenus.deleteOpenMenu(idA, editor.contextId)\n\t\t\t\t\t\t\t\t\t\t\t\tsetIsOpenA(false)\n\t\t\t\t\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\t\t\t\t\ttitle={`${msg(labelA)} \u2014 ${msg(`${uiTypeA}-style.${item.value}`)}`}\n\t\t\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t\t\t\t<TldrawUiButtonIcon icon={item.icon} invertIcon />\n\t\t\t\t\t\t\t\t\t\t</TldrawUiToolbarButton>\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</TldrawUiMenuContextProvider>\n\t\t\t\t\t\t</TldrawUiToolbar>\n\t\t\t\t\t</TldrawUiPopoverContent>\n\t\t\t\t</TldrawUiPopover>\n\t\t\t\t<TldrawUiPopover id={idB} open={isOpenB} onOpenChange={setIsOpenB}>\n\t\t\t\t\t<TldrawUiPopoverTrigger>\n\t\t\t\t\t\t<TldrawUiToolbarButton\n\t\t\t\t\t\t\ttype=\"icon\"\n\t\t\t\t\t\t\tdata-testid={`style.${uiTypeB}`}\n\t\t\t\t\t\t\ttitle={\n\t\t\t\t\t\t\t\tmsg(labelB) +\n\t\t\t\t\t\t\t\t' \u2014 ' +\n\t\t\t\t\t\t\t\t(valueB === null || valueB.type === 'mixed'\n\t\t\t\t\t\t\t\t\t? msg('style-panel.mixed')\n\t\t\t\t\t\t\t\t\t: msg(`${uiTypeB}-style.${valueB.value}` as TLUiTranslationKey))\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t<TldrawUiButtonIcon icon={iconB} small />\n\t\t\t\t\t\t</TldrawUiToolbarButton>\n\t\t\t\t\t</TldrawUiPopoverTrigger>\n\t\t\t\t\t<TldrawUiPopoverContent side=\"left\" align=\"center\" sideOffset={116} alignOffset={0}>\n\t\t\t\t\t\t<TldrawUiToolbar label={msg(labelB)} className=\"tlui-buttons__grid\">\n\t\t\t\t\t\t\t<TldrawUiMenuContextProvider type=\"icons\" sourceId=\"style-panel\">\n\t\t\t\t\t\t\t\t{itemsB.map((item) => {\n\t\t\t\t\t\t\t\t\treturn (\n\t\t\t\t\t\t\t\t\t\t<TldrawUiToolbarButton\n\t\t\t\t\t\t\t\t\t\t\tkey={item.value}\n\t\t\t\t\t\t\t\t\t\t\ttype=\"icon\"\n\t\t\t\t\t\t\t\t\t\t\ttitle={`${msg(labelB)} \u2014 ${msg(`${uiTypeB}-style.${item.value}` as TLUiTranslationKey)}`}\n\t\t\t\t\t\t\t\t\t\t\tdata-testid={`style.${uiTypeB}.${item.value}`}\n\t\t\t\t\t\t\t\t\t\t\tonClick={() => {\n\t\t\t\t\t\t\t\t\t\t\t\tonValueChange(styleB, item.value)\n\t\t\t\t\t\t\t\t\t\t\t\ttlmenus.deleteOpenMenu(idB, editor.contextId)\n\t\t\t\t\t\t\t\t\t\t\t\tsetIsOpenB(false)\n\t\t\t\t\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t\t\t\t<TldrawUiButtonIcon icon={item.icon} />\n\t\t\t\t\t\t\t\t\t\t</TldrawUiToolbarButton>\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</TldrawUiMenuContextProvider>\n\t\t\t\t\t\t</TldrawUiToolbar>\n\t\t\t\t\t</TldrawUiPopoverContent>\n\t\t\t\t</TldrawUiPopover>\n\t\t\t</TldrawUiToolbar>\n\t\t</div>\n\t)\n}\n\n// need to memo like this to get generics\nexport const DoubleDropdownPicker = React.memo(\n\tDoubleDropdownPickerInner\n) as typeof DoubleDropdownPickerInner\n"],
5
- "mappings": "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",
6
- "names": []
7
- }
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../../../../src/lib/ui/components/StylePanel/DropdownPicker.tsx"],
4
- "sourcesContent": ["import { SharedStyle, StyleProp, tlmenus, useEditor } from '@tldraw/editor'\nimport classNames from 'classnames'\nimport * as React from 'react'\nimport { StyleValuesForUi } from '../../../styles'\nimport { TLUiTranslationKey } from '../../hooks/useTranslation/TLUiTranslationKey'\nimport { useTranslation } from '../../hooks/useTranslation/useTranslation'\nimport { TLUiIconType } from '../../icon-types'\nimport { TldrawUiButtonIcon } from '../primitives/Button/TldrawUiButtonIcon'\nimport { TldrawUiButtonLabel } from '../primitives/Button/TldrawUiButtonLabel'\nimport {\n\tTldrawUiPopover,\n\tTldrawUiPopoverContent,\n\tTldrawUiPopoverTrigger,\n} from '../primitives/TldrawUiPopover'\nimport { TldrawUiToolbar, TldrawUiToolbarButton } from '../primitives/TldrawUiToolbar'\nimport { TldrawUiMenuContextProvider } from '../primitives/menus/TldrawUiMenuContext'\n\ninterface DropdownPickerProps<T extends string> {\n\tid: string\n\tlabel?: TLUiTranslationKey | Exclude<string, TLUiTranslationKey>\n\tuiType: string\n\tstylePanelType: string\n\tstyle: StyleProp<T>\n\tvalue: SharedStyle<T>\n\titems: StyleValuesForUi<T>\n\ttype: 'icon' | 'tool' | 'menu'\n\tonValueChange(style: StyleProp<T>, value: T): void\n}\n\nfunction DropdownPickerInner<T extends string>({\n\tid,\n\tlabel,\n\tuiType,\n\tstylePanelType,\n\tstyle,\n\titems,\n\ttype,\n\tvalue,\n\tonValueChange,\n}: DropdownPickerProps<T>) {\n\tconst msg = useTranslation()\n\tconst editor = useEditor()\n\tconst [isOpen, setIsOpen] = React.useState(false)\n\n\tconst icon = React.useMemo(\n\t\t() => items.find((item) => value.type === 'shared' && item.value === value.value)?.icon,\n\t\t[items, value]\n\t)\n\n\tconst stylePanelName = msg(`style-panel.${stylePanelType}` as TLUiTranslationKey)\n\n\tconst titleStr =\n\t\tvalue.type === 'mixed'\n\t\t\t? msg('style-panel.mixed')\n\t\t\t: stylePanelName + ' \u2014 ' + msg(`${uiType}-style.${value.value}` as TLUiTranslationKey)\n\tconst labelStr = label ? msg(label) : ''\n\n\tconst popoverId = `style panel ${id}`\n\treturn (\n\t\t<TldrawUiPopover id={popoverId} open={isOpen} onOpenChange={setIsOpen}>\n\t\t\t<TldrawUiPopoverTrigger>\n\t\t\t\t<TldrawUiToolbarButton\n\t\t\t\t\ttype={type}\n\t\t\t\t\tdata-testid={`style.${uiType}`}\n\t\t\t\t\tdata-direction=\"left\"\n\t\t\t\t\ttitle={titleStr}\n\t\t\t\t>\n\t\t\t\t\t{labelStr && <TldrawUiButtonLabel>{labelStr}</TldrawUiButtonLabel>}\n\t\t\t\t\t<TldrawUiButtonIcon icon={(icon as TLUiIconType) ?? 'mixed'} />\n\t\t\t\t</TldrawUiToolbarButton>\n\t\t\t</TldrawUiPopoverTrigger>\n\t\t\t<TldrawUiPopoverContent side=\"left\" align=\"center\">\n\t\t\t\t<TldrawUiToolbar\n\t\t\t\t\tlabel={labelStr}\n\t\t\t\t\tclassName={classNames('tlui-buttons__grid', `tlui-buttons__${stylePanelType}`)}\n\t\t\t\t>\n\t\t\t\t\t<TldrawUiMenuContextProvider type=\"icons\" sourceId=\"style-panel\">\n\t\t\t\t\t\t{items.map((item) => {\n\t\t\t\t\t\t\treturn (\n\t\t\t\t\t\t\t\t<TldrawUiToolbarButton\n\t\t\t\t\t\t\t\t\tkey={item.value}\n\t\t\t\t\t\t\t\t\ttype=\"icon\"\n\t\t\t\t\t\t\t\t\tdata-testid={`style.${uiType}.${item.value}`}\n\t\t\t\t\t\t\t\t\ttitle={\n\t\t\t\t\t\t\t\t\t\tstylePanelName +\n\t\t\t\t\t\t\t\t\t\t' \u2014 ' +\n\t\t\t\t\t\t\t\t\t\tmsg(`${uiType}-style.${item.value}` as TLUiTranslationKey)\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\tisActive={icon === item.icon}\n\t\t\t\t\t\t\t\t\tonClick={() => {\n\t\t\t\t\t\t\t\t\t\teditor.markHistoryStoppingPoint('select style dropdown item')\n\t\t\t\t\t\t\t\t\t\tonValueChange(style, item.value)\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<TldrawUiButtonIcon icon={item.icon} />\n\t\t\t\t\t\t\t\t</TldrawUiToolbarButton>\n\t\t\t\t\t\t\t)\n\t\t\t\t\t\t})}\n\t\t\t\t\t</TldrawUiMenuContextProvider>\n\t\t\t\t</TldrawUiToolbar>\n\t\t\t</TldrawUiPopoverContent>\n\t\t</TldrawUiPopover>\n\t)\n}\n\n// need to export like this to get generics\nexport const DropdownPicker = React.memo(DropdownPickerInner) as typeof DropdownPickerInner\n"],
5
- "mappings": "AA6DI,SAMc,KANd;AA7DJ,SAAiC,SAAS,iBAAiB;AAC3D,OAAO,gBAAgB;AACvB,YAAY,WAAW;AAGvB,SAAS,sBAAsB;AAE/B,SAAS,0BAA0B;AACnC,SAAS,2BAA2B;AACpC;AAAA,EACC;AAAA,EACA;AAAA,EACA;AAAA,OACM;AACP,SAAS,iBAAiB,6BAA6B;AACvD,SAAS,mCAAmC;AAc5C,SAAS,oBAAsC;AAAA,EAC9C;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACD,GAA2B;AAC1B,QAAM,MAAM,eAAe;AAC3B,QAAM,SAAS,UAAU;AACzB,QAAM,CAAC,QAAQ,SAAS,IAAI,MAAM,SAAS,KAAK;AAEhD,QAAM,OAAO,MAAM;AAAA,IAClB,MAAM,MAAM,KAAK,CAAC,SAAS,MAAM,SAAS,YAAY,KAAK,UAAU,MAAM,KAAK,GAAG;AAAA,IACnF,CAAC,OAAO,KAAK;AAAA,EACd;AAEA,QAAM,iBAAiB,IAAI,eAAe,cAAc,EAAwB;AAEhF,QAAM,WACL,MAAM,SAAS,UACZ,IAAI,mBAAmB,IACvB,iBAAiB,aAAQ,IAAI,GAAG,MAAM,UAAU,MAAM,KAAK,EAAwB;AACvF,QAAM,WAAW,QAAQ,IAAI,KAAK,IAAI;AAEtC,QAAM,YAAY,eAAe,EAAE;AACnC,SACC,qBAAC,mBAAgB,IAAI,WAAW,MAAM,QAAQ,cAAc,WAC3D;AAAA,wBAAC,0BACA;AAAA,MAAC;AAAA;AAAA,QACA;AAAA,QACA,eAAa,SAAS,MAAM;AAAA,QAC5B,kBAAe;AAAA,QACf,OAAO;AAAA,QAEN;AAAA,sBAAY,oBAAC,uBAAqB,oBAAS;AAAA,UAC5C,oBAAC,sBAAmB,MAAO,QAAyB,SAAS;AAAA;AAAA;AAAA,IAC9D,GACD;AAAA,IACA,oBAAC,0BAAuB,MAAK,QAAO,OAAM,UACzC;AAAA,MAAC;AAAA;AAAA,QACA,OAAO;AAAA,QACP,WAAW,WAAW,sBAAsB,iBAAiB,cAAc,EAAE;AAAA,QAE7E,8BAAC,+BAA4B,MAAK,SAAQ,UAAS,eACjD,gBAAM,IAAI,CAAC,SAAS;AACpB,iBACC;AAAA,YAAC;AAAA;AAAA,cAEA,MAAK;AAAA,cACL,eAAa,SAAS,MAAM,IAAI,KAAK,KAAK;AAAA,cAC1C,OACC,iBACA,aACA,IAAI,GAAG,MAAM,UAAU,KAAK,KAAK,EAAwB;AAAA,cAE1D,UAAU,SAAS,KAAK;AAAA,cACxB,SAAS,MAAM;AACd,uBAAO,yBAAyB,4BAA4B;AAC5D,8BAAc,OAAO,KAAK,KAAK;AAC/B,wBAAQ,eAAe,WAAW,OAAO,SAAS;AAClD,0BAAU,KAAK;AAAA,cAChB;AAAA,cAEA,8BAAC,sBAAmB,MAAM,KAAK,MAAM;AAAA;AAAA,YAhBhC,KAAK;AAAA,UAiBX;AAAA,QAEF,CAAC,GACF;AAAA;AAAA,IACD,GACD;AAAA,KACD;AAEF;AAGO,MAAM,iBAAiB,MAAM,KAAK,mBAAmB;",
6
- "names": []
7
- }
@@ -1,115 +0,0 @@
1
- import { jsx } from "react/jsx-runtime";
2
- import {
3
- DefaultColorStyle,
4
- useEditor
5
- } from "@tldraw/editor";
6
- import classNames from "classnames";
7
- import { memo, useMemo, useRef } from "react";
8
- import { PORTRAIT_BREAKPOINT } from "../../constants.mjs";
9
- import { useBreakpoint } from "../../context/breakpoints.mjs";
10
- import { useTranslation } from "../../hooks/useTranslation/useTranslation.mjs";
11
- import { TldrawUiButtonIcon } from "./Button/TldrawUiButtonIcon.mjs";
12
- import { TldrawUiToolbarToggleGroup, TldrawUiToolbarToggleItem } from "./TldrawUiToolbar.mjs";
13
- const TldrawUiButtonPicker = memo(function TldrawUiButtonPicker2(props) {
14
- const {
15
- uiType,
16
- items,
17
- title,
18
- style,
19
- value,
20
- // columns = clamp(items.length, 2, 4),
21
- onValueChange,
22
- onHistoryMark,
23
- theme
24
- } = props;
25
- const editor = useEditor();
26
- const msg = useTranslation();
27
- const breakpoint = useBreakpoint();
28
- const rPointing = useRef(false);
29
- const rPointingOriginalActiveElement = useRef(null);
30
- const {
31
- handleButtonClick,
32
- handleButtonPointerDown,
33
- handleButtonPointerEnter,
34
- handleButtonPointerUp
35
- } = useMemo(() => {
36
- const handlePointerUp = () => {
37
- rPointing.current = false;
38
- window.removeEventListener("pointerup", handlePointerUp);
39
- const origActiveEl = rPointingOriginalActiveElement.current;
40
- if (origActiveEl && (["TEXTAREA", "INPUT"].includes(origActiveEl.nodeName) || origActiveEl.isContentEditable)) {
41
- origActiveEl.focus();
42
- } else if (breakpoint >= PORTRAIT_BREAKPOINT.TABLET_SM) {
43
- editor.getContainer().focus();
44
- }
45
- rPointingOriginalActiveElement.current = null;
46
- };
47
- const handleButtonClick2 = (e) => {
48
- const { id } = e.currentTarget.dataset;
49
- if (value.type === "shared" && value.value === id) return;
50
- onHistoryMark?.("point picker item");
51
- onValueChange(style, id);
52
- };
53
- const handleButtonPointerDown2 = (e) => {
54
- const { id } = e.currentTarget.dataset;
55
- onHistoryMark?.("point picker item");
56
- onValueChange(style, id);
57
- rPointing.current = true;
58
- rPointingOriginalActiveElement.current = document.activeElement;
59
- window.addEventListener("pointerup", handlePointerUp);
60
- };
61
- const handleButtonPointerEnter2 = (e) => {
62
- if (!rPointing.current) return;
63
- const { id } = e.currentTarget.dataset;
64
- onValueChange(style, id);
65
- };
66
- const handleButtonPointerUp2 = (e) => {
67
- const { id } = e.currentTarget.dataset;
68
- if (value.type === "shared" && value.value === id) return;
69
- onValueChange(style, id);
70
- };
71
- return {
72
- handleButtonClick: handleButtonClick2,
73
- handleButtonPointerDown: handleButtonPointerDown2,
74
- handleButtonPointerEnter: handleButtonPointerEnter2,
75
- handleButtonPointerUp: handleButtonPointerUp2
76
- };
77
- }, [editor, breakpoint, value, onHistoryMark, onValueChange, style]);
78
- return /* @__PURE__ */ jsx(
79
- TldrawUiToolbarToggleGroup,
80
- {
81
- "data-testid": `style.${uiType}`,
82
- type: "single",
83
- className: classNames("tlui-buttons__grid"),
84
- value: value.type === "shared" ? value.value : void 0,
85
- children: items.map((item) => {
86
- const label = title + " \u2014 " + msg(`${uiType}-style.${item.value}`);
87
- return /* @__PURE__ */ jsx(
88
- TldrawUiToolbarToggleItem,
89
- {
90
- type: "icon",
91
- "data-id": item.value,
92
- "data-testid": `style.${uiType}.${item.value}`,
93
- "aria-label": label,
94
- value: item.value,
95
- "data-state": value.type === "shared" && value.value === item.value ? "on" : "off",
96
- "data-isactive": value.type === "shared" && value.value === item.value,
97
- title: label,
98
- className: classNames("tlui-button-grid__button"),
99
- style: style === DefaultColorStyle ? { color: theme[item.value].solid } : void 0,
100
- onPointerEnter: handleButtonPointerEnter,
101
- onPointerDown: handleButtonPointerDown,
102
- onPointerUp: handleButtonPointerUp,
103
- onClick: handleButtonClick,
104
- children: /* @__PURE__ */ jsx(TldrawUiButtonIcon, { icon: item.icon })
105
- },
106
- item.value
107
- );
108
- })
109
- }
110
- );
111
- });
112
- export {
113
- TldrawUiButtonPicker
114
- };
115
- //# sourceMappingURL=TldrawUiButtonPicker.mjs.map
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../../../../src/lib/ui/components/primitives/TldrawUiButtonPicker.tsx"],
4
- "sourcesContent": ["import {\n\tDefaultColorStyle,\n\tSharedStyle,\n\tStyleProp,\n\tTLDefaultColorStyle,\n\tTLDefaultColorTheme,\n\tuseEditor,\n} from '@tldraw/editor'\nimport classNames from 'classnames'\nimport { ReactElement, memo, useMemo, useRef } from 'react'\nimport { StyleValuesForUi } from '../../../styles'\nimport { PORTRAIT_BREAKPOINT } from '../../constants'\nimport { useBreakpoint } from '../../context/breakpoints'\nimport { TLUiTranslationKey } from '../../hooks/useTranslation/TLUiTranslationKey'\nimport { useTranslation } from '../../hooks/useTranslation/useTranslation'\nimport { TldrawUiButtonIcon } from './Button/TldrawUiButtonIcon'\nimport { TldrawUiToolbarToggleGroup, TldrawUiToolbarToggleItem } from './TldrawUiToolbar'\n\n/** @public */\nexport interface TLUiButtonPickerProps<T extends string> {\n\ttitle: string\n\tuiType: string\n\tstyle: StyleProp<T>\n\tvalue: SharedStyle<T>\n\titems: StyleValuesForUi<T>\n\ttheme: TLDefaultColorTheme\n\tonValueChange(style: StyleProp<T>, value: T): void\n\tonHistoryMark?(id: string): void\n}\n\n/** @public */\nexport const TldrawUiButtonPicker = memo(function TldrawUiButtonPicker<T extends string>(\n\tprops: TLUiButtonPickerProps<T>\n) {\n\tconst {\n\t\tuiType,\n\t\titems,\n\t\ttitle,\n\t\tstyle,\n\t\tvalue,\n\t\t// columns = clamp(items.length, 2, 4),\n\t\tonValueChange,\n\t\tonHistoryMark,\n\t\ttheme,\n\t} = props\n\tconst editor = useEditor()\n\tconst msg = useTranslation()\n\tconst breakpoint = useBreakpoint()\n\n\tconst rPointing = useRef(false)\n\tconst rPointingOriginalActiveElement = useRef<HTMLElement | null>(null)\n\n\tconst {\n\t\thandleButtonClick,\n\t\thandleButtonPointerDown,\n\t\thandleButtonPointerEnter,\n\t\thandleButtonPointerUp,\n\t} = useMemo(() => {\n\t\tconst handlePointerUp = () => {\n\t\t\trPointing.current = false\n\t\t\twindow.removeEventListener('pointerup', handlePointerUp)\n\n\t\t\t// This is fun little micro-optimization to make sure that the focus\n\t\t\t// is retained on a text label. That way, you can continue typing\n\t\t\t// after selecting a style.\n\t\t\tconst origActiveEl = rPointingOriginalActiveElement.current\n\t\t\tif (\n\t\t\t\torigActiveEl &&\n\t\t\t\t(['TEXTAREA', 'INPUT'].includes(origActiveEl.nodeName) || origActiveEl.isContentEditable)\n\t\t\t) {\n\t\t\t\torigActiveEl.focus()\n\t\t\t} else if (breakpoint >= PORTRAIT_BREAKPOINT.TABLET_SM) {\n\t\t\t\teditor.getContainer().focus()\n\t\t\t}\n\t\t\trPointingOriginalActiveElement.current = null\n\t\t}\n\n\t\tconst handleButtonClick = (e: React.PointerEvent<HTMLButtonElement>) => {\n\t\t\tconst { id } = e.currentTarget.dataset\n\t\t\tif (value.type === 'shared' && value.value === id) return\n\n\t\t\tonHistoryMark?.('point picker item')\n\t\t\tonValueChange(style, id as T)\n\t\t}\n\n\t\tconst handleButtonPointerDown = (e: React.PointerEvent<HTMLButtonElement>) => {\n\t\t\tconst { id } = e.currentTarget.dataset\n\n\t\t\tonHistoryMark?.('point picker item')\n\t\t\tonValueChange(style, id as T)\n\n\t\t\trPointing.current = true\n\t\t\trPointingOriginalActiveElement.current = document.activeElement as HTMLElement\n\t\t\twindow.addEventListener('pointerup', handlePointerUp) // see TLD-658\n\t\t}\n\n\t\tconst handleButtonPointerEnter = (e: React.PointerEvent<HTMLButtonElement>) => {\n\t\t\tif (!rPointing.current) return\n\n\t\t\tconst { id } = e.currentTarget.dataset\n\t\t\tonValueChange(style, id as T)\n\t\t}\n\n\t\tconst handleButtonPointerUp = (e: React.PointerEvent<HTMLButtonElement>) => {\n\t\t\tconst { id } = e.currentTarget.dataset\n\t\t\tif (value.type === 'shared' && value.value === id) return\n\n\t\t\tonValueChange(style, id as T)\n\t\t}\n\n\t\treturn {\n\t\t\thandleButtonClick,\n\t\t\thandleButtonPointerDown,\n\t\t\thandleButtonPointerEnter,\n\t\t\thandleButtonPointerUp,\n\t\t}\n\t}, [editor, breakpoint, value, onHistoryMark, onValueChange, style])\n\n\treturn (\n\t\t<TldrawUiToolbarToggleGroup\n\t\t\tdata-testid={`style.${uiType}`}\n\t\t\ttype=\"single\"\n\t\t\tclassName={classNames('tlui-buttons__grid')}\n\t\t\tvalue={value.type === 'shared' ? value.value : undefined}\n\t\t>\n\t\t\t{items.map((item) => {\n\t\t\t\tconst label = title + ' \u2014 ' + msg(`${uiType}-style.${item.value}` as TLUiTranslationKey)\n\t\t\t\treturn (\n\t\t\t\t\t<TldrawUiToolbarToggleItem\n\t\t\t\t\t\ttype=\"icon\"\n\t\t\t\t\t\tkey={item.value}\n\t\t\t\t\t\tdata-id={item.value}\n\t\t\t\t\t\tdata-testid={`style.${uiType}.${item.value}`}\n\t\t\t\t\t\taria-label={label}\n\t\t\t\t\t\tvalue={item.value}\n\t\t\t\t\t\tdata-state={value.type === 'shared' && value.value === item.value ? 'on' : 'off'}\n\t\t\t\t\t\tdata-isactive={value.type === 'shared' && value.value === item.value}\n\t\t\t\t\t\ttitle={label}\n\t\t\t\t\t\tclassName={classNames('tlui-button-grid__button')}\n\t\t\t\t\t\tstyle={\n\t\t\t\t\t\t\tstyle === (DefaultColorStyle as StyleProp<unknown>)\n\t\t\t\t\t\t\t\t? { color: theme[item.value as TLDefaultColorStyle].solid }\n\t\t\t\t\t\t\t\t: undefined\n\t\t\t\t\t\t}\n\t\t\t\t\t\tonPointerEnter={handleButtonPointerEnter}\n\t\t\t\t\t\tonPointerDown={handleButtonPointerDown}\n\t\t\t\t\t\tonPointerUp={handleButtonPointerUp}\n\t\t\t\t\t\tonClick={handleButtonClick}\n\t\t\t\t\t>\n\t\t\t\t\t\t<TldrawUiButtonIcon icon={item.icon} />\n\t\t\t\t\t</TldrawUiToolbarToggleItem>\n\t\t\t\t)\n\t\t\t})}\n\t\t</TldrawUiToolbarToggleGroup>\n\t)\n}) as <T extends string>(props: TLUiButtonPickerProps<T>) => ReactElement\n"],
5
- "mappings": "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",
6
- "names": ["TldrawUiButtonPicker", "handleButtonClick", "handleButtonPointerDown", "handleButtonPointerEnter", "handleButtonPointerUp"]
7
- }
@@ -1,109 +0,0 @@
1
- import { SharedStyle, StyleProp, tlmenus, useEditor } from '@tldraw/editor'
2
- import classNames from 'classnames'
3
- import * as React from 'react'
4
- import { StyleValuesForUi } from '../../../styles'
5
- import { TLUiTranslationKey } from '../../hooks/useTranslation/TLUiTranslationKey'
6
- import { useTranslation } from '../../hooks/useTranslation/useTranslation'
7
- import { TLUiIconType } from '../../icon-types'
8
- import { TldrawUiButtonIcon } from '../primitives/Button/TldrawUiButtonIcon'
9
- import { TldrawUiButtonLabel } from '../primitives/Button/TldrawUiButtonLabel'
10
- import {
11
- TldrawUiPopover,
12
- TldrawUiPopoverContent,
13
- TldrawUiPopoverTrigger,
14
- } from '../primitives/TldrawUiPopover'
15
- import { TldrawUiToolbar, TldrawUiToolbarButton } from '../primitives/TldrawUiToolbar'
16
- import { TldrawUiMenuContextProvider } from '../primitives/menus/TldrawUiMenuContext'
17
-
18
- interface DropdownPickerProps<T extends string> {
19
- id: string
20
- label?: TLUiTranslationKey | Exclude<string, TLUiTranslationKey>
21
- uiType: string
22
- stylePanelType: string
23
- style: StyleProp<T>
24
- value: SharedStyle<T>
25
- items: StyleValuesForUi<T>
26
- type: 'icon' | 'tool' | 'menu'
27
- onValueChange(style: StyleProp<T>, value: T): void
28
- }
29
-
30
- function DropdownPickerInner<T extends string>({
31
- id,
32
- label,
33
- uiType,
34
- stylePanelType,
35
- style,
36
- items,
37
- type,
38
- value,
39
- onValueChange,
40
- }: DropdownPickerProps<T>) {
41
- const msg = useTranslation()
42
- const editor = useEditor()
43
- const [isOpen, setIsOpen] = React.useState(false)
44
-
45
- const icon = React.useMemo(
46
- () => items.find((item) => value.type === 'shared' && item.value === value.value)?.icon,
47
- [items, value]
48
- )
49
-
50
- const stylePanelName = msg(`style-panel.${stylePanelType}` as TLUiTranslationKey)
51
-
52
- const titleStr =
53
- value.type === 'mixed'
54
- ? msg('style-panel.mixed')
55
- : stylePanelName + ' — ' + msg(`${uiType}-style.${value.value}` as TLUiTranslationKey)
56
- const labelStr = label ? msg(label) : ''
57
-
58
- const popoverId = `style panel ${id}`
59
- return (
60
- <TldrawUiPopover id={popoverId} open={isOpen} onOpenChange={setIsOpen}>
61
- <TldrawUiPopoverTrigger>
62
- <TldrawUiToolbarButton
63
- type={type}
64
- data-testid={`style.${uiType}`}
65
- data-direction="left"
66
- title={titleStr}
67
- >
68
- {labelStr && <TldrawUiButtonLabel>{labelStr}</TldrawUiButtonLabel>}
69
- <TldrawUiButtonIcon icon={(icon as TLUiIconType) ?? 'mixed'} />
70
- </TldrawUiToolbarButton>
71
- </TldrawUiPopoverTrigger>
72
- <TldrawUiPopoverContent side="left" align="center">
73
- <TldrawUiToolbar
74
- label={labelStr}
75
- className={classNames('tlui-buttons__grid', `tlui-buttons__${stylePanelType}`)}
76
- >
77
- <TldrawUiMenuContextProvider type="icons" sourceId="style-panel">
78
- {items.map((item) => {
79
- return (
80
- <TldrawUiToolbarButton
81
- key={item.value}
82
- type="icon"
83
- data-testid={`style.${uiType}.${item.value}`}
84
- title={
85
- stylePanelName +
86
- ' — ' +
87
- msg(`${uiType}-style.${item.value}` as TLUiTranslationKey)
88
- }
89
- isActive={icon === item.icon}
90
- onClick={() => {
91
- editor.markHistoryStoppingPoint('select style dropdown item')
92
- onValueChange(style, item.value)
93
- tlmenus.deleteOpenMenu(popoverId, editor.contextId)
94
- setIsOpen(false)
95
- }}
96
- >
97
- <TldrawUiButtonIcon icon={item.icon} />
98
- </TldrawUiToolbarButton>
99
- )
100
- })}
101
- </TldrawUiMenuContextProvider>
102
- </TldrawUiToolbar>
103
- </TldrawUiPopoverContent>
104
- </TldrawUiPopover>
105
- )
106
- }
107
-
108
- // need to export like this to get generics
109
- export const DropdownPicker = React.memo(DropdownPickerInner) as typeof DropdownPickerInner